X-Git-Url: https://gerrit.o-ran-sc.org/r/gitweb?a=blobdiff_plain;f=o2ims%2Fdomain%2Fstx_object.py;h=be668b6c760ed328829d3eb2c964edacd78950ee;hb=a6392b46c7b808b8adeede97c4dd69c5032e0d11;hp=73456944c58c40c453124a773f6057331e3ce676;hpb=f1946a1e90036bb8a758b49f94ac4d3b40bae66e;p=pti%2Fo2.git diff --git a/o2ims/domain/stx_object.py b/o2ims/domain/stx_object.py index 7345694..be668b6 100644 --- a/o2ims/domain/stx_object.py +++ b/o2ims/domain/stx_object.py @@ -13,31 +13,42 @@ # limitations under the License. # from dataclasses import dataclass -# import datetime +import datetime import json +from o2common.domain.base import AgRoot +from o2ims.domain.resource_type import ResourceTypeEnum, MismatchedModel +from o2common.helper import o2logging +logger = o2logging.get_logger(__name__) -class MismatchedModel(Exception): - pass - -class StxGenericModel: - def __init__(self, api_response: dict = None) -> None: +class StxGenericModel(AgRoot): + def __init__(self, type: ResourceTypeEnum, + api_response: dict = None, content_hash=None) -> None: + super().__init__() if api_response: - self.id = api_response.uuid - self.content = json.dumps(api_response.to_dict()) - self.updatetime = api_response.updated_at - self.createtime = api_response.created_at + self.id = str(api_response.uuid) + self.type = type + self.updatetime = datetime.datetime.strptime( + api_response.updated_at.split('.')[0], "%Y-%m-%dT%H:%M:%S") \ + if api_response.updated_at else None + self.createtime = datetime.datetime.strptime( + api_response.created_at.split('.')[0], "%Y-%m-%dT%H:%M:%S") \ + if api_response.created_at else None self.name = api_response.name + self.hash = content_hash if content_hash \ + else str(hash((self.id, self.updatetime))) + self.content = json.dumps(api_response.to_dict()) def is_outdated(self, newmodel) -> bool: - return self.updatetime < newmodel.updatetime + # return self.updatetime < newmodel.updatetime + # logger.warning("hash1: " + self.hash + " vs hash2: " + newmodel.hash) + return self.hash != newmodel.hash def update_by(self, newmodel) -> None: if self.id != newmodel.id: raise MismatchedModel("Mismatched model") self.name = newmodel.name - - self.content = newmodel.content self.createtime = newmodel.createtime self.updatetime = newmodel.updatetime + self.content = newmodel.content