majuna/app/models/onions.py

83 lines
2.2 KiB
Python
Raw Normal View History

2022-11-09 13:36:12 +00:00
import base64
import hashlib
2024-11-10 21:41:54 +00:00
from typing import Optional, TypedDict
from sqlalchemy.orm import Mapped, mapped_column, relationship
2022-11-09 13:36:12 +00:00
2022-06-15 11:50:15 +01:00
from app.brm.brn import BRN
2022-05-04 15:36:36 +01:00
from app.extensions import db
from app.models import AbstractConfiguration, AbstractResource
from app.models.base import Group
2022-05-04 15:36:36 +01:00
2024-11-10 21:41:54 +00:00
class OnionDict(TypedDict):
Id: int
DomainName: str
OnionName: str
2022-05-04 15:36:36 +01:00
class Onion(AbstractConfiguration):
2022-11-08 14:23:32 +00:00
@property
def brn(self) -> BRN:
return BRN(
group_id=self.group_id,
product="eotk",
provider="*",
resource_type="onion",
resource_id=self.onion_name
)
2022-05-04 15:36:36 +01:00
group_id = db.Column(db.Integer(), db.ForeignKey("group.id"), nullable=False)
domain_name = db.Column(db.String(255), nullable=False)
2022-11-09 13:36:12 +00:00
onion_public_key = db.Column(db.LargeBinary, nullable=False)
onion_private_key = db.Column(db.LargeBinary, nullable=False)
tls_public_key = db.Column(db.LargeBinary, nullable=False)
tls_private_key = db.Column(db.LargeBinary, nullable=False)
2022-05-04 15:36:36 +01:00
group = db.relationship("Group", back_populates="onions")
2022-11-09 13:36:12 +00:00
@property
def onion_name(self) -> str:
2022-11-09 13:36:12 +00:00
p = self.onion_public_key[32:]
h = hashlib.sha3_256()
h.update(b".onion checksum")
h.update(p)
h.update(b"\x03")
checksum = h.digest()
result = bytearray(p)
result.extend(checksum[0:2])
result.append(0x03)
onion = base64.b32encode(result).decode("utf-8").strip("=")
return onion.lower()
2024-11-10 21:41:54 +00:00
def to_dict(self) -> OnionDict:
return {
"Id": self.id,
"DomainName": self.domain_name,
"OnionName": self.onion_name,
}
2022-05-04 15:36:36 +01:00
class Eotk(AbstractResource):
group_id: Mapped[int] = mapped_column(db.Integer(), db.ForeignKey("group.id"))
instance_id: Mapped[Optional[str]]
provider: Mapped[str]
region: Mapped[str]
2022-05-04 15:36:36 +01:00
group: Mapped[Group] = relationship("Group", back_populates="eotks")
@property
2022-06-15 11:50:15 +01:00
def brn(self) -> BRN:
return BRN(
group_id=self.group_id,
provider=self.provider,
product="eotk",
resource_type="instance",
resource_id=self.region
)