device.py 736 B

12345678910111213141516171819
  1. from sqlalchemy import Column, Integer, String, DateTime, ForeignKey, UniqueConstraint
  2. from sqlalchemy.sql import func
  3. from app.core.database import Base
  4. class UserDevice(Base):
  5. __tablename__ = "user_devices"
  6. id = Column(Integer, primary_key=True, index=True)
  7. user_id = Column(Integer, ForeignKey("users.id"), nullable=False)
  8. device_token = Column(String(255), nullable=False)
  9. platform = Column(String(20), nullable=False) # ios, android, harmony
  10. device_name = Column(String(100), nullable=True)
  11. last_active = Column(DateTime(timezone=True), server_default=func.now(), onupdate=func.now())
  12. __table_args__ = (
  13. UniqueConstraint('user_id', 'device_token', name='uq_user_device'),
  14. )