2022-05-04 15:36:36 +01:00
|
|
|
from typing import Optional
|
|
|
|
|
|
|
|
from tldextract import extract
|
|
|
|
|
2022-04-22 14:01:16 +01:00
|
|
|
from app import db
|
|
|
|
from app.models import AbstractConfiguration, AbstractResource
|
2022-05-04 15:36:36 +01:00
|
|
|
from app.models.onions import Onion
|
2022-04-22 14:01:16 +01:00
|
|
|
|
|
|
|
|
|
|
|
class Origin(AbstractConfiguration):
|
|
|
|
group_id = db.Column(db.Integer, db.ForeignKey("group.id"), nullable=False)
|
|
|
|
domain_name = db.Column(db.String(255), unique=True, nullable=False)
|
2022-05-01 16:23:45 +01:00
|
|
|
auto_rotation = db.Column(db.Boolean, nullable=False)
|
2022-04-22 14:01:16 +01:00
|
|
|
|
|
|
|
group = db.relationship("Group", back_populates="origins")
|
|
|
|
mirrors = db.relationship("Mirror", back_populates="origin")
|
|
|
|
proxies = db.relationship("Proxy", back_populates="origin")
|
|
|
|
alarms = db.relationship("Alarm", back_populates="origin")
|
|
|
|
|
|
|
|
@classmethod
|
2022-05-01 16:23:45 +01:00
|
|
|
def csv_header(cls):
|
2022-04-22 14:01:16 +01:00
|
|
|
return super().csv_header() + [
|
|
|
|
"group_id", "domain_name"
|
|
|
|
]
|
|
|
|
|
|
|
|
def destroy(self):
|
|
|
|
super().destroy()
|
|
|
|
for proxy in self.proxies:
|
|
|
|
proxy.destroy()
|
|
|
|
|
2022-05-04 15:36:36 +01:00
|
|
|
def onion(self) -> Optional[str]:
|
|
|
|
tld = extract(self.domain_name).registered_domain
|
|
|
|
onion = Onion.query.filter(Onion.domain_name == tld).first()
|
|
|
|
if not onion:
|
|
|
|
return None
|
|
|
|
return self.domain_name.replace(tld, f"{onion.onion_name}")
|
|
|
|
|
2022-04-22 14:01:16 +01:00
|
|
|
|
|
|
|
class Proxy(AbstractResource):
|
|
|
|
origin_id = db.Column(db.Integer, db.ForeignKey("origin.id"), nullable=False)
|
|
|
|
provider = db.Column(db.String(20), nullable=False)
|
2022-04-25 14:56:35 +01:00
|
|
|
psg = db.Column(db.Integer, nullable=True)
|
2022-04-22 14:01:16 +01:00
|
|
|
slug = db.Column(db.String(20), nullable=True)
|
|
|
|
terraform_updated = db.Column(db.DateTime(), nullable=True)
|
|
|
|
url = db.Column(db.String(255), nullable=True)
|
|
|
|
|
|
|
|
origin = db.relationship("Origin", back_populates="proxies")
|
|
|
|
alarms = db.relationship("Alarm", back_populates="proxy")
|
|
|
|
|
|
|
|
@classmethod
|
2022-05-01 16:23:45 +01:00
|
|
|
def csv_header(cls):
|
2022-04-22 14:01:16 +01:00
|
|
|
return super().csv_header() + [
|
2022-04-25 14:56:35 +01:00
|
|
|
"origin_id", "provider", "psg", "slug", "terraform_updated", "url"
|
2022-04-22 14:01:16 +01:00
|
|
|
]
|
|
|
|
|
|
|
|
|
|
|
|
class Mirror(AbstractResource):
|
|
|
|
origin_id = db.Column(db.Integer, db.ForeignKey("origin.id"), nullable=False)
|
|
|
|
url = db.Column(db.String(255), unique=True, nullable=False)
|
|
|
|
|
|
|
|
origin = db.relationship("Origin", back_populates="mirrors")
|
|
|
|
|
|
|
|
@classmethod
|
2022-05-01 16:23:45 +01:00
|
|
|
def csv_header(cls):
|
2022-04-22 14:01:16 +01:00
|
|
|
return super().csv_header() + [
|
|
|
|
"origin_id", "url"
|
|
|
|
]
|