1 # Copyright 2017 Wind River Systems, Inc.
2 # Copyright (c) 2017-2018 VMware, Inc.
4 # Licensed under the Apache License, Version 2.0 (the "License");
5 # you may not use this file except in compliance with the License.
6 # You may obtain a copy of the License at
8 # http://www.apache.org/licenses/LICENSE-2.0
10 # Unless required by applicable law or agreed to in writing, software
11 # distributed under the License is distributed on an "AS IS" BASIS,
12 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 # See the License for the specific language governing permissions and
14 # limitations under the License.
20 # from django.core.files.uploadedfile import InMemoryUploadedFile
21 # from poster.encode import multipart_encode
22 # from poster.streaminghttp import register_openers
24 from rest_framework.views import APIView
25 from rest_framework.views import Response
26 from rest_framework.views import status
27 from multivimbroker.forwarder.base import BaseHandler
28 from multivimbroker.pub.utils.syscomm import originHeaders
29 from multivimbroker.pub.utils import syscomm
30 from multivimbroker.pub.msapi import extsys
33 class BaseServer(BaseHandler, APIView):
35 def get(self, request, vimid):
36 raise NotImplementedError()
38 def post(self, request, vimid):
39 raise NotImplementedError()
41 def put(self, request, vimid):
42 raise NotImplementedError()
44 def delete(self, request, vimid):
45 raise NotImplementedError()
47 def head(self, request, vimid):
48 raise NotImplementedError()
50 def patch(self, request, vimid):
51 raise NotImplementedError()
55 class Identity(BaseServer):
57 def get(self, request, vimid):
59 return self.send(vimid, request.get_full_path(), request.body, "GET",
60 headers=originHeaders(request))
62 def post(self, request, vimid):
64 return self.send(vimid, request.get_full_path(), request.body, "POST",
65 headers=originHeaders(request))
68 class Registry(BaseServer):
70 def post(self, request, vimid):
72 return self.send(vimid, request.get_full_path(), request.body, "POST",
73 headers=originHeaders(request))
76 class UnRegistry(BaseServer):
78 def delete(self, request, vimid):
80 return self.send(vimid, request.get_full_path(), request.body,
81 "DELETE", headers=originHeaders(request))
84 class Extension(BaseServer):
86 def get(self, request, vimid):
88 return self.send(vimid, request.get_full_path(), request.body, "GET",
89 headers=originHeaders(request))
92 class VIMTypes(BaseServer):
94 def get(self, request):
95 return Response(data=syscomm.getVIMTypes(), status=status.HTTP_200_OK)
98 class CheckCapacity(BaseServer):
100 def post(self, request):
102 body = json.loads(request.body)
103 except ValueError as e:
105 data={'error': 'Invalidate request body %s.' % e},
106 status=status.HTTP_400_BAD_REQUEST)
110 "vCPU": body.get("vCPU", 0),
111 "Memory": body.get("Memory", 0),
112 "Storage": body.get("Storage", 0)
114 for vim in body.get("VIMs", []):
115 url = request.get_full_path().replace(
116 "check_vim_capacity", "%s/capacity_check" % vim)
117 resp = self.send(vim, url, json.dumps(newbody), "POST",
118 headers=originHeaders(request))
119 if int(resp.status_code) != status.HTTP_200_OK:
122 resp_body = json.loads(resp.content)
125 if not resp_body.get("result", False):
127 ret['VIMs'].append(vim)
128 return Response(data=ret, status=status.HTTP_200_OK)
132 class Forward(BaseServer):
134 def get(self, request, vimid):
136 return self.send(vimid, request.get_full_path(), request.body, "GET",
137 headers=originHeaders(request))
139 def post(self, request, vimid):
141 return self.send(vimid, request.get_full_path(), request.body, "POST",
142 headers=originHeaders(request))
144 def patch(self, request, vimid):
146 return self.send(vimid, request.get_full_path(), request.body, "PATCH",
147 headers=originHeaders(request))
149 def delete(self, request, vimid):
151 return self.send(vimid, request.get_full_path(), request.body,
152 "DELETE", headers=originHeaders(request))
154 def head(self, request, vimid):
156 return self.send(vimid, request.get_full_path(), request.body, "HEAD",
157 headers=originHeaders(request))
159 def put(self, request, vimid):
161 return self.send(vimid, request.get_full_path(), request.body, "PUT",
162 headers=originHeaders(request))
167 class APIv1Identity(Identity):
169 def get(self, request, cloud_owner, cloud_region_id):
170 vimid = extsys.encode_vim_id(cloud_owner, cloud_region_id)
171 return super(APIv1Identity, self).get(request, vimid)
173 def post(self, request, cloud_owner, cloud_region_id):
174 vimid = extsys.encode_vim_id(cloud_owner, cloud_region_id)
175 return super(APIv1Identity, self).post(request, vimid)
178 class APIv1Registry(Registry):
180 def post(self, request, cloud_owner, cloud_region_id):
181 vimid = extsys.encode_vim_id(cloud_owner, cloud_region_id)
182 return super(APIv1Registry, self).post(request, vimid)
185 class APIv1UnRegistry(UnRegistry):
187 def delete(self, request, cloud_owner, cloud_region_id):
188 vimid = extsys.encode_vim_id(cloud_owner, cloud_region_id)
189 return super(APIv1UnRegistry, self).delete(request, vimid)
192 class APIv1Extension(Extension):
194 def get(self, request, cloud_owner, cloud_region_id):
195 vimid = extsys.encode_vim_id(cloud_owner, cloud_region_id)
196 return super(APIv1Extension, self).get(request, vimid)
199 class APIv1VIMTypes(VIMTypes):
201 def get(self, request):
202 return super(APIv1VIMTypes, self).get(request)
205 class APIv1CheckCapacity(CheckCapacity):
207 def post(self, request):
209 body = json.loads(request.body)
210 except ValueError as e:
212 data={'error': 'Invalidate request body %s.' % e},
213 status=status.HTTP_400_BAD_REQUEST)
217 "vCPU": body.get("vCPU", 0),
218 "Memory": body.get("Memory", 0),
219 "Storage": body.get("Storage", 0)
221 for vim in body.get("VIMs", []):
222 cloud_owner = vim["cloud-owner"]
223 cloud_region_id = vim["cloud-region-id"]
224 url = request.get_full_path().replace(
225 "check_vim_capacity", "%s/%s/capacity_check" %
226 (cloud_owner, cloud_region_id))
227 vimid = extsys.encode_vim_id(cloud_owner, cloud_region_id)
228 resp = self.send(vimid, url, json.dumps(newbody), "POST",
229 headers=originHeaders(request))
231 if int(resp.status_code) != status.HTTP_200_OK:
235 resp_body = json.loads(resp.content)
238 if not resp_body.get("result", False):
240 azCapInfo = resp_body.get("AZs", [])
241 vim["AZs"] = azCapInfo
242 ret['VIMs'].append(vim)
243 return Response(data=ret, status=status.HTTP_200_OK)
247 class APIv1Forward(Forward):
249 def get(self, request, cloud_owner, cloud_region_id):
250 vimid = extsys.encode_vim_id(cloud_owner, cloud_region_id)
251 return super(APIv1Forward, self).get(request, vimid)
253 def post(self, request, cloud_owner, cloud_region_id):
254 vimid = extsys.encode_vim_id(cloud_owner, cloud_region_id)
255 return super(APIv1Forward, self).post(request, vimid)
257 def patch(self, request, cloud_owner, cloud_region_id):
258 vimid = extsys.encode_vim_id(cloud_owner, cloud_region_id)
259 return super(APIv1Forward, self).patch(request, vimid)
261 def delete(self, request, cloud_owner, cloud_region_id):
262 vimid = extsys.encode_vim_id(cloud_owner, cloud_region_id)
263 return super(APIv1Forward, self).delete(request, vimid)
265 def head(self, request, cloud_owner, cloud_region_id):
266 vimid = extsys.encode_vim_id(cloud_owner, cloud_region_id)
267 return super(APIv1Forward, self).head(request, vimid)
269 def put(self, request, cloud_owner, cloud_region_id):
270 vimid = extsys.encode_vim_id(cloud_owner, cloud_region_id)
271 return super(APIv1Forward, self).put(request, vimid)
274 class APIv1InfraWorkload(BaseServer):
276 def post(self, request, cloud_owner, cloud_region_id):
277 vimid = extsys.encode_vim_id(cloud_owner, cloud_region_id)
278 content_type = request.META.get('CONTENT_TYPE', 'application/json')
279 if content_type.startswith("multipart"):
280 return self.__process_multipart(request, vimid)
281 return self.send(vimid, request.get_full_path(), request.body, "POST",
282 headers=originHeaders(request))
284 def get(self, request, cloud_owner, cloud_region_id):
285 vimid = extsys.encode_vim_id(cloud_owner, cloud_region_id)
286 return self.send(vimid, request.get_full_path(), request.body, "GET",
287 headers=originHeaders(request))
289 def delete(self, request, cloud_owner, cloud_region_id):
290 vimid = extsys.encode_vim_id(cloud_owner, cloud_region_id)
291 return self.send(vimid, request.get_full_path(), request.body,
292 "DELETE", headers=originHeaders(request))
294 def __process_multipart(self, request, vimid):
296 data={'error': 'multipart API is not supported yet'},
297 status=status.HTTP_400_BAD_REQUEST)
299 # API is depreciated due to poster not available in py3
301 # dataDict = dict(request.data.iterlists())
303 # for key in dataDict.keys():
304 # dataObj = dataDict[key][0]
305 # if isinstance(dataObj, InMemoryUploadedFile):
306 # f = tempfile.NamedTemporaryFile(prefix="django_",
307 # suffix=dataObj._name,
309 # f.write(dataObj.file.read())
310 # f.seek(dataObj.file.tell(), 0)
311 # dataObj.file.close()
312 # params[key] = open(f.name, 'rb')
314 # params[key] = dataObj
315 # datagen, headers = multipart_encode(params)
316 # regex = re.compile('^HTTP_')
317 # for key, value in request.META.iteritems():
318 # if key.startswith("HTTP_"):
319 # headers[regex.sub('', key).replace('_', '-')] = value
320 # resp = self.send(vimid, request.path, datagen, "POST",
321 # headers=headers, multipart=True)
323 # for key in params or {}:
324 # refobj = params[key]
325 # if type(refobj) is not unicode:
326 # if refobj.closed is False:
327 # print (refobj.close())
328 # os.remove(refobj.name)