Coverage for polar/models/user_session.py: 96%
23 statements
« prev ^ index » next coverage.py v7.10.6, created at 2025-12-05 15:52 +0000
« prev ^ index » next coverage.py v7.10.6, created at 2025-12-05 15:52 +0000
1from datetime import datetime 1ab
2from uuid import UUID 1ab
4from sqlalchemy import CHAR, TIMESTAMP, ForeignKey, Text, Uuid 1ab
5from sqlalchemy.dialects.postgresql import ARRAY 1ab
6from sqlalchemy.orm import Mapped, declared_attr, mapped_column, relationship 1ab
8from polar.auth.scope import Scope 1ab
9from polar.config import settings 1ab
10from polar.kit.db.models.base import RecordModel 1ab
11from polar.kit.extensions.sqlalchemy import StringEnum 1ab
12from polar.kit.utils import utc_now 1ab
13from polar.models.user import User 1ab
16def get_expires_at() -> datetime: 1ab
17 return utc_now() + settings.USER_SESSION_TTL
20class UserSession(RecordModel): 1ab
21 __tablename__ = "user_sessions" 1ab
23 token: Mapped[str] = mapped_column(CHAR(64), unique=True, nullable=False) 1ab
24 expires_at: Mapped[datetime] = mapped_column( 1ab
25 TIMESTAMP(timezone=True), nullable=False, index=True, default=get_expires_at
26 )
27 user_agent: Mapped[str] = mapped_column(Text, nullable=False) 1ab
28 scopes: Mapped[list[Scope]] = mapped_column( 1ab
29 ARRAY(StringEnum(Scope)), nullable=False, default=list
30 )
32 user_id: Mapped[UUID] = mapped_column( 1ab
33 Uuid, ForeignKey("users.id", ondelete="cascade"), nullable=False
34 )
36 @declared_attr 1ab
37 def user(cls) -> Mapped[User]: 1ab
38 return relationship(User, lazy="joined") 1ab