Web service voor het LED-display
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.

57 lines
1.8 KiB

11 years ago
# -*- coding: utf-8 -*-
import datetime as dt
from flask.ext.login import UserMixin
from {{cookiecutter.app_name}}.extensions import bcrypt
from {{cookiecutter.app_name}}.database import (
db,
CRUDMixin,
ReferenceCol,
relationship,
Column,
)
11 years ago
class Role(CRUDMixin, db.Model):
__tablename__ = 'roles'
name = Column(db.String(80), unique=True, nullable=False)
user_id = ReferenceCol('users', nullable=True)
user = relationship('User', backref='roles')
10 years ago
def __init__(self, name, **kwargs):
db.Model.__init__(self, name=name, **kwargs)
11 years ago
class User(UserMixin, CRUDMixin, db.Model):
11 years ago
__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.String(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):
db.Model.__init__(self, username=username, email=email, **kwargs)
if password:
self.set_password(password)
else:
self.password = None
def set_password(self, password):
self.password = bcrypt.generate_password_hash(password)
def check_password(self, value):
return bcrypt.check_password_hash(self.password, value)
11 years ago
@property
def full_name(self):
return "{0} {1}".format(self.first_name, self.last_name)
11 years ago
def __repr__(self):
return '<User {username!r}>'.format(username=self.username)