"""Favorite performers — single-user (na razie), do wewn. powiadomień o nowych scenach.""" from __future__ import annotations import uuid from datetime import datetime from sqlalchemy import DateTime, ForeignKey, func from sqlalchemy.dialects.postgresql import UUID from sqlalchemy.orm import Mapped, mapped_column from app.models.base import Base class FavoritePerformer(Base): __tablename__ = "favorite_performers" performer_id: Mapped[uuid.UUID] = mapped_column( UUID(as_uuid=True), ForeignKey("performers.id", ondelete="CASCADE"), primary_key=True, ) created_at: Mapped[datetime] = mapped_column( DateTime(timezone=True), server_default=func.now(), nullable=False ) # Kiedy user "zobaczył" listę nowych scen — przed tą datą sceny są "stare". Przy # mark-as-seen update'ujemy do now(). Domyślnie = created_at, więc świeży favorite # ma 0 nowych scen do momentu pojawienia się czegoś świeżego. last_seen_at: Mapped[datetime] = mapped_column( DateTime(timezone=True), server_default=func.now(), nullable=False )