29 lines
948 B
Python
29 lines
948 B
Python
import datetime
|
|
|
|
import sqlalchemy as sa
|
|
from sqlalchemy import BigInteger, Boolean, DateTime, String
|
|
from sqlalchemy.orm import DeclarativeBase, Mapped, mapped_column
|
|
|
|
|
|
class Base(DeclarativeBase):
|
|
pass
|
|
|
|
|
|
class WaitlistEntry(Base):
|
|
__tablename__ = "waitlist_entries"
|
|
|
|
id: Mapped[int] = mapped_column(
|
|
BigInteger().with_variant(sa.Integer, "sqlite"),
|
|
primary_key=True,
|
|
autoincrement=True,
|
|
)
|
|
email: Mapped[str] = mapped_column(String(320), unique=True, nullable=False, index=True)
|
|
ip_address: Mapped[str | None] = mapped_column(String(45), nullable=True)
|
|
source: Mapped[str | None] = mapped_column(String(64), nullable=True)
|
|
confirmed: Mapped[bool] = mapped_column(Boolean, default=False, server_default=sa.text("0"))
|
|
created_at: Mapped[datetime.datetime] = mapped_column(
|
|
DateTime(timezone=True),
|
|
server_default=sa.text("CURRENT_TIMESTAMP"),
|
|
nullable=False,
|
|
)
|