2026-03-09 14:05:00 +08:00
|
|
|
"""SigninLog ORM model."""
|
|
|
|
|
|
|
|
|
|
from sqlalchemy import Integer, Column, DateTime, ForeignKey, JSON, String, Text
|
|
|
|
|
from sqlalchemy.orm import relationship
|
|
|
|
|
from sqlalchemy.sql import func
|
|
|
|
|
|
|
|
|
|
from .base import Base
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class SigninLog(Base):
|
|
|
|
|
__tablename__ = "signin_logs"
|
|
|
|
|
id = Column(Integer, primary_key=True, autoincrement=True)
|
2026-04-01 15:09:21 +08:00
|
|
|
account_id = Column(String(36), ForeignKey("accounts.id", ondelete="CASCADE"), nullable=False)
|
2026-03-09 14:05:00 +08:00
|
|
|
topic_title = Column(String(100))
|
2026-03-17 13:54:35 +08:00
|
|
|
status = Column(String(50), nullable=False)
|
2026-03-09 14:05:00 +08:00
|
|
|
reward_info = Column(JSON, nullable=True)
|
|
|
|
|
error_message = Column(Text, nullable=True)
|
|
|
|
|
signed_at = Column(DateTime, server_default=func.now())
|
|
|
|
|
|
|
|
|
|
account = relationship("Account", back_populates="signin_logs")
|
|
|
|
|
|
|
|
|
|
def __repr__(self):
|
|
|
|
|
return f"<SigninLog(id={self.id}, status='{self.status}')>"
|