Release pti-o2imsdms 2.0.1 image
[pti/o2.git] / o2dms / api / dms_lcm_view.py
index 3a634e4..bb5c94d 100644 (file)
 #  See the License for the specific language governing permissions and
 #  limitations under the License.
 
-from sqlalchemy import select
+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 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:
-        res = uow.session.execute(select(deploymentmanager))
-    return [dict(r) for r in res]
+        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:
-        res = uow.session.execute(select(deploymentmanager).where(
-            deploymentmanager.c.deploymentManagerId == deploymentManagerId))
-        first = res.first()
-    return None if first is None else dict(first)
+        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