* @copyright Copyright (c) 2013 - 2020, Alex Tselegidis * @license http://opensource.org/licenses/GPL-3.0 - GPLv3 * @link http://easyappointments.org * @since v1.2.0 * ---------------------------------------------------------------------------- */ require_once __DIR__ . '/API_V1_Controller.php'; use EA\Engine\Api\V1\Request; use EA\Engine\Api\V1\Response; use EA\Engine\Types\NonEmptyText; /** * Categories Controller * * @property CI_Session $session * @property CI_Loader $load * @property CI_Input $input * @property CI_Output $output * @property CI_Config $config * @property CI_Lang $lang * @property CI_Cache $cache * @property CI_DB_query_builder $db * @property CI_Security $security * @property Google_Sync $google_sync * @property Ics_file $ics_file * @property Appointments_model $appointments_model * @property Providers_model $providers_model * @property Services_model $services_model * @property Customers_model $customers_model * @property Settings_model $settings_model * @property Timezones $timezones * @property Roles_model $roles_model * @property Secretaries_model $secretaries_model * @property Admins_model $admins_model * @property User_model $user_model * * @package Controllers */ class Categories extends API_V1_Controller { /** * Categories Resource Parser * * @var \EA\Engine\Api\V1\Parsers\Categories */ protected $parser; /** * Class Constructor */ public function __construct() { parent::__construct(); $this->load->model('services_model'); $this->parser = new \EA\Engine\Api\V1\Parsers\Categories; } /** * GET API Method * * @param int $id Optional (null), the record ID to be returned. */ public function get($id = NULL) { try { $condition = $id !== NULL ? 'id = ' . $id : NULL; $categories = $this->services_model->get_all_categories($condition); if ($id !== NULL && count($categories) === 0) { $this->throw_record_not_found(); } $response = new Response($categories); $response->encode($this->parser) ->search() ->sort() ->paginate() ->minimize() ->singleEntry($id) ->output(); } catch (Exception $exception) { $this->handle_exception($exception); } } /** * POST API Method */ public function post() { try { // Insert the category to the database. $request = new Request(); $category = $request->getBody(); $this->parser->decode($category); if (isset($category['id'])) { unset($category['id']); } $id = $this->services_model->add_category($category); // Fetch the new object from the database and return it to the client. $batch = $this->services_model->get_all_categories('id = ' . $id); $response = new Response($batch); $status = new NonEmptyText('201 Created'); $response->encode($this->parser)->singleEntry(TRUE)->output($status); } catch (Exception $exception) { $this->handle_exception($exception); } } /** * PUT API Method * * @param int $id The record ID to be updated. */ public function put($id) { try { // Update the category record. $batch = $this->services_model->get_all_categories('id = ' . $id); if ($id !== NULL && count($batch) === 0) { $this->throw_record_not_found(); } $request = new Request(); $updated_category = $request->getBody(); $base_category = $batch[0]; $this->parser->decode($updated_category, $base_category); $updated_category['id'] = $id; $id = $this->services_model->add_category($updated_category); // Fetch the updated object from the database and return it to the client. $batch = $this->services_model->get_all_categories('id = ' . $id); $response = new Response($batch); $response->encode($this->parser)->singleEntry($id)->output(); } catch (Exception $exception) { $this->handle_exception($exception); } } /** * DELETE API Method * * @param int $id The record ID to be deleted. */ public function delete($id) { try { $result = $this->services_model->delete_category($id); $response = new Response([ 'code' => 200, 'message' => 'Record was deleted successfully!' ]); $response->output(); } catch (Exception $exception) { $this->handle_exception($exception); } } }