name = CharField()
cooldown_time = IntegerField()
last_scale = DateTimeField(default=datetime.datetime.now)
- scaling_group = ForeignKeyField(ScalingGroup, related_name='scaling_policies')
+ scaling_group = ForeignKeyField(ScalingGroup, related_name='scaling_policies', on_delete='CASCADE')
class ScalingCriteria(BaseModel):
name = CharField()
- scaling_policy = ForeignKeyField(ScalingPolicy, related_name='scaling_criterias')
+ scaling_policy = ForeignKeyField(ScalingPolicy, related_name='scaling_criterias', on_delete='CASCADE')
class ScalingAlarm(BaseModel):
- alarm_id = CharField()
+ alarm_uuid = CharField(unique=True)
action = CharField()
vnf_member_index = IntegerField()
vdu_name = CharField()
- scaling_criteria = ForeignKeyField(ScalingCriteria, related_name='scaling_alarms')
+ scaling_criteria = ForeignKeyField(ScalingCriteria, related_name='scaling_alarms', on_delete='CASCADE')
class DatabaseManager:
def create_tables(self):
- try:
- db.connect()
- db.create_tables([ScalingGroup, ScalingPolicy, ScalingCriteria, ScalingAlarm])
- db.close()
- except Exception as e:
- log.exception("Error creating tables: ")
+ db.connect()
+ db.create_tables([ScalingGroup, ScalingPolicy, ScalingCriteria, ScalingAlarm])
+ db.close()
+
+ def get_alarm(self, alarm_uuid: str):
+ return ScalingAlarm.select().where(ScalingAlarm.alarm_uuid == alarm_uuid).get()