summaryrefslogtreecommitdiffstats
path: root/lenovo/thinkcloud/swagger
diff options
context:
space:
mode:
authorBin Yang <bin.yang@windriver.com>2019-03-06 01:50:30 +0000
committerGerrit Code Review <gerrit@onap.org>2019-03-06 01:50:30 +0000
commitcc4e6853dca01ff1cdbbd6a163d1653e261d9a36 (patch)
treeca1e3575c9b664d61ce92b1e1a475c3109cc5e7d /lenovo/thinkcloud/swagger
parentc67c38021c18377a65a7d054aa280de5baa64d91 (diff)
parent56fd16d9f72b1b7f3f4363eeb7edb24a259a4160 (diff)
Merge "Add Lenovo ThinkCLoud Driver"
Diffstat (limited to 'lenovo/thinkcloud/swagger')
-rw-r--r--lenovo/thinkcloud/swagger/__init__.py13
-rw-r--r--lenovo/thinkcloud/swagger/tests.py31
-rw-r--r--lenovo/thinkcloud/swagger/urls.py26
-rw-r--r--lenovo/thinkcloud/swagger/views.py59
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)