request->isAJAX()) { $reqData = $this->request->getPost(); if (!isset($reqData['draw']) || !isset($reqData['columns'])) { $errstr = 'No data available in response to this specific request.'; $response = $this->respond(Collection::datatable([], 0, 0, $errstr), 400, $errstr); return $response; } $start = $reqData['start'] ?? 0; $length = $reqData['length'] ?? 5; $search = $reqData['search']['value']; $requestedOrder = $reqData['order']['0']['column'] ?? 1; $order = ClienteDireccionesModel::SORTABLE[$requestedOrder >= 0 ? $requestedOrder : 1]; $dir = $reqData['order']['0']['dir'] ?? 'asc'; $id_C = $reqData['id_cliente'] ?? -1; $resourceData = $this->model->getResource($search, $id_C)->orderBy($order, $dir)->limit($length, $start)->get()->getResultObject(); return $this->respond(Collection::datatable( $resourceData, $this->model->getResource()->countAllResults(), $this->model->getResource("", $id_C)->countAllResults() )); } else { return $this->failUnauthorized('Invalid request', 403); } } public function datatable_editor() { if ($this->request->isAJAX()) { include(APPPATH . "ThirdParty/DatatablesEditor/DataTables.php"); // Build our Editor instance and process the data coming from _POST $response = Editor::inst($db, 'clientes_direcciones') ->fields( Field::inst('att') ->validator('Validate::notEmpty', array( 'message' => lang('ClienteDirecciones.validation.required')) ) ->validator( Validate::maxLen( 100 ) , array( 'message' => lang('ClienteDirecciones.validation.max_length')) ), ) /*->validator(function ($editor, $action, $data) { if ($action === Editor::ACTION_CREATE || $action === Editor::ACTION_EDIT) { foreach ($data['data'] as $pkey => $values) { // Si no se quiere borrar... if ($data['data'][$pkey]['is_deleted'] != 1) { $process_data['paginas_min'] = $data['data'][$pkey]['paginas_min']; $process_data['paginas_max'] = $data['data'][$pkey]['paginas_max']; $response = $this->model->checkIntervals($process_data, $pkey, $data['data'][$pkey]['papel_impresion_id']); // No se pueden duplicar valores al crear o al editar if (!empty($response)) { return $response; } } } } })*/ ->debug(true) ->process($_POST) ->data(); $newTokenHash = csrf_hash(); $csrfTokenName = csrf_token(); $response[$csrfTokenName] = $newTokenHash; echo json_encode($response); } else { return $this->failUnauthorized('Invalid request', 403); } } }