study_platform/app/models.py
2025-04-22 22:49:57 +08:00

46 lines
1.7 KiB
Python

from app import db, login_manager
from flask_login import UserMixin
from werkzeug.security import generate_password_hash, check_password_hash
from datetime import datetime
import uuid
from datetime import datetime, timedelta
@login_manager.user_loader
def load_user(user_id):
return User.query.get(user_id)
# 添加验证码模型
class VerificationCode(db.Model):
id = db.Column(db.Integer, primary_key=True)
email = db.Column(db.String(120), nullable=False)
code = db.Column(db.String(10), nullable=False)
created_at = db.Column(db.DateTime, default=datetime.utcnow)
expires_at = db.Column(db.DateTime, default=lambda: datetime.utcnow() + timedelta(minutes=10))
is_used = db.Column(db.Boolean, default=False)
@property
def is_expired(self):
return datetime.utcnow() > self.expires_at
class User(UserMixin, db.Model):
id = db.Column(db.Integer, primary_key=True)
email = db.Column(db.String(120), unique=True, nullable=False)
username = db.Column(db.String(64), nullable=False)
password_hash = db.Column(db.String(128))
created_at = db.Column(db.DateTime, default=datetime.utcnow)
last_login = db.Column(db.DateTime)
is_active = db.Column(db.Boolean, default=True)
language = db.Column(db.String(2), default='zh')
theme = db.Column(db.String(10), default='light')
reset_token = db.Column(db.String(36), unique=True)
def set_password(self, password):
self.password_hash = generate_password_hash(password)
def check_password(self, password):
return check_password_hash(self.password_hash, password)
def generate_reset_token(self):
self.reset_token = str(uuid.uuid4())
return self.reset_token