Add get detail of a resource to API; remove the dependency of the domain in the view...
[pti/o2.git] / o2ims / domain / ocloud.py
index ec41c0e..e3584ed 100644 (file)
@@ -13,8 +13,9 @@
 #  limitations under the License.\r
 \r
 from __future__ import annotations\r
+import json\r
 \r
-from o2common.domain.base import AgRoot\r
+from o2common.domain.base import AgRoot, Serializer\r
 # from dataclasses import dataclass\r
 # from datetime import date\r
 # from typing import Optional, List, Set\r
@@ -22,7 +23,7 @@ from .resource_type import ResourceTypeEnum
 # from uuid import UUID\r
 \r
 \r
-class Subscription(AgRoot):\r
+class Subscription(AgRoot, Serializer):\r
     def __init__(self, id: str, callback: str, consumersubid: str = '',\r
                  filter: str = '') -> None:\r
         super().__init__()\r
@@ -33,7 +34,7 @@ class Subscription(AgRoot):
         self.filter = filter\r
 \r
 \r
-class DeploymentManager(AgRoot):\r
+class DeploymentManager(AgRoot, Serializer):\r
     def __init__(self, id: str, name: str, ocloudid: str,\r
                  dmsendpoint: str, description: str = '',\r
                  supportedLocations: str = '', capabilities: str = '',\r
@@ -51,7 +52,7 @@ class DeploymentManager(AgRoot):
         self.extensions = []\r
 \r
 \r
-class ResourcePool(AgRoot):\r
+class ResourcePool(AgRoot, Serializer):\r
     def __init__(self, id: str, name: str, location: str,\r
                  ocloudid: str, gLocationId: str = '',\r
                  description: str = '') -> None:\r
@@ -66,7 +67,7 @@ class ResourcePool(AgRoot):
         self.extensions = []\r
 \r
 \r
-class ResourceType(AgRoot):\r
+class ResourceType(AgRoot, Serializer):\r
     def __init__(self, typeid: str, name: str, typeEnum: ResourceTypeEnum,\r
                  ocloudid: str, vender: str = '', model: str = '',\r
                  version: str = '',\r
@@ -84,9 +85,9 @@ class ResourceType(AgRoot):
         self.extensions = []\r
 \r
 \r
-class Resource(AgRoot):\r
+class Resource(AgRoot, Serializer):\r
     def __init__(self, resourceId: str, resourceTypeId: str,\r
-                 resourcePoolId: str, parentId: str = '',\r
+                 resourcePoolId: str, name: str, parentId: str = '',\r
                  gAssetId: str = '', elements: str = '',\r
                  description: str = '') -> None:\r
         super().__init__()\r
@@ -94,14 +95,34 @@ class Resource(AgRoot):
         self.version_number = 0\r
         self.resourceTypeId = resourceTypeId\r
         self.resourcePoolId = resourcePoolId\r
+        self.name = name\r
         self.globalAssetId = gAssetId\r
         self.parentId = parentId\r
         self.elements = elements\r
         self.description = description\r
+        self.children = []\r
         self.extensions = []\r
 \r
+    def set_children(self, children: list):\r
+        self.children = children\r
+\r
+    def serialize(self):\r
+        d = Serializer.serialize(self)\r
+\r
+        if 'elements' in d and d['elements'] != '':\r
+            d['elements'] = json.loads(d['elements'])\r
+\r
+        if not hasattr(self, 'children') or len(self.children) == 0:\r
+            return d\r
+        else:\r
+            d['children'] = []\r
+\r
+        for child in self.children:\r
+            d['children'].append(child.serialize())\r
+        return d\r
+\r
 \r
-class Ocloud(AgRoot):\r
+class Ocloud(AgRoot, Serializer):\r
     def __init__(self, ocloudid: str, name: str, imsendpoint: str,\r
                  globalcloudId: str = '',\r
                  description: str = '', version_number: int = 0) -> None:\r