You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
72 lines
2.1 KiB
72 lines
2.1 KiB
# -*- coding: utf-8 -*-
|
|
"""User models."""
|
|
import datetime as dt
|
|
|
|
from flask_login import UserMixin
|
|
|
|
from {{cookiecutter.app_name}}.database import (
|
|
Column,
|
|
Model,
|
|
SurrogatePK,
|
|
db,
|
|
reference_col,
|
|
relationship,
|
|
)
|
|
from {{cookiecutter.app_name}}.extensions import bcrypt
|
|
|
|
|
|
class Role(SurrogatePK, Model):
|
|
"""A role for a user."""
|
|
|
|
__tablename__ = "roles"
|
|
name = Column(db.String(80), unique=True, nullable=False)
|
|
user_id = reference_col("users", nullable=True)
|
|
user = relationship("User", backref="roles")
|
|
|
|
def __init__(self, name, **kwargs):
|
|
"""Create instance."""
|
|
db.Model.__init__(self, name=name, **kwargs)
|
|
|
|
def __repr__(self):
|
|
"""Represent instance as a unique string."""
|
|
return f"<Role({self.name})>"
|
|
|
|
|
|
class User(UserMixin, SurrogatePK, Model):
|
|
"""A user of the app."""
|
|
|
|
__tablename__ = "users"
|
|
username = Column(db.String(80), unique=True, nullable=False)
|
|
email = Column(db.String(80), unique=True, nullable=False)
|
|
#: The hashed password
|
|
password = Column(db.LargeBinary(128), nullable=True)
|
|
created_at = Column(db.DateTime, nullable=False, default=dt.datetime.utcnow)
|
|
first_name = Column(db.String(30), nullable=True)
|
|
last_name = Column(db.String(30), nullable=True)
|
|
active = Column(db.Boolean(), default=False)
|
|
is_admin = Column(db.Boolean(), default=False)
|
|
|
|
def __init__(self, username, email, password=None, **kwargs):
|
|
"""Create instance."""
|
|
db.Model.__init__(self, username=username, email=email, **kwargs)
|
|
if password:
|
|
self.set_password(password)
|
|
else:
|
|
self.password = None
|
|
|
|
def set_password(self, password):
|
|
"""Set password."""
|
|
self.password = bcrypt.generate_password_hash(password)
|
|
|
|
def check_password(self, value):
|
|
"""Check password."""
|
|
return bcrypt.check_password_hash(self.password, value)
|
|
|
|
@property
|
|
def full_name(self):
|
|
"""Full user name."""
|
|
return f"{self.first_name} {self.last_name}"
|
|
|
|
def __repr__(self):
|
|
"""Represent instance as a unique string."""
|
|
return f"<User({self.username!r})>"
|
|
|