Update code in endpoints/signup.post.py
This commit is contained in:
parent
71a3457533
commit
dd0393e596
@ -1,50 +1,53 @@
|
|||||||
from fastapi import APIRouter, HTTPException, Depends
|
from fastapi import APIRouter, Depends, HTTPException
|
||||||
from sqlalchemy.orm import Session
|
from core.database import fake_users_db
|
||||||
from pydantic import BaseModel
|
from typing import List, Optional
|
||||||
from core.database import get_db
|
|
||||||
from core.auth import get_password_hash, create_access_token
|
|
||||||
import uuid
|
|
||||||
from models.user import User
|
|
||||||
|
|
||||||
router = APIRouter()
|
router = APIRouter()
|
||||||
|
|
||||||
class UserCreate(BaseModel):
|
# Simulated book database
|
||||||
username: str
|
fake_books_db = {
|
||||||
email: str
|
"1": {"id": "1", "title": "Sample Book 1", "author": "Author 1", "year": 2023},
|
||||||
password: str
|
"2": {"id": "2", "title": "Sample Book 2", "author": "Author 2", "year": 2022},
|
||||||
|
}
|
||||||
|
|
||||||
@router.post("/signup")
|
@router.get("/books")
|
||||||
async def signup(
|
async def get_books(
|
||||||
user_data: UserCreate,
|
skip: int = 0,
|
||||||
db: Session = Depends(get_db)
|
limit: int = 10,
|
||||||
|
search: Optional[str] = None
|
||||||
):
|
):
|
||||||
"""User registration endpoint"""
|
"""Get list of books with optional pagination and search"""
|
||||||
# Check existing user
|
books = list(fake_books_db.values())
|
||||||
db_user = db.query(User).filter(
|
|
||||||
(User.username == user_data.username) |
|
|
||||||
(User.email == user_data.email)
|
|
||||||
).first()
|
|
||||||
|
|
||||||
if db_user:
|
if search:
|
||||||
raise HTTPException(
|
books = [
|
||||||
status_code=400,
|
book for book in books
|
||||||
detail="Username or email already exists"
|
if search.lower() in book["title"].lower() or search.lower() in book["author"].lower()
|
||||||
)
|
]
|
||||||
|
|
||||||
# Create new user
|
|
||||||
new_user = User(
|
|
||||||
id=str(uuid.uuid4()),
|
|
||||||
username=user_data.username,
|
|
||||||
email=user_data.email,
|
|
||||||
hashed_password=get_password_hash(user_data.password)
|
|
||||||
)
|
|
||||||
|
|
||||||
db.add(new_user)
|
|
||||||
db.commit()
|
|
||||||
|
|
||||||
# Return token directly after registration
|
|
||||||
return {
|
return {
|
||||||
"message": "User created successfully",
|
"message": "Books retrieved successfully",
|
||||||
"access_token": create_access_token({"sub": new_user.id}),
|
"data": books[skip:skip + limit],
|
||||||
"token_type": "bearer"
|
"metadata": {
|
||||||
|
"total": len(books),
|
||||||
|
"skip": skip,
|
||||||
|
"limit": limit
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@router.get("/books/{book_id}")
|
||||||
|
async def get_book(
|
||||||
|
book_id: str
|
||||||
|
):
|
||||||
|
"""Get specific book by ID"""
|
||||||
|
if book_id not in fake_books_db:
|
||||||
|
raise HTTPException(status_code=404, detail="Book not found")
|
||||||
|
|
||||||
|
return {
|
||||||
|
"message": "Book retrieved successfully",
|
||||||
|
"data": fake_books_db[book_id],
|
||||||
|
"metadata": {
|
||||||
|
"source": "demo_db",
|
||||||
|
"result_count": 1
|
||||||
|
}
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user