feat: improved registration signup flow (#1188)

refactored signup flow for entire registration process. Utilized seed data option for optional seeding of Foods, Units, and Labels. Localized registration page.
This commit is contained in:
Hayden
2022-05-06 11:18:06 -08:00
committed by GitHub
parent 6ee9a31c92
commit 7e4da3e5a4
23 changed files with 1056 additions and 316 deletions

View File

@@ -22,5 +22,5 @@ class RegistrationController(BasePublicController):
status_code=status.HTTP_403_FORBIDDEN, detail=ErrorResponse.respond("User Registration is Disabled")
)
registration_service = RegistrationService(self.deps.logger, get_repositories(self.deps.session))
registration_service = RegistrationService(self.deps.logger, get_repositories(self.deps.session), self.deps.t)
return registration_service.register_user(data)

View File

@@ -1,6 +1,7 @@
from uuid import UUID
from fastapi import APIRouter, Depends
from slugify import slugify
from sqlalchemy.orm.session import Session
from mealie.db.db_setup import generate_session
@@ -10,15 +11,23 @@ from mealie.schema.response import ValidationResponse
router = APIRouter()
@router.get("/user/{name}", response_model=ValidationResponse)
@router.get("/user/name", response_model=ValidationResponse)
def validate_user(name: str, session: Session = Depends(generate_session)):
"""Checks if a user with the given name exists"""
db = get_repositories(session)
existing_element = db.users.get_by_username(name)
existing_element = db.users.get_one(name, "username", any_case=True)
return ValidationResponse(valid=existing_element is None)
@router.get("/group/{name}", response_model=ValidationResponse)
@router.get("/user/email", response_model=ValidationResponse)
def validate_user_email(email: str, session: Session = Depends(generate_session)):
"""Checks if a user with the given name exists"""
db = get_repositories(session)
existing_element = db.users.get_one(email, "email", any_case=True)
return ValidationResponse(valid=existing_element is None)
@router.get("/group", response_model=ValidationResponse)
def validate_group(name: str, session: Session = Depends(generate_session)):
"""Checks if a group with the given name exists"""
db = get_repositories(session)
@@ -26,9 +35,10 @@ def validate_group(name: str, session: Session = Depends(generate_session)):
return ValidationResponse(valid=existing_element is None)
@router.get("/recipe/{group_id}/{slug}", response_model=ValidationResponse)
def validate_recipe(group_id: UUID, slug: str, session: Session = Depends(generate_session)):
@router.get("/recipe", response_model=ValidationResponse)
def validate_recipe(group_id: UUID, name: str, session: Session = Depends(generate_session)):
"""Checks if a group with the given slug exists"""
db = get_repositories(session)
slug = slugify(name)
existing_element = db.recipes.get_by_slug(group_id, slug)
return ValidationResponse(valid=existing_element is None)