-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathauth.py
56 lines (47 loc) · 2.18 KB
/
auth.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
56
from fastapi import APIRouter, Request, Form, HTTPException
from fastapi.responses import HTMLResponse
from fastapi.templating import Jinja2Templates
from fastapi.responses import HTMLResponse, RedirectResponse
from pydantic import EmailStr
import json
import bcrypt
# Конфигурация
USER_DB_FILE = "users.json"
router = APIRouter()
templates = Jinja2Templates(directory="templates")
# Загрузка и сохранение пользователей
def load_users():
try:
with open(USER_DB_FILE, "r", encoding="utf-8") as file:
return json.load(file)
except FileNotFoundError:
return {}
def save_users(users):
with open(USER_DB_FILE, "w", encoding="utf-8") as file:
json.dump(users, file, ensure_ascii=False, indent=4)
def hash_password(password: str) -> str:
return bcrypt.hashpw(password.encode("utf-8"), bcrypt.gensalt()).decode("utf-8")
# Маршрут для отображения страницы регистрации
@router.get("/register", response_class=HTMLResponse)
async def show_register_page(request: Request):
return templates.TemplateResponse("register.html", {"request": request})
# Маршрут для обработки данных формы регистрации
@router.post("/register")
async def register(
username: str = Form(...),
email: EmailStr = Form(...),
password: str = Form(...),
):
users = load_users()
# Проверка существующего пользователя
if username in users:
raise HTTPException(status_code=400, detail="Пользователь с таким именем уже существует")
if email in users:
raise HTTPException(status_code=400, detail="Пользователь с такой почтой уже существует")
# Хэшируем пароль и сохраняем пользователя
hashed_password = hash_password(password)
users[username] = {"email": email, "hashed_password": hashed_password}
save_users(users)
print(f"Новый пользователь успешно создан: {username}")
response = RedirectResponse(url="/", status_code=303)
return response