2022-04-22 14:01:16 +01:00
|
|
|
from datetime import datetime
|
2022-05-16 11:44:03 +01:00
|
|
|
from typing import List
|
2022-04-22 14:01:16 +01:00
|
|
|
|
2022-06-23 13:42:45 +01:00
|
|
|
from app.brm.brn import BRN
|
2022-05-17 08:28:37 +01:00
|
|
|
from app.extensions import db
|
2022-05-06 12:28:11 +01:00
|
|
|
from app.models import AbstractConfiguration, AbstractResource
|
2022-04-22 14:01:16 +01:00
|
|
|
|
|
|
|
|
2022-05-06 12:28:11 +01:00
|
|
|
class BridgeConf(AbstractConfiguration):
|
2022-04-22 14:01:16 +01:00
|
|
|
group_id = db.Column(db.Integer, db.ForeignKey("group.id"), nullable=False)
|
|
|
|
provider = db.Column(db.String(20), nullable=False)
|
|
|
|
method = db.Column(db.String(20), nullable=False)
|
|
|
|
number = db.Column(db.Integer())
|
|
|
|
|
|
|
|
group = db.relationship("Group", back_populates="bridgeconfs")
|
|
|
|
bridges = db.relationship("Bridge", back_populates="conf")
|
|
|
|
|
2022-06-23 13:42:45 +01:00
|
|
|
@property
|
|
|
|
def brn(self) -> BRN:
|
|
|
|
return BRN(
|
|
|
|
group_id=self.group_id,
|
|
|
|
product="bridge",
|
|
|
|
provider="",
|
|
|
|
resource_type="bridgeconf",
|
|
|
|
resource_id=str(self.id)
|
|
|
|
)
|
|
|
|
|
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()
|
|
|
|
for bridge in self.bridges:
|
|
|
|
if bridge.destroyed is None:
|
|
|
|
bridge.destroyed = datetime.utcnow()
|
|
|
|
bridge.updated = datetime.utcnow()
|
2022-05-06 12:28:11 +01:00
|
|
|
|
|
|
|
@classmethod
|
2022-05-16 11:44:03 +01:00
|
|
|
def csv_header(cls) -> List[str]:
|
2022-05-06 12:28:11 +01:00
|
|
|
return super().csv_header() + [
|
|
|
|
"group_id", "provider", "method", "description", "number"
|
|
|
|
]
|
2022-04-22 14:01:16 +01:00
|
|
|
|
|
|
|
|
|
|
|
class Bridge(AbstractResource):
|
|
|
|
conf_id = db.Column(db.Integer, db.ForeignKey("bridge_conf.id"), nullable=False)
|
|
|
|
terraform_updated = db.Column(db.DateTime(), nullable=True)
|
|
|
|
nickname = db.Column(db.String(255), nullable=True)
|
|
|
|
fingerprint = db.Column(db.String(255), nullable=True)
|
|
|
|
hashed_fingerprint = db.Column(db.String(255), nullable=True)
|
|
|
|
bridgeline = db.Column(db.String(255), nullable=True)
|
|
|
|
|
|
|
|
conf = db.relationship("BridgeConf", back_populates="bridges")
|
2022-05-06 12:28:11 +01:00
|
|
|
|
2022-07-04 14:50:34 +01:00
|
|
|
@property
|
|
|
|
def brn(self) -> BRN:
|
|
|
|
return BRN(
|
|
|
|
group_id=self.conf.group_id,
|
|
|
|
product="bridge",
|
|
|
|
provider=self.conf.provider,
|
|
|
|
resource_type="bridge",
|
|
|
|
resource_id=str(self.id)
|
|
|
|
)
|
|
|
|
|
2022-05-06 12:28:11 +01:00
|
|
|
@classmethod
|
2022-05-16 11:44:03 +01:00
|
|
|
def csv_header(cls) -> List[str]:
|
2022-05-06 12:28:11 +01:00
|
|
|
return super().csv_header() + [
|
|
|
|
"conf_id", "terraform_updated", "nickname", "fingerprint", "hashed_fingerprint", "bridgeline"
|
|
|
|
]
|