- Add 'language' column to waitlist_entries (en/it/es/fr/de, default en) - Accept 'lang' field in POST /waitlist request body - Translate confirmation email (subject, badge, heading, body, CTA, footer) - Translate confirm/unsubscribe result HTML pages - Return localized success message in WaitlistResponse - Update language preference on duplicate signups - Alembic migration 003_add_language_column
36 lines
1.3 KiB
Python
36 lines
1.3 KiB
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)
|
|
language: Mapped[str] = mapped_column(String(5), nullable=False, server_default=sa.text("'en'"))
|
|
confirmed: Mapped[bool] = mapped_column(Boolean, default=False, server_default=sa.text("0"))
|
|
consent_given_at: Mapped[datetime.datetime | None] = mapped_column(
|
|
DateTime(timezone=True), nullable=True,
|
|
)
|
|
anonymized_at: Mapped[datetime.datetime | None] = mapped_column(
|
|
DateTime(timezone=True), nullable=True,
|
|
)
|
|
created_at: Mapped[datetime.datetime] = mapped_column(
|
|
DateTime(timezone=True),
|
|
server_default=sa.text("CURRENT_TIMESTAMP"),
|
|
nullable=False,
|
|
)
|