from werkzeug.security import generate_password_hash, check_password_hash from app import db, login from flask_login import UserMixin class User(UserMixin, db.Model): id = db.Column(db.Integer, primary_key=True) username = db.Column(db.String(64), index=True, unique=True) password_hash = db.Column(db.String(128)) isAdmin = db.Column(db.Boolean) files = db.relationship('File', backref='user', lazy='dynamic') 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) class File(db.Model): id = db.Column(db.Integer, primary_key=True) name = db.Column(db.Text) folder = db.Column(db.Text) user_id = db.Column(db.Integer, db.ForeignKey('user.id')) @login.user_loader def load_user(id): return User.query.get(int(id))