aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorfujinhua <fu.jinhua@zte.com.cn>2019-04-09 12:11:56 +0800
committerfujinhua <fu.jinhua@zte.com.cn>2019-04-09 12:11:56 +0800
commit823ec7df9d100dab0a99d7c012c727bb5addeb8e (patch)
treeaf0f9154429dc6559b1a11180cbf4be2588da2d5
parent365788469ae57a285ba7590016bdc93cee45ba3f (diff)
Refactor codes for ns descriptor
Change-Id: I6b75f33b6fad70e68a5461f1ce21b4f1a9ea27b3 Issue-ID: VFC-1306 Signed-off-by: fujinhua <fu.jinhua@zte.com.cn>
-rw-r--r--catalog/packages/views/ns_descriptor_views.py62
1 files changed, 16 insertions, 46 deletions
diff --git a/catalog/packages/views/ns_descriptor_views.py b/catalog/packages/views/ns_descriptor_views.py
index 5a5310bd..81836d35 100644
--- a/catalog/packages/views/ns_descriptor_views.py
+++ b/catalog/packages/views/ns_descriptor_views.py
@@ -13,7 +13,6 @@
# limitations under the License.
import logging
-import traceback
from django.http import StreamingHttpResponse
from drf_yasg.utils import no_body, swagger_auto_schema
@@ -26,7 +25,7 @@ from catalog.packages.serializers.create_nsd_info_request import CreateNsdInfoRe
from catalog.packages.serializers.nsd_info import NsdInfoSerializer
from catalog.packages.serializers.nsd_infos import NsdInfosSerializer
from catalog.packages.views.common import validate_data
-from catalog.pub.exceptions import CatalogException, ResourceNotFoundException
+from catalog.pub.exceptions import CatalogException
from .common import view_safe_call_with_log
logger = logging.getLogger(__name__)
@@ -83,30 +82,19 @@ def ns_info_rd(request, **kwargs):
}
)
@api_view(http_method_names=['POST', 'GET'])
+@view_safe_call_with_log(logger=logger)
def ns_descriptors_rc(request):
if request.method == 'POST':
- try:
- create_nsd_info_request = validate_data(request.data, CreateNsdInfoRequestSerializer)
- data = NsDescriptor().create(create_nsd_info_request.data)
- nsd_info = validate_data(data, NsdInfoSerializer)
- return Response(data=nsd_info.data, status=status.HTTP_201_CREATED)
- except Exception as e:
- logger.error(e.message)
- logger.error(traceback.format_exc())
- error_data = {'error': 'Creating a NSD failed.'}
- return Response(data=error_data, status=status.HTTP_500_INTERNAL_SERVER_ERROR)
+ create_nsd_info_request = validate_data(request.data, CreateNsdInfoRequestSerializer)
+ data = NsDescriptor().create(create_nsd_info_request.data)
+ nsd_info = validate_data(data, NsdInfoSerializer)
+ return Response(data=nsd_info.data, status=status.HTTP_201_CREATED)
if request.method == 'GET':
- try:
- nsdId = request.query_params.get("nsdId", None)
- data = NsDescriptor().query_multiple(nsdId)
- nsd_infos = validate_data(data, NsdInfosSerializer)
- return Response(data=nsd_infos.data, status=status.HTTP_200_OK)
- except Exception as e:
- logger.error(e.message)
- logger.error(traceback.format_exc())
- error_data = {'error': 'Query of multiple NSDs failed.'}
- return Response(data=error_data, status=status.HTTP_500_INTERNAL_SERVER_ERROR)
+ nsdId = request.query_params.get("nsdId", None)
+ data = NsDescriptor().query_multiple(nsdId)
+ nsd_infos = validate_data(data, NsdInfosSerializer)
+ return Response(data=nsd_infos.data, status=status.HTTP_200_OK)
@swagger_auto_schema(
@@ -129,6 +117,7 @@ def ns_descriptors_rc(request):
}
)
@api_view(http_method_names=['PUT', 'GET'])
+@view_safe_call_with_log(logger=logger)
def nsd_content_ru(request, **kwargs):
nsd_info_id = kwargs.get("nsdInfoId")
if request.method == 'PUT':
@@ -139,31 +128,12 @@ def nsd_content_ru(request, **kwargs):
return Response(data=None, status=status.HTTP_204_NO_CONTENT)
except CatalogException as e:
NsDescriptor().handle_upload_failed(nsd_info_id)
- logger.error(e.message)
- error_data = {'error': e.message}
+ raise e
except Exception as e:
NsDescriptor().handle_upload_failed(nsd_info_id)
- logger.error(e.message)
- logger.error(traceback.format_exc())
- error_data = {'error': 'Uploading NSD(%s) failed.' % nsd_info_id}
- return Response(data=error_data, status=status.HTTP_500_INTERNAL_SERVER_ERROR)
+ raise e
if request.method == 'GET':
- try:
- file_range = request.META.get('RANGE')
- file_iterator = NsDescriptor().download(nsd_info_id, file_range)
- return StreamingHttpResponse(file_iterator, status=status.HTTP_200_OK)
- except ResourceNotFoundException as e:
- logger.error(e.message)
- error_data = {'error': e.message}
- error_code = status.HTTP_404_NOT_FOUND
- except CatalogException as e:
- logger.error(e.message)
- error_data = {'error': e.message}
- error_code = status.HTTP_500_INTERNAL_SERVER_ERROR
- except Exception as e:
- logger.error(e.message)
- logger.error(traceback.format_exc())
- error_data = {'error': 'Downloading NSD(%s) failed.' % nsd_info_id}
- error_code = status.HTTP_500_INTERNAL_SERVER_ERROR
- return Response(data=error_data, status=error_code)
+ file_range = request.META.get('RANGE')
+ file_iterator = NsDescriptor().download(nsd_info_id, file_range)
+ return StreamingHttpResponse(file_iterator, status=status.HTTP_200_OK)