2022-05-18 15:49:36 +01:00
|
|
|
from abc import abstractmethod
|
2022-04-22 14:01:16 +01:00
|
|
|
from datetime import datetime
|
2022-05-16 09:24:37 +01:00
|
|
|
from typing import Union, List, Optional, Any
|
2022-04-22 14:01:16 +01:00
|
|
|
|
2022-05-18 15:49:36 +01:00
|
|
|
from app.alarms import alarms_for
|
2022-06-15 11:50:15 +01:00
|
|
|
from app.brm.brn import BRN
|
2022-04-22 14:01:16 +01:00
|
|
|
from app.extensions import db
|
2022-05-18 15:49:36 +01:00
|
|
|
from app.models.alarms import Alarm
|
2022-04-22 14:01:16 +01:00
|
|
|
|
|
|
|
|
2022-05-16 11:44:03 +01:00
|
|
|
class AbstractConfiguration(db.Model): # type: ignore
|
2022-04-22 14:01:16 +01:00
|
|
|
__abstract__ = True
|
|
|
|
|
|
|
|
id = db.Column(db.Integer, primary_key=True)
|
|
|
|
description = db.Column(db.String(255), nullable=False)
|
|
|
|
added = db.Column(db.DateTime(), default=datetime.utcnow, nullable=False)
|
|
|
|
updated = db.Column(db.DateTime(), default=datetime.utcnow, nullable=False)
|
|
|
|
destroyed = db.Column(db.DateTime(), nullable=True)
|
|
|
|
|
2022-05-18 15:49:36 +01:00
|
|
|
@property
|
|
|
|
def alarms(self) -> List[Alarm]:
|
|
|
|
return alarms_for(self.brn)
|
|
|
|
|
|
|
|
@property
|
|
|
|
@abstractmethod
|
|
|
|
def brn(self) -> str:
|
|
|
|
raise NotImplementedError()
|
|
|
|
|
2022-05-16 11:44:03 +01:00
|
|
|
def destroy(self) -> None:
|
2022-04-22 14:01:16 +01:00
|
|
|
self.destroyed = datetime.utcnow()
|
|
|
|
self.updated = datetime.utcnow()
|
|
|
|
|
|
|
|
@classmethod
|
2022-05-16 11:44:03 +01:00
|
|
|
def csv_header(cls) -> List[str]:
|
2022-04-22 14:01:16 +01:00
|
|
|
return [
|
|
|
|
"id", "description", "added", "updated", "destroyed"
|
|
|
|
]
|
|
|
|
|
2022-05-16 11:44:03 +01:00
|
|
|
def csv_row(self) -> List[Any]:
|
2022-04-22 14:01:16 +01:00
|
|
|
return [
|
|
|
|
getattr(self, x) for x in self.csv_header()
|
|
|
|
]
|
|
|
|
|
|
|
|
|
2022-05-16 11:44:03 +01:00
|
|
|
class AbstractResource(db.Model): # type: ignore
|
2022-04-22 14:01:16 +01:00
|
|
|
__abstract__ = True
|
|
|
|
|
|
|
|
id = db.Column(db.Integer, primary_key=True)
|
|
|
|
added = db.Column(db.DateTime(), default=datetime.utcnow, nullable=False)
|
|
|
|
updated = db.Column(db.DateTime(), default=datetime.utcnow, nullable=False)
|
|
|
|
deprecated = db.Column(db.DateTime(), nullable=True)
|
2022-05-01 16:23:45 +01:00
|
|
|
deprecation_reason = db.Column(db.String(), nullable=True)
|
2022-04-22 14:01:16 +01:00
|
|
|
destroyed = db.Column(db.DateTime(), nullable=True)
|
|
|
|
|
2022-05-16 09:24:37 +01:00
|
|
|
def __init__(self, *,
|
|
|
|
id: Optional[int] = None,
|
|
|
|
added: Optional[datetime] = None,
|
|
|
|
updated: Optional[datetime] = None,
|
|
|
|
deprecated: Optional[datetime] = None,
|
|
|
|
deprecation_reason: Optional[str] = None,
|
|
|
|
destroyed: Optional[datetime] = None,
|
|
|
|
**kwargs: Any) -> None:
|
|
|
|
super().__init__(id=id,
|
|
|
|
added=added,
|
|
|
|
updated=updated,
|
|
|
|
deprecated=deprecated,
|
|
|
|
deprecation_reason=deprecation_reason,
|
|
|
|
destroyed=destroyed,
|
|
|
|
**kwargs)
|
2022-05-14 10:18:00 +01:00
|
|
|
if self.added is None:
|
|
|
|
self.added = datetime.utcnow()
|
|
|
|
if self.updated is None:
|
|
|
|
self.updated = datetime.utcnow()
|
|
|
|
|
2022-05-18 15:49:36 +01:00
|
|
|
@property
|
|
|
|
@abstractmethod
|
2022-06-15 11:50:15 +01:00
|
|
|
def brn(self) -> BRN:
|
2022-05-18 15:49:36 +01:00
|
|
|
raise NotImplementedError()
|
|
|
|
|
2022-05-16 09:24:37 +01:00
|
|
|
def deprecate(self, *, reason: str) -> None:
|
2022-04-22 14:01:16 +01:00
|
|
|
self.deprecated = datetime.utcnow()
|
2022-05-01 16:23:45 +01:00
|
|
|
self.deprecation_reason = reason
|
2022-04-22 14:01:16 +01:00
|
|
|
self.updated = datetime.utcnow()
|
|
|
|
|
2022-05-16 09:24:37 +01:00
|
|
|
def destroy(self) -> None:
|
2022-04-22 14:01:16 +01:00
|
|
|
if self.deprecated is None:
|
|
|
|
self.deprecated = datetime.utcnow()
|
|
|
|
self.destroyed = datetime.utcnow()
|
|
|
|
self.updated = datetime.utcnow()
|
|
|
|
|
|
|
|
@classmethod
|
2022-05-16 09:24:37 +01:00
|
|
|
def csv_header(cls) -> List[str]:
|
2022-04-22 14:01:16 +01:00
|
|
|
return [
|
2022-05-11 16:29:06 +01:00
|
|
|
"id", "added", "updated", "deprecated", "deprecation_reason", "destroyed"
|
2022-04-22 14:01:16 +01:00
|
|
|
]
|
|
|
|
|
2022-05-16 09:24:37 +01:00
|
|
|
def csv_row(self) -> List[Union[datetime, bool, int, str]]:
|
2022-04-22 14:01:16 +01:00
|
|
|
return [
|
|
|
|
getattr(self, x) for x in self.csv_header()
|
|
|
|
]
|