2019-09-10 01:06:11 +02:00
|
|
|
"Script for everything User related in the database"
|
2019-08-28 03:46:04 +02:00
|
|
|
from models import db
|
|
|
|
|
|
|
|
|
|
|
|
class User(db.Model):
|
2019-09-10 01:06:11 +02:00
|
|
|
"Class used for configuring the User model in the database"
|
2019-08-28 03:46:04 +02:00
|
|
|
id = db.Column(db.Integer, primary_key=True)
|
|
|
|
username = db.Column(db.String(80), unique=True, nullable=False)
|
|
|
|
admin = db.Column(db.Boolean)
|
|
|
|
bias = db.Column(db.Integer)
|
2019-09-05 03:33:29 +02:00
|
|
|
runs = db.relation(
|
|
|
|
"Order",
|
|
|
|
backref="courrier",
|
|
|
|
primaryjoin="Order.courrier_id==User.id",
|
|
|
|
foreign_keys="Order.courrier_id",
|
|
|
|
)
|
|
|
|
orderItems = db.relationship("OrderItem", backref="user", lazy="dynamic")
|
2019-08-28 03:46:04 +02:00
|
|
|
|
2019-09-08 00:41:50 +02:00
|
|
|
def configure(self, username: str, admin: bool, bias: int) -> None:
|
2019-09-10 01:06:11 +02:00
|
|
|
"Configure the User"
|
2019-08-28 03:46:04 +02:00
|
|
|
self.username = username
|
|
|
|
self.admin = admin
|
|
|
|
self.bias = bias
|
|
|
|
|
2019-09-10 01:06:11 +02:00
|
|
|
# pylint: disable=C0111, R0201
|
2019-09-08 00:41:50 +02:00
|
|
|
def is_authenticated(self) -> bool:
|
2019-08-28 03:46:04 +02:00
|
|
|
return True
|
|
|
|
|
2019-09-08 00:41:50 +02:00
|
|
|
def is_active(self) -> bool:
|
2019-08-28 03:46:04 +02:00
|
|
|
return True
|
|
|
|
|
2019-09-08 00:41:50 +02:00
|
|
|
def is_admin(self) -> bool:
|
2019-08-28 03:46:04 +02:00
|
|
|
return self.admin
|
|
|
|
|
2019-09-08 00:41:50 +02:00
|
|
|
def is_anonymous(self) -> bool:
|
2019-08-28 03:46:04 +02:00
|
|
|
return False
|
|
|
|
|
2019-09-08 00:41:50 +02:00
|
|
|
def get_id(self) -> str:
|
2019-08-31 00:50:01 +02:00
|
|
|
return str(self.id)
|
2019-08-28 03:46:04 +02:00
|
|
|
|
2019-09-08 00:41:50 +02:00
|
|
|
def __repr__(self) -> str:
|
2019-09-05 03:33:29 +02:00
|
|
|
return "%s" % self.username
|