102 lines
3.2 KiB
Python
102 lines
3.2 KiB
Python
import os
|
|
from datetime import datetime, timezone
|
|
from sqlmodel import (
|
|
ARRAY,
|
|
CHAR,
|
|
Column,
|
|
Integer,
|
|
Relationship,
|
|
SQLModel,
|
|
Field,
|
|
create_engine,
|
|
)
|
|
|
|
# with open("db.secrets", "r") as f:
|
|
# db_secrets = f.readline().strip()
|
|
db_secrets = f"postgresql+psycopg://{os.environ['DB_USER']}:{os.environ['DB_PASS']}@{os.environ['DB_HOST']}:{os.environ['DB_PORT']}/{os.environ['DB_NAME']}"
|
|
|
|
engine = create_engine(
|
|
db_secrets,
|
|
pool_timeout=20,
|
|
pool_size=2,
|
|
connect_args={"connect_timeout": 8},
|
|
)
|
|
del db_secrets
|
|
|
|
|
|
def utctime():
|
|
return datetime.now(tz=timezone.utc)
|
|
|
|
|
|
class PlayerTeamLink(SQLModel, table=True):
|
|
team_id: int | None = Field(default=None, foreign_key="team.id", primary_key=True)
|
|
player_id: int | None = Field(
|
|
default=None, foreign_key="player.id", primary_key=True
|
|
)
|
|
|
|
|
|
class Team(SQLModel, table=True):
|
|
id: int | None = Field(default=None, primary_key=True)
|
|
name: str
|
|
location: str | None
|
|
country: str | None
|
|
mixed: bool = False
|
|
players: list["Player"] | None = Relationship(
|
|
back_populates="teams", link_model=PlayerTeamLink
|
|
)
|
|
|
|
|
|
class Player(SQLModel, table=True):
|
|
id: int | None = Field(default=None, primary_key=True)
|
|
username: str = Field(default=None, unique=True)
|
|
display_name: str
|
|
email: str | None = None
|
|
full_name: str | None = None
|
|
gender: str | None = Field(default=None, sa_column=Column(CHAR(3)))
|
|
disabled: bool | None = None
|
|
hashed_password: str | None = None
|
|
number: str | None = None
|
|
teams: list[Team] = Relationship(
|
|
back_populates="players", link_model=PlayerTeamLink
|
|
)
|
|
scopes: str = ""
|
|
|
|
|
|
class Chemistry(SQLModel, table=True):
|
|
id: int | None = Field(default=None, primary_key=True)
|
|
time: datetime | None = Field(default_factory=utctime)
|
|
user: int = Field(default=None, foreign_key="player.id")
|
|
hate: list[int] = Field(sa_column=Column(ARRAY(Integer)))
|
|
undecided: list[int] = Field(sa_column=Column(ARRAY(Integer)))
|
|
love: list[int] = Field(sa_column=Column(ARRAY(Integer)))
|
|
team: int = Field(default=None, foreign_key="team.id")
|
|
|
|
|
|
class PlayerType(SQLModel, table=True):
|
|
id: int | None = Field(default=None, primary_key=True)
|
|
time: datetime | None = Field(default_factory=utctime)
|
|
user: int = Field(default=None, foreign_key="player.id")
|
|
handlers: list[int] = Field(sa_column=Column(ARRAY(Integer)))
|
|
combis: list[int] = Field(sa_column=Column(ARRAY(Integer)))
|
|
cutters: list[int] = Field(sa_column=Column(ARRAY(Integer)))
|
|
team: int = Field(default=None, foreign_key="team.id")
|
|
|
|
|
|
class MVPRanking(SQLModel, table=True):
|
|
id: int | None = Field(default=None, primary_key=True)
|
|
time: datetime | None = Field(default_factory=utctime)
|
|
user: int = Field(default=None, foreign_key="player.id")
|
|
mvps: list[int] = Field(sa_column=Column(ARRAY(Integer)))
|
|
team: int = Field(default=None, foreign_key="team.id")
|
|
|
|
|
|
class TokenDB(SQLModel, table=True):
|
|
token: str = Field(index=True, primary_key=True)
|
|
used: bool | None = False
|
|
updated_at: datetime | None = Field(
|
|
default_factory=utctime, sa_column_kwargs={"onupdate": utctime}
|
|
)
|
|
|
|
|
|
SQLModel.metadata.create_all(engine)
|