summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorFu Jinhua <fu.jinhua@zte.com.cn>2018-08-24 00:47:52 +0000
committerGerrit Code Review <gerrit@onap.org>2018-08-24 00:47:52 +0000
commit89e4149fdf0693f643ad91c983d6cec9cfa86ce4 (patch)
treeff4f047b596dba662e7cf35b54461bc539b633b2
parentc175c508173973e83b2ab7a4409a315816d16495 (diff)
parent15959a375e342713a50dde8e28c3e7e0046d75f6 (diff)
Merge "Ns descriptor related stuffs."
-rw-r--r--catalog/packages/views/pnf_descriptor_views.py53
1 files changed, 39 insertions, 14 deletions
diff --git a/catalog/packages/views/pnf_descriptor_views.py b/catalog/packages/views/pnf_descriptor_views.py
index a55fb272..5b970272 100644
--- a/catalog/packages/views/pnf_descriptor_views.py
+++ b/catalog/packages/views/pnf_descriptor_views.py
@@ -20,10 +20,11 @@ from rest_framework import status
from rest_framework.decorators import api_view
from rest_framework.response import Response
-from catalog.packages.biz.pnf_descriptor import create, upload
+from catalog.packages.biz.pnf_descriptor import create, query_multiple, upload
from catalog.packages.serializers.create_pnfd_info_request import \
CreatePnfdInfoRequestSerializer
from catalog.packages.serializers.pnfd_info import PnfdInfoSerializer
+from catalog.packages.serializers.pnfd_infos import PnfdInfosSerializer
from catalog.pub.exceptions import CatalogException
logger = logging.getLogger(__name__)
@@ -62,20 +63,44 @@ def query_single_pnfd(self, request):
status.HTTP_500_INTERNAL_SERVER_ERROR: "Internal error"
}
)
-@api_view(http_method_names=['POST'])
+@swagger_auto_schema(
+ method='GET',
+ operation_description="Query multiple PNF descriptor resources",
+ request_body=no_body,
+ responses={
+ status.HTTP_200_OK: PnfdInfosSerializer(),
+ status.HTTP_500_INTERNAL_SERVER_ERROR: "Internal error"
+ }
+)
+@api_view(http_method_names=['POST', 'GET'])
def pnf_descriptors_rc(request, *args, **kwargs):
- try:
- create_pnfd_info_request = CreatePnfdInfoRequestSerializer(data=request.data)
- if not create_pnfd_info_request.is_valid():
- raise CatalogException
- data = create(create_pnfd_info_request.data)
- pnfd_info = PnfdInfoSerializer(data=data)
- if not pnfd_info.is_valid():
- raise CatalogException
- return Response(data=pnfd_info.data, status=status.HTTP_201_CREATED)
- except CatalogException:
- logger.error(traceback.format_exc())
- return Response(data={'error': 'Creating pnfd info failed.'}, status=status.HTTP_500_INTERNAL_SERVER_ERROR)
+ if request.method == 'POST':
+ try:
+ create_pnfd_info_request = CreatePnfdInfoRequestSerializer(data=request.data)
+ if not create_pnfd_info_request.is_valid():
+ raise CatalogException
+ data = create(create_pnfd_info_request.data)
+ pnfd_info = PnfdInfoSerializer(data=data)
+ if not pnfd_info.is_valid():
+ raise CatalogException
+ return Response(data=pnfd_info.data, status=status.HTTP_201_CREATED)
+ except CatalogException:
+ logger.error(traceback.format_exc())
+ return Response(data={'error': 'Creating pnfd info failed.'}, status=status.HTTP_500_INTERNAL_SERVER_ERROR)
+
+ if request.method == 'GET':
+ try:
+ data = query_multiple()
+ pnfd_infos = PnfdInfosSerializer(data=data)
+ if not pnfd_infos.is_valid():
+ raise CatalogException
+ return Response(data=pnfd_infos.data, status=status.HTTP_200_OK)
+ except CatalogException:
+ logger.error(traceback.format_exc())
+ return Response(
+ data={'error': 'Query of multiple PNF descriptor resources failed.'},
+ status=status.HTTP_500_INTERNAL_SERVER_ERROR
+ )
@swagger_auto_schema(