goon/alembic/versions/20260504_0005_favorite_performers.py
goon-foss ad0284585b Initial commit
Goon — self-hosted aggregator for adult-content scene metadata.

Indexes scenes from TPDB, StashDB, and 30+ public adult tube sites.
Cross-source deduplication via perceptual hash + Levenshtein distance.
FastAPI backend + APScheduler worker + React Native (Expo) mobile client.

FOSS, ad-free, donation-funded. See README for details.
2026-05-20 10:10:22 +02:00

38 lines
1.3 KiB
Python

"""favorite_performers — ulubione performerki (single-user, in-app)
Revision ID: 0005_favorite_performers
Revises: 0004_animated_thumbnail
Create Date: 2026-05-04
Single-user system (brak users), więc tabelka to po prostu zbiór performer_id które
user oznaczył jako ulubione, plus `last_seen_at` żeby mobile mogło policzyć ile nowych
scen pojawiło się od ostatniego oglądania (badge w toolbar/Favorites screen).
Multi-user można dodać potem (kolumna user_id + composite PK), bez breaking change.
"""
from collections.abc import Sequence
import sqlalchemy as sa
from alembic import op
revision: str = "0005_favorite_performers"
down_revision: str | None = "0004_animated_thumbnail"
branch_labels: str | Sequence[str] | None = None
depends_on: str | Sequence[str] | None = None
def upgrade() -> None:
op.create_table(
"favorite_performers",
sa.Column("performer_id", sa.dialects.postgresql.UUID(as_uuid=True),
sa.ForeignKey("performers.id", ondelete="CASCADE"),
primary_key=True),
sa.Column("created_at", sa.DateTime(timezone=True),
server_default=sa.func.now(), nullable=False),
sa.Column("last_seen_at", sa.DateTime(timezone=True),
server_default=sa.func.now(), nullable=False),
)
def downgrade() -> None:
op.drop_table("favorite_performers")