156 lines
4.6 KiB
PHP
156 lines
4.6 KiB
PHP
<?php defined('BASEPATH') or exit('No direct script access allowed');
|
||
|
||
/* ----------------------------------------------------------------------------
|
||
* MaketRandevu - MAKET Randevu Portalı
|
||
*
|
||
* @package EasyAppointments
|
||
* @author A.Tselegidis <alextselegidis@gmail.com>
|
||
* @copyright Copyright (c) Alex Tselegidis
|
||
* @license https://opensource.org/licenses/GPL-3.0 - GPLv3
|
||
* @link https://easyappointments.org
|
||
* @since v1.4.0
|
||
* ---------------------------------------------------------------------------- */
|
||
|
||
/**
|
||
* Easy!Appointments controller.
|
||
*
|
||
* @property EA_Benchmark $benchmark
|
||
* @property EA_Cache $cache
|
||
* @property EA_Calendar $calendar
|
||
* @property EA_Config $config
|
||
* @property EA_DB_forge $dbforge
|
||
* @property EA_DB_query_builder $db
|
||
* @property EA_DB_utility $dbutil
|
||
* @property EA_Email $email
|
||
* @property EA_Encrypt $encrypt
|
||
* @property EA_Encryption $encryption
|
||
* @property EA_Exceptions $exceptions
|
||
* @property EA_Hooks $hooks
|
||
* @property EA_Input $input
|
||
* @property EA_Lang $lang
|
||
* @property EA_Loader $load
|
||
* @property EA_Log $log
|
||
* @property EA_Migration $migration
|
||
* @property EA_Output $output
|
||
* @property EA_Profiler $profiler
|
||
* @property EA_Router $router
|
||
* @property EA_Security $security
|
||
* @property EA_Session $session
|
||
* @property EA_Upload $upload
|
||
* @property EA_URI $uri
|
||
*
|
||
* @property Admins_model $admins_model
|
||
* @property Appointments_model $appointments_model
|
||
* @property Service_categories_model $service_categories_model
|
||
* @property Consents_model $consents_model
|
||
* @property Customers_model $customers_model
|
||
* @property Providers_model $providers_model
|
||
* @property Roles_model $roles_model
|
||
* @property Secretaries_model $secretaries_model
|
||
* @property Services_model $services_model
|
||
* @property Settings_model $settings_model
|
||
* @property Unavailabilities_model $unavailabilities_model
|
||
* @property Users_model $users_model
|
||
* @property Webhooks_model $webhooks_model
|
||
* @property Blocked_periods_model $blocked_periods_model
|
||
*
|
||
* @property Accounts $accounts
|
||
* @property Api $api
|
||
* @property Availability $availability
|
||
* @property Email_messages $email_messages
|
||
* @property Captcha_builder $captcha_builder
|
||
* @property Google_Sync $google_sync
|
||
* @property Ics_file $ics_file
|
||
* @property Instance $instance
|
||
* @property Notifications $notifications
|
||
* @property Permissions $permissions
|
||
* @property Synchronization $synchronization
|
||
* @property Timezones $timezones
|
||
* @property Webhooks_client $webhooks_client
|
||
*/
|
||
class EA_Controller extends CI_Controller
|
||
{
|
||
/**
|
||
* EA_Controller constructor.
|
||
*/
|
||
public function __construct()
|
||
{
|
||
parent::__construct();
|
||
|
||
$this->load->library('accounts');
|
||
|
||
$this->ensure_user_exists();
|
||
|
||
$this->configure_language();
|
||
|
||
$this->load_common_html_vars();
|
||
|
||
$this->load_common_script_vars();
|
||
|
||
rate_limit($this->input->ip_address());
|
||
}
|
||
|
||
private function ensure_user_exists()
|
||
{
|
||
$user_id = session('user_id');
|
||
|
||
if (!$user_id) {
|
||
return;
|
||
}
|
||
|
||
if (!$this->accounts->does_account_exist($user_id)) {
|
||
session_destroy();
|
||
|
||
abort(403, 'Forbidden');
|
||
}
|
||
}
|
||
|
||
/**
|
||
* Configure the language.
|
||
*/
|
||
private function configure_language()
|
||
{
|
||
$session_language = session('language');
|
||
|
||
if ($session_language) {
|
||
$language_codes = config('language_codes');
|
||
|
||
config([
|
||
'language' => $session_language,
|
||
'language_code' => array_search($session_language, $language_codes) ?: 'en',
|
||
]);
|
||
}
|
||
|
||
$this->lang->load('translations');
|
||
$this->lang->load('maketrandevu/translations');
|
||
}
|
||
|
||
/**
|
||
* Load common script vars for all requests.
|
||
*/
|
||
private function load_common_html_vars()
|
||
{
|
||
html_vars([
|
||
'base_url' => config('base_url'),
|
||
'index_page' => config('index_page'),
|
||
'available_languages' => config('available_languages'),
|
||
'language' => $this->lang->language,
|
||
'csrf_token' => $this->security->get_csrf_hash(),
|
||
]);
|
||
}
|
||
|
||
/**
|
||
* Load common script vars for all requests.
|
||
*/
|
||
private function load_common_script_vars()
|
||
{
|
||
script_vars([
|
||
'base_url' => config('base_url'),
|
||
'index_page' => config('index_page'),
|
||
'available_languages' => config('available_languages'),
|
||
'csrf_token' => $this->security->get_csrf_hash(),
|
||
'language' => config('language'),
|
||
'language_code' => config('language_code'),
|
||
]);
|
||
}
|
||
}
|