Release pti-o2imsdms 2.0.1 image
[pti/o2.git] / o2dms / api / dms_lcm_view.py
index 9995e8e..bb5c94d 100644 (file)
@@ -1,34 +1,94 @@
-# Copyright (C) 2021 Wind River Systems, Inc.\r
-#\r
-#  Licensed under the Apache License, Version 2.0 (the "License");\r
-#  you may not use this file except in compliance with the License.\r
-#  You may obtain a copy of the License at\r
-#\r
-#      http://www.apache.org/licenses/LICENSE-2.0\r
-#\r
-#  Unless required by applicable law or agreed to in writing, software\r
-#  distributed under the License is distributed on an "AS IS" BASIS,\r
-#  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r
-#  See the License for the specific language governing permissions and\r
-#  limitations under the License.\r
-\r
-from sqlalchemy import select\r
-from o2common.service import unit_of_work\r
-from o2ims.adapter.orm import deploymentmanager\r
-from o2common.helper import o2logging\r
-logger = o2logging.get_logger(__name__)\r
-\r
-\r
-def deployment_managers(uow: unit_of_work.AbstractUnitOfWork):\r
-    with uow:\r
-        res = uow.session.execute(select(deploymentmanager))\r
-    return [dict(r) for r in res]\r
-\r
-\r
-def deployment_manager_one(deploymentManagerId: str,\r
-                           uow: unit_of_work.AbstractUnitOfWork):\r
-    with uow:\r
-        res = uow.session.execute(select(deploymentmanager).where(\r
-            deploymentmanager.c.deploymentManagerId == deploymentManagerId))\r
-        first = res.first()\r
-    return None if first is None else dict(first)\r
+# Copyright (C) 2021 Wind River 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 string
+import random
+import yaml
+from datetime import datetime
+
+# from sqlalchemy import select
+from o2common.service import unit_of_work
+# from o2ims.adapter.orm import deploymentmanager
+from o2common.helper import o2logging
+from o2common.config import config
+logger = o2logging.get_logger(__name__)
+
+
+def deployment_managers(uow: unit_of_work.AbstractUnitOfWork):
+    # with uow:
+    # res = uow.session.execute(select(deploymentmanager))
+    # return [dict(r) for r in res]
+    with uow:
+        li = uow.deployment_managers.list()
+    return [r.serialize() for r in li]
+
+
+def deployment_manager_one(deploymentManagerId: str,
+                           uow: unit_of_work.AbstractUnitOfWork):
+
+    # with uow:
+    #     res = uow.session.execute(select(deploymentmanager).where(
+    #         deploymentmanager.c.deploymentManagerId == deploymentManagerId))
+    #     first = res.first()
+    #     return None if first is None else dict(first)
+    with uow:
+        first = uow.deployment_managers.get(deploymentManagerId)
+        return first.serialize() if first is not None else None
+
+    # profile = profile.lower()
+    # with uow:
+    #     first = uow.deployment_managers.get(deploymentManagerId)
+    #     if first is None:
+    #         return first
+    #     result = first.serialize()
+
+    # profile_data = result.pop("profile", None)
+    # result['profileName'] = 'default'
+
+    # if "sol018" == profile:
+    #     result['profileName'] = profile
+    #     result['profileData'] = profile_data
+    # elif "file" == profile and result.hasattr("profile"):
+    # p = result.pop("profile", None)
+    # result["profile"] = _gen_kube_config(deploymentManagerId, p)
+
+    # return result
+
+
+def _gen_kube_config(dmId: str, kubeconfig: dict) -> dict:
+
+    data = config.gen_k8s_config_dict(
+        kubeconfig.pop('cluster_api_endpoint', None),
+        kubeconfig.pop('cluster_ca_cert', None),
+        kubeconfig.pop('admin_user', None),
+        kubeconfig.pop('admin_client_cert', None),
+        kubeconfig.pop('admin_client_key', None),
+    )
+
+    # Generate a random key for tmp kube config file
+    letters = string.ascii_uppercase
+    random_key = ''.join(random.choice(letters) for i in range(10))
+
+    # Get datetime of now as tag of the tmp file
+    current_time = datetime.now().strftime("%Y%m%d%H%M%S")
+    tmp_file_name = random_key + "_" + current_time
+
+    # write down the yaml file of kubectl into tmp folder
+    with open('/tmp/kubeconfig_' + tmp_file_name, 'w') as file:
+        yaml.dump(data, file)
+
+    kubeconfig["kube_config_file"] = config.get_api_url() + \
+        config.get_o2dms_api_base() + "/" + dmId + "/download/" + tmp_file_name
+
+    return kubeconfig