diff options
-rw-r--r-- | res/res/pub/exceptions.py | 4 | ||||
-rw-r--r-- | res/res/resources/views.py | 401 |
2 files changed, 191 insertions, 214 deletions
diff --git a/res/res/pub/exceptions.py b/res/res/pub/exceptions.py index 933e844..9629ccd 100644 --- a/res/res/pub/exceptions.py +++ b/res/res/pub/exceptions.py @@ -15,3 +15,7 @@ class VNFRESException(Exception): pass + + +class NotFoundException(Exception): + pass diff --git a/res/res/resources/views.py b/res/res/resources/views.py index 27ec18e..73799f7 100644 --- a/res/res/resources/views.py +++ b/res/res/resources/views.py @@ -20,47 +20,94 @@ from rest_framework import status from rest_framework.response import Response from rest_framework.views import APIView -from res.pub.database.models import NfInstModel, StorageInstModel, NetworkInstModel, VLInstModel, \ - VNFCInstModel, VmInstModel, FlavourInstModel, SubNetworkInstModel, CPInstModel from res.pub.exceptions import VNFRESException +from res.pub.exceptions import NotFoundException from res.pub.utils.syscomm import fun_name -from res.resources.serializers import VolumeInfoSerializer, CpsInfoSerializer, SubnetInfoSerializer, \ - NetworkInfoSerializer, FlavorInfoSerializer, VmInfoSerializer, VnfInfoSerializer, VnfsInfoSerializer +from res.pub.database.models import NfInstModel +from res.pub.database.models import StorageInstModel +from res.pub.database.models import NetworkInstModel +from res.pub.database.models import VLInstModel +from res.pub.database.models import VNFCInstModel +from res.pub.database.models import VmInstModel +from res.pub.database.models import FlavourInstModel +from res.pub.database.models import SubNetworkInstModel +from res.pub.database.models import CPInstModel +from res.resources.serializers import VolumeInfoSerializer +from res.resources.serializers import CpsInfoSerializer +from res.resources.serializers import SubnetInfoSerializer +from res.resources.serializers import NetworkInfoSerializer +from res.resources.serializers import FlavorInfoSerializer +from res.resources.serializers import VmInfoSerializer +from res.resources.serializers import VnfInfoSerializer +from res.resources.serializers import VnfsInfoSerializer logger = logging.getLogger(__name__) +def make_error_resp(status, detail): + return Response( + data={ + 'status': status, + 'detail': detail + }, + status=status + ) + + +def view_safe_call_with_log(logger): + def view_safe_call(func): + def wrapper(*args, **kwargs): + try: + return func(*args, **kwargs) + except NotFoundException as e: + logger.error(e.args[0]) + return make_error_resp( + detail=e.args[0], + status=status.HTTP_404_NOT_FOUND + ) + except VNFRESException as e: + logger.error(e.args[0]) + return make_error_resp( + detail=e.args[0], + status=status.HTTP_500_INTERNAL_SERVER_ERROR + ) + except Exception as e: + logger.error(e.args[0]) + logger.error(traceback.format_exc()) + return make_error_resp( + detail='Unexpected exception', + status=status.HTTP_500_INTERNAL_SERVER_ERROR + ) + return wrapper + return view_safe_call + + class getVnf(APIView): @swagger_auto_schema( responses={ status.HTTP_200_OK: VnfInfoSerializer(), status.HTTP_404_NOT_FOUND: 'Vnf does not exist', - status.HTTP_500_INTERNAL_SERVER_ERROR: 'internal error'}) + status.HTTP_500_INTERNAL_SERVER_ERROR: 'internal error' + } + ) + @view_safe_call_with_log(logger=logger) def get(self, request, vnfInstanceId): logger.debug("[%s]vnf_inst_id=%s", fun_name(), vnfInstanceId) - try: - vnf_inst = NfInstModel.objects.filter(nfinstid=vnfInstanceId) - if not vnf_inst: - return Response( - data={ - 'error': 'Vnf(%s) does not exist' % vnfInstanceId}, - status=status.HTTP_404_NOT_FOUND) - resp_data = fill_resp_data(vnf_inst[0]) - - vnf_info_serializer = VnfInfoSerializer(data=resp_data) - if not vnf_info_serializer.is_valid(): - raise Exception(vnf_info_serializer.errors) - - return Response( - data=resp_data, - status=status.HTTP_200_OK) - except Exception as e: - logger.error(e.args[0]) - logger.error(traceback.format_exc()) - return Response( - data={ - 'error': 'Failed to get Vnf(%s)' % vnfInstanceId}, - status=status.HTTP_500_INTERNAL_SERVER_ERROR) + + vnf_inst = NfInstModel.objects.filter(nfinstid=vnfInstanceId) + if not vnf_inst: + raise NotFoundException('Vnf(%s) does not exist' % vnfInstanceId) + + resp_data = fill_resp_data(vnf_inst[0]) + + vnf_info_serializer = VnfInfoSerializer(data=resp_data) + if not vnf_info_serializer.is_valid(): + raise VNFRESException(vnf_info_serializer.errors) + + return Response( + data=resp_data, + status=status.HTTP_200_OK + ) def fill_resp_data(vnf): @@ -178,70 +225,48 @@ class getVnfs(APIView): @swagger_auto_schema( responses={ status.HTTP_200_OK: VnfsInfoSerializer(), - status.HTTP_404_NOT_FOUND: 'Vnfs does not exist', - status.HTTP_500_INTERNAL_SERVER_ERROR: 'internal error'}) + status.HTTP_500_INTERNAL_SERVER_ERROR: 'internal error' + } + ) + @view_safe_call_with_log(logger=logger) def get(self, request): logger.debug("Query all the vnfs[%s]", fun_name()) - try: - vnf_insts = NfInstModel.objects.all() - if not vnf_insts: - return Response( - data={ - 'error': 'Vnfs does not exist'}, - status=status.HTTP_404_NOT_FOUND) - arr = [] - for vnf_inst in vnf_insts: - arr.append(fill_resp_data(vnf_inst)) - - vnfs_info_serializer = VnfsInfoSerializer(data={'resp_data': arr}) - if not vnfs_info_serializer.is_valid(): - raise Exception(vnfs_info_serializer.errors) - - return Response( - data={'resp_data': arr}, - status=status.HTTP_200_OK) - except Exception as e: - logger.error(e.args[0]) - logger.error(traceback.format_exc()) - return Response( - data={ - 'error': 'Failed to get Vnfs'}, - status=status.HTTP_500_INTERNAL_SERVER_ERROR) + + vnf_insts = NfInstModel.objects.all() + arr = [fill_resp_data(vnf_inst) for vnf_inst in vnf_insts] + + vnfs_info_serializer = VnfsInfoSerializer(data={'resp_data': arr}) + if not vnfs_info_serializer.is_valid(): + raise VNFRESException(vnfs_info_serializer.errors) + + return Response( + data={'resp_data': arr}, + status=status.HTTP_200_OK + ) class getVms(APIView): @swagger_auto_schema( responses={ status.HTTP_200_OK: VmInfoSerializer(), - status.HTTP_404_NOT_FOUND: 'Vms does not exist', - status.HTTP_500_INTERNAL_SERVER_ERROR: 'internal error'}) + status.HTTP_500_INTERNAL_SERVER_ERROR: 'internal error' + } + ) + @view_safe_call_with_log(logger=logger) def get(self, request, vnfInstanceId): logger.debug("Query all the vms by vnfInstanceId[%s]", fun_name()) - try: - vms = VmInstModel.objects.filter(instid=vnfInstanceId) - if not vms: - return Response( - data={ - 'error': 'Vms does not exist'}, - status=status.HTTP_404_NOT_FOUND) - arr = [] - for vm in vms: - arr.append(fill_vms_data(vm)) - - vm_info_serializer = VmInfoSerializer(data={'resp_data': arr}) - if not vm_info_serializer.is_valid(): - raise Exception(vm_info_serializer.errors) - - return Response( - data={'resp_data': arr}, - status=status.HTTP_200_OK) - except Exception as e: - logger.error(e.args[0]) - logger.error(traceback.format_exc()) - return Response( - data={ - 'error': 'Failed to get Vms'}, - status=status.HTTP_500_INTERNAL_SERVER_ERROR) + + vms = VmInstModel.objects.filter(instid=vnfInstanceId) + arr = [fill_vms_data(vm) for vm in vms] + + vm_info_serializer = VmInfoSerializer(data={'resp_data': arr}) + if not vm_info_serializer.is_valid(): + raise VNFRESException(vm_info_serializer.errors) + + return Response( + data={'resp_data': arr}, + status=status.HTTP_200_OK + ) def fill_vms_data(vm): @@ -270,35 +295,24 @@ class getFlavors(APIView): @swagger_auto_schema( responses={ status.HTTP_200_OK: FlavorInfoSerializer(), - status.HTTP_404_NOT_FOUND: 'Flavours does not exist', - status.HTTP_500_INTERNAL_SERVER_ERROR: 'internal error'}) + status.HTTP_500_INTERNAL_SERVER_ERROR: 'internal error' + } + ) + @view_safe_call_with_log(logger=logger) def get(self, request, vnfInstanceId): logger.debug("Query all the flavors by vnfInstanceId[%s]", fun_name()) - try: - flavours = FlavourInstModel.objects.filter(instid=vnfInstanceId) - if not flavours: - return Response( - data={ - 'error': 'Flavours does not exist'}, - status=status.HTTP_404_NOT_FOUND) - arr = [] - for flavour in flavours: - arr.append(fill_flavours_data(flavour)) - - flavor_info_serializer = FlavorInfoSerializer(data={'resp_data': arr}) - if not flavor_info_serializer.is_valid(): - raise Exception(flavor_info_serializer.errors) - - return Response( - data=flavor_info_serializer.data, - status=status.HTTP_200_OK) - except Exception as e: - logger.error(e.args[0]) - logger.error(traceback.format_exc()) - return Response( - data={ - 'error': 'Failed to get flavours'}, - status=status.HTTP_500_INTERNAL_SERVER_ERROR) + + flavours = FlavourInstModel.objects.filter(instid=vnfInstanceId) + arr = [fill_flavours_data(flavour) for flavour in flavours] + + flavor_info_serializer = FlavorInfoSerializer(data={'resp_data': arr}) + if not flavor_info_serializer.is_valid(): + raise VNFRESException(flavor_info_serializer.errors) + + return Response( + data=flavor_info_serializer.data, + status=status.HTTP_200_OK + ) def fill_flavours_data(f): @@ -321,35 +335,24 @@ class getNetworks(APIView): @swagger_auto_schema( responses={ status.HTTP_200_OK: NetworkInfoSerializer(), - status.HTTP_404_NOT_FOUND: 'Networks does not exist', - status.HTTP_500_INTERNAL_SERVER_ERROR: 'internal error'}) + status.HTTP_500_INTERNAL_SERVER_ERROR: 'internal error' + } + ) + @view_safe_call_with_log(logger=logger) def get(self, request, vnfInstanceId): logger.debug("Query all the networks by vnfInstanceId[%s]", fun_name()) - try: - networks = NetworkInstModel.objects.filter(instid=vnfInstanceId) - if not networks: - return Response( - data={ - 'error': 'Networks does not exist'}, - status=status.HTTP_404_NOT_FOUND) - arr = [] - for network in networks: - arr.append(fill_networks_data(network)) - - network_info_serializer = NetworkInfoSerializer(data={'resp_data': arr}) - if not network_info_serializer.is_valid(): - raise Exception(network_info_serializer.errors) - - return Response( - data=network_info_serializer.data, - status=status.HTTP_200_OK) - except Exception as e: - logger.error(e.args[0]) - logger.error(traceback.format_exc()) - return Response( - data={ - 'error': 'Failed to get networks'}, - status=status.HTTP_500_INTERNAL_SERVER_ERROR) + + networks = NetworkInstModel.objects.filter(instid=vnfInstanceId) + arr = [fill_networks_data(network) for network in networks] + + network_info_serializer = NetworkInfoSerializer(data={'resp_data': arr}) + if not network_info_serializer.is_valid(): + raise VNFRESException(network_info_serializer.errors) + + return Response( + data=network_info_serializer.data, + status=status.HTTP_200_OK + ) def fill_networks_data(network): @@ -368,34 +371,24 @@ class getSubnets(APIView): @swagger_auto_schema( responses={ status.HTTP_200_OK: SubnetInfoSerializer(), - status.HTTP_404_NOT_FOUND: 'Subnets does not exist', - status.HTTP_500_INTERNAL_SERVER_ERROR: 'internal error'}) + status.HTTP_500_INTERNAL_SERVER_ERROR: 'internal error' + } + ) + @view_safe_call_with_log(logger=logger) def get(self, request, vnfInstanceId): logger.debug("Query all the subnets by vnfInstanceId[%s]", fun_name()) - try: - subnets = SubNetworkInstModel.objects.filter(instid=vnfInstanceId) - if not subnets: - return Response( - data={ - 'error': 'Subnets does not exist'}, - status=status.HTTP_404_NOT_FOUND) - arr = [] - for subnet in subnets: - arr.append(fill_subnets_data(subnet)) - subnet_info_serializer = SubnetInfoSerializer(data={'resp_data': arr}) - if not subnet_info_serializer.is_valid(): - raise Exception(subnet_info_serializer.errors) - - return Response( - data=subnet_info_serializer.data, - status=status.HTTP_200_OK) - except Exception as e: - logger.error(e.args[0]) - logger.error(traceback.format_exc()) - return Response( - data={ - 'error': 'Failed to get subnets'}, - status=status.HTTP_500_INTERNAL_SERVER_ERROR) + + subnets = SubNetworkInstModel.objects.filter(instid=vnfInstanceId) + arr = [fill_subnets_data(subnet) for subnet in subnets] + + subnet_info_serializer = SubnetInfoSerializer(data={'resp_data': arr}) + if not subnet_info_serializer.is_valid(): + raise VNFRESException(subnet_info_serializer.errors) + + return Response( + data=subnet_info_serializer.data, + status=status.HTTP_200_OK + ) def fill_subnets_data(subnet): @@ -416,34 +409,24 @@ class getCps(APIView): @swagger_auto_schema( responses={ status.HTTP_200_OK: CpsInfoSerializer(), - status.HTTP_404_NOT_FOUND: 'Cps does not exist', - status.HTTP_500_INTERNAL_SERVER_ERROR: 'internal error'}) + status.HTTP_500_INTERNAL_SERVER_ERROR: 'internal error' + } + ) + @view_safe_call_with_log(logger=logger) def get(self, request, vnfInstanceId): logger.debug("Query all the cps by vnfInstanceId[%s]", fun_name()) - try: - cps = CPInstModel.objects.filter(ownerid=vnfInstanceId) - if not cps: - return Response( - data={ - 'error': 'Cps does not exist'}, - status=status.HTTP_404_NOT_FOUND) - arr = [] - for cp in cps: - arr.append(fill_cps_data(cp)) - cp_info_serializer = CpsInfoSerializer(data={'resp_data': arr}) - if not cp_info_serializer.is_valid(): - raise Exception(cp_info_serializer.errors) - - return Response( - data=cp_info_serializer.data, - status=status.HTTP_200_OK) - except Exception as e: - logger.error(e.args[0]) - logger.error(traceback.format_exc()) - return Response( - data={ - 'error': 'Failed to get cps'}, - status=status.HTTP_500_INTERNAL_SERVER_ERROR) + + cps = CPInstModel.objects.filter(ownerid=vnfInstanceId) + arr = [fill_cps_data(cp) for cp in cps] + + cp_info_serializer = CpsInfoSerializer(data={'resp_data': arr}) + if not cp_info_serializer.is_valid(): + raise VNFRESException(cp_info_serializer.errors) + + return Response( + data=cp_info_serializer.data, + status=status.HTTP_200_OK + ) def fill_cps_data(cp): @@ -463,34 +446,24 @@ class getVolumes(APIView): @swagger_auto_schema( responses={ status.HTTP_200_OK: VolumeInfoSerializer(), - status.HTTP_404_NOT_FOUND: 'Volumes does not exist', - status.HTTP_500_INTERNAL_SERVER_ERROR: 'internal error'}) + status.HTTP_500_INTERNAL_SERVER_ERROR: 'internal error' + } + ) + @view_safe_call_with_log(logger=logger) def get(self, request, vnfInstanceId): logger.debug("Query all the volumes by vnfInstanceId[%s]", fun_name()) - try: - volumes = StorageInstModel.objects.filter(instid=vnfInstanceId) - if not volumes: - return Response( - data={ - 'error': 'Volumes does not exist'}, - status=status.HTTP_404_NOT_FOUND) - arr = [] - for v in volumes: - arr.append(fill_volumes_data(v)) - volume_serializer = VolumeInfoSerializer(data={'resp_data': arr}) - if not volume_serializer.is_valid(): - raise Exception(volume_serializer.errors) - - return Response( - data=volume_serializer.data, - status=status.HTTP_200_OK) - except Exception as e: - logger.error(e.args[0]) - logger.error(traceback.format_exc()) - return Response( - data={ - 'error': 'Failed to get volumes'}, - status=status.HTTP_500_INTERNAL_SERVER_ERROR) + + volumes = StorageInstModel.objects.filter(instid=vnfInstanceId) + arr = [fill_volumes_data(v) for v in volumes] + + volume_serializer = VolumeInfoSerializer(data={'resp_data': arr}) + if not volume_serializer.is_valid(): + raise VNFRESException(volume_serializer.errors) + + return Response( + data=volume_serializer.data, + status=status.HTTP_200_OK + ) def fill_volumes_data(v): |