from werkzeug.security import generate_password_hash, check_password_hash from nanoid import generate from . import db class User(db.Model): def __init__(self, username, blog_url): self.username = username self.blog_url = blog_url __tablename__ = 'users' id = db.Column(db.Integer, primary_key=True) username = db.Column(db.Text, unique=True) password = db.Column(db.Text) blog_url = db.Column(db.Text, db.ForeignKey('blogs.url', ondelete='CASCADE'), unique=True) blog = db.relationship('Blog', backref='blog_user', cascade="all,delete") def set_password(self, password): self.password = generate_password_hash(password) def check_password(self, password): return check_password_hash(self.password, password) class Blog(db.Model): def __init__(self, url, is_private=False): self.url = url self.is_private = is_private __tablename__ = "blogs" id = db.Column(db.Integer, primary_key=True) url = db.Column(db.Text, unique=True) is_private = db.Column(db.Boolean, default=False) #TODO this is must be private (VULN) user = db.relationship('User', backref='blog_user', cascade="all,delete", lazy='dynamic') posts = db.relationship("Post", cascade="all,delete") #TODO дописать стуруктуру БД class Post(db.Model): def __init__(self, title, body, blog_url): self.title = title self.body = body self.blog_url = blog_url __tablename__ = "posts" id = db.Column(db.Integer, primary_key=True) title = db.Column(db.String) body = db.Column(db.String) blog_url = db.Column(db.String, db.ForeignKey("blogs.url")) blog = db.relationship("Blog", cascade="all,delete")