LoginController.php 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. <?php
  2. namespace Controllers;
  3. use Firebase\JWT\JWT;
  4. use Libs\ResponseLib;
  5. use Models\UserModel;
  6. use Psr\Http\Message\ServerRequestInterface;
  7. use Respect\Validation\Validator as v;
  8. use Respect\Validation\Exceptions\ValidationException;
  9. class LoginController
  10. {
  11. public function __invoke(ServerRequestInterface $request)
  12. {
  13. $body = json_decode((string) $request->getBody(), true) ?? [];
  14. try {
  15. v::key('username', v::alnum(' ')->notEmpty())
  16. ->key('password', v::stringType()->notEmpty())
  17. ->assert($body);
  18. } catch (ValidationException $e) {
  19. return ResponseLib::sendFail("Validation failed: " . $e->getFullMessage(), [], "E_VALIDATE")->withStatus(401);
  20. }
  21. $username = $body['username'];
  22. $password = $body['password'];
  23. $userModel = new UserModel();
  24. $user = $userModel->validateLogin($username, $password);
  25. if (!$user) {
  26. return ResponseLib::sendFail("Invalid credentials", [], "E_VALIDATE")->withStatus(401);
  27. }
  28. // Gera JWT
  29. $payload = [
  30. 'sub' => $user['user_id'],
  31. 'username' => $user['user_name'],
  32. 'role_id' => $user['role_id'],
  33. 'company_id' => $user['company_id'],
  34. 'iat' => time(),
  35. 'exp' => time() + 3600 // 1 hora
  36. ];
  37. $jwt = JWT::encode($payload, $_ENV['JWT_SECRET'], 'HS256');
  38. return ResponseLib::sendOk(['token' => $jwt, 'user_id' => $user['user_id'], 'role_id' => $user['role_id']]);
  39. }
  40. }