X-Git-Url: https://gerrit.o-ran-sc.org/r/gitweb?a=blobdiff_plain;f=o2ims%2Fdomain%2Fstx_object.py;h=90c166feedfb30b77900828cd29d404922d49aec;hb=b21c925328b0c700fde9001b7a56ea55decdf088;hp=73456944c58c40c453124a773f6057331e3ce676;hpb=f1946a1e90036bb8a758b49f94ac4d3b40bae66e;p=pti%2Fo2.git diff --git a/o2ims/domain/stx_object.py b/o2ims/domain/stx_object.py index 7345694..90c166f 100644 --- a/o2ims/domain/stx_object.py +++ b/o2ims/domain/stx_object.py @@ -13,31 +13,45 @@ # limitations under the License. # from dataclasses import dataclass -# import datetime +import datetime import json +from o2ims.domain.base import AgRoot + +from o2ims.domain.resource_type import ResourceTypeEnum +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: 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.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