2026-03-16 07:24:50 +07:00
|
|
|
<?php
|
|
|
|
|
namespace App\Controllers\Organization;
|
|
|
|
|
|
2026-04-08 08:37:41 +07:00
|
|
|
use App\Traits\PatchValidationTrait;
|
|
|
|
|
use App\Traits\ResponseTrait;
|
|
|
|
|
use App\Controllers\BaseController;
|
|
|
|
|
|
|
|
|
|
use App\Models\Organization\DisciplineModel;
|
2026-03-16 07:24:50 +07:00
|
|
|
|
2026-04-08 08:37:41 +07:00
|
|
|
class DisciplineController extends BaseController {
|
|
|
|
|
use ResponseTrait;
|
|
|
|
|
use PatchValidationTrait;
|
2026-03-16 07:24:50 +07:00
|
|
|
|
|
|
|
|
protected $db;
|
|
|
|
|
protected $model;
|
|
|
|
|
|
|
|
|
|
public function __construct() {
|
|
|
|
|
$this->db = \Config\Database::connect();
|
|
|
|
|
$this->model = new DisciplineModel();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function index() {
|
|
|
|
|
$filter = [
|
|
|
|
|
'DisciplineCode' => $this->request->getVar('DisciplineCode'),
|
|
|
|
|
'DisciplineName' => $this->request->getVar('DisciplineName'),
|
|
|
|
|
];
|
|
|
|
|
$rows = $this->model->getDisciplines($filter);
|
|
|
|
|
|
|
|
|
|
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($DisciplineID = null) {
|
|
|
|
|
$row = $this->model->where('DisciplineID', $DisciplineID)->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 = $input["DisciplineID"];
|
|
|
|
|
if (!$id) { return $this->failValidationErrors('ID is required.'); }
|
|
|
|
|
$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 {
|
|
|
|
|
$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());
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2026-03-16 15:58:56 +07:00
|
|
|
public function update($DisciplineID = null) {
|
2026-04-08 08:37:41 +07:00
|
|
|
$input = $this->requirePatchPayload($this->request->getJSON(true));
|
|
|
|
|
if ($input === null) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$id = $this->requirePatchId($DisciplineID, 'DisciplineID');
|
|
|
|
|
if ($id === null) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$existing = $this->model->find($id);
|
|
|
|
|
if (!$existing) {
|
|
|
|
|
return $this->respond([ 'status' => 'failed', 'message' => 'Discipline not found', 'data' => [] ], 404);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$input['DisciplineID'] = $id;
|
2026-03-16 15:58:56 +07:00
|
|
|
$this->model->update($id, $input);
|
2026-04-08 08:37:41 +07:00
|
|
|
return $this->respond([ 'status' => 'success', 'message' => 'data updated successfully', 'data' => $id ], 200);
|
2026-03-16 07:24:50 +07:00
|
|
|
/*
|
|
|
|
|
try {
|
|
|
|
|
$id = $input['DisciplineID'];
|
|
|
|
|
$this->model->where('DisciplineID', $id)->update();
|
|
|
|
|
echo $this->model->getLastQuery();
|
|
|
|
|
return $this->respondCreated([ 'status' => 'success', 'message' => 'data updated successfully', 'data' => $id ], 201);
|
|
|
|
|
} catch (\Throwable $e) {
|
|
|
|
|
return $this->failServerError('Something went wrong: ' . $e->getMessage() );
|
|
|
|
|
}
|
|
|
|
|
*/
|
|
|
|
|
}
|
|
|
|
|
}
|