From 27885bdcd76c2f974250776ba0a9ede098e8f681 Mon Sep 17 00:00:00 2001 From: Backend IM Bot Date: Tue, 15 Apr 2025 13:08:18 +0000 Subject: [PATCH] feat: Updated endpoint endpoints/login.post.py via AI --- endpoints/login.post.py | 43 +++++++++++------------------------------ 1 file changed, 11 insertions(+), 32 deletions(-) diff --git a/endpoints/login.post.py b/endpoints/login.post.py index a8ab4aa..c56b149 100644 --- a/endpoints/login.post.py +++ b/endpoints/login.post.py @@ -1,37 +1,16 @@ -from fastapi import APIRouter, Depends, HTTPException -from pydantic import BaseModel -from datetime import timedelta -from core.database import get_db -from sqlalchemy.orm import Session -from core.auth import verify_password, create_access_token -from models.user import User +from fastapi import APIRouter, HTTPException, status +from typing import Dict, Any +from helpers.generic_helpers import login_user router = APIRouter() -class UserAuth(BaseModel): - username: str - password: str - -@router.post("/login") +@router.post("/login", status_code=status.HTTP_200_OK, response_model=Dict[str, Any]) async def login( - user_data: UserAuth, - db: Session = Depends(get_db) + user_data: Dict[str, Any] ): - """User authentication endpoint""" - user = db.query(User).filter(User.username == user_data.username).first() - - if not user or not verify_password(user_data.password, user.hashed_password): - raise HTTPException(status_code=400, detail="Invalid credentials") - - # Generate token with expiration - access_token = create_access_token( - data={"sub": user.id}, - expires_delta=timedelta(hours=1) - ) - - return { - "access_token": access_token, - "token_type": "bearer", - "user_id": user.id, - "username": user.username - } + """Login user""" + try: + login_response = login_user(user_data=user_data) + return login_response + except ValueError as e: + raise HTTPException(status_code=400, detail=str(e)) \ No newline at end of file