X-Git-Url: https://osm.etsi.org/gitweb/?a=blobdiff_plain;f=osm_policy_module%2Fcore%2Fdatabase.py;h=e596d74fb48515a550f4b4492e26dbd05f7b6141;hb=refs%2Ftags%2Fv12.0.0rc1;hp=7bf11d82ca10d30d4f6a301ddff816a8b6abeee9;hpb=4584f8e86a492d67d120bfea1195eff1475c0a65;p=osm%2FPOL.git diff --git a/osm_policy_module/core/database.py b/osm_policy_module/core/database.py index 7bf11d8..e596d74 100644 --- a/osm_policy_module/core/database.py +++ b/osm_policy_module/core/database.py @@ -98,6 +98,10 @@ class VnfAlarm(BaseModel): nsr_id = CharField() vnf_member_index = CharField() vdu_name = CharField() + last_action = CharField(default='insufficient-data') + id_suffix = IntegerField() + ok_ack = BooleanField(default=False) + alarm_ack = BooleanField(default=False) class AlarmAction(BaseModel): @@ -106,6 +110,22 @@ class AlarmAction(BaseModel): alarm = ForeignKeyField(VnfAlarm, related_name="actions", on_delete="CASCADE") +class HealingAction(BaseModel): + alarm_id = CharField() + recovery_action = CharField() + alarm_uuid = CharField(unique=True) + nsr_id = CharField() + vnfinstance_id = CharField() + vnf_member_index = CharField() + vdur_name = CharField() + vdu_id = CharField() + cooldown_time = IntegerField() + count_index = IntegerField() + last_heal = DateTimeField(default=datetime.datetime.now) + last_status = CharField(default='insufficient-data') + day1 = BooleanField(default=False) + + class DatabaseManager: def __init__(self, config: Config): db.initialize(connect(config.get("sql", "database_uri"))) @@ -220,3 +240,18 @@ class AlarmActionRepository: @staticmethod def create(**query) -> AlarmAction: return AlarmAction.create(**query) + + +class HealingActionRepository: + @staticmethod + def list(*expressions) -> Iterable[HealingAction]: + log.info("### Printing healing action db alarm {}".format(HealingAction.select().where(*expressions))) + return HealingAction.select().where(*expressions) + + @staticmethod + def get(*expressions) -> HealingAction: + return HealingAction.select().where(*expressions).get() + + @staticmethod + def create(**query) -> HealingAction: + return HealingAction.create(**query)