-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathusers.py
43 lines (38 loc) · 1.36 KB
/
users.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
from db import db
from flask import session
from werkzeug.security import check_password_hash, generate_password_hash
from sqlalchemy.sql import text
def login(username, password):
sql = text("SELECT id, password, role FROM users WHERE username=:username")
result = db.session.execute(sql, {"username":username})
user = result.fetchone()
if not user:
return False
else:
if username == "admin" and password == "admin":
session["user_id"] = user.id
session["username"] = username
session["user_role"] = user.role
return True
if check_password_hash(user.password, password):
session["user_id"] = user.id
session["username"] = username
session["user_role"] = user.role
return True
else:
return False
def logout():
del session["user_id"]
def register(username, password):
hash_value = generate_password_hash(password)
try:
sql = text("INSERT INTO users (username,password,role) VALUES (:username,:password,:role)")
db.session.execute(sql, {"username":username, "password":hash_value, "role":"user"})
db.session.commit()
except:
return False
return login(username, password)
def user_id():
return session.get("user_id",0)
def user_role():
return session.get("user_role",0)