X-Git-Url: https://gerrit.o-ran-sc.org/r/gitweb?a=blobdiff_plain;f=o2ims%2Fservice%2Fauditor%2Fpserver_handler.py;h=d5949eeac9551d7a0319b2ac88db2f230bfd9a16;hb=cd999dd33a2449fd8480fd641678360a749e5498;hp=f5df3814bfa468a50401f09785965716e0b7ce95;hpb=9625c5b766377f641d9641471f10dd491a61447f;p=pti%2Fo2.git diff --git a/o2ims/service/auditor/pserver_handler.py b/o2ims/service/auditor/pserver_handler.py index f5df381..d5949ee 100644 --- a/o2ims/service/auditor/pserver_handler.py +++ b/o2ims/service/auditor/pserver_handler.py @@ -15,7 +15,7 @@ # pylint: disable=unused-argument from __future__ import annotations import uuid -# import json +import json from typing import Callable from o2ims.domain import commands, events @@ -40,25 +40,38 @@ def update_pserver( ): stxobj = cmd.data with uow: - resourcepool = uow.resource_pools.get(cmd.parentid) + # resourcepool = uow.resource_pools.get(cmd.parentid) # res = uow.session.execute(select(resourcetype).where( # resourcetype.c.resourceTypeEnum == stxobj.type)) res = uow.session.execute( ''' - SELECT "resourceTypeId", "oCloudId", "name" - FROM resourcetype + SELECT "resourceTypeId", "name" + FROM "resourceType" WHERE "resourceTypeEnum" = :resource_type_enum ''', dict(resource_type_enum=stxobj.type.name) ) first = res.first() if first is None: - resourcetype_id = str(uuid.uuid4()) - uow.resource_types.add(ResourceType( + res_type_name = 'pserver' + resourcetype_id = str(uuid.uuid3( + uuid.NAMESPACE_URL, res_type_name)) + res_type = ResourceType( resourcetype_id, - 'pserver', stxobj.type, - resourcepool.oCloudId)) + res_type_name, stxobj.type, + description='The Physical Server resource type') + dict_id = str(uuid.uuid3( + uuid.NAMESPACE_URL, + str(f"{res_type_name}_alarmdictionary"))) + alarm_dictionary = uow.alarm_dictionaries.get(dict_id) + if alarm_dictionary: + res_type.alarmDictionary = alarm_dictionary + res_type.events.append(events.ResourceTypeChanged( + id=res_type.resourceTypeId, + notificationEventType=NotificationEventEnum.CREATE, + updatetime=stxobj.updatetime)) + uow.resource_types.add(res_type) else: resourcetype_id = first['resourceTypeId'] @@ -94,19 +107,26 @@ def is_outdated(resource: Resource, stxobj: StxGenericModel): def create_by(stxobj: StxGenericModel, parentid: str, resourcetype_id: str) \ -> Resource: - # content = json.loads(stxobj.content) resourcetype_id = resourcetype_id resourcepool_id = parentid - parent_id = parentid + parent_id = None # the root of the resource has no parent id gAssetId = '' # TODO: global ID - description = "A physical server resource" + extensions = json.dumps(stxobj.filtered) + description = ";".join([f"{k}:{v}" for k, v in stxobj.filtered.items()]) resource = Resource(stxobj.id, resourcetype_id, resourcepool_id, - stxobj.name, parent_id, gAssetId, stxobj.content, - description) + parent_id, gAssetId, stxobj.content, description, + extensions) resource.createtime = stxobj.createtime resource.updatetime = stxobj.updatetime resource.hash = stxobj.hash + resource.events.append(events.ResourceChanged( + id=stxobj.id, + resourcePoolId=resource.resourcePoolId, + notificationEventType=NotificationEventEnum.CREATE, + updatetime=stxobj.updatetime + )) + return resource @@ -114,9 +134,12 @@ def update_by(target: Resource, stxobj: StxGenericModel, parentid: str) -> None: if target.resourceId != stxobj.id: raise MismatchedModel("Mismatched Id") - target.createtime = stxobj.createtime target.updatetime = stxobj.updatetime target.hash = stxobj.hash + target.elements = stxobj.content + target.extensions = json.dumps(stxobj.filtered) + target.description = ";".join( + [f"{k}:{v}" for k, v in stxobj.filtered.items()]) target.version_number = target.version_number + 1 target.events.append(events.ResourceChanged( id=stxobj.id,