+class SampleList(APIView):
+ @swagger_auto_schema(
+ responses={
+ status.HTTP_200_OK: 'Successfully'})
+ def get(self, request):
+ logger.debug("get")
+ return Response({"status": "active"})
+
+
+class Subscribe(APIView):
+ @swagger_auto_schema(
+ responses={
+ status.HTTP_200_OK: SubscribesRespSerializer(),
+ status.HTTP_500_INTERNAL_SERVER_ERROR: "Internal error"
+ }
+ )
+ def get(self, request):
+ logger.debug("====Subscribe get====")
+ resp_data = {
+ "subscriptions": [{
+ "subscribeid": "cdbddb00-452c-11e9-91e8-acc860114657",
+ "filter": [{
+ "vendor": "ZTE",
+ "type": "vCPE",
+ }],
+ "notificationuri": " https://127.0.0.1:80/v2/vnfm/vnfds/notification",
+ }]
+ }
+ return Response(data=resp_data, status=status.HTTP_200_OK)
+
+ @swagger_auto_schema(
+ request_body=SubscribeReqSerializer(),
+ responses={
+ status.HTTP_201_CREATED: SubscribeRespSerializer(),
+ status.HTTP_500_INTERNAL_SERVER_ERROR: "Internal error"
+ }
+ )
+ def post(self, request):
+ logger.debug("====Subscribe post====")
+ resp_data = {"subscribeid": "cdbddb00-452c-11e9-91e8-acc860114657"}
+ return Response(data=resp_data, status=status.HTTP_201_CREATED)
+
+
+class SubscribeDetail(APIView):
+ @swagger_auto_schema(
+ responses={
+ status.HTTP_204_NO_CONTENT: "None",
+ status.HTTP_500_INTERNAL_SERVER_ERROR: "Internal error"
+ }
+ )
+ def delete(self, request, subscribeId):
+ logger.debug("====SubscribeDetail delete %s====", subscribeId)
+ return Response(status=status.HTTP_204_NO_CONTENT)
+
+
+class VnfPkgs(APIView):
+ def get(self, request):
+ logger.debug("====VnfPkgs get====")
+ resp_data = {
+ "data": [{
+ "packageid": "924fc980-4530-11e9-ae68-acc860114657",
+ "vendor": "ZTE",
+ "type": "vCPE",
+ "vnfdfile": "MRP6600_FS_SRIOV_4NIC_200W.zip",
+ "imagefiles": ["MRP6600_FS_SRIOV_MRPISU_IMGV500R008C20SPC030T.tar"],
+ "swfiles": ["MRP6600_SRV_V500R008C20SPC030T.tar"],
+ "description": "This is a service for vCPE.",
+ }]
+ }
+ return Response(data=resp_data, status=status.HTTP_200_OK)
+
+
+class VnfPkg(APIView):
+ def get(self, request, packageId, fileName):
+ logger.debug("====VnfPkg get====%s, %s", packageId, fileName)
+ file_range = request.META.get('RANGE')
+ logger.debug('file_range: %s' % file_range)
+ # TODO: get filepath
+ local_file_path = fileName
+ start, end = parse_file_range(local_file_path, file_range)
+ file_iterator = read(local_file_path, start, end)
+ return StreamingHttpResponse(file_iterator, status=status.HTTP_200_OK)
+
+
+class NfvoInfo(APIView):
+ def put(self, request, vnfmid):
+ logger.debug("====NfvoInfo put====%s", vnfmid)
+ req_data = {
+ "nfvoid": request.data.get("nfvoid", "1"),
+ "vnfmid": vnfmid,
+ "nfvourl": request.data.get("nfvourl", "http://127.0.0.1:80")
+ }
+ ret = get_vnfminfo_from_nslcm(vnfmid)
+ if ret[0] != 0:
+ raise Exception(ret[1])
+
+ vnfm_info = json.JSONDecoder().decode(ret[1])
+ logger.debug("[%s] vnfm_info=%s", fun_name(), vnfm_info)
+ ret = restcall.call_req(
+ base_url=ignorcase_get(vnfm_info, "url"),
+ user=ignorcase_get(vnfm_info, "userName"),
+ passwd=ignorcase_get(vnfm_info, "password"),
+ auth_type=restcall.rest_no_auth,
+ resource="v1/nfvo/info",
+ method='put',
+ content=json.dumps(req_data))
+ if ret[0] != 0:
+ raise Exception(ret[1])
+ logger.debug("update nfvo info successfully.")