|
|
|
from datetime import datetime
|
|
from app.extensions import db
|
|
|
|
|
|
class Message(db.Model):
|
|
__tablename__ = 'message'
|
|
|
|
id = db.Column(db.Integer, primary_key=True)
|
|
customer_id = db.Column(db.Integer, db.ForeignKey('customer.id'), nullable=False)
|
|
content = db.Column(db.Text, nullable=False)
|
|
status = db.Column(db.Enum('unread', 'read'), default='unread')
|
|
msg_type = db.Column(db.String(50))
|
|
created_at = db.Column(db.DateTime, default=datetime.utcnow)
|
|
deleted_flag = db.Column(db.CHAR(1), default='N', nullable=False)
|
|
|
|
@classmethod
|
|
def get_user_messages(cls, customer_id):
|
|
"""获取用户有效消息列表 [^2]"""
|
|
return cls.query.filter_by(
|
|
customer_id=customer_id,
|
|
deleted_flag='N'
|
|
).order_by(cls.created_at.desc()).all()
|
|
|
|
@classmethod
|
|
def mark_as_read(cls, message_id):
|
|
"""标记消息为已读"""
|
|
message = cls.query.get(message_id)
|
|
if message:
|
|
message.status = 'read'
|
|
db.session.commit()
|
|
|
|
|