Detailed login errors

This commit is contained in:
Juan Pablo Vial
2025-06-03 19:20:44 -04:00
parent 7f6d0232c0
commit a750bdbfaa

View File

@ -20,20 +20,23 @@ class Login extends Ideal\Controller
$body = $request->getParsedBody(); $body = $request->getParsedBody();
$output = [ $output = [
'username' => $body['username'], 'username' => $body['username'],
'success' => false
]; ];
$statusCode = 409;
try { try {
$user = $userRepository->fetchByName($body['username']); $user = $userRepository->fetchByName($body['username']);
if ($user->validate($body['password'])) { if (!$user->validate($body['password'])) {
$loginService->login($user); throw new EmptyResult("Invalid password");
$output['token'] = $loginService->getToken();
} }
$loginService->login($user);
$output['token'] = $loginService->getToken();
$output['success'] = true;
$statusCode = 200;
} catch (EmptyResult $exception) { } catch (EmptyResult $exception) {
$output['error'] = [ $this->logger->error($exception, [
'code' => $exception->getCode(), 'username' => $body['username']
'message' => $exception->getMessage(), ]);
'stackTrace' => $exception->getTraceAsString()
];
} }
return $this->withJson($response, $output); return $this->withJson($response, $output, $statusCode);
} }
} }