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
All checks were successful
Deploy to Production / Build and Deploy (push) Successful in 2m44s
This commit is contained in:
@@ -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
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -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
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -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é",
|
||||||
},
|
},
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|||||||
@@ -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"),
|
||||||
|
|||||||
Reference in New Issue
Block a user