Files
slop-farmer-server/slopserver/models.py
Jack Case 4931a785a1 create basic user table
this will allow users to sign up and submit reports
2025-10-17 20:29:14 +00:00

34 lines
1.0 KiB
Python

from sqlmodel import Field, SQLModel, create_engine, Relationship
NAMING_CONVENTION = {
"ix": "ix_%(column_0_label)s",
"uq": "uq_%(table_name)s_%(column_0_name)s",
"ck": "ck_%(table_name)s_%(constraint_name)s",
"fk": "fk_%(table_name)s_%(column_0_name)s_%(referred_table_name)s",
"pk": "pk_%(table_name)s",
}
metadata = SQLModel.metadata
metadata.naming_convention = NAMING_CONVENTION
class Domain(SQLModel, table=True):
id: int | None = Field(default=None, primary_key=True)
domain_name: str = Field(index=True, unique=True)
paths: list["Path"] = Relationship(back_populates="domain")
class Path(SQLModel, table=True):
id: int | None = Field(default=None, primary_key=True)
path: str
domain_id: int = Field(foreign_key="domain.id")
domain: Domain = Relationship(back_populates="paths")
class User(SQLModel, table=True):
id: int | None = Field(default=None, primary_key=True)
email: str = Field(index=True, unique=True)
password_hash: str
salt: str
email_verified: bool = Field(default=False)