19 lines
837 B
Python
19 lines
837 B
Python
|
|
"""浏览器推送订阅模型"""
|
||
|
|
from sqlalchemy import Column, String, Text, DateTime, func, JSON
|
||
|
|
from sqlalchemy.dialects.mysql import CHAR
|
||
|
|
from app.core.database import Base
|
||
|
|
import uuid
|
||
|
|
|
||
|
|
|
||
|
|
class PushSubscription(Base):
|
||
|
|
__tablename__ = "push_subscriptions"
|
||
|
|
|
||
|
|
id = Column(CHAR(36), primary_key=True, default=lambda: str(uuid.uuid4()))
|
||
|
|
user_id = Column(CHAR(36), nullable=True, index=True, comment="关联用户ID")
|
||
|
|
endpoint = Column(Text, nullable=False, comment="推送端点URL")
|
||
|
|
p256dh = Column(Text, nullable=False, comment="公钥")
|
||
|
|
auth = Column(Text, nullable=False, comment="认证密钥")
|
||
|
|
user_agent = Column(String(500), nullable=True, comment="设备UA")
|
||
|
|
created_at = Column(DateTime, server_default=func.now())
|
||
|
|
updated_at = Column(DateTime, server_default=func.now(), onupdate=func.now())
|