from app import db, login from flask_login import UserMixin from werkzeug.security import generate_password_hash, check_password_hash item_category = db.Table("item_category", db.Column("item", db.ForeignKey("item.id"), primary_key=True), db.Column("category", db.ForeignKey("category.id"), primary_key=True) ) class User(UserMixin, db.Model): id = db.Column(db.String(10), primary_key=True) name = db.Column(db.String(64)) password_hash = db.Column(db.String(128)) Bought = db.relationship("Bought", 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) def __repr__(self) -> str: return f"" class Brand(db.Model): id = db.Column(db.Integer, primary_key=True) name = db.Column(db.String(32)) def __repr__(self) -> str: return f"" class Category(db.Model): id = db.Column(db.Integer, primary_key=True) name = db.Column(db.String(32)) Item = db.relationship("Item", secondary=item_category, lazy="dynamic", back_populates="Category") def __repr__(self) -> str: return f"" class Item(db.Model): id = db.Column(db.BigInteger, primary_key=True) name = db.Column(db.String(64)) brand = db.Column(db.ForeignKey('brand.id')) description = db.Column(db.Text) Category = db.relationship("Category", secondary=item_category, lazy="dynamic", back_populates="Item") Item = db.relationship("Bought", backref='Item', lazy='dynamic') def __repr__(self) -> str: return f"" class Bought(db.Model): user = db.Column(db.ForeignKey('user.id'), primary_key=True) item = db.Column(db.ForeignKey('item.id'), primary_key=True) date = db.Column(db.Date) amount = db.Column(db.SmallInteger) def __repr__(self) -> str: return f"" class PriceChange(db.Model): item = db.Column(db.ForeignKey('item.id'), primary_key=True) date = db.Column(db.Date, primary_key=True) price = db.Column(db.SmallInteger) def __repr__(self) -> str: return f"" class AmountChange(db.Model): item = db.Column(db.ForeignKey('item.id'), primary_key=True) date = db.Column(db.Date, primary_key=True) amount = db.Column(db.SmallInteger) def __repr__(self) -> str: return f"" @login.user_loader def load_user(id): return User.query.get(int(id))