from app import db, login_manager from flask_login import UserMixin from werkzeug.security import generate_password_hash, check_password_hash @login_manager.user_loader def get_user(user_id): return User.query.get(user_id) class User(db.Model, UserMixin): __tablename__ = "users" # fields id = db.Column(db.Integer, primary_key=True) username = db.Column(db.String(80), unique=True, nullable=False) password = db.Column(db.String(80)) email = db.Column(db.String(120), unique=True, nullable=False) # relationships workouts = db.relationship("Workout", backref="user", lazy="dynamic") def __init__(self, username, password, email): self.username = username self.password = generate_password_hash(password) self.email = email def __repr__(self): return f"" def verify_password(self, pwd): return check_password_hash(self.password, pwd)