-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathusers.py
More file actions
24 lines (20 loc) · 793 Bytes
/
users.py
File metadata and controls
24 lines (20 loc) · 793 Bytes
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
from werkzeug.security import check_password_hash, generate_password_hash
import db
def create_user(username, password):
password_hash = generate_password_hash(password)
sql = "INSERT INTO users (username, password_hash) VALUES (?, ?)"
db.execute(sql, [username, password_hash])
def check_login(username, password):
sql = "SELECT id, password_hash FROM users WHERE username = ?"
result = db.query(sql, [username])
if len(result) == 1:
user_id, password_hash = result[0]
if check_password_hash(password_hash, password):
return user_id
return None
def get_user(user_id):
sql = """SELECT id, username
FROM users
WHERE id = ?"""
result = db.query(sql, [user_id])
return result[0] if result else None