-
Notifications
You must be signed in to change notification settings - Fork 1.9k
/
Copy pathmodels.py
55 lines (44 loc) · 1.69 KB
/
models.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
from flask_sqlalchemy import SQLAlchemy
from werkzeug.security import generate_password_hash, check_password_hash
db = SQLAlchemy()
class User(db.Model):
id = db.Column(db.Integer, primary_key=True)
fullName = db.Column(db.String(120), unique=True, nullable=False)
username = db.Column(db.String(120), unique=True, nullable=False)
address = db.Column(db.String(120), unique=True, nullable=False)
email = db.Column(db.String(120), unique=True, nullable=False)
password_hash = db.Column(db.String(512), unique=False, nullable=False)
is_artist = db.Column(db.Boolean(), default=False)
is_active = db.Column(db.Boolean(), default=True)
def __repr__(self):
return f'<User {self.email}>'
def artist(is_artist):
if is_artist:
return "Si"
else:
return "No"
def serialize(self):
return {
"id": self.id,
"fullName": self.fullName,
"username": self.username,
"email": self.email,
"address":self.address,
"artist":self.artist()
# do not serialize the password, its a security breach
}
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)
# GENRES MODEL TO LOAD GENRES
class Genre(db.Model):
id = db.Column(db.Integer, primary_key=True)
name = db.Column(db.String(250), unique=True, nullable=False)
def __repr__(self):
return f'<Genre {self.name}>'
def serialize(self):
return {
"id": self.id,
"name": self.name,
}