db = \Config\Database::connect(); $this->model = new HostAppModel(); } public function index() { $filter = [ 'HostAppID' => $this->request->getVar('HostAppID'), 'HostAppName' => $this->request->getVar('HostAppName'), ]; $builder = $this->model->select('hostapp.*, site.SiteName') ->join('site', 'site.SiteID = hostapp.SiteID', 'left'); if (!empty($filter['HostAppID'])) { if (!ctype_digit((string) $filter['HostAppID'])) { return $this->failValidationErrors('HostAppID filter must be a valid integer.'); } $builder->where('hostapp.HostAppID', (int) $filter['HostAppID']); } if (!empty($filter['HostAppName'])) { $builder->like('hostapp.HostAppName', $filter['HostAppName'], 'both'); } $rows = $builder->findAll(); if (empty($rows)) { return $this->respond(['status' => 'success', 'message' => 'no Data.', 'data' => []], 200); } return $this->respond(['status' => 'success', 'message' => 'fetch success', 'data' => $rows], 200); } public function show($HostAppID = null) { $id = $this->requirePatchId($HostAppID, 'HostAppID'); if ($id === null) { return; } $row = $this->model->select('hostapp.*, site.SiteName') ->join('site', 'site.SiteID = hostapp.SiteID', 'left') ->where('hostapp.HostAppID', $id) ->first(); if (empty($row)) { return $this->respond(['status' => 'success', 'message' => 'no Data.', 'data' => null], 200); } return $this->respond(['status' => 'success', 'message' => 'fetch success', 'data' => $row], 200); } public function delete() { try { $input = $this->request->getJSON(true); $id = $this->requirePatchId($input['HostAppID'] ?? null, 'HostAppID'); if ($id === null) { return; } $this->model->delete($id); return $this->respondDeleted(['status' => 'success', 'message' => "{$id} deleted successfully."]); } catch (\Throwable $e) { return $this->failServerError('Something went wrong: ' . $e->getMessage()); } } public function create() { $input = $this->request->getJSON(true); try { unset($input['HostAppID']); $id = $this->model->insert($input, true); return $this->respondCreated(['status' => 'success', 'message' => 'data created successfully', 'data' => $id], 201); } catch (\Throwable $e) { return $this->failServerError('Something went wrong: ' . $e->getMessage()); } } public function update($HostAppID = null) { $input = $this->requirePatchPayload($this->request->getJSON(true)); if ($input === null) { return; } $id = $this->requirePatchId($HostAppID, 'HostAppID'); if ($id === null) { return; } $existing = $this->model->find($id); if (!$existing) { return $this->respond(['status' => 'failed', 'message' => 'HostApp not found', 'data' => []], 404); } if (isset($input['HostAppID'])) { if ((string) $input['HostAppID'] !== (string) $id) { return $this->failValidationErrors('HostAppID in URL does not match body.'); } unset($input['HostAppID']); } try { $this->model->update($id, $input); return $this->respond(['status' => 'success', 'message' => 'data updated successfully', 'data' => $id], 200); } catch (\Throwable $e) { return $this->failServerError('Something went wrong: ' . $e->getMessage()); } } }