diff options
author | Bin Yang <bin.yang@windriver.com> | 2019-03-06 01:50:30 +0000 |
---|---|---|
committer | Gerrit Code Review <gerrit@onap.org> | 2019-03-06 01:50:30 +0000 |
commit | cc4e6853dca01ff1cdbbd6a163d1653e261d9a36 (patch) | |
tree | ca1e3575c9b664d61ce92b1e1a475c3109cc5e7d /lenovo/thinkcloud/swagger | |
parent | c67c38021c18377a65a7d054aa280de5baa64d91 (diff) | |
parent | 56fd16d9f72b1b7f3f4363eeb7edb24a259a4160 (diff) |
Merge "Add Lenovo ThinkCLoud Driver"
Diffstat (limited to 'lenovo/thinkcloud/swagger')
-rw-r--r-- | lenovo/thinkcloud/swagger/__init__.py | 13 | ||||
-rw-r--r-- | lenovo/thinkcloud/swagger/tests.py | 31 | ||||
-rw-r--r-- | lenovo/thinkcloud/swagger/urls.py | 26 | ||||
-rw-r--r-- | lenovo/thinkcloud/swagger/views.py | 59 |
4 files changed, 129 insertions, 0 deletions
diff --git a/lenovo/thinkcloud/swagger/__init__.py b/lenovo/thinkcloud/swagger/__init__.py new file mode 100644 index 00000000..5b09b2fd --- /dev/null +++ b/lenovo/thinkcloud/swagger/__init__.py @@ -0,0 +1,13 @@ +# Copyright (c) 2017-2018 Lenovo Systems, Inc. +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. diff --git a/lenovo/thinkcloud/swagger/tests.py b/lenovo/thinkcloud/swagger/tests.py new file mode 100644 index 00000000..400292a3 --- /dev/null +++ b/lenovo/thinkcloud/swagger/tests.py @@ -0,0 +1,31 @@ +# Copyright (c) 2017-2018 Lenovo Systems, Inc. +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +import unittest +from django.test import Client +from rest_framework import status + + +class SampleViewTest(unittest.TestCase): + def setUp(self): + self.client = Client() + + def tearDown(self): + pass + + def test_sample(self): + response = self.client.get("/api/multicloud-thinkcloud/v0/swagger.json") + self.assertEqual(status.HTTP_200_OK, response.status_code, response.content) +# resp_data = response.json() +# self.assertEqual({"status": "active"}, resp_data) diff --git a/lenovo/thinkcloud/swagger/urls.py b/lenovo/thinkcloud/swagger/urls.py new file mode 100644 index 00000000..7061cc41 --- /dev/null +++ b/lenovo/thinkcloud/swagger/urls.py @@ -0,0 +1,26 @@ +# Copyright (c) 2017-2018 Lenovo Systems, Inc. +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +from django.conf.urls import url +from rest_framework.urlpatterns import format_suffix_patterns + +from thinkcloud.swagger.views import SwaggerJsonView +from thinkcloud.swagger.views import APIv1SwaggerJsonView + +urlpatterns = [ + url(r'^api/multicloud-thinkcloud/v0/swagger.json$', SwaggerJsonView.as_view()), + url(r'^api/multicloud-thinkcloud/v1/swagger.json$', APIv1SwaggerJsonView.as_view()), +] + +urlpatterns = format_suffix_patterns(urlpatterns) diff --git a/lenovo/thinkcloud/swagger/views.py b/lenovo/thinkcloud/swagger/views.py new file mode 100644 index 00000000..e3c14c81 --- /dev/null +++ b/lenovo/thinkcloud/swagger/views.py @@ -0,0 +1,59 @@ +# Copyright (c) 2017-2018 Lenovo Systems, Inc. +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +import logging + +from rest_framework.response import Response + +from newton_base.swagger import views as newton_json_view + +logger = logging.getLogger(__name__) + + +class SwaggerJsonView(newton_json_view.SwaggerJsonView): + + def get(self, request): + ''' + reuse newton code and update the basePath + :param request: + :return: + ''' + + resp = super(SwaggerJsonView, self).get(request) + json_data = resp.data if resp else None + if json_data: + json_data["basePath"] = "/api/multicloud-thinkcloud/v0/" + json_data["info"]["title"] = "Service NBI of MultiCloud plugin for OpenStack Thinkcloud" + return Response(data=json_data, status=200) + else: + return Response(data={'error': 'internal error'}, status=500) + + +class APIv1SwaggerJsonView(newton_json_view.SwaggerJsonView): + + def get(self, request): + ''' + reuse newton code and update the basePath + :param request: + :return: + ''' + + resp = super(APIv1SwaggerJsonView, self).get(request) + json_data = resp.data if resp else None + if json_data: + json_data["basePath"] = "/api/multicloud-thinkcloud/v1/" + json_data["info"]["title"] = "Service NBI v1 of MultiCloud plugin for Thinkcloud" + return Response(data=json_data, status=200) + else: + return Response(data={'error': 'internal error'}, status=500) |