File size: 1,965 Bytes
726a881 3651488 726a881 3651488 726a881 3651488 726a881 3651488 726a881 3651488 726a881 3651488 726a881 3651488 726a881 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 |
from typing import Optional
from sqlmodel import SQLModel, Field, Relationship
from datetime import datetime
class User(SQLModel, table=True):
id: Optional[int] = Field(default=None, primary_key=True)
address: str = Field(index=True, unique=True) # Base58の公開鍵(ED25519)
created_at: datetime = Field(default_factory=datetime.utcnow)
visits: list["Visit"] = Relationship(back_populates="user")
balances: list["TokenBalance"] = Relationship(back_populates="user")
class Venue(SQLModel, table=True):
id: Optional[int] = Field(default=None, primary_key=True)
name: str
slug: str = Field(index=True, unique=True)
created_at: datetime = Field(default_factory=datetime.utcnow)
class CheckinSession(SQLModel, table=True):
id: Optional[int] = Field(default=None, primary_key=True)
session_id: str = Field(index=True, unique=True)
venue_id: int = Field(foreign_key="venue.id")
nonce: str
expires_at: datetime
used: bool = Field(default=False)
class Visit(SQLModel, table=True):
id: Optional[int] = Field(default=None, primary_key=True)
user_id: int = Field(foreign_key="user.id")
venue_id: int = Field(foreign_key="venue.id")
session_id: int = Field(foreign_key="checkinsession.id")
created_at: datetime = Field(default_factory=datetime.utcnow, index=True)
user: User = Relationship(back_populates="visits")
class TokenBalance(SQLModel, table=True):
id: Optional[int] = Field(default=None, primary_key=True)
user_id: int = Field(foreign_key="user.id")
symbol: str = Field(default="POINT")
amount: int = Field(default=0)
user: User = Relationship(back_populates="balances")
class RewardLog(SQLModel, table=True):
id: Optional[int] = Field(default=None, primary_key=True)
user_id: int = Field(foreign_key="user.id")
venue_id: int = Field(foreign_key="venue.id")
points: int
created_at: datetime = Field(default_factory=datetime.utcnow)
|