LoginController.php 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  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 val;
  8. use Respect\Validation\Exceptions\ValidationException;
  9. class LoginController
  10. {
  11. private UserModel $userModel;
  12. public function __construct()
  13. {
  14. $this->userModel = new UserModel();
  15. }
  16. public function __invoke(ServerRequestInterface $request)
  17. {
  18. $body = json_decode((string) $request->getBody(), true) ?? [];
  19. try {
  20. val::key('email', val::email())
  21. ->key('password', val::stringType()->notEmpty()->length(8, null))
  22. ->assert($body);
  23. } catch (ValidationException $e) {
  24. return ResponseLib::sendFail("Validation failed: " . $e->getFullMessage(), [], "E_VALIDATE")->withStatus(401);
  25. }
  26. $email = $body['email'];
  27. $password = $body['password'];
  28. $user = $this->userModel->validateLogin($email, $password);
  29. if (!$user) {
  30. return ResponseLib::sendFail("Invalid credentials", [], "E_VALIDATE")->withStatus(401);
  31. }
  32. $payload = [
  33. 'sub' => $user['user_id'],
  34. 'email' => $user['user_email'],
  35. 'iat' => time(),
  36. 'exp' => time() + 3600
  37. ];
  38. $jwt = JWT::encode($payload, $_ENV['JWT_SECRET'], 'HS256');
  39. return ResponseLib::sendOk(['token' => $jwt, 'user_id' => $user['user_id'], 'company_id' => $user['company_id']]);
  40. }
  41. }