fix(i18n): return French error messages in auth, register, download endpoints
All checks were successful
Deploy to Production / Build and Deploy (push) Successful in 2m44s

This commit is contained in:
2026-06-14 18:13:41 +02:00
parent 45e44dd7b2
commit f05399aeba
4 changed files with 24 additions and 24 deletions

View File

@@ -242,11 +242,11 @@ class UserCreate(BaseModel):
if len(v) < 8: if len(v) < 8:
raise ValueError("Password must be at least 8 characters") raise ValueError("Password must be at least 8 characters")
if not re.search(r"[A-Z]", v): if not re.search(r"[A-Z]", v):
raise ValueError("Password must contain at least one uppercase letter") raise ValueError("Le mot de passe doit contenir au moins une majuscule")
if not re.search(r"[a-z]", v): if not re.search(r"[a-z]", v):
raise ValueError("Password must contain at least one lowercase letter") raise ValueError("Le mot de passe doit contenir au moins une minuscule")
if not re.search(r"[0-9]", v): if not re.search(r"[0-9]", v):
raise ValueError("Password must contain at least one digit") raise ValueError("Le mot de passe doit contenir au moins un chiffre")
return v return v

View File

@@ -137,7 +137,7 @@ async def require_admin(authorization: Optional[str] = Header(None)) -> str:
) )
token = parts[1] token = parts[1]
if not verify_admin_token(token): if not verify_admin_token(token):
raise HTTPException(status_code=401, detail="Invalid or expired token") raise HTTPException(status_code=401, detail="Token invalide ou expiré")
return ADMIN_USERNAME return ADMIN_USERNAME

View File

