+
+ if int(resp.status_code) != status.HTTP_200_OK:
+ continue
+
+ try:
+ resp_body = json.loads(resp.content)
+ except ValueError:
+ continue
+ if not resp_body.get("result", False):
+ continue
+ azCapInfo = resp_body.get("AZs", [])
+ vim["AZs"] = azCapInfo
+ ret['VIMs'].append(vim)
+ return Response(data=ret, status=status.HTTP_200_OK)
+
+
+# forward handler
+class APIv1Forward(Forward):
+
+ def get(self, request, cloud_owner, cloud_region_id):
+ vimid = extsys.encode_vim_id(cloud_owner, cloud_region_id)
+ return super(APIv1Forward, self).get(request, vimid)
+
+ def post(self, request, cloud_owner, cloud_region_id):
+ vimid = extsys.encode_vim_id(cloud_owner, cloud_region_id)
+ return super(APIv1Forward, self).post(request, vimid)
+
+ def patch(self, request, cloud_owner, cloud_region_id):
+ vimid = extsys.encode_vim_id(cloud_owner, cloud_region_id)
+ return super(APIv1Forward, self).patch(request, vimid)
+
+ def delete(self, request, cloud_owner, cloud_region_id):
+ vimid = extsys.encode_vim_id(cloud_owner, cloud_region_id)
+ return super(APIv1Forward, self).delete(request, vimid)
+
+ def head(self, request, cloud_owner, cloud_region_id):
+ vimid = extsys.encode_vim_id(cloud_owner, cloud_region_id)
+ return super(APIv1Forward, self).head(request, vimid)
+
+ def put(self, request, cloud_owner, cloud_region_id):
+ vimid = extsys.encode_vim_id(cloud_owner, cloud_region_id)
+ return super(APIv1Forward, self).put(request, vimid)
+
+
+class APIv1InfraWorkload(BaseServer):
+
+ def post(self, request, cloud_owner, cloud_region_id):
+ vimid = extsys.encode_vim_id(cloud_owner, cloud_region_id)
+ content_type = request.META.get('CONTENT_TYPE', 'application/json')
+ if content_type.startswith("multipart"):
+ return self.__process_multipart(request, vimid)
+ return self.send(vimid, request.get_full_path(), request.body, "POST",
+ headers=originHeaders(request))
+
+ def get(self, request, cloud_owner, cloud_region_id):
+ vimid = extsys.encode_vim_id(cloud_owner, cloud_region_id)
+ return self.send(vimid, request.get_full_path(), request.body, "GET",
+ headers=originHeaders(request))
+
+ def delete(self, request, cloud_owner, cloud_region_id):
+ vimid = extsys.encode_vim_id(cloud_owner, cloud_region_id)
+ return self.send(vimid, request.get_full_path(), request.body,
+ "DELETE", headers=originHeaders(request))
+
+ def __process_multipart(self, request, vimid):
+ return Response(
+ data={'error': 'multipart API is not supported yet'},
+ status=status.HTTP_400_BAD_REQUEST)
+# try:
+# API is depreciated due to poster not available in py3
+# register_openers()
+# dataDict = dict(request.data.iterlists())
+# params = {}
+# for key in dataDict.keys():
+# dataObj = dataDict[key][0]
+# if isinstance(dataObj, InMemoryUploadedFile):
+# f = tempfile.NamedTemporaryFile(prefix="django_",
+# suffix=dataObj._name,
+# delete=False)
+# f.write(dataObj.file.read())
+# f.seek(dataObj.file.tell(), 0)
+# dataObj.file.close()
+# params[key] = open(f.name, 'rb')
+# else:
+# params[key] = dataObj
+# datagen, headers = multipart_encode(params)
+# regex = re.compile('^HTTP_')
+# for key, value in request.META.iteritems():
+# if key.startswith("HTTP_"):
+# headers[regex.sub('', key).replace('_', '-')] = value
+# resp = self.send(vimid, request.path, datagen, "POST",
+# headers=headers, multipart=True)
+# finally:
+# for key in params or {}:
+# refobj = params[key]
+# if type(refobj) is not unicode:
+# if refobj.closed is False:
+# print (refobj.close())
+# os.remove(refobj.name)
+# return resp