majuna/app/models/bridges.py

81 lines
2.6 KiB
Python
Raw Normal View History

import enum
from datetime import datetime, timezone
from typing import List, Optional
2022-04-22 14:01:16 +01:00
from sqlalchemy.orm import Mapped, mapped_column, relationship
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
from app.models.base import Pool
2022-04-22 14:01:16 +01:00
class ProviderAllocation(enum.Enum):
RANDOM = "random"
COST = "cost"
2022-05-06 12:28:11 +01:00
class BridgeConf(AbstractConfiguration):
pool_id: Mapped[int] = mapped_column(db.Integer, db.ForeignKey("pool.id"))
method: Mapped[str]
target_number: Mapped[int]
max_number: Mapped[int]
expiry_hours: Mapped[int]
provider_allocation: Mapped[ProviderAllocation]
pool: Mapped[Pool] = relationship("Pool", back_populates="bridgeconfs")
bridges: Mapped[List["Bridge"]] = relationship("Bridge", back_populates="conf")
2022-04-22 14:01:16 +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:
self.destroyed = datetime.now(tz=timezone.utc)
self.updated = datetime.now(tz=timezone.utc)
2022-04-22 14:01:16 +01:00
for bridge in self.bridges:
if bridge.destroyed is None:
bridge.destroyed = datetime.now(tz=timezone.utc)
bridge.updated = datetime.now(tz=timezone.utc)
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() + [
"pool_id", "provider", "method", "description", "target_number", "max_number", "expiry_hours"
2022-05-06 12:28:11 +01:00
]
2022-04-22 14:01:16 +01:00
class Bridge(AbstractResource):
conf_id: Mapped[int] = mapped_column(db.ForeignKey("bridge_conf.id"))
cloud_account_id: Mapped[int] = mapped_column(db.ForeignKey("cloud_account.id"))
terraform_updated: Mapped[Optional[datetime]] = mapped_column(db.DateTime(timezone=True), nullable=True)
nickname: Mapped[Optional[str]]
fingerprint: Mapped[Optional[str]]
hashed_fingerprint: Mapped[Optional[str]]
bridgeline: Mapped[Optional[str]]
2022-04-22 14:01:16 +01:00
conf = db.relationship("BridgeConf", back_populates="bridges")
2023-02-26 12:52:08 +00:00
cloud_account = db.relationship("CloudAccount", 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=0,
2022-07-04 14:50:34 +01:00
product="bridge",
2023-02-26 12:52:08 +00:00
provider=self.cloud_account.provider.key,
2022-07-04 14:50:34 +01:00
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"
]