| from datetime import datetime
|
| from decimal import Decimal
|
|
|
| from werkzeug.security import generate_password_hash, check_password_hash
|
|
|
| from app import db
|
|
|
|
|
| class Customer(db.Model):
|
| """ 前台用户表 """
|
| __tablename__ = 'customer'
|
| id = db.Column(db.Integer, primary_key=True, autoincrement=True)
|
| customer_no = db.Column(db.String(32))
|
| phone = db.Column(db.String(11))
|
| name = db.Column(db.String(255))
|
| password = db.Column(db.String(64), nullable=False)
|
| email = db.Column(db.String(255), nullable=False)
|
| level = db.Column(db.Enum('common', 'vip'), default='common')
|
| status = db.Column(db.Enum('enabled', 'disabled'), default='enabled')
|
| deleted_flag = db.Column(db.Enum('N', 'Y'), default='N')
|
| created_at = db.Column(db.DateTime, default=datetime.utcnow)
|
| updated_at = db.Column(db.DateTime, onupdate=datetime.utcnow)
|
| storage = db.Column(db.BigInteger, default=0)
|
|
|
| def set_password(self, password):
|
| self.password = generate_password_hash(password)
|
|
|
| def verify_password(self, password):
|
| return check_password_hash(self.password, password)
|
|
|
| def to_dict(self):
|
| """将模型实例转换为字典,处理所有需要序列化的字段"""
|
| return {
|
| 'id': self.id,
|
| 'name': self.name,
|
| 'customer_no': self.customer_no,
|
| 'email': self.email,
|
| 'status': 'enabled' if self.deleted_flag == 'N'and self.status == 'enabled' else 'disabled',
|
| 'level': self.level,
|
| 'storage': int(self.storage),
|
|
|
| 'created_at': self.created_at.isoformat() if self.created_at else None,
|
| 'updated_at': self.updated_at.isoformat() if self.updated_at else None
|
| }
|
|
|