@@ -94,7 +94,7 @@ async def require_user(credentials: HTTPAuthorizationCredentials = Depends(secur
raise HTTPException(status_code=401, detail="Not authenticated") raise HTTPException(status_code=401, detail="Not authenticated")
payload = verify_token(credentials.credentials) payload = verify_token(credentials.credentials)
if not payload: if not payload:
raise HTTPException(status_code=401, detail="Invalid or expired token") raise HTTPException(status_code=401, detail="Token invalide ou expiré")
user = get_user_by_id(payload.get("sub")) user = get_user_by_id(payload.get("sub"))
if not user: if not user:
raise HTTPException(status_code=401, detail="User not found") raise HTTPException(status_code=401, detail="User not found")
@@ -216,7 +216,7 @@ async def register_v1(request: Request):
status_code=400, status_code=400,
content={ content={
"error": "INVALID_REQUEST", "error": "INVALID_REQUEST",
"message": "Invalid JSON request body", "message": "Corps de requête JSON invalide",
}, },
) )
@@ -342,7 +342,7 @@ Déconnecte l'utilisateur en révoquant son token d'accès.
"description": "Déconnexion réussie", "description": "Déconnexion réussie",
"content": { "content": {
"application/json": { "application/json": {
"example": {"data": {"message": "Logged out successfully"}, "meta": {}} "example": {"data": {"message": "Déconnexion réussie"}, "meta": {}}
} }
}, },
}, },
@@ -355,14 +355,14 @@ Déconnecte l'utilisateur en révoquant son token d'accès.
"summary": "Missing token", "summary": "Missing token",
"value": { "value": {
"error": "TOKEN_MISSING", "error": "TOKEN_MISSING",
"message": "Authentication token required", "message": "Token d'authentification requis",
}, },
}, },
"TOKEN_INVALID": { "TOKEN_INVALID": {
"summary": "Invalid token", "summary": "Invalid token",
"value": { "value": {
"error": "TOKEN_INVALID", "error": "TOKEN_INVALID",
"message": "Invalid or expired token", "message": "Token invalide ou expiré",
}, },
}, },
} }
@@ -379,7 +379,7 @@ async def logout_v1(request: Request):
status_code=401, status_code=401,
content={ content={
"error": "TOKEN_MISSING", "error": "TOKEN_MISSING",
"message": "Authentication token required", "message": "Token d'authentification requis",
}, },
) )
access_token = auth_header[7:] access_token = auth_header[7:]
@@ -390,7 +390,7 @@ async def logout_v1(request: Request):
status_code=401, status_code=401,
content={ content={
"error": "TOKEN_INVALID", "error": "TOKEN_INVALID",
"message": "Invalid or expired token", "message": "Token invalide ou expiré",
}, },
) )
@@ -413,7 +413,7 @@ async def logout_v1(request: Request):
return JSONResponse( return JSONResponse(
status_code=200, status_code=200,
content={"data": {"message": "Logged out successfully"}, "meta": {}}, content={"data": {"message": "Déconnexion réussie"}, "meta": {}},
) )
@@ -460,7 +460,7 @@ Authentifie un utilisateur et retourne les tokens JWT.
"summary": "Invalid body", "summary": "Invalid body",
"value": { "value": {
"error": "INVALID_REQUEST", "error": "INVALID_REQUEST",
"message": "Invalid JSON request body", "message": "Corps de requête JSON invalide",
}, },
}, },
"INVALID_EMAIL": { "INVALID_EMAIL": {
@@ -496,7 +496,7 @@ async def login_v1(request: Request):
status_code=400, status_code=400,
content={ content={
"error": "INVALID_REQUEST", "error": "INVALID_REQUEST",
"message": "Invalid JSON request body", "message": "Corps de requête JSON invalide",
}, },
) )
@@ -668,7 +668,7 @@ async def refresh_v1(request: Request):
status_code=400, status_code=400,
content={ content={
"error": "INVALID_REQUEST", "error": "INVALID_REQUEST",
"message": "Invalid JSON request body", "message": "Corps de requête JSON invalide",
}, },
) )
@@ -677,7 +677,7 @@ async def refresh_v1(request: Request):
status_code=400, status_code=400,
content={ content={
"error": "INVALID_REQUEST", "error": "INVALID_REQUEST",
"message": "Invalid JSON request body", "message": "Corps de requête JSON invalide",
}, },
) )
@@ -691,7 +691,7 @@ async def refresh_v1(request: Request):
status_code=400, status_code=400,
content={ content={
"error": "INVALID_REQUEST", "error": "INVALID_REQUEST",
"message": "Refresh token required", "message": "Refresh token requis",
}, },
) )
@@ -701,7 +701,7 @@ async def refresh_v1(request: Request):
status_code=401, status_code=401,
content={ content={
"error": "TOKEN_EXPIRED", "error": "TOKEN_EXPIRED",
"message": "Invalid or expired token", "message": "Token invalide ou expiré",
}, },
) )
@@ -710,7 +710,7 @@ async def refresh_v1(request: Request):
status_code=401, status_code=401,
content={ content={
"error": "TOKEN_EXPIRED", "error": "TOKEN_EXPIRED",
"message": "Invalid or expired token", "message": "Token invalide ou expiré",
}, },
) )
@@ -720,7 +720,7 @@ async def refresh_v1(request: Request):
status_code=401, status_code=401,
content={ content={
"error": "TOKEN_EXPIRED", "error": "TOKEN_EXPIRED",
"message": "Invalid or expired token", "message": "Token invalide ou expiré",
}, },
) )
@@ -972,7 +972,7 @@ async def forgot_password(request: Request):
status_code=400, status_code=400,
content={ content={
"error": "INVALID_REQUEST", "error": "INVALID_REQUEST",
"message": "Invalid JSON request body", "message": "Corps de requête JSON invalide",
}, },
) )
@@ -1074,7 +1074,7 @@ async def reset_password(request: Request):
status_code=400, status_code=400,
content={ content={
"error": "INVALID_REQUEST", "error": "INVALID_REQUEST",
"message": "Invalid JSON request body", "message": "Corps de requête JSON invalide",
}, },
) )
@@ -1118,7 +1118,7 @@ async def reset_password(request: Request):
status_code=400, status_code=400,
content={ content={
"error": "INVALID_TOKEN", "error": "INVALID_TOKEN",
"message": "Invalid or expired token", "message": "Token invalide ou expiré",
}, },
) )

View File

@@ -1673,7 +1673,7 @@ async def download_translated_file(
status_code=404, status_code=404,
content={ content={
"error": "NOT_READY", "error": "NOT_READY",
"message": "Translation is still in progress.", "message": "La traduction est encore en cours.",
"details": { "details": {
"job_id": job_id, "job_id": job_id,
"status": job.get("status"), "status": job.get("status"),