TemasController.php 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. <?php
  2. namespace v1\controllers;
  3. use common\data\Respuesta;
  4. use common\rest\AuthController;
  5. use yii\db\Expression;
  6. class TemasController extends AuthController {
  7. // Establece la clase del modelo a utilizar
  8. public $modelClass = "v1\models\Temas";
  9. // Acción para obtener una lista de temas
  10. public function actionIndex() {
  11. $id = trim($this->req->get("id", ""));
  12. $buscar = trim($this->req->get("q", ""));
  13. $notIn = trim($this->req->get("notIn", ""));
  14. $query = $this->queryInicial;
  15. // Filtrar por ID si se proporciona
  16. if (!empty($id)) {
  17. $query->andWhere(["id" => $id]);
  18. }
  19. if (!empty($notIn)) {
  20. $explode = explode(",", $notIn);
  21. $query->andWhere(["NOT IN", "id", $explode]);
  22. }
  23. // Realizar una búsqueda en el nombre del tema
  24. if ($buscar) {
  25. $query->andWhere([
  26. "OR",
  27. "f_unaccent([[nombre]]) ilike f_unaccent(:q)",
  28. ])->addParams([':q' => "%{$buscar}%"]);
  29. }
  30. // Devolver una respuesta con los resultados de la consulta
  31. return new Respuesta($query, $this->limite, $this->pagina, $this->ordenar);
  32. }
  33. // Acción para guardar un tema
  34. public function actionGuardar() {
  35. $id = trim($this->req->getBodyParam("id", ""));
  36. $modelo = null;
  37. if (!empty($id)) {
  38. $modelo = $this->modelClass::findOne($id);
  39. }
  40. if ($modelo === null) {
  41. $modelo = new $this->modelClass();
  42. $modelo->creado = new Expression('now()');
  43. $modelo->uuid();
  44. } else {
  45. $modelo->modificado = new Expression('now()');
  46. }
  47. $modelo->load($this->req->getBodyParams(), '');
  48. // Guardar el modelo en la base de datos
  49. if (!$modelo->save()) {
  50. return (new Respuesta($modelo))
  51. ->mensaje("Hubo un problema al guardar el registro de temas");
  52. }
  53. $modelo->refresh();
  54. return (new Respuesta($modelo))
  55. ->mensaje("Registro de temas guardado con éxito.");
  56. }
  57. // Acción para eliminar un tema
  58. public function actionEliminar() {
  59. $id = trim($this->req->getBodyParam("id", ""));
  60. $modelo = null;
  61. if ($id !== "") {
  62. $modelo = $this->modelClass::findOne(["id" => $id]);
  63. }
  64. if ($modelo === null) {
  65. return (new Respuesta())
  66. ->esError()
  67. ->mensaje("Registro de temas no encontrado");
  68. }
  69. $modelo->eliminado = new Expression('now()');
  70. if (!$modelo->save()) {
  71. return (new Respuesta($modelo))
  72. ->mensaje("No se pudo eliminar el registro de temas");
  73. }
  74. return (new Respuesta())
  75. ->mensaje("Registro de temas eliminado");
  76. }
  77. }