TagController.php 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238
  1. <?php
  2. namespace App\Controllers\Web;
  3. use App\Utils\Api;
  4. use App\Utils\Url;
  5. use PH7\JustHttp\StatusCode;
  6. class TagController
  7. {
  8. /*
  9. * Obtiene los nombres de los campos del formulario.
  10. */
  11. private function getFormFields()
  12. {
  13. return ['name'];
  14. }
  15. /*
  16. * Renderiza el formulario de registro de tags.
  17. */
  18. public function new($req, $res)
  19. {
  20. $values = [];
  21. $validations = [];
  22. $error = $req->session['error'] ?? null;
  23. /*
  24. * Obtiene los valores y los mensajes de validación
  25. * de los campos del formulario.
  26. */
  27. foreach ($this->getFormFields() as $field) {
  28. $values[$field] = $req->session['values'][$field] ?? null;
  29. $validations[$field] = $req->session['validations'][$field] ?? null;
  30. }
  31. foreach (['values', 'validations', 'error'] as $key) {
  32. unset($req->session[$key]);
  33. }
  34. $res->render('tags/new', [
  35. 'app' => $req->app,
  36. 'values' => $values,
  37. 'validations' => $validations,
  38. 'error' => $error
  39. ]);
  40. }
  41. /*
  42. * Registra el tag de un usuario.
  43. */
  44. public function create($req, $res)
  45. {
  46. $data = [];
  47. // Obtiene los valores de los campos del formulario.
  48. foreach ($this->getFormFields() as $field) {
  49. $data[$field] = $req->body[$field] ?? null;
  50. }
  51. $client = Api::client();
  52. // Realiza la petición de registro del tag del usuario.
  53. $response = $client->post('v1/tags', [], $data);
  54. $body = json_decode($response->body ?? '', true);
  55. // Comprueba el cuerpo de la petición.
  56. if (empty($response->success) || empty($body['data'])) {
  57. $req->session['values'] = $data;
  58. // Envía los mensajes de validación de los campos del formulario.
  59. if (!empty($body['validations'])) {
  60. $req->session['validations'] = $body['validations'];
  61. }
  62. // Envía el mensaje de error de la petición..
  63. $req->session['error'] = $body['error'] ?? 'The tag could not be created';
  64. $res->redirect(Url::build('tags/new'), StatusCode::FOUND);
  65. }
  66. $req->session['success'] = 'The tag was created correctly';
  67. $res->redirect(Url::build('tags'), StatusCode::FOUND);
  68. }
  69. /*
  70. * Consulta los tags del usuario.
  71. */
  72. public function index($req, $res)
  73. {
  74. $client = Api::client();
  75. // Realiza la petición de consulta de los tags del usuario.
  76. $response = $client->get('v1/tags');
  77. $body = json_decode($response->body ?? '', true);
  78. $tags = $body['data'] ?? [];
  79. $error = $body['error'] ?? $req->session['error'] ?? null;
  80. $success = $req->session['success'] ?? null;
  81. foreach (['success', 'error'] as $key) {
  82. unset($req->session[$key]);
  83. }
  84. $res->render('tags/index', [
  85. 'app' => $req->app,
  86. 'tags' => $tags,
  87. 'success' => $success,
  88. 'error' => $error
  89. ]);
  90. }
  91. /*
  92. * Renderiza el formulario de modificación de tags.
  93. */
  94. public function edit($req, $res)
  95. {
  96. $uuid = $req->params['uuid'] ?? '';
  97. $client = Api::client();
  98. /*
  99. * Realiza la petición de consulta de
  100. * la información del tag del usuario.
  101. */
  102. $response = $client->get('v1/tags/' . $uuid);
  103. $body = json_decode($response->body ?? '', true);
  104. $tag = $body['data'] ?? [];
  105. // Comprueba el cuerpo de la petición.
  106. if (empty($response->success) || empty($tag)) {
  107. // Envía el mensaje de error de la petición.
  108. $req->session['error'] = $body['error'] ?? 'The tag could not be edited';
  109. $res->redirect(Url::build('tags'), StatusCode::FOUND);
  110. }
  111. $validations = [];
  112. $error = $req->session['error'] ?? null;
  113. $success = $req->session['success'] ?? null;
  114. /*
  115. * Obtiene los valores y los mensajes de validación
  116. * de los campos del formulario.
  117. */
  118. foreach ($this->getFormFields() as $field) {
  119. $validations[$field] = $req->session['validations'][$field] ?? null;
  120. }
  121. foreach (['validations', 'error', 'success'] as $key) {
  122. unset($req->session[$key]);
  123. }
  124. $res->render('tags/edit', [
  125. 'app' => $req->app,
  126. 'tag' => $tag,
  127. 'validations' => $validations,
  128. 'error' => $error,
  129. 'success' => $success
  130. ]);
  131. }
  132. /*
  133. * Modifica el tag de un usuario.
  134. */
  135. public function update($req, $res)
  136. {
  137. $uuid = $req->params['uuid'] ?? '';
  138. $data = [];
  139. // Obtiene los valores de los campos del formulario.
  140. foreach ($this->getFormFields() as $field) {
  141. $data[$field] = $req->body[$field] ?? null;
  142. }
  143. $client = Api::client();
  144. $headers = ['Content-Type' => 'application/x-www-form-urlencoded'];
  145. // Realiza la petición de modificación del tag del usuario.
  146. $response = $client->put('v1/tags/' . $uuid, $headers, $data);
  147. $body = json_decode($response->body ?? '', true);
  148. // Comprueba el cuerpo de la petición.
  149. if (empty($response->success) || empty($body['data'])) {
  150. // Envía los mensajes de validación de los campos del formulario.
  151. if (!empty($body['validations'])) {
  152. $req->session['validations'] = $body['validations'];
  153. }
  154. // Envía el mensaje de error de la petición.
  155. $req->session['error'] = $body['error'] ?? 'The tag could not be updated';
  156. $res->redirect(Url::build('tags/edit/' . $uuid), StatusCode::FOUND);
  157. }
  158. $req->session['success'] = 'The tag was modified correctly';
  159. $res->redirect(Url::build('tags/edit/' . $uuid), StatusCode::FOUND);
  160. }
  161. /*
  162. * Elimina el tag de un usuario.
  163. */
  164. public function delete($req, $res)
  165. {
  166. $uuid = $req->params['uuid'] ?? '';
  167. $client = Api::client();
  168. // Realiza la petición de eliminación del tag del usuario.
  169. $response = $client->delete('v1/tags/' . $uuid);
  170. $body = json_decode($response->body ?? '', true);
  171. // Comprueba el cuerpo de la petición.
  172. if (empty($response->success) || empty($body['data'])) {
  173. // Envía el mensaje de error de la petición.
  174. $req->session['error'] = $body['error'] ?? 'The tag could not be deleted';
  175. $res->redirect(Url::build('tags'), StatusCode::FOUND);
  176. }
  177. $req->session['success'] = 'The tag was deleted correctly';
  178. $res->redirect(Url::build('tags'), StatusCode::FOUND);
  179. }
  180. }