LoginController.php 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142
  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. class LoginController
  8. {
  9. public function __invoke(ServerRequestInterface $request)
  10. {
  11. $body = json_decode((string) $request->getBody(), true);
  12. $username = $body['username'] ?? '';
  13. $password = $body['password'] ?? '';
  14. if (empty($username) || empty($password)) {
  15. return ResponseLib::sendFail("Missing username or password", [], "E_VALIDATE")->withStatus(401);
  16. }
  17. $userModel = new UserModel();
  18. $user = $userModel->validateLogin($username, $password);
  19. if (!$user) {
  20. return ResponseLib::sendFail("Invalid credentials", [], "E_VALIDATE")->withStatus(401);
  21. }
  22. // Gera JWT
  23. $payload = [
  24. 'sub' => $user['user_id'],
  25. 'username' => $user['user_name'],
  26. 'role_id' => $user['role_id'],
  27. 'company_id' => $user['company_id'],
  28. 'iat' => time(),
  29. 'exp' => time() + 3600 // 1 hora
  30. ];
  31. $jwt = JWT::encode($payload, $_ENV['JWT_SECRET'], 'HS256');
  32. return ResponseLib::sendOk(['token' => $jwt, 'user_id' => $user['user_id'], 'role_id' => $user['role_id']]);
  33. }
  34. }