AuthController.php 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. <?php
  2. namespace App\Controllers\Web;
  3. use App\Utils\Api;
  4. use App\Utils\Url;
  5. use PH7\JustHttp\StatusCode;
  6. class AuthController
  7. {
  8. /*
  9. * Obtiene los nombres de los campos del formulario.
  10. */
  11. private function getFormFields()
  12. {
  13. return ['nickname', 'password'];
  14. }
  15. /*
  16. * Obtiene las opciones de configuración
  17. * de la cookie de autenticación.
  18. */
  19. private function getCookieOptions()
  20. {
  21. return [
  22. 'path' => '/',
  23. 'httpOnly' => true
  24. ];
  25. }
  26. /*
  27. * Renderiza el formulario de inicio de sesión.
  28. */
  29. public function loginView($req, $res)
  30. {
  31. $values = [];
  32. $validations = [];
  33. $error = $req->session['error'] ?? null;
  34. /*
  35. * Obtiene los valores y los mensajes de validación
  36. * de los campos del formulario.
  37. */
  38. foreach ($this->getFormFields() as $field) {
  39. $values[$field] = $req->session['values'][$field] ?? null;
  40. $validations[$field] = $req->session['validations'][$field] ?? null;
  41. }
  42. foreach (['values', 'validations', 'error'] as $key) {
  43. unset($req->session[$key]);
  44. }
  45. $res->render('auth/login', [
  46. 'app' => $req->app,
  47. 'values' => $values,
  48. 'validations' => $validations,
  49. 'error' => $error
  50. ]);
  51. }
  52. /*
  53. * Inicia la sesión de un usuario.
  54. */
  55. public function loginAction($req, $res)
  56. {
  57. $data = [];
  58. // Obtiene los valores de los campos del formulario.
  59. foreach ($this->getFormFields() as $field) {
  60. $data[$field] = $req->body[$field] ?? null;
  61. }
  62. $client = Api::client();
  63. // Realiza la petición de inicio de sesión del usuario.
  64. $response = $client->post('v1/auth/login', [], $data);
  65. $body = json_decode($response->body ?? '', true);
  66. $token = $body['data']['token'] ?? null;
  67. // Comprueba el cuerpo de la petición.
  68. if (empty($response->success) || empty($token)) {
  69. $req->session['values'] = $data;
  70. // Envía los mensajes de validación de los campos del formulario.
  71. if (!empty($body['validations'])) {
  72. $req->session['validations'] = $body['validations'];
  73. }
  74. // Envía el mensaje de error de la petición.
  75. $req->session['error'] = $body['error'] ?? 'Could not login';
  76. $res->redirect(Url::build('login'), StatusCode::FOUND);
  77. }
  78. $cookieOptions = $this->getCookieOptions();
  79. // 24 horas
  80. $cookieOptions['expire'] = strtotime('tomorrow');
  81. // Genera la cookie de autenticación del usuario.
  82. $res->cookie('userAuth', $token, $cookieOptions);
  83. $res->redirect(Url::build('notes'), StatusCode::FOUND);
  84. }
  85. /*
  86. * Cierra la sesión de un usuario.
  87. */
  88. public function logout($req, $res)
  89. {
  90. $res->clearCookie('userAuth', $this->getCookieOptions());
  91. $res->redirect(Url::build('login'), StatusCode::FOUND);
  92. }
  93. }