PonenciaController.php 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. <?php
  2. namespace v1\controllers;
  3. use common\data\Respuesta;
  4. use common\rest\AuthController;
  5. use yii\db\Expression;
  6. class PonenciaController extends AuthController {
  7. public $modelClass = "v1\models\Ponencia";
  8. public function actionIndex() {
  9. $id = trim($this->req->get("id", ""));
  10. $q = trim($this->req->get("q", ""));
  11. $query = $this->queryInicial;
  12. if ($id !== "") {
  13. $query->andWhere(["id" => $id]);
  14. }
  15. if ($q) {
  16. $query->andWhere([
  17. "OR",
  18. 'f_unaccent([[id]]) ilike f_unaccent(:q)',
  19. 'f_unaccent([[clave]]) ilike f_unaccent(:q)',
  20. 'f_unaccent([[nombre]]) ilike f_unaccent(:q)',
  21. ])->addParams([':q' => "%{$q}%"]);
  22. }
  23. return new Respuesta($query, $this->limite, $this->pagina, $this->ordenar);
  24. }
  25. public function actionGuardar() {
  26. $id = trim($this->req->getBodyParam("id", null));
  27. $modelo = null;
  28. if ($id !== "") {
  29. $modelo = $this->modelClass::findOne($id);
  30. }
  31. try {
  32. if ($modelo === null) {
  33. $modelo = new $this->modelClass();
  34. $modelo->uuid();
  35. $modelo->creado = new Expression('now()');
  36. } else {
  37. $modelo->modificado = new Expression('now()');
  38. }
  39. $modelo->load($this->req->getBodyParams(), '');
  40. if (!$modelo->save()) {
  41. return (new Respuesta($modelo))
  42. ->mensaje("Hubo un problema al guardar la Ponencia");
  43. }
  44. $modelo->refresh();
  45. return (new Respuesta($modelo))
  46. ->mensaje("Registro de Ponencia guardado");
  47. } catch (\Exception $e) {
  48. return (new Respuesta())
  49. ->esError()
  50. ->mensaje("Hubo un error en el servidor" . $e->getMessage());
  51. }
  52. }
  53. public function actionEliminar() {
  54. $id = trim($this->req->getBodyParam("id", null));
  55. $modelo = null;
  56. if ($id > 0) {
  57. $modelo = $this->modelClass::findOne(["id" => $id]);
  58. }
  59. if ($modelo === null) {
  60. return (new Respuesta())
  61. ->esError()
  62. ->mensaje("Registro de Ponencia no encontrada");
  63. }
  64. $modelo->eliminado = new Expression('now()');
  65. if (!$modelo->save()) {
  66. return (new Respuesta($modelo))
  67. ->mensaje("No se pudo eliminar el registro de Ponencia");
  68. }
  69. return (new Respuesta())
  70. ->mensaje("Ponencia eliminado");
  71. }
  72. }