from . import db from datetime import datetime from flask_login import UserMixin from werkzeug.security import generate_password_hash, check_password_hash class User(UserMixin, db.Model): id = db.Column(db.Integer, primary_key=True) email = db.Column(db.String(100), unique=True) password_hash = db.Column(db.String(128)) 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 Site(db.Model): id = db.Column(db.Integer, primary_key=True) user_id = db.Column(db.Integer) name = db.Column(db.String(100)) subdomain = db.Column(db.String(100), unique=True) last_accessed = db.Column(db.DateTime) created_at = db.Column(db.DateTime, default=datetime.utcnow)