majuna/app/models/base.py

64 lines
2.1 KiB
Python
Raw Normal View History

2022-04-22 14:01:16 +01:00
from datetime import datetime
from app import db
from app.models import AbstractConfiguration
class Group(AbstractConfiguration):
group_name = db.Column(db.String(80), unique=True, nullable=False)
eotk = db.Column(db.Boolean())
origins = db.relationship("Origin", back_populates="group")
bridgeconfs = db.relationship("BridgeConf", back_populates="group")
2022-05-04 15:36:36 +01:00
eotks = db.relationship("Eotk", back_populates="group")
onions = db.relationship("Onion", back_populates="group")
2022-04-22 14:01:16 +01:00
alarms = db.relationship("Alarm", back_populates="group")
@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_name", "eotk"
]
class MirrorList(AbstractConfiguration):
provider = db.Column(db.String(255), nullable=False)
format = db.Column(db.String(20), nullable=False)
# obfuscate = db.Column(db.Boolean(), nullable=False)
2022-04-22 14:01:16 +01:00
container = db.Column(db.String(255), nullable=False)
branch = db.Column(db.String(255), nullable=False)
2022-05-11 16:12:52 +01:00
role = db.Column(db.String(255), nullable=True)
2022-04-22 14:01:16 +01:00
filename = db.Column(db.String(255), nullable=False)
providers_supported = {
"github": "GitHub",
"gitlab": "GitLab",
"s3": "AWS S3",
}
formats_supported = {
"bc2": "Bypass Censorship v2",
"bc3": "Bypass Censorship v3",
"bca": "Bypass Censorship Analytics",
"bridgelines": "Tor Bridge Lines"
}
2022-04-22 14:01:16 +01:00
def destroy(self):
self.destroyed = datetime.utcnow()
self.updated = datetime.utcnow()
db.session.commit()
def url(self):
if self.provider == "gitlab":
return f"https://gitlab.com/{self.container}/-/raw/{self.branch}/{self.filename}"
if self.provider == "github":
return f"https://raw.githubusercontent.com/{self.container}/{self.branch}/{self.filename}"
if self.provider == "s3":
return f"s3://{self.container}/{self.filename}"
@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() + [
"provider", "format", "container", "branch", "filename"
]