69 lines
2.6 KiB
PHP
69 lines
2.6 KiB
PHP
<?php
|
|
namespace App\Controllers\Contact;
|
|
|
|
use App\Traits\ResponseTrait;
|
|
use App\Controllers\BaseController;
|
|
use App\Models\Contact\OccupationModel;
|
|
|
|
class OccupationController extends BaseController {
|
|
use ResponseTrait;
|
|
|
|
protected $db;
|
|
protected $model;
|
|
protected $rules;
|
|
|
|
public function __construct() {
|
|
$this->db = \Config\Database::connect();
|
|
$this->model = new OccupationModel();
|
|
$this->rules = [ 'OccCode' => 'required','OccText' => 'required' ];
|
|
}
|
|
|
|
public function index() {
|
|
$OccCode = $this->request->getVar('OccCode');
|
|
$OccText = $this->request->getVar('OccText');
|
|
$rows = $this->model->getOccupations($OccCode,$OccText);
|
|
|
|
if (empty($rows)) {
|
|
return $this->respond([ 'status' => 'success', 'message' => "no Data."], 200);
|
|
}
|
|
|
|
return $this->respond([ 'status' => 'success', 'message'=> "fetch success", 'data' => $rows ], 200);
|
|
}
|
|
|
|
public function show($OccupationID = null) {
|
|
$model = new OccupationModel();
|
|
$row = $model->find($OccupationID);
|
|
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 create() {
|
|
$input = $this->request->getJSON(true);
|
|
try {
|
|
$this->model->insert($input);
|
|
$id = $this->model->getInsertID();
|
|
return $this->respondCreated([ 'status' => 'success', 'message' => 'data created successfully', 'data' => $id ], 201);
|
|
} catch (\Throwable $e) {
|
|
$this->db->transRollback();
|
|
return $this->failServerError('Exception : ' . $e->getMessage());
|
|
}
|
|
}
|
|
|
|
public function update($OccupationID = null) {
|
|
$input = $this->request->getJSON(true);
|
|
if (!$OccupationID || !ctype_digit((string) $OccupationID)) {
|
|
return $this->respond(['status' => 'error', 'message' => 'OccupationID is required and must be a valid integer'], 400);
|
|
}
|
|
$input['OccupationID'] = (int) $OccupationID;
|
|
try {
|
|
$this->model->update($input['OccupationID'], $input);
|
|
return $this->respondCreated([ 'status' => 'success', 'message' => 'Data updated successfully', 'data' => $input['OccupationID'] ], 201);
|
|
} catch (\Throwable $e) {
|
|
return $this->failServerError('Exception : ' . $e->getMessage());
|
|
}
|
|
}
|
|
|
|
}
|