Merge branch 'local-original-dev' into develop

This commit is contained in:
Aliberk Sandıkçı 2023-12-23 00:15:29 +03:00
commit 9c58c12c79
Signed by: asandikci
GPG key ID: 25C67A03B5666BC1
219 changed files with 2815 additions and 2646 deletions

View file

@ -5,8 +5,8 @@
"bracketSpacing": false, "bracketSpacing": false,
"bracketSameLine": false, "bracketSameLine": false,
"quoteProps": "preserve", "quoteProps": "preserve",
"trailingComma": "none", "trailingComma": "all",
"trailingCommaPHP": false, "trailingCommaPHP": true,
"phpVersion": "8.0", "phpVersion": "8.0",
"plugins": ["@prettier/plugin-php"] "plugins": ["@prettier/plugin-php"]
} }

View file

@ -17,7 +17,7 @@
$protocol = $protocol =
(isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] === 'on') || (isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] === 'on') ||
(isset($_SERVER['SERVER_PORT']) && (int) $_SERVER['SERVER_PORT'] === 443) || (isset($_SERVER['SERVER_PORT']) && (int)$_SERVER['SERVER_PORT'] === 443) ||
(isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] === 'https') (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] === 'https')
? 'https://' ? 'https://'
: 'http://'; : 'http://';
@ -26,7 +26,8 @@ $domain = $_SERVER['HTTP_HOST'] ?? 'localhost';
$request_uri = dirname($_SERVER['SCRIPT_NAME']); $request_uri = dirname($_SERVER['SCRIPT_NAME']);
if ($request_uri === '.') { if ($request_uri === '.')
{
$request_uri = ''; $request_uri = '';
} }
@ -136,7 +137,7 @@ $config['charset'] = 'UTF-8';
| setting this variable to TRUE (boolean). See the user guide for details. | setting this variable to TRUE (boolean). See the user guide for details.
| |
*/ */
$config['enable_hooks'] = true; $config['enable_hooks'] = TRUE;
/* /*
|-------------------------------------------------------------------------- |--------------------------------------------------------------------------
@ -196,8 +197,8 @@ $config['permitted_uri_chars'] = 'a-z 0-9~%.:_\-';
| use segment based URLs. | use segment based URLs.
| |
*/ */
$config['allow_get_array'] = true; $config['allow_get_array'] = TRUE;
$config['enable_query_strings'] = false; $config['enable_query_strings'] = FALSE;
$config['controller_trigger'] = 'c'; $config['controller_trigger'] = 'c';
$config['function_trigger'] = 'm'; $config['function_trigger'] = 'm';
$config['directory_trigger'] = 'd'; // experimental not currently in use $config['directory_trigger'] = 'd'; // experimental not currently in use
@ -290,9 +291,9 @@ $config['sess_driver'] = 'files';
$config['sess_cookie_name'] = 'ea_session'; $config['sess_cookie_name'] = 'ea_session';
$config['sess_expiration'] = 7200; $config['sess_expiration'] = 7200;
$config['sess_save_path'] = __DIR__ . '/../../storage/sessions'; $config['sess_save_path'] = __DIR__ . '/../../storage/sessions';
$config['sess_match_ip'] = false; $config['sess_match_ip'] = FALSE;
$config['sess_time_to_update'] = 300; $config['sess_time_to_update'] = 300;
$config['sess_regenerate_destroy'] = false; $config['sess_regenerate_destroy'] = FALSE;
/* /*
|-------------------------------------------------------------------------- |--------------------------------------------------------------------------
@ -308,7 +309,7 @@ $config['sess_regenerate_destroy'] = false;
$config['cookie_prefix'] = ''; $config['cookie_prefix'] = '';
$config['cookie_domain'] = ''; $config['cookie_domain'] = '';
$config['cookie_path'] = '/'; $config['cookie_path'] = '/';
$config['cookie_secure'] = strpos($config['base_url'], 'https') !== false; $config['cookie_secure'] = strpos($config['base_url'], 'https') !== FALSE;
/* /*
|-------------------------------------------------------------------------- |--------------------------------------------------------------------------
@ -322,7 +323,7 @@ $config['cookie_secure'] = strpos($config['base_url'], 'https') !== false;
| 'csrf_cookie_name' = The cookie name | 'csrf_cookie_name' = The cookie name
| 'csrf_expire' = The number in seconds the token should expire. | 'csrf_expire' = The number in seconds the token should expire.
*/ */
$config['csrf_protection'] = true; $config['csrf_protection'] = TRUE;
$config['csrf_token_name'] = 'csrf_token'; $config['csrf_token_name'] = 'csrf_token';
$config['csrf_cookie_name'] = 'csrf_cookie'; $config['csrf_cookie_name'] = 'csrf_cookie';
$config['csrf_expire'] = 7200; $config['csrf_expire'] = 7200;
@ -345,7 +346,7 @@ $config['csrf_exclude_uris'] = ['api/v1/.*', 'booking/.*', 'booking_cancellation
| by the output class. Do not 'echo' any values with compression enabled. | by the output class. Do not 'echo' any values with compression enabled.
| |
*/ */
$config['compress_output'] = false; $config['compress_output'] = FALSE;
/* /*
|-------------------------------------------------------------------------- |--------------------------------------------------------------------------
@ -370,7 +371,7 @@ $config['time_reference'] = 'local';
| in your view files. Options are TRUE or FALSE (boolean) | in your view files. Options are TRUE or FALSE (boolean)
| |
*/ */
$config['rewrite_short_tags'] = false; $config['rewrite_short_tags'] = FALSE;
/* /*
|-------------------------------------------------------------------------- |--------------------------------------------------------------------------
@ -394,7 +395,7 @@ $config['proxy_ips'] = '';
| will control the number of requests a client can sent to the app. | will control the number of requests a client can sent to the app.
| |
*/ */
$config['rate_limiting'] = true; $config['rate_limiting'] = TRUE;
/* End of file config.php */ /* End of file config.php */
/* Location: ./application/config/config.php */ /* Location: ./application/config/config.php */

View file

@ -47,7 +47,7 @@
*/ */
$active_group = 'default'; $active_group = 'default';
$query_builder = true; $query_builder = TRUE;
$db['default']['hostname'] = Config::DB_HOST; $db['default']['hostname'] = Config::DB_HOST;
$db['default']['username'] = Config::DB_USERNAME; $db['default']['username'] = Config::DB_USERNAME;
@ -55,15 +55,15 @@ $db['default']['password'] = Config::DB_PASSWORD;
$db['default']['database'] = Config::DB_NAME; $db['default']['database'] = Config::DB_NAME;
$db['default']['dbdriver'] = 'mysqli'; $db['default']['dbdriver'] = 'mysqli';
$db['default']['dbprefix'] = 'ea_'; $db['default']['dbprefix'] = 'ea_';
$db['default']['pconnect'] = true; $db['default']['pconnect'] = TRUE;
$db['default']['db_debug'] = true; $db['default']['db_debug'] = TRUE;
$db['default']['cache_on'] = false; $db['default']['cache_on'] = FALSE;
$db['default']['cachedir'] = ''; $db['default']['cachedir'] = '';
$db['default']['char_set'] = 'utf8mb4'; $db['default']['char_set'] = 'utf8mb4';
$db['default']['dbcollat'] = 'utf8mb4_unicode_ci'; $db['default']['dbcollat'] = 'utf8mb4_unicode_ci';
$db['default']['swap_pre'] = ''; $db['default']['swap_pre'] = '';
$db['default']['autoinit'] = true; $db['default']['autoinit'] = TRUE;
$db['default']['stricton'] = false; $db['default']['stricton'] = FALSE;
/* End of file database.php */ /* End of file database.php */
/* Location: ./application/config/database.php */ /* Location: ./application/config/database.php */

View file

@ -9,7 +9,7 @@
| whenever you intend to do a schema migration. | whenever you intend to do a schema migration.
| |
*/ */
$config['migration_enabled'] = true; $config['migration_enabled'] = TRUE;
/* /*
|-------------------------------------------------------------------------- |--------------------------------------------------------------------------

View file

@ -14,7 +14,7 @@ return [
'application/mac-binhex40', 'application/mac-binhex40',
'application/mac-binhex', 'application/mac-binhex',
'application/x-binhex40', 'application/x-binhex40',
'application/x-mac-binhex40' 'application/x-mac-binhex40',
], ],
'cpt' => 'application/mac-compactpro', 'cpt' => 'application/mac-compactpro',
'csv' => [ 'csv' => [
@ -28,14 +28,14 @@ return [
'application/csv', 'application/csv',
'application/excel', 'application/excel',
'application/vnd.msexcel', 'application/vnd.msexcel',
'text/plain' 'text/plain',
], ],
'bin' => [ 'bin' => [
'application/macbinary', 'application/macbinary',
'application/mac-binary', 'application/mac-binary',
'application/octet-stream', 'application/octet-stream',
'application/x-binary', 'application/x-binary',
'application/x-macbinary' 'application/x-macbinary',
], ],
'dms' => 'application/octet-stream', 'dms' => 'application/octet-stream',
'lha' => 'application/octet-stream', 'lha' => 'application/octet-stream',
@ -66,18 +66,18 @@ return [
'application/excel', 'application/excel',
'application/download', 'application/download',
'application/vnd.ms-office', 'application/vnd.ms-office',
'application/msword' 'application/msword',
], ],
'ppt' => [ 'ppt' => [
'application/powerpoint', 'application/powerpoint',
'application/vnd.ms-powerpoint', 'application/vnd.ms-powerpoint',
'application/vnd.ms-office', 'application/vnd.ms-office',
'application/msword' 'application/msword',
], ],
'pptx' => [ 'pptx' => [
'application/vnd.openxmlformats-officedocument.presentationml.presentation', 'application/vnd.openxmlformats-officedocument.presentationml.presentation',
'application/x-zip', 'application/x-zip',
'application/zip' 'application/zip',
], ],
'wbxml' => 'application/wbxml', 'wbxml' => 'application/wbxml',
'wmlc' => 'application/wmlc', 'wmlc' => 'application/wmlc',
@ -94,7 +94,7 @@ return [
'application/x-php', 'application/x-php',
'text/php', 'text/php',
'text/x-php', 'text/x-php',
'application/x-httpd-php-source' 'application/x-httpd-php-source',
], ],
'php4' => 'application/x-httpd-php', 'php4' => 'application/x-httpd-php',
'php3' => 'application/x-httpd-php', 'php3' => 'application/x-httpd-php',
@ -113,7 +113,7 @@ return [
'application/zip', 'application/zip',
'application/x-zip-compressed', 'application/x-zip-compressed',
'application/s-compressed', 'application/s-compressed',
'multipart/x-zip' 'multipart/x-zip',
], ],
'rar' => ['application/x-rar', 'application/rar', 'application/x-rar-compressed'], 'rar' => ['application/x-rar', 'application/rar', 'application/x-rar-compressed'],
'mid' => 'audio/midi', 'mid' => 'audio/midi',
@ -141,7 +141,7 @@ return [
'image/x-ms-bmp', 'image/x-ms-bmp',
'application/bmp', 'application/bmp',
'application/x-bmp', 'application/x-bmp',
'application/x-win-bitmap' 'application/x-win-bitmap',
], ],
'gif' => 'image/gif', 'gif' => 'image/gif',
'jpeg' => ['image/jpeg', 'image/pjpeg'], 'jpeg' => ['image/jpeg', 'image/pjpeg'],
@ -181,20 +181,20 @@ return [
'application/vnd.openxmlformats-officedocument.wordprocessingml.document', 'application/vnd.openxmlformats-officedocument.wordprocessingml.document',
'application/zip', 'application/zip',
'application/msword', 'application/msword',
'application/x-zip' 'application/x-zip',
], ],
'dot' => ['application/msword', 'application/vnd.ms-office'], 'dot' => ['application/msword', 'application/vnd.ms-office'],
'dotx' => [ 'dotx' => [
'application/vnd.openxmlformats-officedocument.wordprocessingml.document', 'application/vnd.openxmlformats-officedocument.wordprocessingml.document',
'application/zip', 'application/zip',
'application/msword' 'application/msword',
], ],
'xlsx' => [ 'xlsx' => [
'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet', 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet',
'application/zip', 'application/zip',
'application/vnd.ms-excel', 'application/vnd.ms-excel',
'application/msword', 'application/msword',
'application/x-zip' 'application/x-zip',
], ],
'word' => ['application/msword', 'application/octet-stream'], 'word' => ['application/msword', 'application/octet-stream'],
'xl' => 'application/excel', 'xl' => 'application/excel',
@ -245,14 +245,14 @@ return [
'application/x-compressed', 'application/x-compressed',
'application/x-zip-compressed', 'application/x-zip-compressed',
'application/zip', 'application/zip',
'multipart/x-zip' 'multipart/x-zip',
], ],
'7zip' => [ '7zip' => [
'application/x-7z-compressed', 'application/x-7z-compressed',
'application/x-compressed', 'application/x-compressed',
'application/x-zip-compressed', 'application/x-zip-compressed',
'application/zip', 'application/zip',
'multipart/x-zip' 'multipart/x-zip',
], ],
'cdr' => [ 'cdr' => [
'application/cdr', 'application/cdr',
@ -261,14 +261,14 @@ return [
'application/x-coreldraw', 'application/x-coreldraw',
'image/cdr', 'image/cdr',
'image/x-cdr', 'image/x-cdr',
'zz-application/zz-winassoc-cdr' 'zz-application/zz-winassoc-cdr',
], ],
'wma' => ['audio/x-ms-wma', 'video/x-ms-asf'], 'wma' => ['audio/x-ms-wma', 'video/x-ms-asf'],
'jar' => [ 'jar' => [
'application/java-archive', 'application/java-archive',
'application/x-java-application', 'application/x-java-application',
'application/x-jar', 'application/x-jar',
'application/x-compressed' 'application/x-compressed',
], ],
'svg' => ['image/svg+xml', 'application/xml', 'text/xml'], 'svg' => ['image/svg+xml', 'application/xml', 'text/xml'],
'vcf' => 'text/x-vcard', 'vcf' => 'text/x-vcard',
@ -290,5 +290,5 @@ return [
'odt' => 'application/vnd.oasis.opendocument.text', 'odt' => 'application/vnd.oasis.opendocument.text',
'odm' => 'application/vnd.oasis.opendocument.text-master', 'odm' => 'application/vnd.oasis.opendocument.text-master',
'ott' => 'application/vnd.oasis.opendocument.text-template', 'ott' => 'application/vnd.oasis.opendocument.text-template',
'oth' => 'application/vnd.oasis.opendocument.text-web' 'oth' => 'application/vnd.oasis.opendocument.text-web',
]; ];

View file

@ -55,7 +55,7 @@ $route['default_controller'] = 'booking';
$route['404_override'] = ''; $route['404_override'] = '';
$route['translate_uri_dashes'] = false; $route['translate_uri_dashes'] = FALSE;
/* /*
| ------------------------------------------------------------------------- | -------------------------------------------------------------------------
@ -86,16 +86,19 @@ header('Access-Control-Allow-Origin: ' . ($_SERVER['HTTP_ORIGIN'] ?? '*')); // N
header('Access-Control-Allow-Credentials: "true"'); header('Access-Control-Allow-Credentials: "true"');
if (isset($_SERVER['HTTP_ACCESS_CONTROL_REQUEST_METHOD'])) { if (isset($_SERVER['HTTP_ACCESS_CONTROL_REQUEST_METHOD']))
{
// May also be using PUT, PATCH, HEAD etc // May also be using PUT, PATCH, HEAD etc
header('Access-Control-Allow-Methods: GET, POST, PUT, PATCH, DELETE, OPTIONS, HEAD'); header('Access-Control-Allow-Methods: GET, POST, PUT, PATCH, DELETE, OPTIONS, HEAD');
} }
if (isset($_SERVER['HTTP_ACCESS_CONTROL_REQUEST_HEADERS'])) { if (isset($_SERVER['HTTP_ACCESS_CONTROL_REQUEST_HEADERS']))
{
header('Access-Control-Allow-Headers: ' . $_SERVER['HTTP_ACCESS_CONTROL_REQUEST_HEADERS']); header('Access-Control-Allow-Headers: ' . $_SERVER['HTTP_ACCESS_CONTROL_REQUEST_HEADERS']);
} }
if (isset($_SERVER['REQUEST_METHOD']) && $_SERVER['REQUEST_METHOD'] === 'OPTIONS') { if (isset($_SERVER['REQUEST_METHOD']) && $_SERVER['REQUEST_METHOD'] === 'OPTIONS')
{
exit(0); exit(0);
} }

View file

@ -13,7 +13,7 @@
$route['default_controller'] = 'test/index'; $route['default_controller'] = 'test/index';
$route['404_override'] = 'test/index'; // when in doubt, use the hammer $route['404_override'] = 'test/index'; // when in doubt, use the hammer
$route['translate_uri_dashes'] = false; $route['translate_uri_dashes'] = FALSE;
/* End of file routes.php */ /* End of file routes.php */
/* Location: ./application/config/testing/routes.php */ /* Location: ./application/config/testing/routes.php */

View file

@ -64,14 +64,14 @@ class About extends EA_Controller
script_vars([ script_vars([
'user_id' => $user_id, 'user_id' => $user_id,
'role_slug' => $role_slug 'role_slug' => $role_slug,
]); ]);
html_vars([ html_vars([
'page_title' => lang('settings'), 'page_title' => lang('settings'),
'active_menu' => PRIV_SYSTEM_SETTINGS, 'active_menu' => PRIV_SYSTEM_SETTINGS,
'user_display_name' => $this->accounts->get_user_display_name($user_id), 'user_display_name' => $this->accounts->get_user_display_name($user_id),
'privileges' => $this->roles_model->get_permissions_by_slug($role_slug) 'privileges' => $this->roles_model->get_permissions_by_slug($role_slug),
]); ]);
$this->load->view('pages/about'); $this->load->view('pages/about');

View file

@ -63,14 +63,14 @@ class Account extends EA_Controller
$account = $this->users_model->find($user_id); $account = $this->users_model->find($user_id);
script_vars([ script_vars([
'account' => $account 'account' => $account,
]); ]);
html_vars([ html_vars([
'page_title' => lang('settings'), 'page_title' => lang('settings'),
'active_menu' => PRIV_SYSTEM_SETTINGS, 'active_menu' => PRIV_SYSTEM_SETTINGS,
'user_display_name' => $this->accounts->get_user_display_name($user_id), 'user_display_name' => $this->accounts->get_user_display_name($user_id),
'grouped_timezones' => $this->timezones->to_grouped_array() 'grouped_timezones' => $this->timezones->to_grouped_array(),
]); ]);
$this->load->view('pages/account'); $this->load->view('pages/account');
@ -104,7 +104,7 @@ class Account extends EA_Controller
'notes', 'notes',
'timezone', 'timezone',
'language', 'language',
'settings' 'settings',
]); ]);
$this->users_model->only($account['settings'], ['username', 'password', 'notifications', 'calendar_view']); $this->users_model->only($account['settings'], ['username', 'password', 'notifications', 'calendar_view']);
@ -119,7 +119,7 @@ class Account extends EA_Controller
'user_email' => $account['email'], 'user_email' => $account['email'],
'username' => $account['settings']['username'], 'username' => $account['settings']['username'],
'timezone' => $account['timezone'], 'timezone' => $account['timezone'],
'language' => $account['language'] 'language' => $account['language'],
]); ]);
response(); response();
@ -141,7 +141,7 @@ class Account extends EA_Controller
$is_valid = $this->users_model->validate_username($username, $user_id); $is_valid = $this->users_model->validate_username($username, $user_id);
json_response([ json_response([
'is_valid' => $is_valid 'is_valid' => $is_valid,
]); ]);
} catch (Throwable $e) { } catch (Throwable $e) {
json_exception($e); json_exception($e);

View file

@ -63,7 +63,7 @@ class Admins extends EA_Controller
'user_id' => $user_id, 'user_id' => $user_id,
'role_slug' => $role_slug, 'role_slug' => $role_slug,
'timezones' => $this->timezones->to_array(), 'timezones' => $this->timezones->to_array(),
'min_password_length' => MIN_PASSWORD_LENGTH 'min_password_length' => MIN_PASSWORD_LENGTH,
]); ]);
html_vars([ html_vars([
@ -71,7 +71,7 @@ class Admins extends EA_Controller
'active_menu' => PRIV_USERS, 'active_menu' => PRIV_USERS,
'user_display_name' => $this->accounts->get_user_display_name($user_id), 'user_display_name' => $this->accounts->get_user_display_name($user_id),
'grouped_timezones' => $this->timezones->to_grouped_array(), 'grouped_timezones' => $this->timezones->to_grouped_array(),
'privileges' => $this->roles_model->get_permissions_by_slug($role_slug) 'privileges' => $this->roles_model->get_permissions_by_slug($role_slug),
]); ]);
$this->load->view('pages/admins'); $this->load->view('pages/admins');
@ -128,7 +128,7 @@ class Admins extends EA_Controller
'notes', 'notes',
'timezone', 'timezone',
'language', 'language',
'settings' 'settings',
]); ]);
$this->admins_model->only($admin['settings'], ['username', 'password', 'notifications', 'calendar_view']); $this->admins_model->only($admin['settings'], ['username', 'password', 'notifications', 'calendar_view']);
@ -141,7 +141,7 @@ class Admins extends EA_Controller
json_response([ json_response([
'success' => true, 'success' => true,
'id' => $admin_id 'id' => $admin_id,
]); ]);
} catch (Throwable $e) { } catch (Throwable $e) {
json_exception($e); json_exception($e);
@ -194,7 +194,7 @@ class Admins extends EA_Controller
'notes', 'notes',
'timezone', 'timezone',
'language', 'language',
'settings' 'settings',
]); ]);
$this->admins_model->only($admin['settings'], ['username', 'password', 'notifications', 'calendar_view']); $this->admins_model->only($admin['settings'], ['username', 'password', 'notifications', 'calendar_view']);
@ -207,7 +207,7 @@ class Admins extends EA_Controller
json_response([ json_response([
'success' => true, 'success' => true,
'id' => $admin_id 'id' => $admin_id,
]); ]);
} catch (Throwable $e) { } catch (Throwable $e) {
json_exception($e); json_exception($e);
@ -233,7 +233,7 @@ class Admins extends EA_Controller
$this->webhooks_client->trigger(WEBHOOK_ADMIN_DELETE, $admin); $this->webhooks_client->trigger(WEBHOOK_ADMIN_DELETE, $admin);
json_response([ json_response([
'success' => true 'success' => true,
]); ]);
} catch (Throwable $e) { } catch (Throwable $e) {
json_exception($e); json_exception($e);

View file

@ -56,13 +56,13 @@ class Api_settings extends EA_Controller
script_vars([ script_vars([
'user_id' => $user_id, 'user_id' => $user_id,
'role_slug' => $role_slug, 'role_slug' => $role_slug,
'api_settings' => $this->settings_model->get('name like "api_%"') 'api_settings' => $this->settings_model->get('name like "api_%"'),
]); ]);
html_vars([ html_vars([
'page_title' => lang('api'), 'page_title' => lang('api'),
'active_menu' => PRIV_SYSTEM_SETTINGS, 'active_menu' => PRIV_SYSTEM_SETTINGS,
'user_display_name' => $this->accounts->get_user_display_name($user_id) 'user_display_name' => $this->accounts->get_user_display_name($user_id),
]); ]);
$this->load->view('pages/api_settings'); $this->load->view('pages/api_settings');

View file

@ -97,7 +97,7 @@ class Appointments extends EA_Controller
'is_unavailability', 'is_unavailability',
'id_users_provider', 'id_users_provider',
'id_users_customer', 'id_users_customer',
'id_services' 'id_services',
]); ]);
$appointment_id = $this->appointments_model->save($appointment); $appointment_id = $this->appointments_model->save($appointment);
@ -108,7 +108,7 @@ class Appointments extends EA_Controller
json_response([ json_response([
'success' => true, 'success' => true,
'id' => $appointment_id 'id' => $appointment_id,
]); ]);
} catch (Throwable $e) { } catch (Throwable $e) {
json_exception($e); json_exception($e);
@ -157,14 +157,14 @@ class Appointments extends EA_Controller
'is_unavailability', 'is_unavailability',
'id_users_provider', 'id_users_provider',
'id_users_customer', 'id_users_customer',
'id_services' 'id_services',
]); ]);
$appointment_id = $this->appointments_model->save($appointment); $appointment_id = $this->appointments_model->save($appointment);
json_response([ json_response([
'success' => true, 'success' => true,
'id' => $appointment_id 'id' => $appointment_id,
]); ]);
} catch (Throwable $e) { } catch (Throwable $e) {
json_exception($e); json_exception($e);
@ -190,7 +190,7 @@ class Appointments extends EA_Controller
$this->webhooks_client->trigger(WEBHOOK_APPOINTMENT_DELETE, $appointment); $this->webhooks_client->trigger(WEBHOOK_APPOINTMENT_DELETE, $appointment);
json_response([ json_response([
'success' => true 'success' => true,
]); ]);
} catch (Throwable $e) { } catch (Throwable $e) {
json_exception($e); json_exception($e);

View file

@ -64,7 +64,7 @@ class Blocked_periods extends EA_Controller
'role_slug' => $role_slug, 'role_slug' => $role_slug,
'date_format' => setting('date_format'), 'date_format' => setting('date_format'),
'time_format' => setting('time_format'), 'time_format' => setting('time_format'),
'first_weekday' => setting('first_weekday') 'first_weekday' => setting('first_weekday'),
]); ]);
html_vars([ html_vars([
@ -72,7 +72,7 @@ class Blocked_periods extends EA_Controller
'active_menu' => PRIV_BLOCKED_PERIODS, 'active_menu' => PRIV_BLOCKED_PERIODS,
'user_display_name' => $this->accounts->get_user_display_name($user_id), 'user_display_name' => $this->accounts->get_user_display_name($user_id),
'timezones' => $this->timezones->to_array(), 'timezones' => $this->timezones->to_array(),
'privileges' => $this->roles_model->get_permissions_by_slug($role_slug) 'privileges' => $this->roles_model->get_permissions_by_slug($role_slug),
]); ]);
$this->load->view('pages/blocked_periods'); $this->load->view('pages/blocked_periods');
@ -126,7 +126,7 @@ class Blocked_periods extends EA_Controller
json_response([ json_response([
'success' => true, 'success' => true,
'id' => $blocked_period_id 'id' => $blocked_period_id,
]); ]);
} catch (Throwable $e) { } catch (Throwable $e) {
json_exception($e); json_exception($e);
@ -170,7 +170,7 @@ class Blocked_periods extends EA_Controller
'name', 'name',
'start_datetime', 'start_datetime',
'end_datetime', 'end_datetime',
'notes' 'notes',
]); ]);
$blocked_period_id = $this->blocked_periods_model->save($blocked_period); $blocked_period_id = $this->blocked_periods_model->save($blocked_period);
@ -181,7 +181,7 @@ class Blocked_periods extends EA_Controller
json_response([ json_response([
'success' => true, 'success' => true,
'id' => $blocked_period_id 'id' => $blocked_period_id,
]); ]);
} catch (Throwable $e) { } catch (Throwable $e) {
json_exception($e); json_exception($e);
@ -207,7 +207,7 @@ class Blocked_periods extends EA_Controller
$this->webhooks_client->trigger(WEBHOOK_BLOCKED_PERIOD_DELETE, $blocked_period); $this->webhooks_client->trigger(WEBHOOK_BLOCKED_PERIOD_DELETE, $blocked_period);
json_response([ json_response([
'success' => true 'success' => true,
]); ]);
} catch (Throwable $e) { } catch (Throwable $e) {
json_exception($e); json_exception($e);

View file

@ -91,7 +91,7 @@ class Booking extends EA_Controller
'message_text' => $disable_booking_message, 'message_text' => $disable_booking_message,
'message_icon' => base_url('assets/img/error.png'), 'message_icon' => base_url('assets/img/error.png'),
'google_analytics_code' => $google_analytics_code, 'google_analytics_code' => $google_analytics_code,
'matomo_analytics_url' => $matomo_analytics_url 'matomo_analytics_url' => $matomo_analytics_url,
]); ]);
$this->load->view('pages/booking_message'); $this->load->view('pages/booking_message');
@ -110,7 +110,7 @@ class Booking extends EA_Controller
'first_name', 'first_name',
'last_name', 'last_name',
'services', 'services',
'timezone' 'timezone',
]); ]);
} }
@ -169,7 +169,7 @@ class Booking extends EA_Controller
'message_text' => lang('appointment_does_not_exist_in_db'), 'message_text' => lang('appointment_does_not_exist_in_db'),
'message_icon' => base_url('assets/img/error.png'), 'message_icon' => base_url('assets/img/error.png'),
'google_analytics_code' => $google_analytics_code, 'google_analytics_code' => $google_analytics_code,
'matomo_analytics_url' => $matomo_analytics_url 'matomo_analytics_url' => $matomo_analytics_url,
]); ]);
$this->load->view('pages/booking_message'); $this->load->view('pages/booking_message');
@ -193,11 +193,11 @@ class Booking extends EA_Controller
'page_title' => lang('page_title') . ' ' . $company_name, 'page_title' => lang('page_title') . ' ' . $company_name,
'message_title' => lang('appointment_locked'), 'message_title' => lang('appointment_locked'),
'message_text' => strtr(lang('appointment_locked_message'), [ 'message_text' => strtr(lang('appointment_locked_message'), [
'{$limit}' => sprintf('%02d:%02d', $hours, $minutes) '{$limit}' => sprintf('%02d:%02d', $hours, $minutes),
]), ]),
'message_icon' => base_url('assets/img/error.png'), 'message_icon' => base_url('assets/img/error.png'),
'google_analytics_code' => $google_analytics_code, 'google_analytics_code' => $google_analytics_code,
'matomo_analytics_url' => $matomo_analytics_url 'matomo_analytics_url' => $matomo_analytics_url,
]); ]);
$this->load->view('pages/booking_message'); $this->load->view('pages/booking_message');
@ -232,7 +232,7 @@ class Booking extends EA_Controller
'future_booking_limit' => setting('future_booking_limit'), 'future_booking_limit' => setting('future_booking_limit'),
'appointment_data' => $appointment, 'appointment_data' => $appointment,
'provider_data' => $provider, 'provider_data' => $provider,
'customer_data' => $customer 'customer_data' => $customer,
]); ]);
html_vars([ html_vars([
@ -278,7 +278,7 @@ class Booking extends EA_Controller
'customer_token' => $customer_token, 'customer_token' => $customer_token,
'appointment_data' => $appointment, 'appointment_data' => $appointment,
'provider_data' => $provider, 'provider_data' => $provider,
'customer_data' => $customer 'customer_data' => $customer,
]); ]);
$this->load->view('pages/booking'); $this->load->view('pages/booking');
@ -290,6 +290,12 @@ class Booking extends EA_Controller
public function register() public function register()
{ {
try { try {
$disable_booking = setting('disable_booking');
if ($disable_booking) {
abort(403);
}
$post_data = request('post_data'); $post_data = request('post_data');
$captcha = request('captcha'); $captcha = request('captcha');
$appointment = $post_data['appointment']; $appointment = $post_data['appointment'];
@ -335,7 +341,7 @@ class Booking extends EA_Controller
if ($require_captcha && strtoupper($captcha_phrase) !== strtoupper($captcha)) { if ($require_captcha && strtoupper($captcha_phrase) !== strtoupper($captcha)) {
json_response([ json_response([
'captcha_verification' => false 'captcha_verification' => false,
]); ]);
return; return;
@ -347,7 +353,7 @@ class Booking extends EA_Controller
$existing_appointments = $this->appointments_model->get([ $existing_appointments = $this->appointments_model->get([
'id_users_customer' => $customer['id'], 'id_users_customer' => $customer['id'],
'start_datetime <=' => $appointment['start_datetime'], 'start_datetime <=' => $appointment['start_datetime'],
'end_datetime >=' => $appointment['end_datetime'] 'end_datetime >=' => $appointment['end_datetime'],
]); ]);
if (count($existing_appointments)) { if (count($existing_appointments)) {
@ -370,7 +376,7 @@ class Booking extends EA_Controller
'first_name' => $customer['first_name'] ?? '-', 'first_name' => $customer['first_name'] ?? '-',
'last_name' => $customer['last_name'] ?? '-', 'last_name' => $customer['last_name'] ?? '-',
'email' => $customer['email'] ?? '-', 'email' => $customer['email'] ?? '-',
'ip' => $customer_ip 'ip' => $customer_ip,
]; ];
if (setting('display_terms_and_conditions')) { if (setting('display_terms_and_conditions')) {
@ -399,7 +405,7 @@ class Booking extends EA_Controller
'state', 'state',
'zip_code', 'zip_code',
'timezone', 'timezone',
'language' 'language',
]); ]);
$customer_id = $this->customers_model->save($customer); $customer_id = $this->customers_model->save($customer);
@ -424,7 +430,7 @@ class Booking extends EA_Controller
'is_unavailability', 'is_unavailability',
'id_users_provider', 'id_users_provider',
'id_users_customer', 'id_users_customer',
'id_services' 'id_services',
]); ]);
$appointment_id = $this->appointments_model->save($appointment); $appointment_id = $this->appointments_model->save($appointment);
@ -435,7 +441,7 @@ class Booking extends EA_Controller
'company_link' => setting('company_link'), 'company_link' => setting('company_link'),
'company_email' => setting('company_email'), 'company_email' => setting('company_email'),
'date_format' => setting('date_format'), 'date_format' => setting('date_format'),
'time_format' => setting('time_format') 'time_format' => setting('time_format'),
]; ];
$this->synchronization->sync_appointment_saved($appointment, $service, $provider, $customer, $settings); $this->synchronization->sync_appointment_saved($appointment, $service, $provider, $customer, $settings);
@ -446,14 +452,14 @@ class Booking extends EA_Controller
$provider, $provider,
$customer, $customer,
$settings, $settings,
$manage_mode $manage_mode,
); );
$this->webhooks_client->trigger(WEBHOOK_APPOINTMENT_SAVE, $appointment); $this->webhooks_client->trigger(WEBHOOK_APPOINTMENT_SAVE, $appointment);
$response = [ $response = [
'appointment_id' => $appointment['id'], 'appointment_id' => $appointment['id'],
'appointment_hash' => $appointment['hash'] 'appointment_hash' => $appointment['hash'],
]; ];
json_response($response); json_response($response);
@ -504,7 +510,7 @@ class Booking extends EA_Controller
$date, $date,
$service, $service,
$provider, $provider,
$exclude_appointment_id $exclude_appointment_id,
); );
$is_still_available = false; $is_still_available = false;
@ -574,6 +580,12 @@ class Booking extends EA_Controller
public function get_available_hours() public function get_available_hours()
{ {
try { try {
$disable_booking = setting('disable_booking');
if ($disable_booking) {
abort(403);
}
$provider_id = request('provider_id'); $provider_id = request('provider_id');
$service_id = request('service_id'); $service_id = request('service_id');
$selected_date = request('selected_date'); $selected_date = request('selected_date');
@ -610,7 +622,7 @@ class Booking extends EA_Controller
$selected_date, $selected_date,
$service, $service,
$provider, $provider,
$exclude_appointment_id $exclude_appointment_id,
); );
$available_hours = array_merge($available_hours, $provider_available_hours); $available_hours = array_merge($available_hours, $provider_available_hours);
@ -628,7 +640,7 @@ class Booking extends EA_Controller
$selected_date, $selected_date,
$service, $service,
$provider, $provider,
$exclude_appointment_id $exclude_appointment_id,
); );
} }
@ -650,6 +662,12 @@ class Booking extends EA_Controller
public function get_unavailable_dates() public function get_unavailable_dates()
{ {
try { try {
$disable_booking = setting('disable_booking');
if ($disable_booking) {
abort(403);
}
$provider_id = request('provider_id'); $provider_id = request('provider_id');
$service_id = request('service_id'); $service_id = request('service_id');
$appointment_id = request('appointment_id'); $appointment_id = request('appointment_id');
@ -684,7 +702,7 @@ class Booking extends EA_Controller
$current_date->format('Y-m-d'), $current_date->format('Y-m-d'),
$service, $service,
$provider, $provider,
$exclude_appointment_id $exclude_appointment_id,
); );
if (!empty($available_hours)) { if (!empty($available_hours)) {
@ -700,7 +718,7 @@ class Booking extends EA_Controller
if (count($unavailable_dates) === $number_of_days_in_month) { if (count($unavailable_dates) === $number_of_days_in_month) {
json_response([ json_response([
'is_month_unavailable' => true 'is_month_unavailable' => true,
]); ]);
return; return;

View file

@ -49,6 +49,12 @@ class Booking_cancellation extends EA_Controller
public function of(string $appointment_hash) public function of(string $appointment_hash)
{ {
try { try {
$disable_booking = setting('disable_booking');
if ($disable_booking) {
abort(403);
}
$cancellation_reason = request('cancellation_reason'); $cancellation_reason = request('cancellation_reason');
if ($this->input->method() !== 'post' || empty($cancellation_reason)) { if ($this->input->method() !== 'post' || empty($cancellation_reason)) {
@ -65,7 +71,7 @@ class Booking_cancellation extends EA_Controller
'message_text' => lang('appointment_does_not_exist_in_db'), 'message_text' => lang('appointment_does_not_exist_in_db'),
'message_icon' => base_url('assets/img/error.png'), 'message_icon' => base_url('assets/img/error.png'),
'google_analytics_code' => setting('google_analytics_code'), 'google_analytics_code' => setting('google_analytics_code'),
'matomo_analytics_url' => setting('matomo_analytics_url') 'matomo_analytics_url' => setting('matomo_analytics_url'),
]); ]);
$this->load->view('pages/booking_message'); $this->load->view('pages/booking_message');
@ -86,7 +92,7 @@ class Booking_cancellation extends EA_Controller
'company_email' => setting('company_email'), 'company_email' => setting('company_email'),
'company_link' => setting('company_link'), 'company_link' => setting('company_link'),
'date_format' => setting('date_format'), 'date_format' => setting('date_format'),
'time_format' => setting('time_format') 'time_format' => setting('time_format'),
]; ];
$this->appointments_model->delete($appointment['id']); $this->appointments_model->delete($appointment['id']);
@ -99,7 +105,7 @@ class Booking_cancellation extends EA_Controller
$provider, $provider,
$customer, $customer,
$settings, $settings,
$cancellation_reason $cancellation_reason,
); );
$this->webhooks_client->trigger(WEBHOOK_APPOINTMENT_DELETE, $appointment); $this->webhooks_client->trigger(WEBHOOK_APPOINTMENT_DELETE, $appointment);
@ -111,7 +117,7 @@ class Booking_cancellation extends EA_Controller
'page_title' => lang('appointment_cancelled_title'), 'page_title' => lang('appointment_cancelled_title'),
'company_color' => setting('company_color'), 'company_color' => setting('company_color'),
'google_analytics_code' => setting('google_analytics_code'), 'google_analytics_code' => setting('google_analytics_code'),
'matomo_analytics_url' => setting('matomo_analytics_url') 'matomo_analytics_url' => setting('matomo_analytics_url'),
]); ]);
$this->load->view('pages/booking_cancellation'); $this->load->view('pages/booking_cancellation');

View file

@ -61,7 +61,7 @@ class Booking_confirmation extends EA_Controller
'company_color' => setting('company_color'), 'company_color' => setting('company_color'),
'google_analytics_code' => setting('google_analytics_code'), 'google_analytics_code' => setting('google_analytics_code'),
'matomo_analytics_url' => setting('matomo_analytics_url'), 'matomo_analytics_url' => setting('matomo_analytics_url'),
'add_to_google_url' => $add_to_google_url 'add_to_google_url' => $add_to_google_url,
]); ]);
$this->load->view('pages/booking_confirmation'); $this->load->view('pages/booking_confirmation');

View file

@ -65,13 +65,13 @@ class Booking_settings extends EA_Controller
script_vars([ script_vars([
'user_id' => $user_id, 'user_id' => $user_id,
'role_slug' => $role_slug, 'role_slug' => $role_slug,
'booking_settings' => $this->settings_model->get_batch() 'booking_settings' => $this->settings_model->get_batch(),
]); ]);
html_vars([ html_vars([
'page_title' => lang('settings'), 'page_title' => lang('settings'),
'active_menu' => PRIV_SYSTEM_SETTINGS, 'active_menu' => PRIV_SYSTEM_SETTINGS,
'user_display_name' => $this->accounts->get_user_display_name($user_id) 'user_display_name' => $this->accounts->get_user_display_name($user_id),
]); ]);
$this->load->view('pages/booking_settings'); $this->load->view('pages/booking_settings');

View file

@ -67,13 +67,13 @@ class Business_settings extends EA_Controller
'role_slug' => $role_slug, 'role_slug' => $role_slug,
'business_settings' => $this->settings_model->get(), 'business_settings' => $this->settings_model->get(),
'first_weekday' => setting('first_weekday'), 'first_weekday' => setting('first_weekday'),
'time_format' => setting('time_format') 'time_format' => setting('time_format'),
]); ]);
html_vars([ html_vars([
'page_title' => lang('settings'), 'page_title' => lang('settings'),
'active_menu' => PRIV_SYSTEM_SETTINGS, 'active_menu' => PRIV_SYSTEM_SETTINGS,
'user_display_name' => $this->accounts->get_user_display_name($user_id) 'user_display_name' => $this->accounts->get_user_display_name($user_id),
]); ]);
$this->load->view('pages/business_settings'); $this->load->view('pages/business_settings');

View file

@ -112,7 +112,7 @@ class Calendar extends EA_Controller
$available_providers = array_values( $available_providers = array_values(
array_filter($available_providers, function ($available_provider) use ($user_id) { array_filter($available_providers, function ($available_provider) use ($user_id) {
return (int) $available_provider['id'] === (int) $user_id; return (int) $available_provider['id'] === (int) $user_id;
}) }),
); );
} }
@ -120,7 +120,7 @@ class Calendar extends EA_Controller
$available_providers = array_values( $available_providers = array_values(
array_filter($available_providers, function ($available_provider) use ($secretary_providers) { array_filter($available_providers, function ($available_provider) use ($secretary_providers) {
return in_array($available_provider['id'], $secretary_providers); return in_array($available_provider['id'], $secretary_providers);
}) }),
); );
} }
@ -144,7 +144,7 @@ class Calendar extends EA_Controller
'available_services' => $available_services, 'available_services' => $available_services,
'secretary_providers' => $secretary_providers, 'secretary_providers' => $secretary_providers,
'edit_appointment' => $edit_appointment, 'edit_appointment' => $edit_appointment,
'customers' => $this->customers_model->get(null, 50, null, 'update_datetime DESC') 'customers' => $this->customers_model->get(null, 50, null, 'update_datetime DESC'),
]); ]);
html_vars([ html_vars([
@ -167,7 +167,7 @@ class Calendar extends EA_Controller
'require_address' => setting('require_address'), 'require_address' => setting('require_address'),
'require_city' => setting('require_city'), 'require_city' => setting('require_city'),
'require_zip_code' => setting('require_zip_code'), 'require_zip_code' => setting('require_zip_code'),
'require_notes' => setting('require_notes') 'require_notes' => setting('require_notes'),
]); ]);
$this->load->view('pages/calendar'); $this->load->view('pages/calendar');
@ -208,7 +208,7 @@ class Calendar extends EA_Controller
'zip_code', 'zip_code',
'timezone', 'timezone',
'language', 'language',
'notes' 'notes',
]); ]);
$customer['id'] = $this->customers_model->save($customer); $customer['id'] = $this->customers_model->save($customer);
@ -250,7 +250,7 @@ class Calendar extends EA_Controller
'is_unavailability', 'is_unavailability',
'id_users_provider', 'id_users_provider',
'id_users_customer', 'id_users_customer',
'id_services' 'id_services',
]); ]);
$appointment['id'] = $this->appointments_model->save($appointment); $appointment['id'] = $this->appointments_model->save($appointment);
@ -270,7 +270,7 @@ class Calendar extends EA_Controller
'company_link' => setting('company_link'), 'company_link' => setting('company_link'),
'company_email' => setting('company_email'), 'company_email' => setting('company_email'),
'date_format' => setting('date_format'), 'date_format' => setting('date_format'),
'time_format' => setting('time_format') 'time_format' => setting('time_format'),
]; ];
$this->synchronization->sync_appointment_saved($appointment, $service, $provider, $customer, $settings); $this->synchronization->sync_appointment_saved($appointment, $service, $provider, $customer, $settings);
@ -281,13 +281,13 @@ class Calendar extends EA_Controller
$provider, $provider,
$customer, $customer,
$settings, $settings,
$manage_mode $manage_mode,
); );
$this->webhooks_client->trigger(WEBHOOK_APPOINTMENT_SAVE, $appointment); $this->webhooks_client->trigger(WEBHOOK_APPOINTMENT_SAVE, $appointment);
json_response([ json_response([
'success' => true 'success' => true,
]); ]);
} catch (Throwable $e) { } catch (Throwable $e) {
json_exception($e); json_exception($e);
@ -346,7 +346,7 @@ class Calendar extends EA_Controller
'company_email' => setting('company_email'), 'company_email' => setting('company_email'),
'company_link' => setting('company_link'), 'company_link' => setting('company_link'),
'date_format' => setting('date_format'), 'date_format' => setting('date_format'),
'time_format' => setting('time_format') 'time_format' => setting('time_format'),
]; ];
// Delete appointment record from the database. // Delete appointment record from the database.
@ -358,7 +358,7 @@ class Calendar extends EA_Controller
$provider, $provider,
$customer, $customer,
$settings, $settings,
$cancellation_reason $cancellation_reason,
); );
$this->synchronization->sync_appointment_deleted($appointment, $provider); $this->synchronization->sync_appointment_deleted($appointment, $provider);
@ -366,7 +366,7 @@ class Calendar extends EA_Controller
$this->webhooks_client->trigger(WEBHOOK_APPOINTMENT_DELETE, $appointment); $this->webhooks_client->trigger(WEBHOOK_APPOINTMENT_DELETE, $appointment);
json_response([ json_response([
'success' => true 'success' => true,
]); ]);
} catch (Throwable $e) { } catch (Throwable $e) {
json_exception($e); json_exception($e);
@ -406,7 +406,7 @@ class Calendar extends EA_Controller
json_response([ json_response([
'success' => true, 'success' => true,
'warnings' => $warnings ?? [] 'warnings' => $warnings ?? [],
]); ]);
} catch (Throwable $e) { } catch (Throwable $e) {
json_exception($e); json_exception($e);
@ -438,7 +438,7 @@ class Calendar extends EA_Controller
$this->webhooks_client->trigger(WEBHOOK_UNAVAILABILITY_DELETE, $unavailability); $this->webhooks_client->trigger(WEBHOOK_UNAVAILABILITY_DELETE, $unavailability);
json_response([ json_response([
'success' => true 'success' => true,
]); ]);
} catch (Throwable $e) { } catch (Throwable $e) {
json_exception($e); json_exception($e);
@ -468,7 +468,7 @@ class Calendar extends EA_Controller
$this->providers_model->save_working_plan_exception($provider_id, $date, $working_plan_exception); $this->providers_model->save_working_plan_exception($provider_id, $date, $working_plan_exception);
json_response([ json_response([
'success' => true 'success' => true,
]); ]);
} catch (Throwable $e) { } catch (Throwable $e) {
json_exception($e); json_exception($e);
@ -494,7 +494,7 @@ class Calendar extends EA_Controller
$this->providers_model->delete_working_plan_exception($provider_id, $date); $this->providers_model->delete_working_plan_exception($provider_id, $date);
json_response([ json_response([
'success' => true 'success' => true,
]); ]);
} catch (Throwable $e) { } catch (Throwable $e) {
json_exception($e); json_exception($e);
@ -522,12 +522,12 @@ class Calendar extends EA_Controller
$response = [ $response = [
'appointments' => $this->appointments_model->get([ 'appointments' => $this->appointments_model->get([
'start_datetime >=' => $start_date, 'start_datetime >=' => $start_date,
'end_datetime <=' => $end_date 'end_datetime <=' => $end_date,
]), ]),
'unavailabilities' => $this->unavailabilities_model->get([ 'unavailabilities' => $this->unavailabilities_model->get([
'start_datetime >=' => $start_date, 'start_datetime >=' => $start_date,
'end_datetime <=' => $end_date 'end_datetime <=' => $end_date,
]) ]),
]; ];
foreach ($response['appointments'] as &$appointment) { foreach ($response['appointments'] as &$appointment) {
@ -613,7 +613,7 @@ class Calendar extends EA_Controller
if (!$filter_type && $record_id !== FILTER_TYPE_ALL) { if (!$filter_type && $record_id !== FILTER_TYPE_ALL) {
json_response([ json_response([
'appointments' => [], 'appointments' => [],
'unavailabilities' => [] 'unavailabilities' => [],
]); ]);
return; return;

View file

@ -53,7 +53,7 @@ class Consents extends EA_Controller
// Do not create a new consent. // Do not create a new consent.
json_response([ json_response([
'success' => true 'success' => true,
]); ]);
return; return;
@ -64,7 +64,7 @@ class Consents extends EA_Controller
json_response([ json_response([
'success' => true, 'success' => true,
'id' => $consent['id'] 'id' => $consent['id'],
]); ]);
} catch (Throwable $e) { } catch (Throwable $e) {
json_exception($e); json_exception($e);

View file

@ -58,7 +58,7 @@ class Console extends EA_Controller
$password = $this->instance->seed(); $password = $this->instance->seed();
response( response(
PHP_EOL . '⇾ Installation completed, login with "administrator" / "' . $password . '".' . PHP_EOL . PHP_EOL PHP_EOL . '⇾ Installation completed, login with "administrator" / "' . $password . '".' . PHP_EOL . PHP_EOL,
); );
} }
@ -173,7 +173,7 @@ class Console extends EA_Controller
'⇾ php index.php console backup', '⇾ php index.php console backup',
'⇾ php index.php console sync', '⇾ php index.php console sync',
'', '',
'' '',
]; ];
response(implode(PHP_EOL, $help)); response(implode(PHP_EOL, $help));

View file

@ -86,7 +86,7 @@ class Customers extends EA_Controller
'date_format' => $date_format, 'date_format' => $date_format,
'time_format' => $time_format, 'time_format' => $time_format,
'timezones' => $this->timezones->to_array(), 'timezones' => $this->timezones->to_array(),
'secretary_providers' => $secretary_providers 'secretary_providers' => $secretary_providers,
]); ]);
html_vars([ html_vars([
@ -103,7 +103,7 @@ class Customers extends EA_Controller
'require_address' => $require_address, 'require_address' => $require_address,
'require_city' => $require_city, 'require_city' => $require_city,
'require_zip_code' => $require_zip_code, 'require_zip_code' => $require_zip_code,
'available_languages' => config('available_languages') 'available_languages' => config('available_languages'),
]); ]);
$this->load->view('pages/customers'); $this->load->view('pages/customers');
@ -211,7 +211,7 @@ class Customers extends EA_Controller
'custom_field_2', 'custom_field_2',
'custom_field_3', 'custom_field_3',
'custom_field_4', 'custom_field_4',
'custom_field_5' 'custom_field_5',
]); ]);
$customer_id = $this->customers_model->save($customer); $customer_id = $this->customers_model->save($customer);
@ -222,7 +222,7 @@ class Customers extends EA_Controller
json_response([ json_response([
'success' => true, 'success' => true,
'id' => $customer_id 'id' => $customer_id,
]); ]);
} catch (Throwable $e) { } catch (Throwable $e) {
json_exception($e); json_exception($e);
@ -264,7 +264,7 @@ class Customers extends EA_Controller
'custom_field_2', 'custom_field_2',
'custom_field_3', 'custom_field_3',
'custom_field_4', 'custom_field_4',
'custom_field_5' 'custom_field_5',
]); ]);
$customer_id = $this->customers_model->save($customer); $customer_id = $this->customers_model->save($customer);
@ -275,7 +275,7 @@ class Customers extends EA_Controller
json_response([ json_response([
'success' => true, 'success' => true,
'id' => $customer_id 'id' => $customer_id,
]); ]);
} catch (Throwable $e) { } catch (Throwable $e) {
json_exception($e); json_exception($e);
@ -307,7 +307,7 @@ class Customers extends EA_Controller
$this->webhooks_client->trigger(WEBHOOK_CUSTOMER_DELETE, $customer); $this->webhooks_client->trigger(WEBHOOK_CUSTOMER_DELETE, $customer);
json_response([ json_response([
'success' => true 'success' => true,
]); ]);
} catch (Throwable $e) { } catch (Throwable $e) {
json_exception($e); json_exception($e);

View file

@ -62,14 +62,14 @@ class General_settings extends EA_Controller
script_vars([ script_vars([
'user_id' => $user_id, 'user_id' => $user_id,
'role_slug' => $role_slug, 'role_slug' => $role_slug,
'general_settings' => $this->settings_model->get() 'general_settings' => $this->settings_model->get(),
]); ]);
html_vars([ html_vars([
'page_title' => lang('settings'), 'page_title' => lang('settings'),
'active_menu' => PRIV_SYSTEM_SETTINGS, 'active_menu' => PRIV_SYSTEM_SETTINGS,
'user_display_name' => $this->accounts->get_user_display_name($user_id), 'user_display_name' => $this->accounts->get_user_display_name($user_id),
'available_themes' => $available_themes 'available_themes' => $available_themes,
]); ]);
$this->load->view('pages/general_settings'); $this->load->view('pages/general_settings');

View file

@ -93,7 +93,7 @@ class Google extends EA_Controller
$where = [ $where = [
'start_datetime >=' => date('Y-m-d H:i:s', $start), 'start_datetime >=' => date('Y-m-d H:i:s', $start),
'end_datetime <=' => date('Y-m-d H:i:s', $end), 'end_datetime <=' => date('Y-m-d H:i:s', $end),
'id_users_provider' => $provider['id'] 'id_users_provider' => $provider['id'],
]; ];
$appointments = $CI->appointments_model->get($where); $appointments = $CI->appointments_model->get($where);
@ -105,7 +105,7 @@ class Google extends EA_Controller
$settings = [ $settings = [
'company_name' => setting('company_name'), 'company_name' => setting('company_name'),
'company_link' => setting('company_link'), 'company_link' => setting('company_link'),
'company_email' => setting('company_email') 'company_email' => setting('company_email'),
]; ];
$provider_timezone = new DateTimeZone($provider['timezone']); $provider_timezone = new DateTimeZone($provider['timezone']);
@ -129,7 +129,7 @@ class Google extends EA_Controller
$provider, $provider,
$service, $service,
$customer, $customer,
$settings $settings,
); );
$local_event['id_google_calendar'] = $google_event->getId(); $local_event['id_google_calendar'] = $google_event->getId();
@ -152,11 +152,11 @@ class Google extends EA_Controller
$local_event_start = strtotime($local_event['start_datetime']); $local_event_start = strtotime($local_event['start_datetime']);
$local_event_end = strtotime($local_event['end_datetime']); $local_event_end = strtotime($local_event['end_datetime']);
$google_event_start = new DateTime( $google_event_start = new DateTime(
$google_event->getStart()->getDateTime() ?? $google_event->getEnd()->getDate() $google_event->getStart()->getDateTime() ?? $google_event->getEnd()->getDate(),
); );
$google_event_start->setTimezone($provider_timezone); $google_event_start->setTimezone($provider_timezone);
$google_event_end = new DateTime( $google_event_end = new DateTime(
$google_event->getEnd()->getDateTime() ?? $google_event->getEnd()->getDate() $google_event->getEnd()->getDateTime() ?? $google_event->getEnd()->getDate(),
); );
$google_event_end->setTimezone($provider_timezone); $google_event_end->setTimezone($provider_timezone);
@ -223,7 +223,7 @@ class Google extends EA_Controller
} }
$unavailability_results = $CI->unavailabilities_model->get([ $unavailability_results = $CI->unavailabilities_model->get([
'id_google_calendar' => $google_event->getId() 'id_google_calendar' => $google_event->getId(),
]); ]);
if (!empty($unavailability_results)) { if (!empty($unavailability_results)) {
@ -240,19 +240,19 @@ class Google extends EA_Controller
'id_users_provider' => $provider_id, 'id_users_provider' => $provider_id,
'id_google_calendar' => $google_event->getId(), 'id_google_calendar' => $google_event->getId(),
'id_users_customer' => null, 'id_users_customer' => null,
'id_services' => null 'id_services' => null,
]; ];
$CI->unavailabilities_model->save($local_event); $CI->unavailabilities_model->save($local_event);
} }
json_response([ json_response([
'success' => true 'success' => true,
]); ]);
} catch (Throwable $e) { } catch (Throwable $e) {
log_message( log_message(
'error', 'error',
'Google - Sync completed with an error (provider ID "' . $provider_id . '"): ' . $e->getMessage() 'Google - Sync completed with an error (provider ID "' . $provider_id . '"): ' . $e->getMessage(),
); );
json_exception($e); json_exception($e);
@ -348,7 +348,7 @@ class Google extends EA_Controller
if (!$google_sync) { if (!$google_sync) {
json_response([ json_response([
'success' => false 'success' => false,
]); ]);
return; return;
@ -387,7 +387,7 @@ class Google extends EA_Controller
$this->providers_model->set_setting($provider_id, 'google_calendar', $calendar_id); $this->providers_model->set_setting($provider_id, 'google_calendar', $calendar_id);
json_response([ json_response([
'success' => true 'success' => true,
]); ]);
} catch (Throwable $e) { } catch (Throwable $e) {
json_exception($e); json_exception($e);
@ -423,7 +423,7 @@ class Google extends EA_Controller
$this->appointments_model->clear_google_sync_ids($provider_id); $this->appointments_model->clear_google_sync_ids($provider_id);
json_response([ json_response([
'success' => true 'success' => true,
]); ]);
} catch (Throwable $e) { } catch (Throwable $e) {
json_exception($e); json_exception($e);

View file

@ -56,13 +56,13 @@ class Google_analytics_settings extends EA_Controller
script_vars([ script_vars([
'user_id' => $user_id, 'user_id' => $user_id,
'role_slug' => $role_slug, 'role_slug' => $role_slug,
'google_analytics_settings' => $this->settings_model->get('name like "google_analytics_%"') 'google_analytics_settings' => $this->settings_model->get('name like "google_analytics_%"'),
]); ]);
html_vars([ html_vars([
'page_title' => lang('google_analytics'), 'page_title' => lang('google_analytics'),
'active_menu' => PRIV_SYSTEM_SETTINGS, 'active_menu' => PRIV_SYSTEM_SETTINGS,
'user_display_name' => $this->accounts->get_user_display_name($user_id) 'user_display_name' => $this->accounts->get_user_display_name($user_id),
]); ]);
$this->load->view('pages/google_analytics_settings'); $this->load->view('pages/google_analytics_settings');

View file

@ -47,7 +47,7 @@ class Installation extends EA_Controller
} }
$this->load->view('pages/installation', [ $this->load->view('pages/installation', [
'base_url' => config('base_url') 'base_url' => config('base_url'),
]); ]);
} }
@ -80,14 +80,14 @@ class Installation extends EA_Controller
'user_email' => $admin['email'], 'user_email' => $admin['email'],
'role_slug' => DB_SLUG_ADMIN, 'role_slug' => DB_SLUG_ADMIN,
'timezone' => $admin['timezone'], 'timezone' => $admin['timezone'],
'username' => $admin['settings']['username'] 'username' => $admin['settings']['username'],
]); ]);
// Save company settings // Save company settings
setting([ setting([
'company_name' => $company['company_name'], 'company_name' => $company['company_name'],
'company_email' => $company['company_email'], 'company_email' => $company['company_email'],
'company_link' => $company['company_link'] 'company_link' => $company['company_link'],
]); ]);
// Service // Service
@ -97,7 +97,7 @@ class Installation extends EA_Controller
'price' => '0', 'price' => '0',
'currency' => '', 'currency' => '',
'availabilities_type' => 'flexible', 'availabilities_type' => 'flexible',
'attendants_number' => '1' 'attendants_number' => '1',
]); ]);
// Provider // Provider
@ -115,8 +115,8 @@ class Installation extends EA_Controller
'google_sync' => false, 'google_sync' => false,
'sync_past_days' => 30, 'sync_past_days' => 30,
'sync_future_days' => 90, 'sync_future_days' => 90,
'calendar_view' => CALENDAR_VIEW_DEFAULT 'calendar_view' => CALENDAR_VIEW_DEFAULT,
] ],
]); ]);
// Customer // Customer
@ -124,11 +124,11 @@ class Installation extends EA_Controller
'first_name' => 'James', 'first_name' => 'James',
'last_name' => 'Doe', 'last_name' => 'Doe',
'email' => 'james@example.org', 'email' => 'james@example.org',
'phone_number' => '+1 (000) 000-0000' 'phone_number' => '+1 (000) 000-0000',
]); ]);
json_response([ json_response([
'success' => true 'success' => true,
]); ]);
} catch (Throwable $e) { } catch (Throwable $e) {
json_exception($e); json_exception($e);

View file

@ -66,7 +66,7 @@ class Integrations extends EA_Controller
'page_title' => lang('integrations'), 'page_title' => lang('integrations'),
'active_menu' => PRIV_SYSTEM_SETTINGS, 'active_menu' => PRIV_SYSTEM_SETTINGS,
'user_display_name' => $this->accounts->get_user_display_name($user_id), 'user_display_name' => $this->accounts->get_user_display_name($user_id),
'privileges' => $this->roles_model->get_permissions_by_slug($role_slug) 'privileges' => $this->roles_model->get_permissions_by_slug($role_slug),
]); ]);
$this->load->view('pages/integrations'); $this->load->view('pages/integrations');

View file

@ -56,13 +56,13 @@ class Legal_settings extends EA_Controller
script_vars([ script_vars([
'user_id' => $user_id, 'user_id' => $user_id,
'role_slug' => $role_slug, 'role_slug' => $role_slug,
'legal_settings' => $this->settings_model->get() 'legal_settings' => $this->settings_model->get(),
]); ]);
html_vars([ html_vars([
'page_title' => lang('settings'), 'page_title' => lang('settings'),
'active_menu' => PRIV_SYSTEM_SETTINGS, 'active_menu' => PRIV_SYSTEM_SETTINGS,
'user_display_name' => $this->accounts->get_user_display_name($user_id) 'user_display_name' => $this->accounts->get_user_display_name($user_id),
]); ]);
$this->load->view('pages/legal_settings'); $this->load->view('pages/legal_settings');

View file

@ -35,7 +35,7 @@ class Localization extends EA_Controller
if (!in_array($language, config('available_languages'))) { if (!in_array($language, config('available_languages'))) {
throw new RuntimeException( throw new RuntimeException(
'Translations for the given language does not exist (' . request('language') . ').' 'Translations for the given language does not exist (' . request('language') . ').',
); );
} }
@ -46,7 +46,7 @@ class Localization extends EA_Controller
config(['language' => $language]); config(['language' => $language]);
json_response([ json_response([
'success' => true 'success' => true,
]); ]);
} catch (Throwable $e) { } catch (Throwable $e) {
json_exception($e); json_exception($e);

View file

@ -31,7 +31,7 @@ class Login extends EA_Controller
$this->load->library('email_messages'); $this->load->library('email_messages');
script_vars([ script_vars([
'dest_url' => session('dest_url', site_url('calendar')) 'dest_url' => session('dest_url', site_url('calendar')),
]); ]);
} }
@ -44,7 +44,7 @@ class Login extends EA_Controller
'page_title' => lang('login'), 'page_title' => lang('login'),
'base_url' => config('base_url'), 'base_url' => config('base_url'),
'dest_url' => session('dest_url', site_url('calendar')), 'dest_url' => session('dest_url', site_url('calendar')),
'company_name' => setting('company_name') 'company_name' => setting('company_name'),
]); ]);
$this->load->view('pages/login'); $this->load->view('pages/login');
@ -79,7 +79,7 @@ class Login extends EA_Controller
session($user_data); // Save data in the session. session($user_data); // Save data in the session.
json_response([ json_response([
'success' => true 'success' => true,
]); ]);
} catch (Throwable $e) { } catch (Throwable $e) {
json_exception($e); json_exception($e);

View file

@ -31,7 +31,7 @@ class Logout extends EA_Controller
html_vars([ html_vars([
'page_title' => lang('log_out'), 'page_title' => lang('log_out'),
'company_name' => $company_name 'company_name' => $company_name,
]); ]);
$this->load->view('pages/logout'); $this->load->view('pages/logout');

View file

@ -56,13 +56,13 @@ class Matomo_analytics_settings extends EA_Controller
script_vars([ script_vars([
'user_id' => $user_id, 'user_id' => $user_id,
'role_slug' => $role_slug, 'role_slug' => $role_slug,
'matomo_analytics_settings' => $this->settings_model->get('name like "matomo_analytics_%"') 'matomo_analytics_settings' => $this->settings_model->get('name like "matomo_analytics_%"'),
]); ]);
html_vars([ html_vars([
'page_title' => lang('matomo_analytics'), 'page_title' => lang('matomo_analytics'),
'active_menu' => PRIV_SYSTEM_SETTINGS, 'active_menu' => PRIV_SYSTEM_SETTINGS,
'user_display_name' => $this->accounts->get_user_display_name($user_id) 'user_display_name' => $this->accounts->get_user_display_name($user_id),
]); ]);
$this->load->view('pages/matomo_analytics_settings'); $this->load->view('pages/matomo_analytics_settings');

View file

@ -54,14 +54,14 @@ class Privacy extends EA_Controller
if (empty($customer_id)) { if (empty($customer_id)) {
throw new InvalidArgumentException( throw new InvalidArgumentException(
'Customer ID does not exist, please reload the page ' . 'and try again.' 'Customer ID does not exist, please reload the page ' . 'and try again.',
); );
} }
$this->customers_model->delete($customer_id); $this->customers_model->delete($customer_id);
json_response([ json_response([
'success' => true 'success' => true,
]); ]);
} catch (Throwable $e) { } catch (Throwable $e) {
json_exception($e); json_exception($e);

View file

@ -75,7 +75,7 @@ class Providers extends EA_Controller
'first_weekday' => setting('first_weekday'), 'first_weekday' => setting('first_weekday'),
'min_password_length' => MIN_PASSWORD_LENGTH, 'min_password_length' => MIN_PASSWORD_LENGTH,
'timezones' => $this->timezones->to_array(), 'timezones' => $this->timezones->to_array(),
'services' => $services 'services' => $services,
]); ]);
html_vars([ html_vars([
@ -84,7 +84,7 @@ class Providers extends EA_Controller
'user_display_name' => $this->accounts->get_user_display_name($user_id), 'user_display_name' => $this->accounts->get_user_display_name($user_id),
'grouped_timezones' => $this->timezones->to_grouped_array(), 'grouped_timezones' => $this->timezones->to_grouped_array(),
'privileges' => $this->roles_model->get_permissions_by_slug($role_slug), 'privileges' => $this->roles_model->get_permissions_by_slug($role_slug),
'services' => $this->services_model->get() 'services' => $this->services_model->get(),
]); ]);
$this->load->view('pages/providers'); $this->load->view('pages/providers');
@ -144,7 +144,7 @@ class Providers extends EA_Controller
'is_private', 'is_private',
'id_roles', 'id_roles',
'settings', 'settings',
'services' 'services',
]); ]);
$this->providers_model->only($provider['settings'], [ $this->providers_model->only($provider['settings'], [
@ -153,11 +153,11 @@ class Providers extends EA_Controller
'working_plan', 'working_plan',
'working_plan_exceptions', 'working_plan_exceptions',
'notifications', 'notifications',
'calendar_view' 'calendar_view',
]); ]);
$this->providers_model->optional($provider, [ $this->providers_model->optional($provider, [
'services' => [] 'services' => [],
]); ]);
$provider_id = $this->providers_model->save($provider); $provider_id = $this->providers_model->save($provider);
@ -168,7 +168,7 @@ class Providers extends EA_Controller
json_response([ json_response([
'success' => true, 'success' => true,
'id' => $provider_id 'id' => $provider_id,
]); ]);
} catch (Throwable $e) { } catch (Throwable $e) {
json_exception($e); json_exception($e);
@ -224,7 +224,7 @@ class Providers extends EA_Controller
'is_private', 'is_private',
'id_roles', 'id_roles',
'settings', 'settings',
'services' 'services',
]); ]);
$this->providers_model->only($provider['settings'], [ $this->providers_model->only($provider['settings'], [
@ -233,11 +233,11 @@ class Providers extends EA_Controller
'working_plan', 'working_plan',
'working_plan_exceptions', 'working_plan_exceptions',
'notifications', 'notifications',
'calendar_view' 'calendar_view',
]); ]);
$this->providers_model->optional($provider, [ $this->providers_model->optional($provider, [
'services' => [] 'services' => [],
]); ]);
$provider_id = $this->providers_model->save($provider); $provider_id = $this->providers_model->save($provider);
@ -248,7 +248,7 @@ class Providers extends EA_Controller
json_response([ json_response([
'success' => true, 'success' => true,
'id' => $provider_id 'id' => $provider_id,
]); ]);
} catch (Throwable $e) { } catch (Throwable $e) {
json_exception($e); json_exception($e);
@ -274,7 +274,7 @@ class Providers extends EA_Controller
$this->webhooks_client->trigger(WEBHOOK_PROVIDER_DELETE, $provider); $this->webhooks_client->trigger(WEBHOOK_PROVIDER_DELETE, $provider);
json_response([ json_response([
'success' => true 'success' => true,
]); ]);
} catch (Throwable $e) { } catch (Throwable $e) {
json_exception($e); json_exception($e);

View file

@ -41,7 +41,7 @@ class Recovery extends EA_Controller
html_vars([ html_vars([
'page_title' => lang('forgot_your_password'), 'page_title' => lang('forgot_your_password'),
'dest_url' => session('dest_url', site_url('backend')), 'dest_url' => session('dest_url', site_url('backend')),
'company_name' => $company_name 'company_name' => $company_name,
]); ]);
$this->load->view('pages/recovery'); $this->load->view('pages/recovery');
@ -71,14 +71,14 @@ class Recovery extends EA_Controller
$settings = [ $settings = [
'company_name' => setting('company_name'), 'company_name' => setting('company_name'),
'company_link' => setting('company_link'), 'company_link' => setting('company_link'),
'company_email' => setting('company_email') 'company_email' => setting('company_email'),
]; ];
$this->email_messages->send_password($new_password, $email, $settings); $this->email_messages->send_password($new_password, $email, $settings);
} }
json_response([ json_response([
'success' => true 'success' => true,
]); ]);
} catch (Throwable $e) { } catch (Throwable $e) {
json_exception($e); json_exception($e);

View file

@ -71,7 +71,7 @@ class Secretaries extends EA_Controller
'role_slug' => $role_slug, 'role_slug' => $role_slug,
'timezones' => $this->timezones->to_array(), 'timezones' => $this->timezones->to_array(),
'min_password_length' => MIN_PASSWORD_LENGTH, 'min_password_length' => MIN_PASSWORD_LENGTH,
'providers' => $providers 'providers' => $providers,
]); ]);
html_vars([ html_vars([
@ -80,7 +80,7 @@ class Secretaries extends EA_Controller
'user_display_name' => $this->accounts->get_user_display_name($user_id), 'user_display_name' => $this->accounts->get_user_display_name($user_id),
'grouped_timezones' => $this->timezones->to_grouped_array(), 'grouped_timezones' => $this->timezones->to_grouped_array(),
'privileges' => $this->roles_model->get_permissions_by_slug($role_slug), 'privileges' => $this->roles_model->get_permissions_by_slug($role_slug),
'providers' => $this->providers_model->get() 'providers' => $this->providers_model->get(),
]); ]);
$this->load->view('pages/secretaries'); $this->load->view('pages/secretaries');
@ -140,18 +140,18 @@ class Secretaries extends EA_Controller
'is_private', 'is_private',
'id_roles', 'id_roles',
'settings', 'settings',
'providers' 'providers',
]); ]);
$this->secretaries_model->only($secretary['settings'], [ $this->secretaries_model->only($secretary['settings'], [
'username', 'username',
'password', 'password',
'notifications', 'notifications',
'calendar_view' 'calendar_view',
]); ]);
$this->secretaries_model->optional($secretary, [ $this->secretaries_model->optional($secretary, [
'providers' => [] 'providers' => [],
]); ]);
$secretary_id = $this->secretaries_model->save($secretary); $secretary_id = $this->secretaries_model->save($secretary);
@ -162,7 +162,7 @@ class Secretaries extends EA_Controller
json_response([ json_response([
'success' => true, 'success' => true,
'id' => $secretary_id 'id' => $secretary_id,
]); ]);
} catch (Throwable $e) { } catch (Throwable $e) {
json_exception($e); json_exception($e);
@ -218,18 +218,18 @@ class Secretaries extends EA_Controller
'is_private', 'is_private',
'id_roles', 'id_roles',
'settings', 'settings',
'providers' 'providers',
]); ]);
$this->secretaries_model->only($secretary['settings'], [ $this->secretaries_model->only($secretary['settings'], [
'username', 'username',
'password', 'password',
'notifications', 'notifications',
'calendar_view' 'calendar_view',
]); ]);
$this->secretaries_model->optional($secretary, [ $this->secretaries_model->optional($secretary, [
'providers' => [] 'providers' => [],
]); ]);
$secretary_id = $this->secretaries_model->save($secretary); $secretary_id = $this->secretaries_model->save($secretary);
@ -240,7 +240,7 @@ class Secretaries extends EA_Controller
json_response([ json_response([
'success' => true, 'success' => true,
'id' => $secretary_id 'id' => $secretary_id,
]); ]);
} catch (Throwable $e) { } catch (Throwable $e) {
json_exception($e); json_exception($e);
@ -266,7 +266,7 @@ class Secretaries extends EA_Controller
$this->webhooks_client->trigger(WEBHOOK_SECRETARY_DELETE, $secretary); $this->webhooks_client->trigger(WEBHOOK_SECRETARY_DELETE, $secretary);
json_response([ json_response([
'success' => true 'success' => true,
]); ]);
} catch (Throwable $e) { } catch (Throwable $e) {
json_exception($e); json_exception($e);

View file

@ -61,7 +61,7 @@ class Service_categories extends EA_Controller
script_vars([ script_vars([
'user_id' => $user_id, 'user_id' => $user_id,
'role_slug' => $role_slug 'role_slug' => $role_slug,
]); ]);
html_vars([ html_vars([
@ -69,7 +69,7 @@ class Service_categories extends EA_Controller
'active_menu' => PRIV_SERVICES, 'active_menu' => PRIV_SERVICES,
'user_display_name' => $this->accounts->get_user_display_name($user_id), 'user_display_name' => $this->accounts->get_user_display_name($user_id),
'timezones' => $this->timezones->to_array(), 'timezones' => $this->timezones->to_array(),
'privileges' => $this->roles_model->get_permissions_by_slug($role_slug) 'privileges' => $this->roles_model->get_permissions_by_slug($role_slug),
]); ]);
$this->load->view('pages/service_categories'); $this->load->view('pages/service_categories');
@ -123,7 +123,7 @@ class Service_categories extends EA_Controller
json_response([ json_response([
'success' => true, 'success' => true,
'id' => $service_category_id 'id' => $service_category_id,
]); ]);
} catch (Throwable $e) { } catch (Throwable $e) {
json_exception($e); json_exception($e);
@ -172,7 +172,7 @@ class Service_categories extends EA_Controller
json_response([ json_response([
'success' => true, 'success' => true,
'id' => $service_category_id 'id' => $service_category_id,
]); ]);
} catch (Throwable $e) { } catch (Throwable $e) {
json_exception($e); json_exception($e);
@ -198,7 +198,7 @@ class Service_categories extends EA_Controller
$this->webhooks_client->trigger(WEBHOOK_SERVICE_CATEGORY_DELETE, $service_category); $this->webhooks_client->trigger(WEBHOOK_SERVICE_CATEGORY_DELETE, $service_category);
json_response([ json_response([
'success' => true 'success' => true,
]); ]);
} catch (Throwable $e) { } catch (Throwable $e) {
json_exception($e); json_exception($e);

View file

@ -62,7 +62,7 @@ class Services extends EA_Controller
script_vars([ script_vars([
'user_id' => $user_id, 'user_id' => $user_id,
'role_slug' => $role_slug, 'role_slug' => $role_slug,
'event_minimum_duration' => EVENT_MINIMUM_DURATION 'event_minimum_duration' => EVENT_MINIMUM_DURATION,
]); ]);
html_vars([ html_vars([
@ -70,7 +70,7 @@ class Services extends EA_Controller
'active_menu' => PRIV_SERVICES, 'active_menu' => PRIV_SERVICES,
'user_display_name' => $this->accounts->get_user_display_name($user_id), 'user_display_name' => $this->accounts->get_user_display_name($user_id),
'timezones' => $this->timezones->to_array(), 'timezones' => $this->timezones->to_array(),
'privileges' => $this->roles_model->get_permissions_by_slug($role_slug) 'privileges' => $this->roles_model->get_permissions_by_slug($role_slug),
]); ]);
$this->load->view('pages/services'); $this->load->view('pages/services');
@ -125,11 +125,11 @@ class Services extends EA_Controller
'availabilities_type', 'availabilities_type',
'attendants_number', 'attendants_number',
'is_private', 'is_private',
'id_service_categories' 'id_service_categories',
]); ]);
$this->services_model->optional($service, [ $this->services_model->optional($service, [
'id_service_categories' => null 'id_service_categories' => null,
]); ]);
$service_id = $this->services_model->save($service); $service_id = $this->services_model->save($service);
@ -140,7 +140,7 @@ class Services extends EA_Controller
json_response([ json_response([
'success' => true, 'success' => true,
'id' => $service_id 'id' => $service_id,
]); ]);
} catch (Throwable $e) { } catch (Throwable $e) {
json_exception($e); json_exception($e);
@ -191,11 +191,11 @@ class Services extends EA_Controller
'availabilities_type', 'availabilities_type',
'attendants_number', 'attendants_number',
'is_private', 'is_private',
'id_service_categories' 'id_service_categories',
]); ]);
$this->services_model->optional($service, [ $this->services_model->optional($service, [
'id_service_categories' => null 'id_service_categories' => null,
]); ]);
$service_id = $this->services_model->save($service); $service_id = $this->services_model->save($service);
@ -206,7 +206,7 @@ class Services extends EA_Controller
json_response([ json_response([
'success' => true, 'success' => true,
'id' => $service_id 'id' => $service_id,
]); ]);
} catch (Throwable $e) { } catch (Throwable $e) {
json_exception($e); json_exception($e);
@ -232,7 +232,7 @@ class Services extends EA_Controller
$this->webhooks_client->trigger(WEBHOOK_SERVICE_DELETE, $service); $this->webhooks_client->trigger(WEBHOOK_SERVICE_DELETE, $service);
json_response([ json_response([
'success' => true 'success' => true,
]); ]);
} catch (Throwable $e) { } catch (Throwable $e) {
json_exception($e); json_exception($e);

View file

@ -84,7 +84,7 @@ class Unavailabilities extends EA_Controller
'zip_code', 'zip_code',
'notes', 'notes',
'timezone', 'timezone',
'language' 'language',
]); ]);
$unavailability_id = $this->unavailabilities_model->save($unavailability); $unavailability_id = $this->unavailabilities_model->save($unavailability);
@ -99,7 +99,7 @@ class Unavailabilities extends EA_Controller
json_response([ json_response([
'success' => true, 'success' => true,
'id' => $unavailability_id 'id' => $unavailability_id,
]); ]);
} catch (Throwable $e) { } catch (Throwable $e) {
json_exception($e); json_exception($e);
@ -150,7 +150,7 @@ class Unavailabilities extends EA_Controller
json_response([ json_response([
'success' => true, 'success' => true,
'id' => $unavailability_id 'id' => $unavailability_id,
]); ]);
} catch (Throwable $e) { } catch (Throwable $e) {
json_exception($e); json_exception($e);
@ -176,7 +176,7 @@ class Unavailabilities extends EA_Controller
$this->webhooks_client->trigger(WEBHOOK_UNAVAILABILITY_DELETE, $unavailability); $this->webhooks_client->trigger(WEBHOOK_UNAVAILABILITY_DELETE, $unavailability);
json_response([ json_response([
'success' => true 'success' => true,
]); ]);
} catch (Throwable $e) { } catch (Throwable $e) {
json_exception($e); json_exception($e);

View file

@ -60,7 +60,7 @@ class Webhooks extends EA_Controller
script_vars([ script_vars([
'user_id' => $user_id, 'user_id' => $user_id,
'role_slug' => $role_slug 'role_slug' => $role_slug,
]); ]);
html_vars([ html_vars([
@ -87,8 +87,8 @@ class Webhooks extends EA_Controller
WEBHOOK_SECRETARY_SAVE, WEBHOOK_SECRETARY_SAVE,
WEBHOOK_SECRETARY_DELETE, WEBHOOK_SECRETARY_DELETE,
WEBHOOK_ADMIN_SAVE, WEBHOOK_ADMIN_SAVE,
WEBHOOK_ADMIN_DELETE WEBHOOK_ADMIN_DELETE,
] ],
]); ]);
$this->load->view('pages/webhooks'); $this->load->view('pages/webhooks');
@ -138,14 +138,14 @@ class Webhooks extends EA_Controller
'actions', 'actions',
'secret_token', 'secret_token',
'is_ssl_verified', 'is_ssl_verified',
'notes' 'notes',
]); ]);
$webhook_id = $this->webhooks_model->save($webhook); $webhook_id = $this->webhooks_model->save($webhook);
json_response([ json_response([
'success' => true, 'success' => true,
'id' => $webhook_id 'id' => $webhook_id,
]); ]);
} catch (Throwable $e) { } catch (Throwable $e) {
json_exception($e); json_exception($e);
@ -171,14 +171,14 @@ class Webhooks extends EA_Controller
'actions', 'actions',
'secret_token', 'secret_token',
'is_ssl_verified', 'is_ssl_verified',
'notes' 'notes',
]); ]);
$webhook_id = $this->webhooks_model->save($webhook); $webhook_id = $this->webhooks_model->save($webhook);
json_response([ json_response([
'success' => true, 'success' => true,
'id' => $webhook_id 'id' => $webhook_id,
]); ]);
} catch (Throwable $e) { } catch (Throwable $e) {
json_exception($e); json_exception($e);
@ -200,7 +200,7 @@ class Webhooks extends EA_Controller
$this->webhooks_model->delete($webhook_id); $this->webhooks_model->delete($webhook_id);
json_response([ json_response([
'success' => true 'success' => true,
]); ]);
} catch (Throwable $e) { } catch (Throwable $e) {
json_exception($e); json_exception($e);

View file

@ -150,15 +150,15 @@ class Appointments_api_v1 extends EA_Controller
if ($aggregates) { if ($aggregates) {
$appointment['service'] = $this->services_model->find( $appointment['service'] = $this->services_model->find(
$appointment['id_services'] ?? ($appointment['serviceId'] ?? null), $appointment['id_services'] ?? ($appointment['serviceId'] ?? null),
true true,
); );
$appointment['provider'] = $this->providers_model->find( $appointment['provider'] = $this->providers_model->find(
$appointment['id_users_provider'] ?? ($appointment['providerId'] ?? null), $appointment['id_users_provider'] ?? ($appointment['providerId'] ?? null),
true true,
); );
$appointment['customer'] = $this->customers_model->find( $appointment['customer'] = $this->customers_model->find(
$appointment['id_users_customer'] ?? ($appointment['customerId'] ?? null), $appointment['id_users_customer'] ?? ($appointment['customerId'] ?? null),
true true,
); );
$this->services_model->api_encode($appointment['service']); $this->services_model->api_encode($appointment['service']);
$this->providers_model->api_encode($appointment['provider']); $this->providers_model->api_encode($appointment['provider']);
@ -275,7 +275,7 @@ class Appointments_api_v1 extends EA_Controller
'company_email' => setting('company_email'), 'company_email' => setting('company_email'),
'company_link' => setting('company_link'), 'company_link' => setting('company_link'),
'date_format' => setting('date_format'), 'date_format' => setting('date_format'),
'time_format' => setting('time_format') 'time_format' => setting('time_format'),
]; ];
$this->synchronization->sync_appointment_saved($appointment, $service, $provider, $customer, $settings); $this->synchronization->sync_appointment_saved($appointment, $service, $provider, $customer, $settings);
@ -286,7 +286,7 @@ class Appointments_api_v1 extends EA_Controller
$provider, $provider,
$customer, $customer,
$settings, $settings,
$manage_mode $manage_mode,
); );
} }
@ -355,7 +355,7 @@ class Appointments_api_v1 extends EA_Controller
'company_email' => setting('company_email'), 'company_email' => setting('company_email'),
'company_link' => setting('company_link'), 'company_link' => setting('company_link'),
'date_format' => setting('date_format'), 'date_format' => setting('date_format'),
'time_format' => setting('time_format') 'time_format' => setting('time_format'),
]; ];
$this->appointments_model->delete($id); $this->appointments_model->delete($id);
@ -367,7 +367,7 @@ class Appointments_api_v1 extends EA_Controller
$service, $service,
$provider, $provider,
$customer, $customer,
$settings $settings,
); );
response('', 204); response('', 204);

View file

@ -78,7 +78,7 @@ class Settings_api_v1 extends EA_Controller
json_response([ json_response([
'name' => $name, 'name' => $name,
'value' => $value 'value' => $value,
]); ]);
} catch (Throwable $e) { } catch (Throwable $e) {
json_exception($e); json_exception($e);
@ -99,7 +99,7 @@ class Settings_api_v1 extends EA_Controller
json_response([ json_response([
'name' => $name, 'name' => $name,
'value' => $value 'value' => $value,
]); ]);
} catch (Throwable $e) { } catch (Throwable $e) {
json_exception($e); json_exception($e);

View file

@ -117,7 +117,7 @@ class EA_Controller extends CI_Controller
config([ config([
'language' => $session_language, 'language' => $session_language,
'language_code' => array_search($session_language, $language_codes) ?: 'en' 'language_code' => array_search($session_language, $language_codes) ?: 'en',
]); ]);
} }
@ -135,7 +135,7 @@ class EA_Controller extends CI_Controller
'index_page' => config('index_page'), 'index_page' => config('index_page'),
'available_languages' => config('available_languages'), 'available_languages' => config('available_languages'),
'language' => $this->lang->language, 'language' => $this->lang->language,
'csrf_token' => $this->security->get_csrf_hash() 'csrf_token' => $this->security->get_csrf_hash(),
]); ]);
} }
@ -150,7 +150,7 @@ class EA_Controller extends CI_Controller
'available_languages' => config('available_languages'), 'available_languages' => config('available_languages'),
'csrf_token' => $this->security->get_csrf_hash(), 'csrf_token' => $this->security->get_csrf_hash(),
'language' => config('language'), 'language' => config('language'),
'language_code' => config('language_code') 'language_code' => config('language_code'),
]); ]);
} }
} }

View file

@ -59,7 +59,7 @@ class EA_Loader extends CI_Loader
$result = $this->_ci_load([ $result = $this->_ci_load([
'_ci_view' => $view, '_ci_view' => $view,
'_ci_vars' => $this->_ci_prepare_view_vars($vars), '_ci_vars' => $this->_ci_prepare_view_vars($vars),
'_ci_return' => $return '_ci_return' => $return,
]); ]);
$layout = config('layout'); $layout = config('layout');
@ -68,7 +68,7 @@ class EA_Loader extends CI_Loader
$result = $this->_ci_load([ $result = $this->_ci_load([
'_ci_view' => $layout['filename'], '_ci_view' => $layout['filename'],
'_ci_vars' => $this->_ci_prepare_view_vars($vars), '_ci_vars' => $this->_ci_prepare_view_vars($vars),
'_ci_return' => $return '_ci_return' => $return,
]); ]);
} }

View file

@ -68,7 +68,7 @@ if (!function_exists('array_fields')) {
function ($field) use ($fields) { function ($field) use ($fields) {
return in_array($field, $fields); return in_array($field, $fields);
}, },
ARRAY_FILTER_USE_KEY ARRAY_FILTER_USE_KEY,
); );
} }
} }

View file

@ -25,7 +25,7 @@ if (!function_exists('get_date_format')) {
'DMY' => 'd/m/Y', 'DMY' => 'd/m/Y',
'MDY' => 'm/d/Y', 'MDY' => 'm/d/Y',
'YMD' => 'Y/m/d', 'YMD' => 'Y/m/d',
default => throw new RuntimeException('Invalid date format value: ' . $date_format) default => throw new RuntimeException('Invalid date format value: ' . $date_format),
}; };
} }
} }
@ -43,7 +43,7 @@ if (!function_exists('get_time_format')) {
return match ($time_format) { return match ($time_format) {
'military' => 'H:i', 'military' => 'H:i',
'regular' => 'g:i a', 'regular' => 'g:i a',
default => throw new RuntimeException('Invalid time format value: ' . $time_format) default => throw new RuntimeException('Invalid time format value: ' . $time_format),
}; };
} }
} }

View file

@ -69,8 +69,8 @@ if (!function_exists('extend')) {
'layout' => [ 'layout' => [
'filename' => $layout, 'filename' => $layout,
'sections' => [], 'sections' => [],
'tmp' => [] 'tmp' => [],
] ],
]); ]);
} }
} }

View file

@ -137,9 +137,9 @@ if (!function_exists('json_exception')) {
[ [
'success' => false, 'success' => false,
'message' => $e->getMessage(), 'message' => $e->getMessage(),
'trace' => config('debug') ? $e->getTrace() : [] 'trace' => config('debug') ? $e->getTrace() : [],
], ],
500 500,
); );
} }
} }

View file

@ -53,7 +53,7 @@ if (!function_exists('setting')) {
if (empty($setting)) { if (empty($setting)) {
$setting = [ $setting = [
'name' => $name 'name' => $name,
]; ];
} }

View file

@ -56,7 +56,7 @@ class Accounts
$user_settings = $this->CI->db $user_settings = $this->CI->db
->get_where('user_settings', [ ->get_where('user_settings', [
'username' => $username, 'username' => $username,
'password' => $password 'password' => $password,
]) ])
->row_array(); ->row_array();
@ -76,7 +76,7 @@ class Accounts
'username' => $username, 'username' => $username,
'timezone' => !empty($user['timezone']) ? $user['timezone'] : $default_timezone, 'timezone' => !empty($user['timezone']) ? $user['timezone'] : $default_timezone,
'language' => !empty($user['language']) ? $user['language'] : Config::LANGUAGE, 'language' => !empty($user['language']) ? $user['language'] : Config::LANGUAGE,
'role_slug' => $role['slug'] 'role_slug' => $role['slug'],
]; ];
} }

View file

@ -83,7 +83,7 @@ class Api
throw new RuntimeException( throw new RuntimeException(
'The provided credentials do not match any admin user!', 'The provided credentials do not match any admin user!',
401, 401,
'Unauthorized' 'Unauthorized',
); );
} }
} catch (Throwable) { } catch (Throwable) {
@ -133,7 +133,7 @@ class Api
// about capitalization for Authorization). // about capitalization for Authorization).
$requestHeaders = array_combine( $requestHeaders = array_combine(
array_map('ucwords', array_keys($requestHeaders)), array_map('ucwords', array_keys($requestHeaders)),
array_values($requestHeaders) array_values($requestHeaders),
); );
if (isset($requestHeaders['Authorization'])) { if (isset($requestHeaders['Authorization'])) {

View file

@ -60,7 +60,7 @@ class Availability
string $date, string $date,
array $service, array $service,
array $provider, array $provider,
int $exclude_appointment_id = null int $exclude_appointment_id = null,
): array { ): array {
if ($this->CI->blocked_periods_model->is_entire_date_blocked($date)) { if ($this->CI->blocked_periods_model->is_entire_date_blocked($date)) {
return []; return [];
@ -97,13 +97,13 @@ class Availability
string $date, string $date,
array $service, array $service,
array $provider, array $provider,
int $exclude_appointment_id = null int $exclude_appointment_id = null,
): array { ): array {
$unavailability_events = $this->CI->unavailabilities_model->get([ $unavailability_events = $this->CI->unavailabilities_model->get([
'is_unavailability' => true, 'is_unavailability' => true,
'DATE(start_datetime) <=' => $date, 'DATE(start_datetime) <=' => $date,
'DATE(end_datetime) >=' => $date, 'DATE(end_datetime) >=' => $date,
'id_users_provider' => $provider['id'] 'id_users_provider' => $provider['id'],
]); ]);
$working_plan = json_decode($provider['settings']['working_plan'], true); $working_plan = json_decode($provider['settings']['working_plan'], true);
@ -126,8 +126,8 @@ class Availability
$periods = [ $periods = [
[ [
'start' => new DateTime($date . ' ' . $date_working_plan['start']), 'start' => new DateTime($date . ' ' . $date_working_plan['start']),
'end' => new DateTime($date . ' ' . $date_working_plan['end']) 'end' => new DateTime($date . ' ' . $date_working_plan['end']),
] ],
]; ];
$blocked_periods = $this->CI->blocked_periods_model->get_for_period($date, $date); $blocked_periods = $this->CI->blocked_periods_model->get_for_period($date, $date);
@ -154,7 +154,7 @@ class Availability
$slot_end, $slot_end,
$service['id'], $service['id'],
$provider['id'], $provider['id'],
$exclude_appointment_id $exclude_appointment_id,
); );
if ($other_service_attendants_number > 0) { if ($other_service_attendants_number > 0) {
@ -169,7 +169,7 @@ class Availability
$slot_end, $slot_end,
$service['id'], $service['id'],
$provider['id'], $provider['id'],
$exclude_appointment_id $exclude_appointment_id,
); );
if ($appointment_attendants_number < $service['attendants_number']) { if ($appointment_attendants_number < $service['attendants_number']) {
@ -227,7 +227,7 @@ class Availability
$period['end'] = $break_start; $period['end'] = $break_start;
$periods[] = [ $periods[] = [
'start' => $break_end, 'start' => $break_end,
'end' => $period_end 'end' => $period_end,
]; ];
continue; continue;
} }
@ -290,7 +290,7 @@ class Availability
$period['end'] = $unavailability_start; $period['end'] = $unavailability_start;
$periods[] = [ $periods[] = [
'start' => $unavailability_end, 'start' => $unavailability_end,
'end' => $period_end 'end' => $period_end,
]; ];
continue; continue;
} }
@ -365,8 +365,8 @@ class Availability
array_merge( array_merge(
$this->CI->appointments_model->get($where), $this->CI->appointments_model->get($where),
$this->CI->unavailabilities_model->get($where), $this->CI->unavailabilities_model->get($where),
$this->CI->blocked_periods_model->get_for_period($date, $date) $this->CI->blocked_periods_model->get_for_period($date, $date),
) ),
); );
// Find the empty spaces on the plan. The first split between the plan is due to a break (if any). After that // Find the empty spaces on the plan. The first split between the plan is due to a break (if any). After that
@ -389,7 +389,7 @@ class Availability
if (isset($date_working_plan['breaks'])) { if (isset($date_working_plan['breaks'])) {
$periods[] = [ $periods[] = [
'start' => $date_working_plan['start'], 'start' => $date_working_plan['start'],
'end' => $date_working_plan['end'] 'end' => $date_working_plan['end'],
]; ];
$day_start = new DateTime($date_working_plan['start']); $day_start = new DateTime($date_working_plan['start']);
@ -421,7 +421,7 @@ class Availability
if ($break_start > $period_start && $break_start < $period_end && $break_end > $period_start) { if ($break_start > $period_start && $break_start < $period_end && $break_end > $period_start) {
$periods[] = [ $periods[] = [
'start' => $period_start->format('H:i'), 'start' => $period_start->format('H:i'),
'end' => $break_start->format('H:i') 'end' => $break_start->format('H:i'),
]; ];
$remove_current_period = true; $remove_current_period = true;
@ -430,7 +430,7 @@ class Availability
if ($break_start < $period_end && $break_end > $period_start && $break_end < $period_end) { if ($break_start < $period_end && $break_end > $period_start && $break_end < $period_end) {
$periods[] = [ $periods[] = [
'start' => $break_end->format('H:i'), 'start' => $break_end->format('H:i'),
'end' => $period_end->format('H:i') 'end' => $period_end->format('H:i'),
]; ];
$remove_current_period = true; $remove_current_period = true;
@ -484,12 +484,12 @@ class Availability
$periods[] = [ $periods[] = [
'start' => $period_start->format('H:i'), 'start' => $period_start->format('H:i'),
'end' => $appointment_start->format('H:i') 'end' => $appointment_start->format('H:i'),
]; ];
$periods[] = [ $periods[] = [
'start' => $appointment_end->format('H:i'), 'start' => $appointment_end->format('H:i'),
'end' => $period_end->format('H:i') 'end' => $period_end->format('H:i'),
]; ];
} elseif ($appointment_start == $period_start && $appointment_end == $period_end) { } elseif ($appointment_start == $period_start && $appointment_end == $period_end) {
unset($periods[$index]); // The whole period is blocked so remove it from the available periods array. unset($periods[$index]); // The whole period is blocked so remove it from the available periods array.
@ -623,7 +623,7 @@ class Availability
protected function consider_future_booking_limit( protected function consider_future_booking_limit(
string $selected_date, string $selected_date,
array $available_hours, array $available_hours,
array $provider array $provider,
): array { ): array {
$provider_timezone = new DateTimeZone($provider['timezone']); $provider_timezone = new DateTimeZone($provider['timezone']);

View file

@ -251,7 +251,7 @@ class Captcha_builder
if (!in_array($imageType, $this->allowedBackgroundImageTypes)) { if (!in_array($imageType, $this->allowedBackgroundImageTypes)) {
throw new Exception( throw new Exception(
'Invalid background image type! Allowed types are: ' . join(', ', $this->allowedBackgroundImageTypes) 'Invalid background image type! Allowed types are: ' . join(', ', $this->allowedBackgroundImageTypes),
); );
} }
@ -395,7 +395,7 @@ class Captcha_builder
$this->getCol($image, floor($nX), floor($nY), $bg), $this->getCol($image, floor($nX), floor($nY), $bg),
$this->getCol($image, ceil($nX), floor($nY), $bg), $this->getCol($image, ceil($nX), floor($nY), $bg),
$this->getCol($image, floor($nX), ceil($nY), $bg), $this->getCol($image, floor($nX), ceil($nY), $bg),
$this->getCol($image, ceil($nX), ceil($nY), $bg) $this->getCol($image, ceil($nX), ceil($nY), $bg),
); );
} else { } else {
$p = $this->getCol($image, round($nX), round($nY), $bg); $p = $this->getCol($image, round($nX), round($nY), $bg);

View file

@ -72,7 +72,7 @@ class Email_messages
string $appointment_link, string $appointment_link,
string $recipient_email, string $recipient_email,
string $ics_stream, string $ics_stream,
string $timezone = null string $timezone = null,
): void { ): void {
$appointment_timezone = new DateTimeZone($provider['timezone']); $appointment_timezone = new DateTimeZone($provider['timezone']);
@ -101,9 +101,9 @@ class Email_messages
'customer' => $customer, 'customer' => $customer,
'settings' => $settings, 'settings' => $settings,
'timezone' => $timezone, 'timezone' => $timezone,
'appointment_link' => $appointment_link 'appointment_link' => $appointment_link,
], ],
true true,
); );
$this->CI->email->from($settings['company_email'], $settings['company_email']); $this->CI->email->from($settings['company_email'], $settings['company_email']);
@ -143,7 +143,7 @@ class Email_messages
array $settings, array $settings,
string $recipient_email, string $recipient_email,
string $reason = null, string $reason = null,
string $timezone = null string $timezone = null,
): void { ): void {
$appointment_timezone = new DateTimeZone($provider['timezone']); $appointment_timezone = new DateTimeZone($provider['timezone']);
@ -170,9 +170,9 @@ class Email_messages
'customer' => $customer, 'customer' => $customer,
'settings' => $settings, 'settings' => $settings,
'timezone' => $timezone, 'timezone' => $timezone,
'reason' => $reason 'reason' => $reason,
], ],
true true,
); );
$this->CI->email->from($settings['company_email'], $settings['company_email']); $this->CI->email->from($settings['company_email'], $settings['company_email']);
@ -202,9 +202,9 @@ class Email_messages
[ [
'subject' => lang('new_account_password'), 'subject' => lang('new_account_password'),
'message' => str_replace('$password', '<strong>' . $password . '</strong>', lang('new_password_is')), 'message' => str_replace('$password', '<strong>' . $password . '</strong>', lang('new_password_is')),
'settings' => $settings 'settings' => $settings,
], ],
true true,
); );
$this->CI->email->from($settings['company_email'], $settings['company_email']); $this->CI->email->from($settings['company_email'], $settings['company_email']);

View file

@ -62,7 +62,7 @@ class Google_sync
public function initialize_clients(): void public function initialize_clients(): void
{ {
$http = new GuzzleHttp\Client([ $http = new GuzzleHttp\Client([
'verify' => false 'verify' => false,
]); ]);
$this->client = new Google_Client(); $this->client = new Google_Client();
@ -109,7 +109,7 @@ class Google_sync
if (isset($response['error'])) { if (isset($response['error'])) {
throw new RuntimeException( throw new RuntimeException(
'Google Authentication Error (' . $response['error'] . '): ' . $response['error_description'] 'Google Authentication Error (' . $response['error'] . '): ' . $response['error_description'],
); );
} }
@ -155,7 +155,7 @@ class Google_sync
array $provider, array $provider,
array $service, array $service,
array $customer, array $customer,
array $settings array $settings,
): Event { ): Event {
$event = new Google_Service_Calendar_Event(); $event = new Google_Service_Calendar_Event();
$event->setSummary(!empty($service) ? $service['name'] : 'Unavailable'); $event->setSummary(!empty($service) ? $service['name'] : 'Unavailable');
@ -166,7 +166,7 @@ class Google_sync
$start = new Google_Service_Calendar_EventDateTime(); $start = new Google_Service_Calendar_EventDateTime();
$start->setDateTime( $start->setDateTime(
(new DateTime($appointment['start_datetime'], $timezone))->format(DateTimeInterface::RFC3339) (new DateTime($appointment['start_datetime'], $timezone))->format(DateTimeInterface::RFC3339),
); );
$event->setStart($start); $event->setStart($start);
@ -213,11 +213,11 @@ class Google_sync
array $provider, array $provider,
array $service, array $service,
array $customer, array $customer,
array $settings array $settings,
): Event { ): Event {
$event = $this->service->events->get( $event = $this->service->events->get(
$provider['settings']['google_calendar'], $provider['settings']['google_calendar'],
$appointment['id_google_calendar'] $appointment['id_google_calendar'],
); );
$event->setSummary($service['name']); $event->setSummary($service['name']);
@ -228,7 +228,7 @@ class Google_sync
$start = new Google_Service_Calendar_EventDateTime(); $start = new Google_Service_Calendar_EventDateTime();
$start->setDateTime( $start->setDateTime(
(new DateTime($appointment['start_datetime'], $timezone))->format(DateTimeInterface::RFC3339) (new DateTime($appointment['start_datetime'], $timezone))->format(DateTimeInterface::RFC3339),
); );
$event->setStart($start); $event->setStart($start);
@ -284,13 +284,13 @@ class Google_sync
$start = new Google_Service_Calendar_EventDateTime(); $start = new Google_Service_Calendar_EventDateTime();
$start->setDateTime( $start->setDateTime(
(new DateTime($unavailability['start_datetime'], $timezone))->format(DateTimeInterface::RFC3339) (new DateTime($unavailability['start_datetime'], $timezone))->format(DateTimeInterface::RFC3339),
); );
$event->setStart($start); $event->setStart($start);
$end = new Google_Service_Calendar_EventDateTime(); $end = new Google_Service_Calendar_EventDateTime();
$end->setDateTime( $end->setDateTime(
(new DateTime($unavailability['end_datetime'], $timezone))->format(DateTimeInterface::RFC3339) (new DateTime($unavailability['end_datetime'], $timezone))->format(DateTimeInterface::RFC3339),
); );
$event->setEnd($end); $event->setEnd($end);
@ -312,7 +312,7 @@ class Google_sync
{ {
$event = $this->service->events->get( $event = $this->service->events->get(
$provider['settings']['google_calendar'], $provider['settings']['google_calendar'],
$unavailability['id_google_calendar'] $unavailability['id_google_calendar'],
); );
$event->setSummary('Unavailable'); $event->setSummary('Unavailable');
@ -322,13 +322,13 @@ class Google_sync
$start = new Google_Service_Calendar_EventDateTime(); $start = new Google_Service_Calendar_EventDateTime();
$start->setDateTime( $start->setDateTime(
(new DateTime($unavailability['start_datetime'], $timezone))->format(DateTimeInterface::RFC3339) (new DateTime($unavailability['start_datetime'], $timezone))->format(DateTimeInterface::RFC3339),
); );
$event->setStart($start); $event->setStart($start);
$end = new Google_Service_Calendar_EventDateTime(); $end = new Google_Service_Calendar_EventDateTime();
$end->setDateTime( $end->setDateTime(
(new DateTime($unavailability['end_datetime'], $timezone))->format(DateTimeInterface::RFC3339) (new DateTime($unavailability['end_datetime'], $timezone))->format(DateTimeInterface::RFC3339),
); );
$event->setEnd($end); $event->setEnd($end);
@ -373,7 +373,7 @@ class Google_sync
$params = [ $params = [
'timeMin' => date(DateTimeInterface::RFC3339, $start), 'timeMin' => date(DateTimeInterface::RFC3339, $start),
'timeMax' => date(DateTimeInterface::RFC3339, $end), 'timeMax' => date(DateTimeInterface::RFC3339, $end),
'singleEvents' => true 'singleEvents' => true,
]; ];
return $this->service->events->listEvents($google_calendar, $params); return $this->service->events->listEvents($google_calendar, $params);
@ -400,7 +400,7 @@ class Google_sync
$calendars[] = [ $calendars[] = [
'id' => $google_calendar->getId(), 'id' => $google_calendar->getId(),
'summary' => $google_calendar->getSummary() 'summary' => $google_calendar->getSummary(),
]; ];
} }
@ -453,7 +453,7 @@ class Google_sync
$appointment_end_instance->format('Ymd\THis\Z'), $appointment_end_instance->format('Ymd\THis\Z'),
'location' => setting('company_name'), 'location' => setting('company_name'),
'details' => 'View/Change Appointment: ' . site_url('appointments/index/' . $appointment['hash']), 'details' => 'View/Change Appointment: ' . site_url('appointments/index/' . $appointment['hash']),
'add' => implode(', ', $add) 'add' => implode(', ', $add),
]; ];
return 'https://calendar.google.com/calendar/render?' . http_build_query($add_to_google_url_params); return 'https://calendar.google.com/calendar/render?' . http_build_query($add_to_google_url_params);

View file

@ -252,13 +252,13 @@ class Ics_calendar extends Calendar
if ($image['VALUE'] == 'URI' && $image['URI']) { if ($image['VALUE'] == 'URI' && $image['URI']) {
$new_image = [ $new_image = [
'VALUE' => 'URI', 'VALUE' => 'URI',
'URI' => $image['URI'] 'URI' => $image['URI'],
]; ];
} elseif ($image['VALUE'] == 'BINARY' && $image['ENCODING'] && $image['BINARY']) { } elseif ($image['VALUE'] == 'BINARY' && $image['ENCODING'] && $image['BINARY']) {
$new_image = [ $new_image = [
'VALUE' => 'BINARY', 'VALUE' => 'BINARY',
'ENCODING' => $image['ENCODING'], 'ENCODING' => $image['ENCODING'],
'BINARY' => $image['BINARY'] 'BINARY' => $image['BINARY'],
]; ];
} else { } else {
return; return;

View file

@ -108,7 +108,7 @@ class Ics_file
'', '',
lang('notes'), lang('notes'),
'', '',
$appointment['notes'] $appointment['notes'],
]; ];
$event->setDescription(implode("\\n", $description)); $event->setDescription(implode("\\n", $description));

View file

@ -91,7 +91,7 @@ class Instance
setting([ setting([
'company_name' => 'Company Name', 'company_name' => 'Company Name',
'company_email' => 'info@example.org', 'company_email' => 'info@example.org',
'company_link' => 'https://example.org' 'company_link' => 'https://example.org',
]); ]);
// Admin // Admin
@ -107,8 +107,8 @@ class Instance
'username' => 'administrator', 'username' => 'administrator',
'password' => $password, 'password' => $password,
'notifications' => true, 'notifications' => true,
'calendar_view' => CALENDAR_VIEW_DEFAULT 'calendar_view' => CALENDAR_VIEW_DEFAULT,
] ],
]); ]);
// Service // Service
@ -119,7 +119,7 @@ class Instance
'price' => '0', 'price' => '0',
'currency' => '', 'currency' => '',
'availabilities_type' => 'flexible', 'availabilities_type' => 'flexible',
'attendants_number' => '1' 'attendants_number' => '1',
]); ]);
// Provider // Provider
@ -139,8 +139,8 @@ class Instance
'google_sync' => false, 'google_sync' => false,
'sync_past_days' => 30, 'sync_past_days' => 30,
'sync_future_days' => 90, 'sync_future_days' => 90,
'calendar_view' => CALENDAR_VIEW_DEFAULT 'calendar_view' => CALENDAR_VIEW_DEFAULT,
] ],
]); ]);
// Customer // Customer
@ -149,7 +149,7 @@ class Instance
'first_name' => 'James', 'first_name' => 'James',
'last_name' => 'Doe', 'last_name' => 'Doe',
'email' => 'james@example.org', 'email' => 'james@example.org',
'phone_number' => '+10000000000' 'phone_number' => '+10000000000',
]); ]);
return $password; return $password;

View file

@ -60,7 +60,7 @@ class Notifications
array $provider, array $provider,
array $customer, array $customer,
array $settings, array $settings,
bool $manage_mode = false bool $manage_mode = false,
): void { ): void {
try { try {
$current_language = config('english'); $current_language = config('english');
@ -92,14 +92,14 @@ class Notifications
$customer_link, $customer_link,
$customer['email'], $customer['email'],
$ics_stream, $ics_stream,
$customer['timezone'] $customer['timezone'],
); );
} }
// Notify provider. // Notify provider.
$send_provider = filter_var( $send_provider = filter_var(
$this->CI->providers_model->get_setting($provider['id'], 'notifications'), $this->CI->providers_model->get_setting($provider['id'], 'notifications'),
FILTER_VALIDATE_BOOLEAN FILTER_VALIDATE_BOOLEAN,
); );
if ($send_provider === true) { if ($send_provider === true) {
@ -119,7 +119,7 @@ class Notifications
$provider_link, $provider_link,
$provider['email'], $provider['email'],
$ics_stream, $ics_stream,
$provider['timezone'] $provider['timezone'],
); );
} }
@ -147,7 +147,7 @@ class Notifications
$provider_link, $provider_link,
$admin['email'], $admin['email'],
$ics_stream, $ics_stream,
$admin['timezone'] $admin['timezone'],
); );
} }
@ -179,7 +179,7 @@ class Notifications
$provider_link, $provider_link,
$secretary['email'], $secretary['email'],
$ics_stream, $ics_stream,
$secretary['timezone'] $secretary['timezone'],
); );
} }
} catch (Throwable $e) { } catch (Throwable $e) {
@ -188,7 +188,7 @@ class Notifications
'Notifications - Could not email confirmation details of appointment (' . 'Notifications - Could not email confirmation details of appointment (' .
($appointment['id'] ?? '-') . ($appointment['id'] ?? '-') .
') : ' . ') : ' .
$e->getMessage() $e->getMessage(),
); );
log_message('error', $e->getTraceAsString()); log_message('error', $e->getTraceAsString());
} finally { } finally {
@ -212,7 +212,7 @@ class Notifications
array $provider, array $provider,
array $customer, array $customer,
array $settings, array $settings,
string $cancellation_reason = '' string $cancellation_reason = '',
): void { ): void {
try { try {
$current_language = config('language'); $current_language = config('language');
@ -220,7 +220,7 @@ class Notifications
// Notify provider. // Notify provider.
$send_provider = filter_var( $send_provider = filter_var(
$this->CI->providers_model->get_setting($provider['id'], 'notifications'), $this->CI->providers_model->get_setting($provider['id'], 'notifications'),
FILTER_VALIDATE_BOOLEAN FILTER_VALIDATE_BOOLEAN,
); );
if ($send_provider === true) { if ($send_provider === true) {
@ -235,7 +235,7 @@ class Notifications
$settings, $settings,
$provider['email'], $provider['email'],
$cancellation_reason, $cancellation_reason,
$provider['timezone'] $provider['timezone'],
); );
} }
@ -255,7 +255,7 @@ class Notifications
$settings, $settings,
$customer['email'], $customer['email'],
$cancellation_reason, $cancellation_reason,
$customer['timezone'] $customer['timezone'],
); );
} }
@ -278,7 +278,7 @@ class Notifications
$settings, $settings,
$admin['email'], $admin['email'],
$cancellation_reason, $cancellation_reason,
$admin['timezone'] $admin['timezone'],
); );
} }
@ -305,7 +305,7 @@ class Notifications
$settings, $settings,
$secretary['email'], $secretary['email'],
$cancellation_reason, $cancellation_reason,
$secretary['timezone'] $secretary['timezone'],
); );
} }
} catch (Throwable $e) { } catch (Throwable $e) {
@ -314,7 +314,7 @@ class Notifications
'Notifications - Could not email cancellation details of appointment (' . 'Notifications - Could not email cancellation details of appointment (' .
($appointment['id'] ?? '-') . ($appointment['id'] ?? '-') .
') : ' . ') : ' .
$e->getMessage() $e->getMessage(),
); );
log_message('error', $e->getTraceAsString()); log_message('error', $e->getTraceAsString());
} finally { } finally {

View file

@ -52,7 +52,7 @@ class Synchronization
array $service, array $service,
array $provider, array $provider,
array $customer, array $customer,
array $settings array $settings,
): void { ): void {
try { try {
if (!$provider['settings']['google_sync']) { if (!$provider['settings']['google_sync']) {
@ -73,7 +73,7 @@ class Synchronization
$provider, $provider,
$service, $service,
$customer, $customer,
$settings $settings,
); );
$appointment['id_google_calendar'] = $google_event->getId(); $appointment['id_google_calendar'] = $google_event->getId();
@ -88,7 +88,7 @@ class Synchronization
'Synchronization - Could not sync confirmation details of appointment (' . 'Synchronization - Could not sync confirmation details of appointment (' .
($appointment['id'] ?? '-') . ($appointment['id'] ?? '-') .
') : ' . ') : ' .
$e->getMessage() $e->getMessage(),
); );
log_message('error', $e->getTraceAsString()); log_message('error', $e->getTraceAsString());
} }
@ -130,7 +130,7 @@ class Synchronization
'Synchronization - Could not sync cancellation details of unavailability (' . 'Synchronization - Could not sync cancellation details of unavailability (' .
($appointment['id'] ?? '-') . ($appointment['id'] ?? '-') .
') : ' . ') : ' .
$e->getMessage() $e->getMessage(),
); );
log_message('error', $e->getTraceAsString()); log_message('error', $e->getTraceAsString());
} }
@ -164,7 +164,7 @@ class Synchronization
'Synchronization - Could not sync cancellation details of unavailability (' . 'Synchronization - Could not sync cancellation details of unavailability (' .
($appointment['id'] ?? '-') . ($appointment['id'] ?? '-') .
') : ' . ') : ' .
$e->getMessage() $e->getMessage(),
); );
log_message('error', $e->getTraceAsString()); log_message('error', $e->getTraceAsString());
} }
@ -223,7 +223,7 @@ class Synchronization
'Synchronization - Could not sync cancellation details of appointment (' . 'Synchronization - Could not sync cancellation details of appointment (' .
($appointment['id'] ?? '-') . ($appointment['id'] ?? '-') .
') : ' . ') : ' .
$e->getMessage() $e->getMessage(),
); );
log_message('error', $e->getTraceAsString()); log_message('error', $e->getTraceAsString());
} }

View file

@ -35,7 +35,7 @@ class Timezones
*/ */
protected array $timezones = [ protected array $timezones = [
'UTC' => [ 'UTC' => [
'UTC' => 'UTC' 'UTC' => 'UTC',
], ],
'America' => [ 'America' => [
'America/Adak' => 'Adak (-10:00)', 'America/Adak' => 'Adak (-10:00)',
@ -166,7 +166,7 @@ class Timezones
'America/Sao_Paulo' => 'Sao_Paulo (-3:00)', 'America/Sao_Paulo' => 'Sao_Paulo (-3:00)',
'America/Noronha' => 'Noronha (-2:00)', 'America/Noronha' => 'Noronha (-2:00)',
'America/Scoresbysund' => 'Scoresbysund (-1:00)', 'America/Scoresbysund' => 'Scoresbysund (-1:00)',
'America/Danmarkshavn' => 'Danmarkshavn (+0:00)' 'America/Danmarkshavn' => 'Danmarkshavn (+0:00)',
], ],
'Canada' => [ 'Canada' => [
'Canada/Pacific' => 'Pacific (-8:00)', 'Canada/Pacific' => 'Pacific (-8:00)',
@ -177,16 +177,16 @@ class Timezones
'Canada/Saskatchewan' => 'Saskatchewan (-6:00)', 'Canada/Saskatchewan' => 'Saskatchewan (-6:00)',
'Canada/Eastern' => 'Eastern (-5:00)', 'Canada/Eastern' => 'Eastern (-5:00)',
'Canada/Atlantic' => 'Atlantic (-4:00)', 'Canada/Atlantic' => 'Atlantic (-4:00)',
'Canada/Newfoundland' => 'Newfoundland (-3:-30)' 'Canada/Newfoundland' => 'Newfoundland (-3:-30)',
], ],
'Mexico' => [ 'Mexico' => [
'Mexico/BajaNorte' => 'BajaNorte (-8:00)', 'Mexico/BajaNorte' => 'BajaNorte (-8:00)',
'Mexico/BajaSur' => 'BajaSur (-7:00)', 'Mexico/BajaSur' => 'BajaSur (-7:00)',
'Mexico/General' => 'General (-6:00)' 'Mexico/General' => 'General (-6:00)',
], ],
'Chile' => [ 'Chile' => [
'Chile/EasterIsland' => 'EasterIsland (-6:00)', 'Chile/EasterIsland' => 'EasterIsland (-6:00)',
'Chile/Continental' => 'Continental (-4:00)' 'Chile/Continental' => 'Continental (-4:00)',
], ],
'Antarctica' => [ 'Antarctica' => [
'Antarctica/Palmer' => 'Palmer (-4:00)', 'Antarctica/Palmer' => 'Palmer (-4:00)',
@ -198,7 +198,7 @@ class Timezones
'Antarctica/Casey' => 'Casey (+8:00)', 'Antarctica/Casey' => 'Casey (+8:00)',
'Antarctica/DumontDUrville' => 'DumontDUrville (+10:00)', 'Antarctica/DumontDUrville' => 'DumontDUrville (+10:00)',
'Antarctica/McMurdo' => 'McMurdo (+12:00)', 'Antarctica/McMurdo' => 'McMurdo (+12:00)',
'Antarctica/South_Pole' => 'South_Pole (+12:00)' 'Antarctica/South_Pole' => 'South_Pole (+12:00)',
], ],
'Atlantic' => [ 'Atlantic' => [
'Atlantic/Bermuda' => 'Bermuda (-4:00)', 'Atlantic/Bermuda' => 'Bermuda (-4:00)',
@ -212,13 +212,13 @@ class Timezones
'Atlantic/Madeira' => 'Madeira (+0:00)', 'Atlantic/Madeira' => 'Madeira (+0:00)',
'Atlantic/Reykjavik' => 'Reykjavik (+0:00)', 'Atlantic/Reykjavik' => 'Reykjavik (+0:00)',
'Atlantic/St_Helena' => 'St_Helena (+0:00)', 'Atlantic/St_Helena' => 'St_Helena (+0:00)',
'Atlantic/Jan_Mayen' => 'Jan_Mayen (+1:00)' 'Atlantic/Jan_Mayen' => 'Jan_Mayen (+1:00)',
], ],
'Brazil' => [ 'Brazil' => [
'Brazil/Acre' => 'Acre (-4:00)', 'Brazil/Acre' => 'Acre (-4:00)',
'Brazil/West' => 'West (-4:00)', 'Brazil/West' => 'West (-4:00)',
'Brazil/East' => 'East (-3:00)', 'Brazil/East' => 'East (-3:00)',
'Brazil/DeNoronha' => 'DeNoronha (-2:00)' 'Brazil/DeNoronha' => 'DeNoronha (-2:00)',
], ],
'Africa' => [ 'Africa' => [
'Africa/Abidjan' => 'Abidjan (+0:00)', 'Africa/Abidjan' => 'Abidjan (+0:00)',
@ -273,7 +273,7 @@ class Timezones
'Africa/Kampala' => 'Kampala (+3:00)', 'Africa/Kampala' => 'Kampala (+3:00)',
'Africa/Khartoum' => 'Khartoum (+3:00)', 'Africa/Khartoum' => 'Khartoum (+3:00)',
'Africa/Mogadishu' => 'Mogadishu (+3:00)', 'Africa/Mogadishu' => 'Mogadishu (+3:00)',
'Africa/Nairobi' => 'Nairobi (+3:00)' 'Africa/Nairobi' => 'Nairobi (+3:00)',
], ],
'Europe' => [ 'Europe' => [
'Europe/Belfast' => 'Belfast (+0:00)', 'Europe/Belfast' => 'Belfast (+0:00)',
@ -333,10 +333,10 @@ class Timezones
'Europe/Zaporozhye' => 'Zaporozhye (+2:00)', 'Europe/Zaporozhye' => 'Zaporozhye (+2:00)',
'Europe/Moscow' => 'Moscow (+3:00)', 'Europe/Moscow' => 'Moscow (+3:00)',
'Europe/Volgograd' => 'Volgograd (+3:00)', 'Europe/Volgograd' => 'Volgograd (+3:00)',
'Europe/Samara' => 'Samara (+4:00)' 'Europe/Samara' => 'Samara (+4:00)',
], ],
'Arctic' => [ 'Arctic' => [
'Arctic/Longyearbyen' => 'Longyearbyen (+1:00)' 'Arctic/Longyearbyen' => 'Longyearbyen (+1:00)',
], ],
'Asia' => [ 'Asia' => [
'Asia/Amman' => 'Amman (+2:00)', 'Asia/Amman' => 'Amman (+2:00)',
@ -423,7 +423,7 @@ class Timezones
'Asia/Vladivostok' => 'Vladivostok (+10:00)', 'Asia/Vladivostok' => 'Vladivostok (+10:00)',
'Asia/Magadan' => 'Magadan (+11:00)', 'Asia/Magadan' => 'Magadan (+11:00)',
'Asia/Anadyr' => 'Anadyr (+12:00)', 'Asia/Anadyr' => 'Anadyr (+12:00)',
'Asia/Kamchatka' => 'Kamchatka (+12:00)' 'Asia/Kamchatka' => 'Kamchatka (+12:00)',
], ],
'Indian' => [ 'Indian' => [
'Indian/Antananarivo' => 'Antananarivo (+3:00)', 'Indian/Antananarivo' => 'Antananarivo (+3:00)',
@ -436,7 +436,7 @@ class Timezones
'Indian/Maldives' => 'Maldives (+5:00)', 'Indian/Maldives' => 'Maldives (+5:00)',
'Indian/Chagos' => 'Chagos (+6:00)', 'Indian/Chagos' => 'Chagos (+6:00)',
'Indian/Cocos' => 'Cocos (+6:30)', 'Indian/Cocos' => 'Cocos (+6:30)',
'Indian/Christmas' => 'Christmas (+7:00)' 'Indian/Christmas' => 'Christmas (+7:00)',
], ],
'Australia' => [ 'Australia' => [
'Australia/Perth' => 'Perth (+8:00)', 'Australia/Perth' => 'Perth (+8:00)',
@ -461,7 +461,7 @@ class Timezones
'Australia/Tasmania' => 'Tasmania (+10:00)', 'Australia/Tasmania' => 'Tasmania (+10:00)',
'Australia/Victoria' => 'Victoria (+10:00)', 'Australia/Victoria' => 'Victoria (+10:00)',
'Australia/LHI' => 'LHI (+10:30)', 'Australia/LHI' => 'LHI (+10:30)',
'Australia/Lord_Howe' => 'Lord_Howe (+10:30)' 'Australia/Lord_Howe' => 'Lord_Howe (+10:30)',
], ],
'Pacific' => [ 'Pacific' => [
'Pacific/Apia' => 'Apia (+13:00)', 'Pacific/Apia' => 'Apia (+13:00)',
@ -499,8 +499,8 @@ class Timezones
'Pacific/Tarawa' => 'Tarawa (+12:00)', 'Pacific/Tarawa' => 'Tarawa (+12:00)',
'Pacific/Tongatapu' => 'Tongatapu (+13:00)', 'Pacific/Tongatapu' => 'Tongatapu (+13:00)',
'Pacific/Wake' => 'Wake (+12:00)', 'Pacific/Wake' => 'Wake (+12:00)',
'Pacific/Wallis' => 'Wallis (+12:00)' 'Pacific/Wallis' => 'Wallis (+12:00)',
] ],
]; ];
/** /**

View file

@ -78,8 +78,8 @@ class Webhooks_client
'verify' => $webhook['is_ssl_verified'], 'verify' => $webhook['is_ssl_verified'],
'json' => [ 'json' => [
'action' => $action, 'action' => $action,
'payload' => $payload 'payload' => $payload,
] ],
]); ]);
} catch (Throwable $e) { } catch (Throwable $e) {
log_message( log_message(
@ -87,7 +87,7 @@ class Webhooks_client
'Webhooks Client - The webhook (' . 'Webhooks Client - The webhook (' .
($webhook['id'] ?? null) . ($webhook['id'] ?? null) .
') request received an unexpected exception: ' . ') request received an unexpected exception: ' .
$e->getMessage() $e->getMessage(),
); );
log_message('error', $e->getTraceAsString()); log_message('error', $e->getTraceAsString());
} }

View file

@ -28,55 +28,55 @@ class Migration_Specific_calendar_sync extends EA_Migration
'type' => 'BIGINT', 'type' => 'BIGINT',
'constraint' => '20', 'constraint' => '20',
'unsigned' => true, 'unsigned' => true,
'auto_increment' => true 'auto_increment' => true,
], ],
'book_datetime' => [ 'book_datetime' => [
'type' => 'DATETIME', 'type' => 'DATETIME',
'null' => true 'null' => true,
], ],
'start_datetime' => [ 'start_datetime' => [
'type' => 'DATETIME', 'type' => 'DATETIME',
'null' => true 'null' => true,
], ],
'end_datetime' => [ 'end_datetime' => [
'type' => 'DATETIME', 'type' => 'DATETIME',
'null' => true 'null' => true,
], ],
'notes' => [ 'notes' => [
'type' => 'TEXT', 'type' => 'TEXT',
'null' => true 'null' => true,
], ],
'hash' => [ 'hash' => [
'type' => 'TEXT', 'type' => 'TEXT',
'null' => true 'null' => true,
], ],
'is_unavailability' => [ 'is_unavailability' => [
'type' => 'TINYINT', 'type' => 'TINYINT',
'constraint' => '4', 'constraint' => '4',
'default' => '0' 'default' => '0',
], ],
'id_users_provider' => [ 'id_users_provider' => [
'type' => 'BIGINT', 'type' => 'BIGINT',
'constraint' => '20', 'constraint' => '20',
'unsigned' => true, 'unsigned' => true,
'null' => true 'null' => true,
], ],
'id_users_customer' => [ 'id_users_customer' => [
'type' => 'BIGINT', 'type' => 'BIGINT',
'constraint' => '20', 'constraint' => '20',
'unsigned' => true, 'unsigned' => true,
'null' => true 'null' => true,
], ],
'id_services' => [ 'id_services' => [
'type' => 'BIGINT', 'type' => 'BIGINT',
'constraint' => '20', 'constraint' => '20',
'unsigned' => true, 'unsigned' => true,
'null' => true 'null' => true,
], ],
'id_google_calendar' => [ 'id_google_calendar' => [
'type' => 'TEXT', 'type' => 'TEXT',
'null' => true 'null' => true,
] ],
]); ]);
$this->dbforge->add_key('id', true); $this->dbforge->add_key('id', true);
$this->dbforge->add_key('id_users_provider'); $this->dbforge->add_key('id_users_provider');
@ -89,53 +89,53 @@ class Migration_Specific_calendar_sync extends EA_Migration
'type' => 'BIGINT', 'type' => 'BIGINT',
'constraint' => '20', 'constraint' => '20',
'unsigned' => true, 'unsigned' => true,
'auto_increment' => true 'auto_increment' => true,
], ],
'name' => [ 'name' => [
'type' => 'VARCHAR', 'type' => 'VARCHAR',
'constraint' => '256', 'constraint' => '256',
'null' => true 'null' => true,
], ],
'slug' => [ 'slug' => [
'type' => 'VARCHAR', 'type' => 'VARCHAR',
'constraint' => '256', 'constraint' => '256',
'null' => true 'null' => true,
], ],
'is_admin' => [ 'is_admin' => [
'type' => 'TINYINT', 'type' => 'TINYINT',
'constraint' => '4', 'constraint' => '4',
'null' => true 'null' => true,
], ],
'appointments' => [ 'appointments' => [
'type' => 'INT', 'type' => 'INT',
'constraint' => '4', 'constraint' => '4',
'null' => true 'null' => true,
], ],
'customers' => [ 'customers' => [
'type' => 'INT', 'type' => 'INT',
'constraint' => '4', 'constraint' => '4',
'null' => true 'null' => true,
], ],
'services' => [ 'services' => [
'type' => 'INT', 'type' => 'INT',
'constraint' => '4', 'constraint' => '4',
'null' => true 'null' => true,
], ],
'users' => [ 'users' => [
'type' => 'INT', 'type' => 'INT',
'constraint' => '4', 'constraint' => '4',
'null' => true 'null' => true,
], ],
'system_settings' => [ 'system_settings' => [
'type' => 'INT', 'type' => 'INT',
'constraint' => '4', 'constraint' => '4',
'null' => true 'null' => true,
], ],
'user_settings' => [ 'user_settings' => [
'type' => 'INT', 'type' => 'INT',
'constraint' => '4', 'constraint' => '4',
'null' => true 'null' => true,
] ],
]); ]);
$this->dbforge->add_key('id', true); $this->dbforge->add_key('id', true);
$this->dbforge->create_table('roles', true, ['engine' => 'InnoDB']); $this->dbforge->create_table('roles', true, ['engine' => 'InnoDB']);
@ -144,13 +144,13 @@ class Migration_Specific_calendar_sync extends EA_Migration
'id_users_secretary' => [ 'id_users_secretary' => [
'type' => 'BIGINT', 'type' => 'BIGINT',
'constraint' => '20', 'constraint' => '20',
'unsigned' => true 'unsigned' => true,
], ],
'id_users_provider' => [ 'id_users_provider' => [
'type' => 'BIGINT', 'type' => 'BIGINT',
'constraint' => '20', 'constraint' => '20',
'unsigned' => true 'unsigned' => true,
] ],
]); ]);
$this->dbforge->add_key('id_users_secretary', true); $this->dbforge->add_key('id_users_secretary', true);
$this->dbforge->add_key('id_users_provider', true); $this->dbforge->add_key('id_users_provider', true);
@ -161,38 +161,38 @@ class Migration_Specific_calendar_sync extends EA_Migration
'type' => 'BIGINT', 'type' => 'BIGINT',
'constraint' => '20', 'constraint' => '20',
'unsigned' => true, 'unsigned' => true,
'auto_increment' => true 'auto_increment' => true,
], ],
'name' => [ 'name' => [
'type' => 'VARCHAR', 'type' => 'VARCHAR',
'constraint' => '256', 'constraint' => '256',
'null' => true 'null' => true,
], ],
'duration' => [ 'duration' => [
'type' => 'INT', 'type' => 'INT',
'constraint' => '11', 'constraint' => '11',
'null' => true 'null' => true,
], ],
'price' => [ 'price' => [
'type' => 'DECIMAL', 'type' => 'DECIMAL',
'constraint' => '10,2', 'constraint' => '10,2',
'null' => true 'null' => true,
], ],
'currency' => [ 'currency' => [
'type' => 'VARCHAR', 'type' => 'VARCHAR',
'constraint' => '32', 'constraint' => '32',
'null' => true 'null' => true,
], ],
'description' => [ 'description' => [
'type' => 'TEXT', 'type' => 'TEXT',
'null' => true 'null' => true,
], ],
'id_service_categories' => [ 'id_service_categories' => [
'type' => 'BIGINT', 'type' => 'BIGINT',
'constraint' => '20', 'constraint' => '20',
'unsigned' => true, 'unsigned' => true,
'null' => true 'null' => true,
] ],
]); ]);
$this->dbforge->add_key('id', true); $this->dbforge->add_key('id', true);
$this->dbforge->add_key('id_service_categories'); $this->dbforge->add_key('id_service_categories');
@ -202,13 +202,13 @@ class Migration_Specific_calendar_sync extends EA_Migration
'id_users' => [ 'id_users' => [
'type' => 'BIGINT', 'type' => 'BIGINT',
'constraint' => '20', 'constraint' => '20',
'unsigned' => true 'unsigned' => true,
], ],
'id_services' => [ 'id_services' => [
'type' => 'BIGINT', 'type' => 'BIGINT',
'constraint' => '20', 'constraint' => '20',
'unsigned' => true 'unsigned' => true,
] ],
]); ]);
$this->dbforge->add_key('id_users', true); $this->dbforge->add_key('id_users', true);
$this->dbforge->add_key('id_services', true); $this->dbforge->add_key('id_services', true);
@ -219,17 +219,17 @@ class Migration_Specific_calendar_sync extends EA_Migration
'type' => 'BIGINT', 'type' => 'BIGINT',
'constraint' => '20', 'constraint' => '20',
'unsigned' => true, 'unsigned' => true,
'auto_increment' => true 'auto_increment' => true,
], ],
'name' => [ 'name' => [
'type' => 'VARCHAR', 'type' => 'VARCHAR',
'constraint' => '256', 'constraint' => '256',
'null' => true 'null' => true,
], ],
'description' => [ 'description' => [
'type' => 'TEXT', 'type' => 'TEXT',
'null' => true 'null' => true,
] ],
]); ]);
$this->dbforge->add_key('id', true); $this->dbforge->add_key('id', true);
$this->dbforge->add_key('id_service_categories'); $this->dbforge->add_key('id_service_categories');
@ -240,17 +240,17 @@ class Migration_Specific_calendar_sync extends EA_Migration
'type' => 'BIGINT', 'type' => 'BIGINT',
'constraint' => '20', 'constraint' => '20',
'unsigned' => true, 'unsigned' => true,
'auto_increment' => true 'auto_increment' => true,
], ],
'name' => [ 'name' => [
'type' => 'VARCHAR', 'type' => 'VARCHAR',
'constraint' => '512', 'constraint' => '512',
'null' => true 'null' => true,
], ],
'value' => [ 'value' => [
'type' => 'LONGTEXT', 'type' => 'LONGTEXT',
'null' => true 'null' => true,
] ],
]); ]);
$this->dbforge->add_key('id', true); $this->dbforge->add_key('id', true);
$this->dbforge->create_table('settings', true, ['engine' => 'InnoDB']); $this->dbforge->create_table('settings', true, ['engine' => 'InnoDB']);
@ -260,62 +260,62 @@ class Migration_Specific_calendar_sync extends EA_Migration
'type' => 'BIGINT', 'type' => 'BIGINT',
'constraint' => '20', 'constraint' => '20',
'unsigned' => true, 'unsigned' => true,
'auto_increment' => true 'auto_increment' => true,
], ],
'first_name' => [ 'first_name' => [
'type' => 'VARCHAR', 'type' => 'VARCHAR',
'constraint' => '256', 'constraint' => '256',
'null' => true 'null' => true,
], ],
'last_name' => [ 'last_name' => [
'type' => 'VARCHAR', 'type' => 'VARCHAR',
'constraint' => '512', 'constraint' => '512',
'null' => true 'null' => true,
], ],
'email' => [ 'email' => [
'type' => 'VARCHAR', 'type' => 'VARCHAR',
'constraint' => '512', 'constraint' => '512',
'null' => true 'null' => true,
], ],
'mobile_number' => [ 'mobile_number' => [
'type' => 'VARCHAR', 'type' => 'VARCHAR',
'constraint' => '128', 'constraint' => '128',
'null' => true 'null' => true,
], ],
'phone_number' => [ 'phone_number' => [
'type' => 'VARCHAR', 'type' => 'VARCHAR',
'constraint' => '128', 'constraint' => '128',
'null' => true 'null' => true,
], ],
'address' => [ 'address' => [
'type' => 'VARCHAR', 'type' => 'VARCHAR',
'constraint' => '256', 'constraint' => '256',
'null' => true 'null' => true,
], ],
'city' => [ 'city' => [
'type' => 'VARCHAR', 'type' => 'VARCHAR',
'constraint' => '256', 'constraint' => '256',
'null' => true 'null' => true,
], ],
'state' => [ 'state' => [
'type' => 'VARCHAR', 'type' => 'VARCHAR',
'constraint' => '128', 'constraint' => '128',
'null' => true 'null' => true,
], ],
'zip_code' => [ 'zip_code' => [
'type' => 'VARCHAR', 'type' => 'VARCHAR',
'constraint' => '64', 'constraint' => '64',
'null' => true 'null' => true,
], ],
'notes' => [ 'notes' => [
'type' => 'TEXT', 'type' => 'TEXT',
'null' => true 'null' => true,
], ],
'id_roles' => [ 'id_roles' => [
'type' => 'BIGINT', 'type' => 'BIGINT',
'constraint' => '20', 'constraint' => '20',
'unsigned' => true 'unsigned' => true,
] ],
]); ]);
$this->dbforge->add_key('id', true); $this->dbforge->add_key('id', true);
$this->dbforge->add_key('id_roles'); $this->dbforge->add_key('id_roles');
@ -325,58 +325,58 @@ class Migration_Specific_calendar_sync extends EA_Migration
'id_users' => [ 'id_users' => [
'type' => 'BIGINT', 'type' => 'BIGINT',
'constraint' => '20', 'constraint' => '20',
'unsigned' => true 'unsigned' => true,
], ],
'username' => [ 'username' => [
'type' => 'VARCHAR', 'type' => 'VARCHAR',
'constraint' => '256', 'constraint' => '256',
'null' => true 'null' => true,
], ],
'password' => [ 'password' => [
'type' => 'VARCHAR', 'type' => 'VARCHAR',
'constraint' => '512', 'constraint' => '512',
'null' => true 'null' => true,
], ],
'salt' => [ 'salt' => [
'type' => 'VARCHAR', 'type' => 'VARCHAR',
'constraint' => '512', 'constraint' => '512',
'null' => true 'null' => true,
], ],
'working_plan' => [ 'working_plan' => [
'type' => 'TEXT', 'type' => 'TEXT',
'null' => true 'null' => true,
], ],
'notifications' => [ 'notifications' => [
'type' => 'TINYINT', 'type' => 'TINYINT',
'constraint' => '4', 'constraint' => '4',
'null' => true 'null' => true,
], ],
'google_sync' => [ 'google_sync' => [
'type' => 'TINYINT', 'type' => 'TINYINT',
'constraint' => '4', 'constraint' => '4',
'null' => true 'null' => true,
], ],
'google_token' => [ 'google_token' => [
'type' => 'TEXT', 'type' => 'TEXT',
'null' => true 'null' => true,
], ],
'google_calendar' => [ 'google_calendar' => [
'type' => 'VARCHAR', 'type' => 'VARCHAR',
'constraint' => '128', 'constraint' => '128',
'null' => true 'null' => true,
], ],
'sync_past_days' => [ 'sync_past_days' => [
'type' => 'INT', 'type' => 'INT',
'constraint' => '11', 'constraint' => '11',
'null' => true, 'null' => true,
'default' => '5' 'default' => '5',
], ],
'sync_future_days' => [ 'sync_future_days' => [
'type' => 'INT', 'type' => 'INT',
'constraint' => '11', 'constraint' => '11',
'null' => true, 'null' => true,
'default' => '5' 'default' => '5',
] ],
]); ]);
$this->dbforge->add_key('id_users', true); $this->dbforge->add_key('id_users', true);
$this->dbforge->create_table('user_settings', true, ['engine' => 'InnoDB']); $this->dbforge->create_table('user_settings', true, ['engine' => 'InnoDB']);
@ -401,7 +401,7 @@ class Migration_Specific_calendar_sync extends EA_Migration
'_ibfk_4` FOREIGN KEY (`id_users_provider`) REFERENCES `' . '_ibfk_4` FOREIGN KEY (`id_users_provider`) REFERENCES `' .
$this->db->dbprefix('users') . $this->db->dbprefix('users') .
'` (`id`) ON DELETE CASCADE ON UPDATE CASCADE; '` (`id`) ON DELETE CASCADE ON UPDATE CASCADE;
' ',
); );
$this->db->query( $this->db->query(
@ -419,7 +419,7 @@ class Migration_Specific_calendar_sync extends EA_Migration
'_2` FOREIGN KEY (`id_users_provider`) REFERENCES `' . '_2` FOREIGN KEY (`id_users_provider`) REFERENCES `' .
$this->db->dbprefix('users') . $this->db->dbprefix('users') .
'` (`id`) ON DELETE CASCADE ON UPDATE CASCADE; '` (`id`) ON DELETE CASCADE ON UPDATE CASCADE;
' ',
); );
$this->db->query( $this->db->query(
@ -432,7 +432,7 @@ class Migration_Specific_calendar_sync extends EA_Migration
'_ibfk_1` FOREIGN KEY (`id_service_categories`) REFERENCES `' . '_ibfk_1` FOREIGN KEY (`id_service_categories`) REFERENCES `' .
$this->db->dbprefix('service_categories') . $this->db->dbprefix('service_categories') .
'` (`id`) ON DELETE SET NULL ON UPDATE CASCADE; '` (`id`) ON DELETE SET NULL ON UPDATE CASCADE;
' ',
); );
$this->db->query( $this->db->query(
@ -450,7 +450,7 @@ class Migration_Specific_calendar_sync extends EA_Migration
'_ibfk_2` FOREIGN KEY (`id_services`) REFERENCES `' . '_ibfk_2` FOREIGN KEY (`id_services`) REFERENCES `' .
$this->db->dbprefix('services') . $this->db->dbprefix('services') .
'` (`id`) ON DELETE CASCADE ON UPDATE CASCADE; '` (`id`) ON DELETE CASCADE ON UPDATE CASCADE;
' ',
); );
$this->db->query( $this->db->query(
@ -463,7 +463,7 @@ class Migration_Specific_calendar_sync extends EA_Migration
'_ibfk_1` FOREIGN KEY (`id_roles`) REFERENCES `' . '_ibfk_1` FOREIGN KEY (`id_roles`) REFERENCES `' .
$this->db->dbprefix('roles') . $this->db->dbprefix('roles') .
'` (`id`) ON DELETE CASCADE ON UPDATE CASCADE; '` (`id`) ON DELETE CASCADE ON UPDATE CASCADE;
' ',
); );
$this->db->query( $this->db->query(
@ -477,7 +477,7 @@ class Migration_Specific_calendar_sync extends EA_Migration
$this->db->dbprefix('users') . $this->db->dbprefix('users') .
'` (`id`) ON DELETE CASCADE ON UPDATE CASCADE; '` (`id`) ON DELETE CASCADE ON UPDATE CASCADE;
' ',
); );
$this->db->insert('roles', [ $this->db->insert('roles', [
@ -489,7 +489,7 @@ class Migration_Specific_calendar_sync extends EA_Migration
'services' => 15, 'services' => 15,
'users' => 15, 'users' => 15,
'system_settings' => 15, 'system_settings' => 15,
'user_settings' => 15 'user_settings' => 15,
]); ]);
$this->db->insert('roles', [ $this->db->insert('roles', [
@ -501,7 +501,7 @@ class Migration_Specific_calendar_sync extends EA_Migration
'services' => 0, 'services' => 0,
'users' => 0, 'users' => 0,
'system_settings' => 0, 'system_settings' => 0,
'user_settings' => 15 'user_settings' => 15,
]); ]);
$this->db->insert('roles', [ $this->db->insert('roles', [
@ -513,7 +513,7 @@ class Migration_Specific_calendar_sync extends EA_Migration
'services' => 0, 'services' => 0,
'users' => 0, 'users' => 0,
'system_settings' => 0, 'system_settings' => 0,
'user_settings' => 0 'user_settings' => 0,
]); ]);
$this->db->insert('roles', [ $this->db->insert('roles', [
@ -525,18 +525,18 @@ class Migration_Specific_calendar_sync extends EA_Migration
'services' => 0, 'services' => 0,
'users' => 0, 'users' => 0,
'system_settings' => 0, 'system_settings' => 0,
'user_settings' => 15 'user_settings' => 15,
]); ]);
$this->db->insert('settings', [ $this->db->insert('settings', [
'name' => 'company_working_plan', 'name' => 'company_working_plan',
'value' => 'value' =>
'{"monday":{"start":"09:00","end":"18:00","breaks":[{"start":"14:30","end":"15:00"}]},"tuesday":{"start":"09:00","end":"18:00","breaks":[{"start":"14:30","end":"15:00"}]},"wednesday":{"start":"09:00","end":"18:00","breaks":[{"start":"14:30","end":"15:00"}]},"thursday":{"start":"09:00","end":"18:00","breaks":[{"start":"14:30","end":"15:00"}]},"friday":{"start":"09:00","end":"18:00","breaks":[{"start":"14:30","end":"15:00"}]},"saturday":{"start":"09:00","end":"18:00","breaks":[{"start":"14:30","end":"15:00"}]},"sunday":{"start":"09:00","end":"18:00","breaks":[{"start":"14:30","end":"15:00"}]}}' '{"monday":{"start":"09:00","end":"18:00","breaks":[{"start":"14:30","end":"15:00"}]},"tuesday":{"start":"09:00","end":"18:00","breaks":[{"start":"14:30","end":"15:00"}]},"wednesday":{"start":"09:00","end":"18:00","breaks":[{"start":"14:30","end":"15:00"}]},"thursday":{"start":"09:00","end":"18:00","breaks":[{"start":"14:30","end":"15:00"}]},"friday":{"start":"09:00","end":"18:00","breaks":[{"start":"14:30","end":"15:00"}]},"saturday":{"start":"09:00","end":"18:00","breaks":[{"start":"14:30","end":"15:00"}]},"sunday":{"start":"09:00","end":"18:00","breaks":[{"start":"14:30","end":"15:00"}]}}',
]); ]);
$this->db->insert('settings', [ $this->db->insert('settings', [
'name' => 'book_advance_timeout', 'name' => 'book_advance_timeout',
'value' => '30' 'value' => '30',
]); ]);
} }
@ -550,70 +550,70 @@ class Migration_Specific_calendar_sync extends EA_Migration
$this->db->dbprefix('appointments') . $this->db->dbprefix('appointments') .
'` DROP FOREIGN KEY `' . '` DROP FOREIGN KEY `' .
$this->db->dbprefix('appointments') . $this->db->dbprefix('appointments') .
'_ibfk_2`' '_ibfk_2`',
); );
$this->db->query( $this->db->query(
'ALTER TABLE `' . 'ALTER TABLE `' .
$this->db->dbprefix('appointments') . $this->db->dbprefix('appointments') .
'` DROP FOREIGN KEY `' . '` DROP FOREIGN KEY `' .
$this->db->dbprefix('appointments') . $this->db->dbprefix('appointments') .
'_ibfk_3`' '_ibfk_3`',
); );
$this->db->query( $this->db->query(
'ALTER TABLE `' . 'ALTER TABLE `' .
$this->db->dbprefix('appointments') . $this->db->dbprefix('appointments') .
'` DROP FOREIGN KEY `' . '` DROP FOREIGN KEY `' .
$this->db->dbprefix('appointments') . $this->db->dbprefix('appointments') .
'_ibfk_4`' '_ibfk_4`',
); );
$this->db->query( $this->db->query(
'ALTER TABLE `' . 'ALTER TABLE `' .
$this->db->dbprefix('secretaries_providers') . $this->db->dbprefix('secretaries_providers') .
'` DROP FOREIGN KEY `fk_' . '` DROP FOREIGN KEY `fk_' .
$this->db->dbprefix('secretaries_providers') . $this->db->dbprefix('secretaries_providers') .
'_1`' '_1`',
); );
$this->db->query( $this->db->query(
'ALTER TABLE `' . 'ALTER TABLE `' .
$this->db->dbprefix('secretaries_providers') . $this->db->dbprefix('secretaries_providers') .
'` DROP FOREIGN KEY `fk_' . '` DROP FOREIGN KEY `fk_' .
$this->db->dbprefix('secretaries_providers') . $this->db->dbprefix('secretaries_providers') .
'_2`' '_2`',
); );
$this->db->query( $this->db->query(
'ALTER TABLE `' . 'ALTER TABLE `' .
$this->db->dbprefix('services_providers') . $this->db->dbprefix('services_providers') .
'` DROP FOREIGN KEY `' . '` DROP FOREIGN KEY `' .
$this->db->dbprefix('services_providers') . $this->db->dbprefix('services_providers') .
'_ibfk_1`' '_ibfk_1`',
); );
$this->db->query( $this->db->query(
'ALTER TABLE `' . 'ALTER TABLE `' .
$this->db->dbprefix('services_providers') . $this->db->dbprefix('services_providers') .
'` DROP FOREIGN KEY `' . '` DROP FOREIGN KEY `' .
$this->db->dbprefix('services_providers') . $this->db->dbprefix('services_providers') .
'_ibfk_2`' '_ibfk_2`',
); );
$this->db->query( $this->db->query(
'ALTER TABLE `' . 'ALTER TABLE `' .
$this->db->dbprefix('services') . $this->db->dbprefix('services') .
'` DROP FOREIGN KEY `' . '` DROP FOREIGN KEY `' .
$this->db->dbprefix('services') . $this->db->dbprefix('services') .
'_ibfk_1`' '_ibfk_1`',
); );
$this->db->query( $this->db->query(
'ALTER TABLE `' . 'ALTER TABLE `' .
$this->db->dbprefix('users') . $this->db->dbprefix('users') .
'` DROP FOREIGN KEY `' . '` DROP FOREIGN KEY `' .
$this->db->dbprefix('users') . $this->db->dbprefix('users') .
'_ibfk_1`' '_ibfk_1`',
); );
$this->db->query( $this->db->query(
'ALTER TABLE `' . 'ALTER TABLE `' .
$this->db->dbprefix('user_settings') . $this->db->dbprefix('user_settings') .
'` DROP FOREIGN KEY `' . '` DROP FOREIGN KEY `' .
$this->db->dbprefix('user_settings') . $this->db->dbprefix('user_settings') .
'_ibfk_1`' '_ibfk_1`',
); );
$this->dbforge->drop_table('appointments'); $this->dbforge->drop_table('appointments');

View file

@ -23,7 +23,7 @@ class Migration_Add_google_analytics_setting extends EA_Migration
if (!$this->db->get_where('settings', ['name' => 'google_analytics_code'])->num_rows()) { if (!$this->db->get_where('settings', ['name' => 'google_analytics_code'])->num_rows()) {
$this->db->insert('settings', [ $this->db->insert('settings', [
'name' => 'google_analytics_code', 'name' => 'google_analytics_code',
'value' => '' 'value' => '',
]); ]);
} }
} }

View file

@ -23,7 +23,7 @@ class Migration_Add_customer_notifications_setting extends EA_Migration
if (!$this->db->get_where('settings', ['name' => 'customer_notifications'])->num_rows()) { if (!$this->db->get_where('settings', ['name' => 'customer_notifications'])->num_rows()) {
$this->db->insert('settings', [ $this->db->insert('settings', [
'name' => 'customer_notifications', 'name' => 'customer_notifications',
'value' => '1' 'value' => '1',
]); ]);
} }
} }

View file

@ -23,7 +23,7 @@ class Migration_Add_date_format_setting extends EA_Migration
if (!$this->db->get_where('settings', ['name' => 'date_format'])->num_rows()) { if (!$this->db->get_where('settings', ['name' => 'date_format'])->num_rows()) {
$this->db->insert('settings', [ $this->db->insert('settings', [
'name' => 'date_format', 'name' => 'date_format',
'value' => 'DMY' 'value' => 'DMY',
]); ]);
} }
} }

View file

@ -23,7 +23,7 @@ class Migration_Add_require_captcha_setting extends EA_Migration
if (!$this->db->get_where('settings', ['name' => 'require_captcha'])->num_rows()) { if (!$this->db->get_where('settings', ['name' => 'require_captcha'])->num_rows()) {
$this->db->insert('settings', [ $this->db->insert('settings', [
'name' => 'require_captcha', 'name' => 'require_captcha',
'value' => '0' 'value' => '0',
]); ]);
} }
} }

View file

@ -23,8 +23,8 @@ class Migration_Add_calendar_view_setting extends EA_Migration
'calendar_view' => [ 'calendar_view' => [
'type' => 'VARCHAR', 'type' => 'VARCHAR',
'constraint' => '32', 'constraint' => '32',
'default' => 'default' 'default' => 'default',
] ],
]; ];
$this->dbforge->add_column('user_settings', $fields); $this->dbforge->add_column('user_settings', $fields);

View file

@ -24,8 +24,8 @@ class Migration_Add_service_availabilities_type extends EA_Migration
'type' => 'VARCHAR', 'type' => 'VARCHAR',
'constraint' => '32', 'constraint' => '32',
'default' => 'flexible', 'default' => 'flexible',
'after' => 'description' 'after' => 'description',
] ],
]; ];
$this->dbforge->add_column('services', $fields); $this->dbforge->add_column('services', $fields);

View file

@ -24,8 +24,8 @@ class Migration_Add_service_attendants_number extends EA_Migration
'type' => 'INT', 'type' => 'INT',
'constraint' => '11', 'constraint' => '11',
'default' => '1', 'default' => '1',
'after' => 'availabilities_type' 'after' => 'availabilities_type',
] ],
]; ];
$this->dbforge->add_column('services', $fields); $this->dbforge->add_column('services', $fields);

View file

@ -24,70 +24,70 @@ class Migration_Change_column_types extends EA_Migration
$this->db->dbprefix('appointments') . $this->db->dbprefix('appointments') .
'` DROP FOREIGN KEY `' . '` DROP FOREIGN KEY `' .
$this->db->dbprefix('appointments') . $this->db->dbprefix('appointments') .
'_ibfk_2`' '_ibfk_2`',
); );
$this->db->query( $this->db->query(
'ALTER TABLE `' . 'ALTER TABLE `' .
$this->db->dbprefix('appointments') . $this->db->dbprefix('appointments') .
'` DROP FOREIGN KEY `' . '` DROP FOREIGN KEY `' .
$this->db->dbprefix('appointments') . $this->db->dbprefix('appointments') .
'_ibfk_3`' '_ibfk_3`',
); );
$this->db->query( $this->db->query(
'ALTER TABLE `' . 'ALTER TABLE `' .
$this->db->dbprefix('appointments') . $this->db->dbprefix('appointments') .
'` DROP FOREIGN KEY `' . '` DROP FOREIGN KEY `' .
$this->db->dbprefix('appointments') . $this->db->dbprefix('appointments') .
'_ibfk_4`' '_ibfk_4`',
); );
$this->db->query( $this->db->query(
'ALTER TABLE `' . 'ALTER TABLE `' .
$this->db->dbprefix('secretaries_providers') . $this->db->dbprefix('secretaries_providers') .
'` DROP FOREIGN KEY `fk_' . '` DROP FOREIGN KEY `fk_' .
$this->db->dbprefix('secretaries_providers') . $this->db->dbprefix('secretaries_providers') .
'_1`' '_1`',
); );
$this->db->query( $this->db->query(
'ALTER TABLE `' . 'ALTER TABLE `' .
$this->db->dbprefix('secretaries_providers') . $this->db->dbprefix('secretaries_providers') .
'` DROP FOREIGN KEY `fk_' . '` DROP FOREIGN KEY `fk_' .
$this->db->dbprefix('secretaries_providers') . $this->db->dbprefix('secretaries_providers') .
'_2`' '_2`',
); );
$this->db->query( $this->db->query(
'ALTER TABLE `' . 'ALTER TABLE `' .
$this->db->dbprefix('services_providers') . $this->db->dbprefix('services_providers') .
'` DROP FOREIGN KEY `' . '` DROP FOREIGN KEY `' .
$this->db->dbprefix('services_providers') . $this->db->dbprefix('services_providers') .
'_ibfk_1`' '_ibfk_1`',
); );
$this->db->query( $this->db->query(
'ALTER TABLE `' . 'ALTER TABLE `' .
$this->db->dbprefix('services_providers') . $this->db->dbprefix('services_providers') .
'` DROP FOREIGN KEY `' . '` DROP FOREIGN KEY `' .
$this->db->dbprefix('services_providers') . $this->db->dbprefix('services_providers') .
'_ibfk_2`' '_ibfk_2`',
); );
$this->db->query( $this->db->query(
'ALTER TABLE `' . 'ALTER TABLE `' .
$this->db->dbprefix('services') . $this->db->dbprefix('services') .
'` DROP FOREIGN KEY `' . '` DROP FOREIGN KEY `' .
$this->db->dbprefix('services') . $this->db->dbprefix('services') .
'_ibfk_1`' '_ibfk_1`',
); );
$this->db->query( $this->db->query(
'ALTER TABLE `' . 'ALTER TABLE `' .
$this->db->dbprefix('users') . $this->db->dbprefix('users') .
'` DROP FOREIGN KEY `' . '` DROP FOREIGN KEY `' .
$this->db->dbprefix('users') . $this->db->dbprefix('users') .
'_ibfk_1`' '_ibfk_1`',
); );
$this->db->query( $this->db->query(
'ALTER TABLE `' . 'ALTER TABLE `' .
$this->db->dbprefix('user_settings') . $this->db->dbprefix('user_settings') .
'` DROP FOREIGN KEY `' . '` DROP FOREIGN KEY `' .
$this->db->dbprefix('user_settings') . $this->db->dbprefix('user_settings') .
'_ibfk_1`' '_ibfk_1`',
); );
// Appointments // Appointments
@ -96,23 +96,23 @@ class Migration_Change_column_types extends EA_Migration
'name' => 'id', 'name' => 'id',
'type' => 'int', 'type' => 'int',
'constraint' => '11', 'constraint' => '11',
'auto_increment' => true 'auto_increment' => true,
], ],
'id_users_provider' => [ 'id_users_provider' => [
'name' => 'id_users_provider', 'name' => 'id_users_provider',
'type' => 'int', 'type' => 'int',
'constraint' => '11' 'constraint' => '11',
], ],
'id_users_customer' => [ 'id_users_customer' => [
'name' => 'id_users_customer', 'name' => 'id_users_customer',
'type' => 'int', 'type' => 'int',
'constraint' => '11' 'constraint' => '11',
], ],
'id_services' => [ 'id_services' => [
'name' => 'id_services', 'name' => 'id_services',
'type' => 'int', 'type' => 'int',
'constraint' => '11' 'constraint' => '11',
] ],
]; ];
$this->dbforge->modify_column('appointments', $fields); $this->dbforge->modify_column('appointments', $fields);
@ -123,38 +123,38 @@ class Migration_Change_column_types extends EA_Migration
'name' => 'id', 'name' => 'id',
'type' => 'int', 'type' => 'int',
'constraint' => '11', 'constraint' => '11',
'auto_increment' => true 'auto_increment' => true,
], ],
'appointments' => [ 'appointments' => [
'name' => 'appointments', 'name' => 'appointments',
'type' => 'int', 'type' => 'int',
'constraint' => '11' 'constraint' => '11',
], ],
'customers' => [ 'customers' => [
'name' => 'customers', 'name' => 'customers',
'type' => 'int', 'type' => 'int',
'constraint' => '11' 'constraint' => '11',
], ],
'services' => [ 'services' => [
'name' => 'services', 'name' => 'services',
'type' => 'int', 'type' => 'int',
'constraint' => '11' 'constraint' => '11',
], ],
'users' => [ 'users' => [
'name' => 'users', 'name' => 'users',
'type' => 'int', 'type' => 'int',
'constraint' => '11' 'constraint' => '11',
], ],
'system_settings' => [ 'system_settings' => [
'name' => 'system_settings', 'name' => 'system_settings',
'type' => 'int', 'type' => 'int',
'constraint' => '11' 'constraint' => '11',
], ],
'user_settings' => [ 'user_settings' => [
'name' => 'user_settings', 'name' => 'user_settings',
'type' => 'int', 'type' => 'int',
'constraint' => '11' 'constraint' => '11',
] ],
]; ];
$this->dbforge->modify_column('roles', $fields); $this->dbforge->modify_column('roles', $fields);
@ -164,13 +164,13 @@ class Migration_Change_column_types extends EA_Migration
'id_users_secretary' => [ 'id_users_secretary' => [
'name' => 'id_users_secretary', 'name' => 'id_users_secretary',
'type' => 'int', 'type' => 'int',
'constraint' => '11' 'constraint' => '11',
], ],
'id_users_provider' => [ 'id_users_provider' => [
'name' => 'id_users_provider', 'name' => 'id_users_provider',
'type' => 'int', 'type' => 'int',
'constraint' => '11' 'constraint' => '11',
] ],
]; ];
$this->dbforge->modify_column('secretaries_providers', $fields); $this->dbforge->modify_column('secretaries_providers', $fields);
@ -181,13 +181,13 @@ class Migration_Change_column_types extends EA_Migration
'name' => 'id', 'name' => 'id',
'type' => 'int', 'type' => 'int',
'constraint' => '11', 'constraint' => '11',
'auto_increment' => true 'auto_increment' => true,
], ],
'id_service_categories' => [ 'id_service_categories' => [
'name' => 'id_service_categories', 'name' => 'id_service_categories',
'type' => 'int', 'type' => 'int',
'constraint' => '11' 'constraint' => '11',
] ],
]; ];
$this->dbforge->modify_column('services', $fields); $this->dbforge->modify_column('services', $fields);
@ -197,13 +197,13 @@ class Migration_Change_column_types extends EA_Migration
'id_users' => [ 'id_users' => [
'name' => 'id_users', 'name' => 'id_users',
'type' => 'int', 'type' => 'int',
'constraint' => '11' 'constraint' => '11',
], ],
'id_services' => [ 'id_services' => [
'name' => 'id_services', 'name' => 'id_services',
'type' => 'int', 'type' => 'int',
'constraint' => '11' 'constraint' => '11',
] ],
]; ];
$this->dbforge->modify_column('services_providers', $fields); $this->dbforge->modify_column('services_providers', $fields);
@ -214,8 +214,8 @@ class Migration_Change_column_types extends EA_Migration
'name' => 'id', 'name' => 'id',
'type' => 'int', 'type' => 'int',
'constraint' => '11', 'constraint' => '11',
'auto_increment' => true 'auto_increment' => true,
] ],
]; ];
$this->dbforge->modify_column('service_categories', $fields); $this->dbforge->modify_column('service_categories', $fields);
@ -226,8 +226,8 @@ class Migration_Change_column_types extends EA_Migration
'name' => 'id', 'name' => 'id',
'type' => 'int', 'type' => 'int',
'constraint' => '11', 'constraint' => '11',
'auto_increment' => true 'auto_increment' => true,
] ],
]; ];
$this->dbforge->modify_column('settings', $fields); $this->dbforge->modify_column('settings', $fields);
@ -238,13 +238,13 @@ class Migration_Change_column_types extends EA_Migration
'name' => 'id', 'name' => 'id',
'type' => 'int', 'type' => 'int',
'constraint' => '11', 'constraint' => '11',
'auto_increment' => true 'auto_increment' => true,
], ],
'id_roles' => [ 'id_roles' => [
'name' => 'id_roles', 'name' => 'id_roles',
'type' => 'int', 'type' => 'int',
'constraint' => '11' 'constraint' => '11',
] ],
]; ];
$this->dbforge->modify_column('users', $fields); $this->dbforge->modify_column('users', $fields);
@ -254,8 +254,8 @@ class Migration_Change_column_types extends EA_Migration
'id_users' => [ 'id_users' => [
'name' => 'id_users', 'name' => 'id_users',
'type' => 'int', 'type' => 'int',
'constraint' => '11' 'constraint' => '11',
] ],
]; ];
$this->dbforge->modify_column('user_settings', $fields); $this->dbforge->modify_column('user_settings', $fields);
@ -279,7 +279,7 @@ class Migration_Change_column_types extends EA_Migration
$this->db->dbprefix('appointments') . $this->db->dbprefix('appointments') .
'_ibfk_4` FOREIGN KEY (`id_users_provider`) REFERENCES `' . '_ibfk_4` FOREIGN KEY (`id_users_provider`) REFERENCES `' .
$this->db->dbprefix('users') . $this->db->dbprefix('users') .
'` (`id`) ON DELETE CASCADE ON UPDATE CASCADE' '` (`id`) ON DELETE CASCADE ON UPDATE CASCADE',
); );
$this->db->query( $this->db->query(
@ -295,7 +295,7 @@ class Migration_Change_column_types extends EA_Migration
$this->db->dbprefix('secretaries_providers') . $this->db->dbprefix('secretaries_providers') .
'_2` FOREIGN KEY (`id_users_provider`) REFERENCES `' . '_2` FOREIGN KEY (`id_users_provider`) REFERENCES `' .
$this->db->dbprefix('users') . $this->db->dbprefix('users') .
'` (`id`) ON DELETE CASCADE ON UPDATE CASCADE' '` (`id`) ON DELETE CASCADE ON UPDATE CASCADE',
); );
$this->db->query( $this->db->query(
@ -306,7 +306,7 @@ class Migration_Change_column_types extends EA_Migration
$this->db->dbprefix('services') . $this->db->dbprefix('services') .
'_ibfk_1` FOREIGN KEY (`id_service_categories`) REFERENCES `' . '_ibfk_1` FOREIGN KEY (`id_service_categories`) REFERENCES `' .
$this->db->dbprefix('service_categories') . $this->db->dbprefix('service_categories') .
'` (`id`) ON DELETE SET NULL ON UPDATE CASCADE' '` (`id`) ON DELETE SET NULL ON UPDATE CASCADE',
); );
$this->db->query( $this->db->query(
@ -322,7 +322,7 @@ class Migration_Change_column_types extends EA_Migration
$this->db->dbprefix('services_providers') . $this->db->dbprefix('services_providers') .
'_ibfk_2` FOREIGN KEY (`id_services`) REFERENCES `' . '_ibfk_2` FOREIGN KEY (`id_services`) REFERENCES `' .
$this->db->dbprefix('services') . $this->db->dbprefix('services') .
'` (`id`) ON DELETE CASCADE ON UPDATE CASCADE' '` (`id`) ON DELETE CASCADE ON UPDATE CASCADE',
); );
$this->db->query( $this->db->query(
@ -333,7 +333,7 @@ class Migration_Change_column_types extends EA_Migration
$this->db->dbprefix('users') . $this->db->dbprefix('users') .
'_ibfk_1` FOREIGN KEY (`id_roles`) REFERENCES `' . '_ibfk_1` FOREIGN KEY (`id_roles`) REFERENCES `' .
$this->db->dbprefix('roles') . $this->db->dbprefix('roles') .
'` (`id`) ON DELETE CASCADE ON UPDATE CASCADE' '` (`id`) ON DELETE CASCADE ON UPDATE CASCADE',
); );
$this->db->query( $this->db->query(
@ -344,12 +344,12 @@ class Migration_Change_column_types extends EA_Migration
$this->db->dbprefix('user_settings') . $this->db->dbprefix('user_settings') .
'_ibfk_1` FOREIGN KEY (`id_users`) REFERENCES `' . '_ibfk_1` FOREIGN KEY (`id_users`) REFERENCES `' .
$this->db->dbprefix('users') . $this->db->dbprefix('users') .
'` (`id`) ON DELETE CASCADE ON UPDATE CASCADE' '` (`id`) ON DELETE CASCADE ON UPDATE CASCADE',
); );
// Change charset of ' . $this->db->dbprefix('secretaries_providers') . ' table for databases created with EA! 1.2.1 version // Change charset of ' . $this->db->dbprefix('secretaries_providers') . ' table for databases created with EA! 1.2.1 version
$this->db->query( $this->db->query(
'ALTER TABLE ' . $this->db->dbprefix('secretaries_providers') . ' CONVERT TO CHARACTER SET utf8' 'ALTER TABLE ' . $this->db->dbprefix('secretaries_providers') . ' CONVERT TO CHARACTER SET utf8',
); );
} }
@ -364,70 +364,70 @@ class Migration_Change_column_types extends EA_Migration
$this->db->dbprefix('appointments') . $this->db->dbprefix('appointments') .
'` DROP FOREIGN KEY `' . '` DROP FOREIGN KEY `' .
$this->db->dbprefix('appointments') . $this->db->dbprefix('appointments') .
'_ibfk_2`' '_ibfk_2`',
); );
$this->db->query( $this->db->query(
'ALTER TABLE `' . 'ALTER TABLE `' .
$this->db->dbprefix('appointments') . $this->db->dbprefix('appointments') .
'` DROP FOREIGN KEY `' . '` DROP FOREIGN KEY `' .
$this->db->dbprefix('appointments') . $this->db->dbprefix('appointments') .
'_ibfk_3`' '_ibfk_3`',
); );
$this->db->query( $this->db->query(
'ALTER TABLE `' . 'ALTER TABLE `' .
$this->db->dbprefix('appointments') . $this->db->dbprefix('appointments') .
'` DROP FOREIGN KEY `' . '` DROP FOREIGN KEY `' .
$this->db->dbprefix('appointments') . $this->db->dbprefix('appointments') .
'_ibfk_4`' '_ibfk_4`',
); );
$this->db->query( $this->db->query(
'ALTER TABLE `' . 'ALTER TABLE `' .
$this->db->dbprefix('secretaries_providers') . $this->db->dbprefix('secretaries_providers') .
'` DROP FOREIGN KEY `fk_' . '` DROP FOREIGN KEY `fk_' .
$this->db->dbprefix('secretaries_providers') . $this->db->dbprefix('secretaries_providers') .
'_1`' '_1`',
); );
$this->db->query( $this->db->query(
'ALTER TABLE `' . 'ALTER TABLE `' .
$this->db->dbprefix('secretaries_providers') . $this->db->dbprefix('secretaries_providers') .
'` DROP FOREIGN KEY `fk_' . '` DROP FOREIGN KEY `fk_' .
$this->db->dbprefix('secretaries_providers') . $this->db->dbprefix('secretaries_providers') .
'_2`' '_2`',
); );
$this->db->query( $this->db->query(
'ALTER TABLE `' . 'ALTER TABLE `' .
$this->db->dbprefix('services_providers') . $this->db->dbprefix('services_providers') .
'` DROP FOREIGN KEY `' . '` DROP FOREIGN KEY `' .
$this->db->dbprefix('services_providers') . $this->db->dbprefix('services_providers') .
'_ibfk_1`' '_ibfk_1`',
); );
$this->db->query( $this->db->query(
'ALTER TABLE `' . 'ALTER TABLE `' .
$this->db->dbprefix('services_providers') . $this->db->dbprefix('services_providers') .
'` DROP FOREIGN KEY `' . '` DROP FOREIGN KEY `' .
$this->db->dbprefix('services_providers') . $this->db->dbprefix('services_providers') .
'_ibfk_2`' '_ibfk_2`',
); );
$this->db->query( $this->db->query(
'ALTER TABLE `' . 'ALTER TABLE `' .
$this->db->dbprefix('services') . $this->db->dbprefix('services') .
'` DROP FOREIGN KEY `' . '` DROP FOREIGN KEY `' .
$this->db->dbprefix('services') . $this->db->dbprefix('services') .
'_ibfk_1`' '_ibfk_1`',
); );
$this->db->query( $this->db->query(
'ALTER TABLE `' . 'ALTER TABLE `' .
$this->db->dbprefix('users') . $this->db->dbprefix('users') .
'` DROP FOREIGN KEY `' . '` DROP FOREIGN KEY `' .
$this->db->dbprefix('users') . $this->db->dbprefix('users') .
'_ibfk_1`' '_ibfk_1`',
); );
$this->db->query( $this->db->query(
'ALTER TABLE `' . 'ALTER TABLE `' .
$this->db->dbprefix('user_settings') . $this->db->dbprefix('user_settings') .
'` DROP FOREIGN KEY `' . '` DROP FOREIGN KEY `' .
$this->db->dbprefix('user_settings') . $this->db->dbprefix('user_settings') .
'_ibfk_1`' '_ibfk_1`',
); );
// Appointments // Appointments
@ -436,23 +436,23 @@ class Migration_Change_column_types extends EA_Migration
'name' => 'id', 'name' => 'id',
'type' => 'bigint', 'type' => 'bigint',
'constraint' => '20', 'constraint' => '20',
'auto_increment' => true 'auto_increment' => true,
], ],
'id_users_provider' => [ 'id_users_provider' => [
'name' => 'id_users_provider', 'name' => 'id_users_provider',
'type' => 'bigint', 'type' => 'bigint',
'constraint' => '20' 'constraint' => '20',
], ],
'id_users_customer' => [ 'id_users_customer' => [
'name' => 'id_users_customer', 'name' => 'id_users_customer',
'type' => 'bigint', 'type' => 'bigint',
'constraint' => '20' 'constraint' => '20',
], ],
'id_services' => [ 'id_services' => [
'name' => 'id_services', 'name' => 'id_services',
'type' => 'bigint', 'type' => 'bigint',
'constraint' => '20' 'constraint' => '20',
] ],
]; ];
$this->dbforge->modify_column('appointments', $fields); $this->dbforge->modify_column('appointments', $fields);
@ -463,38 +463,38 @@ class Migration_Change_column_types extends EA_Migration
'name' => 'id', 'name' => 'id',
'type' => 'bigint', 'type' => 'bigint',
'constraint' => '20', 'constraint' => '20',
'auto_increment' => true 'auto_increment' => true,
], ],
'appointments' => [ 'appointments' => [
'name' => 'appointments', 'name' => 'appointments',
'type' => 'bigint', 'type' => 'bigint',
'constraint' => '20' 'constraint' => '20',
], ],
'customers' => [ 'customers' => [
'name' => 'customers', 'name' => 'customers',
'type' => 'bigint', 'type' => 'bigint',
'constraint' => '20' 'constraint' => '20',
], ],
'services' => [ 'services' => [
'name' => 'services', 'name' => 'services',
'type' => 'bigint', 'type' => 'bigint',
'constraint' => '20' 'constraint' => '20',
], ],
'users' => [ 'users' => [
'name' => 'users', 'name' => 'users',
'type' => 'bigint', 'type' => 'bigint',
'constraint' => '20' 'constraint' => '20',
], ],
'system_settings' => [ 'system_settings' => [
'name' => 'system_settings', 'name' => 'system_settings',
'type' => 'bigint', 'type' => 'bigint',
'constraint' => '20' 'constraint' => '20',
], ],
'user_settings' => [ 'user_settings' => [
'name' => 'user_settings', 'name' => 'user_settings',
'type' => 'bigint', 'type' => 'bigint',
'constraint' => '20' 'constraint' => '20',
] ],
]; ];
$this->dbforge->modify_column('roles', $fields); $this->dbforge->modify_column('roles', $fields);
@ -504,13 +504,13 @@ class Migration_Change_column_types extends EA_Migration
'id_users_secretary' => [ 'id_users_secretary' => [
'name' => 'id_users_secretary', 'name' => 'id_users_secretary',
'type' => 'bigint', 'type' => 'bigint',
'constraint' => '20' 'constraint' => '20',
], ],
'id_users_provider' => [ 'id_users_provider' => [
'name' => 'id_users_provider', 'name' => 'id_users_provider',
'type' => 'bigint', 'type' => 'bigint',
'constraint' => '20' 'constraint' => '20',
] ],
]; ];
$this->dbforge->modify_column('secretaries_providers', $fields); $this->dbforge->modify_column('secretaries_providers', $fields);
@ -521,13 +521,13 @@ class Migration_Change_column_types extends EA_Migration
'name' => 'id', 'name' => 'id',
'type' => 'bigint', 'type' => 'bigint',
'constraint' => '20', 'constraint' => '20',
'auto_increment' => true 'auto_increment' => true,
], ],
'id_service_categories' => [ 'id_service_categories' => [
'name' => 'id_service_categories', 'name' => 'id_service_categories',
'type' => 'bigint', 'type' => 'bigint',
'constraint' => '20' 'constraint' => '20',
] ],
]; ];
$this->dbforge->modify_column('services', $fields); $this->dbforge->modify_column('services', $fields);
@ -537,13 +537,13 @@ class Migration_Change_column_types extends EA_Migration
'id_users' => [ 'id_users' => [
'name' => 'id_users', 'name' => 'id_users',
'type' => 'bigint', 'type' => 'bigint',
'constraint' => '20' 'constraint' => '20',
], ],
'id_services' => [ 'id_services' => [
'name' => 'id_services', 'name' => 'id_services',
'type' => 'bigint', 'type' => 'bigint',
'constraint' => '20' 'constraint' => '20',
] ],
]; ];
$this->dbforge->modify_column('services_providers', $fields); $this->dbforge->modify_column('services_providers', $fields);
@ -554,8 +554,8 @@ class Migration_Change_column_types extends EA_Migration
'name' => 'id', 'name' => 'id',
'type' => 'bigint', 'type' => 'bigint',
'constraint' => '20', 'constraint' => '20',
'auto_increment' => true 'auto_increment' => true,
] ],
]; ];
$this->dbforge->modify_column('service_categories', $fields); $this->dbforge->modify_column('service_categories', $fields);
@ -566,8 +566,8 @@ class Migration_Change_column_types extends EA_Migration
'name' => 'id', 'name' => 'id',
'type' => 'bigint', 'type' => 'bigint',
'constraint' => '20', 'constraint' => '20',
'auto_increment' => true 'auto_increment' => true,
] ],
]; ];
$this->dbforge->modify_column('settings', $fields); $this->dbforge->modify_column('settings', $fields);
@ -578,13 +578,13 @@ class Migration_Change_column_types extends EA_Migration
'name' => 'id', 'name' => 'id',
'type' => 'bigint', 'type' => 'bigint',
'constraint' => '20', 'constraint' => '20',
'auto_increment' => true 'auto_increment' => true,
], ],
'id_roles' => [ 'id_roles' => [
'name' => 'id_roles', 'name' => 'id_roles',
'type' => 'bigint', 'type' => 'bigint',
'constraint' => '20' 'constraint' => '20',
] ],
]; ];
$this->dbforge->modify_column('users', $fields); $this->dbforge->modify_column('users', $fields);
@ -594,8 +594,8 @@ class Migration_Change_column_types extends EA_Migration
'id_users' => [ 'id_users' => [
'name' => 'id_users', 'name' => 'id_users',
'type' => 'bigint', 'type' => 'bigint',
'constraint' => '20' 'constraint' => '20',
] ],
]; ];
$this->dbforge->modify_column('user_settings', $fields); $this->dbforge->modify_column('user_settings', $fields);
@ -619,7 +619,7 @@ class Migration_Change_column_types extends EA_Migration
$this->db->dbprefix('appointments') . $this->db->dbprefix('appointments') .
'_ibfk_4` FOREIGN KEY (`id_users_provider`) REFERENCES `' . '_ibfk_4` FOREIGN KEY (`id_users_provider`) REFERENCES `' .
$this->db->dbprefix('users') . $this->db->dbprefix('users') .
'` (`id`) ON DELETE CASCADE ON UPDATE CASCADE' '` (`id`) ON DELETE CASCADE ON UPDATE CASCADE',
); );
$this->db->query( $this->db->query(
@ -635,7 +635,7 @@ class Migration_Change_column_types extends EA_Migration
$this->db->dbprefix('secretaries_providers') . $this->db->dbprefix('secretaries_providers') .
'_2` FOREIGN KEY (`id_users_provider`) REFERENCES `' . '_2` FOREIGN KEY (`id_users_provider`) REFERENCES `' .
$this->db->dbprefix('users') . $this->db->dbprefix('users') .
'` (`id`) ON DELETE CASCADE ON UPDATE CASCADE' '` (`id`) ON DELETE CASCADE ON UPDATE CASCADE',
); );
$this->db->query( $this->db->query(
@ -646,7 +646,7 @@ class Migration_Change_column_types extends EA_Migration
$this->db->dbprefix('services') . $this->db->dbprefix('services') .
'_ibfk_1` FOREIGN KEY (`id_service_categories`) REFERENCES `' . '_ibfk_1` FOREIGN KEY (`id_service_categories`) REFERENCES `' .
$this->db->dbprefix('service_categories') . $this->db->dbprefix('service_categories') .
'` (`id`) ON DELETE SET NULL ON UPDATE CASCADE' '` (`id`) ON DELETE SET NULL ON UPDATE CASCADE',
); );
$this->db->query( $this->db->query(
@ -662,7 +662,7 @@ class Migration_Change_column_types extends EA_Migration
$this->db->dbprefix('services_providers') . $this->db->dbprefix('services_providers') .
'_ibfk_2` FOREIGN KEY (`id_services`) REFERENCES `' . '_ibfk_2` FOREIGN KEY (`id_services`) REFERENCES `' .
$this->db->dbprefix('services') . $this->db->dbprefix('services') .
'` (`id`) ON DELETE CASCADE ON UPDATE CASCADE' '` (`id`) ON DELETE CASCADE ON UPDATE CASCADE',
); );
$this->db->query( $this->db->query(
@ -673,7 +673,7 @@ class Migration_Change_column_types extends EA_Migration
$this->db->dbprefix('users') . $this->db->dbprefix('users') .
'_ibfk_1` FOREIGN KEY (`id_roles`) REFERENCES `' . '_ibfk_1` FOREIGN KEY (`id_roles`) REFERENCES `' .
$this->db->dbprefix('roles') . $this->db->dbprefix('roles') .
'` (`id`) ON DELETE CASCADE ON UPDATE CASCADE' '` (`id`) ON DELETE CASCADE ON UPDATE CASCADE',
); );
$this->db->query( $this->db->query(
@ -684,7 +684,7 @@ class Migration_Change_column_types extends EA_Migration
$this->db->dbprefix('user_settings') . $this->db->dbprefix('user_settings') .
'_ibfk_1` FOREIGN KEY (`id_users`) REFERENCES `' . '_ibfk_1` FOREIGN KEY (`id_users`) REFERENCES `' .
$this->db->dbprefix('users') . $this->db->dbprefix('users') .
'` (`id`) ON DELETE CASCADE ON UPDATE CASCADE' '` (`id`) ON DELETE CASCADE ON UPDATE CASCADE',
); );
} }
} }

View file

@ -21,7 +21,7 @@ class Migration_Add_time_format_setting extends EA_Migration
if (!$this->db->get_where('settings', ['name' => 'time_format'])->num_rows()) { if (!$this->db->get_where('settings', ['name' => 'time_format'])->num_rows()) {
$this->db->insert('settings', [ $this->db->insert('settings', [
'name' => 'time_format', 'name' => 'time_format',
'value' => 'regular' 'value' => 'regular',
]); ]);
} }
} }

View file

@ -24,70 +24,70 @@ class Migration_Remove_prefix_from_fkey_constraints extends EA_Migration
$this->db->dbprefix('appointments') . $this->db->dbprefix('appointments') .
'` DROP FOREIGN KEY `' . '` DROP FOREIGN KEY `' .
$this->db->dbprefix('appointments') . $this->db->dbprefix('appointments') .
'_ibfk_2`' '_ibfk_2`',
); );
$this->db->query( $this->db->query(
'ALTER TABLE `' . 'ALTER TABLE `' .
$this->db->dbprefix('appointments') . $this->db->dbprefix('appointments') .
'` DROP FOREIGN KEY `' . '` DROP FOREIGN KEY `' .
$this->db->dbprefix('appointments') . $this->db->dbprefix('appointments') .
'_ibfk_3`' '_ibfk_3`',
); );
$this->db->query( $this->db->query(
'ALTER TABLE `' . 'ALTER TABLE `' .
$this->db->dbprefix('appointments') . $this->db->dbprefix('appointments') .
'` DROP FOREIGN KEY `' . '` DROP FOREIGN KEY `' .
$this->db->dbprefix('appointments') . $this->db->dbprefix('appointments') .
'_ibfk_4`' '_ibfk_4`',
); );
$this->db->query( $this->db->query(
'ALTER TABLE `' . 'ALTER TABLE `' .
$this->db->dbprefix('secretaries_providers') . $this->db->dbprefix('secretaries_providers') .
'` DROP FOREIGN KEY `fk_' . '` DROP FOREIGN KEY `fk_' .
$this->db->dbprefix('secretaries_providers') . $this->db->dbprefix('secretaries_providers') .
'_1`' '_1`',
); );
$this->db->query( $this->db->query(
'ALTER TABLE `' . 'ALTER TABLE `' .
$this->db->dbprefix('secretaries_providers') . $this->db->dbprefix('secretaries_providers') .
'` DROP FOREIGN KEY `fk_' . '` DROP FOREIGN KEY `fk_' .
$this->db->dbprefix('secretaries_providers') . $this->db->dbprefix('secretaries_providers') .
'_2`' '_2`',
); );
$this->db->query( $this->db->query(
'ALTER TABLE `' . 'ALTER TABLE `' .
$this->db->dbprefix('services_providers') . $this->db->dbprefix('services_providers') .
'` DROP FOREIGN KEY `' . '` DROP FOREIGN KEY `' .
$this->db->dbprefix('services_providers') . $this->db->dbprefix('services_providers') .
'_ibfk_1`' '_ibfk_1`',
); );
$this->db->query( $this->db->query(
'ALTER TABLE `' . 'ALTER TABLE `' .
$this->db->dbprefix('services_providers') . $this->db->dbprefix('services_providers') .
'` DROP FOREIGN KEY `' . '` DROP FOREIGN KEY `' .
$this->db->dbprefix('services_providers') . $this->db->dbprefix('services_providers') .
'_ibfk_2`' '_ibfk_2`',
); );
$this->db->query( $this->db->query(
'ALTER TABLE `' . 'ALTER TABLE `' .
$this->db->dbprefix('services') . $this->db->dbprefix('services') .
'` DROP FOREIGN KEY `' . '` DROP FOREIGN KEY `' .
$this->db->dbprefix('services') . $this->db->dbprefix('services') .
'_ibfk_1`' '_ibfk_1`',
); );
$this->db->query( $this->db->query(
'ALTER TABLE `' . 'ALTER TABLE `' .
$this->db->dbprefix('users') . $this->db->dbprefix('users') .
'` DROP FOREIGN KEY `' . '` DROP FOREIGN KEY `' .
$this->db->dbprefix('users') . $this->db->dbprefix('users') .
'_ibfk_1`' '_ibfk_1`',
); );
$this->db->query( $this->db->query(
'ALTER TABLE `' . 'ALTER TABLE `' .
$this->db->dbprefix('user_settings') . $this->db->dbprefix('user_settings') .
'` DROP FOREIGN KEY `' . '` DROP FOREIGN KEY `' .
$this->db->dbprefix('user_settings') . $this->db->dbprefix('user_settings') .
'_ibfk_1`' '_ibfk_1`',
); );
// Add table constraints again without the "ea" prefix. // Add table constraints again without the "ea" prefix.
@ -109,7 +109,7 @@ class Migration_Remove_prefix_from_fkey_constraints extends EA_Migration
$this->db->dbprefix('users') . $this->db->dbprefix('users') .
'` (`id`) '` (`id`)
ON DELETE CASCADE ON DELETE CASCADE
ON UPDATE CASCADE' ON UPDATE CASCADE',
); );
$this->db->query( $this->db->query(
@ -125,7 +125,7 @@ class Migration_Remove_prefix_from_fkey_constraints extends EA_Migration
$this->db->dbprefix('users') . $this->db->dbprefix('users') .
'` (`id`) '` (`id`)
ON DELETE CASCADE ON DELETE CASCADE
ON UPDATE CASCADE' ON UPDATE CASCADE',
); );
$this->db->query( $this->db->query(
@ -136,7 +136,7 @@ class Migration_Remove_prefix_from_fkey_constraints extends EA_Migration
$this->db->dbprefix('service_categories') . $this->db->dbprefix('service_categories') .
'` (`id`) '` (`id`)
ON DELETE SET NULL ON DELETE SET NULL
ON UPDATE CASCADE' ON UPDATE CASCADE',
); );
$this->db->query( $this->db->query(
@ -152,7 +152,7 @@ class Migration_Remove_prefix_from_fkey_constraints extends EA_Migration
$this->db->dbprefix('services') . $this->db->dbprefix('services') .
'` (`id`) '` (`id`)
ON DELETE CASCADE ON DELETE CASCADE
ON UPDATE CASCADE' ON UPDATE CASCADE',
); );
$this->db->query( $this->db->query(
@ -163,7 +163,7 @@ class Migration_Remove_prefix_from_fkey_constraints extends EA_Migration
$this->db->dbprefix('roles') . $this->db->dbprefix('roles') .
'` (`id`) '` (`id`)
ON DELETE CASCADE ON DELETE CASCADE
ON UPDATE CASCADE' ON UPDATE CASCADE',
); );
$this->db->query( $this->db->query(
@ -174,7 +174,7 @@ class Migration_Remove_prefix_from_fkey_constraints extends EA_Migration
$this->db->dbprefix('users') . $this->db->dbprefix('users') .
'` (`id`) '` (`id`)
ON DELETE CASCADE ON DELETE CASCADE
ON UPDATE CASCADE' ON UPDATE CASCADE',
); );
} }
@ -185,40 +185,40 @@ class Migration_Remove_prefix_from_fkey_constraints extends EA_Migration
{ {
// Drop table constraints. // Drop table constraints.
$this->db->query( $this->db->query(
'ALTER TABLE `' . $this->db->dbprefix('appointments') . '` DROP FOREIGN KEY `appointments_services`' 'ALTER TABLE `' . $this->db->dbprefix('appointments') . '` DROP FOREIGN KEY `appointments_services`',
); );
$this->db->query( $this->db->query(
'ALTER TABLE `' . $this->db->dbprefix('appointments') . '` DROP FOREIGN KEY `appointments_users_customer`' 'ALTER TABLE `' . $this->db->dbprefix('appointments') . '` DROP FOREIGN KEY `appointments_users_customer`',
); );
$this->db->query( $this->db->query(
'ALTER TABLE `' . $this->db->dbprefix('appointments') . '` DROP FOREIGN KEY `appointments_users_provider`' 'ALTER TABLE `' . $this->db->dbprefix('appointments') . '` DROP FOREIGN KEY `appointments_users_provider`',
); );
$this->db->query( $this->db->query(
'ALTER TABLE `' . 'ALTER TABLE `' .
$this->db->dbprefix('secretaries_providers') . $this->db->dbprefix('secretaries_providers') .
'` DROP FOREIGN KEY `secretaries_users_secretary`' '` DROP FOREIGN KEY `secretaries_users_secretary`',
); );
$this->db->query( $this->db->query(
'ALTER TABLE `' . 'ALTER TABLE `' .
$this->db->dbprefix('secretaries_providers') . $this->db->dbprefix('secretaries_providers') .
'` DROP FOREIGN KEY `secretaries_users_provider`' '` DROP FOREIGN KEY `secretaries_users_provider`',
); );
$this->db->query( $this->db->query(
'ALTER TABLE `' . 'ALTER TABLE `' .
$this->db->dbprefix('services_providers') . $this->db->dbprefix('services_providers') .
'` DROP FOREIGN KEY `services_providers_users_provider`' '` DROP FOREIGN KEY `services_providers_users_provider`',
); );
$this->db->query( $this->db->query(
'ALTER TABLE `' . 'ALTER TABLE `' .
$this->db->dbprefix('services_providers') . $this->db->dbprefix('services_providers') .
'` DROP FOREIGN KEY `services_providers_services`' '` DROP FOREIGN KEY `services_providers_services`',
); );
$this->db->query( $this->db->query(
'ALTER TABLE `' . $this->db->dbprefix('services') . '` DROP FOREIGN KEY `services_service_categories`' 'ALTER TABLE `' . $this->db->dbprefix('services') . '` DROP FOREIGN KEY `services_service_categories`',
); );
$this->db->query('ALTER TABLE `' . $this->db->dbprefix('users') . '` DROP FOREIGN KEY `users_roles`'); $this->db->query('ALTER TABLE `' . $this->db->dbprefix('users') . '` DROP FOREIGN KEY `users_roles`');
$this->db->query( $this->db->query(
'ALTER TABLE `' . $this->db->dbprefix('user_settings') . '` DROP FOREIGN KEY `user_settings_users`' 'ALTER TABLE `' . $this->db->dbprefix('user_settings') . '` DROP FOREIGN KEY `user_settings_users`',
); );
// Add table constraints again. // Add table constraints again.
@ -240,7 +240,7 @@ class Migration_Remove_prefix_from_fkey_constraints extends EA_Migration
$this->db->dbprefix('appointments') . $this->db->dbprefix('appointments') .
'_ibfk_4` FOREIGN KEY (`id_users_provider`) REFERENCES `' . '_ibfk_4` FOREIGN KEY (`id_users_provider`) REFERENCES `' .
$this->db->dbprefix('users') . $this->db->dbprefix('users') .
'` (`id`) ON DELETE CASCADE ON UPDATE CASCADE' '` (`id`) ON DELETE CASCADE ON UPDATE CASCADE',
); );
$this->db->query( $this->db->query(
@ -256,7 +256,7 @@ class Migration_Remove_prefix_from_fkey_constraints extends EA_Migration
$this->db->dbprefix('secretaries_providers') . $this->db->dbprefix('secretaries_providers') .
'_2` FOREIGN KEY (`id_users_provider`) REFERENCES `' . '_2` FOREIGN KEY (`id_users_provider`) REFERENCES `' .
$this->db->dbprefix('users') . $this->db->dbprefix('users') .
'` (`id`) ON DELETE CASCADE ON UPDATE CASCADE' '` (`id`) ON DELETE CASCADE ON UPDATE CASCADE',
); );
$this->db->query( $this->db->query(
@ -267,7 +267,7 @@ class Migration_Remove_prefix_from_fkey_constraints extends EA_Migration
$this->db->dbprefix('services') . $this->db->dbprefix('services') .
'_ibfk_1` FOREIGN KEY (`id_service_categories`) REFERENCES `' . '_ibfk_1` FOREIGN KEY (`id_service_categories`) REFERENCES `' .
$this->db->dbprefix('service_categories') . $this->db->dbprefix('service_categories') .
'` (`id`) ON DELETE SET NULL ON UPDATE CASCADE' '` (`id`) ON DELETE SET NULL ON UPDATE CASCADE',
); );
$this->db->query( $this->db->query(
@ -283,7 +283,7 @@ class Migration_Remove_prefix_from_fkey_constraints extends EA_Migration
$this->db->dbprefix('services_providers') . $this->db->dbprefix('services_providers') .
'_ibfk_2` FOREIGN KEY (`id_services`) REFERENCES `' . '_ibfk_2` FOREIGN KEY (`id_services`) REFERENCES `' .
$this->db->dbprefix('services') . $this->db->dbprefix('services') .
'` (`id`) ON DELETE CASCADE ON UPDATE CASCADE' '` (`id`) ON DELETE CASCADE ON UPDATE CASCADE',
); );
$this->db->query( $this->db->query(
@ -294,7 +294,7 @@ class Migration_Remove_prefix_from_fkey_constraints extends EA_Migration
$this->db->dbprefix('users') . $this->db->dbprefix('users') .
'_ibfk_1` FOREIGN KEY (`id_roles`) REFERENCES `' . '_ibfk_1` FOREIGN KEY (`id_roles`) REFERENCES `' .
$this->db->dbprefix('roles') . $this->db->dbprefix('roles') .
'` (`id`) ON DELETE CASCADE ON UPDATE CASCADE' '` (`id`) ON DELETE CASCADE ON UPDATE CASCADE',
); );
$this->db->query( $this->db->query(
@ -305,7 +305,7 @@ class Migration_Remove_prefix_from_fkey_constraints extends EA_Migration
$this->db->dbprefix('user_settings') . $this->db->dbprefix('user_settings') .
'_ibfk_1` FOREIGN KEY (`id_users`) REFERENCES `' . '_ibfk_1` FOREIGN KEY (`id_users`) REFERENCES `' .
$this->db->dbprefix('users') . $this->db->dbprefix('users') .
'` (`id`) ON DELETE CASCADE ON UPDATE CASCADE' '` (`id`) ON DELETE CASCADE ON UPDATE CASCADE',
); );
} }
} }

View file

@ -21,42 +21,42 @@ class Migration_Legal_contents extends EA_Migration
if (!$this->db->get_where('settings', ['name' => 'display_cookie_notice'])->num_rows()) { if (!$this->db->get_where('settings', ['name' => 'display_cookie_notice'])->num_rows()) {
$this->db->insert('settings', [ $this->db->insert('settings', [
'name' => 'display_cookie_notice', 'name' => 'display_cookie_notice',
'value' => '0' 'value' => '0',
]); ]);
} }
if (!$this->db->get_where('settings', ['name' => 'cookie_notice_content'])->num_rows()) { if (!$this->db->get_where('settings', ['name' => 'cookie_notice_content'])->num_rows()) {
$this->db->insert('settings', [ $this->db->insert('settings', [
'name' => 'cookie_notice_content', 'name' => 'cookie_notice_content',
'value' => 'Cookie notice content.' 'value' => 'Cookie notice content.',
]); ]);
} }
if (!$this->db->get_where('settings', ['name' => 'display_terms_and_conditions'])->num_rows()) { if (!$this->db->get_where('settings', ['name' => 'display_terms_and_conditions'])->num_rows()) {
$this->db->insert('settings', [ $this->db->insert('settings', [
'name' => 'display_terms_and_conditions', 'name' => 'display_terms_and_conditions',
'value' => '0' 'value' => '0',
]); ]);
} }
if (!$this->db->get_where('settings', ['name' => 'terms_and_conditions_content'])->num_rows()) { if (!$this->db->get_where('settings', ['name' => 'terms_and_conditions_content'])->num_rows()) {
$this->db->insert('settings', [ $this->db->insert('settings', [
'name' => 'terms_and_conditions_content', 'name' => 'terms_and_conditions_content',
'value' => 'Terms and conditions content.' 'value' => 'Terms and conditions content.',
]); ]);
} }
if (!$this->db->get_where('settings', ['name' => 'display_privacy_policy'])->num_rows()) { if (!$this->db->get_where('settings', ['name' => 'display_privacy_policy'])->num_rows()) {
$this->db->insert('settings', [ $this->db->insert('settings', [
'name' => 'display_privacy_policy', 'name' => 'display_privacy_policy',
'value' => '0' 'value' => '0',
]); ]);
} }
if (!$this->db->get_where('settings', ['name' => 'privacy_policy_content'])->num_rows()) { if (!$this->db->get_where('settings', ['name' => 'privacy_policy_content'])->num_rows()) {
$this->db->insert('settings', [ $this->db->insert('settings', [
'name' => 'privacy_policy_content', 'name' => 'privacy_policy_content',
'value' => 'Privacy policy content.' 'value' => 'Privacy policy content.',
]); ]);
} }
@ -65,41 +65,41 @@ class Migration_Legal_contents extends EA_Migration
'id' => [ 'id' => [
'type' => 'INT', 'type' => 'INT',
'constraint' => 11, 'constraint' => 11,
'auto_increment' => true 'auto_increment' => true,
], ],
'created' => [ 'created' => [
'type' => 'TIMESTAMP', 'type' => 'TIMESTAMP',
'null' => true 'null' => true,
], ],
'modified' => [ 'modified' => [
'type' => 'TIMESTAMP', 'type' => 'TIMESTAMP',
'null' => true 'null' => true,
], ],
'first_name' => [ 'first_name' => [
'type' => 'VARCHAR', 'type' => 'VARCHAR',
'constraint' => '256', 'constraint' => '256',
'null' => true 'null' => true,
], ],
'last_name' => [ 'last_name' => [
'type' => 'VARCHAR', 'type' => 'VARCHAR',
'constraint' => '256', 'constraint' => '256',
'null' => true 'null' => true,
], ],
'email' => [ 'email' => [
'type' => 'VARCHAR', 'type' => 'VARCHAR',
'constraint' => '512', 'constraint' => '512',
'null' => true 'null' => true,
], ],
'ip' => [ 'ip' => [
'type' => 'VARCHAR', 'type' => 'VARCHAR',
'constraint' => '256', 'constraint' => '256',
'null' => true 'null' => true,
], ],
'type' => [ 'type' => [
'type' => 'VARCHAR', 'type' => 'VARCHAR',
'constraint' => '256', 'constraint' => '256',
'null' => true 'null' => true,
] ],
]); ]);
$this->dbforge->add_key('id', true); $this->dbforge->add_key('id', true);
@ -115,37 +115,37 @@ class Migration_Legal_contents extends EA_Migration
{ {
if ($this->db->get_where('settings', ['name' => 'display_cookie_notice'])->num_rows()) { if ($this->db->get_where('settings', ['name' => 'display_cookie_notice'])->num_rows()) {
$this->db->delete('settings', [ $this->db->delete('settings', [
'name' => 'display_cookie_notice' 'name' => 'display_cookie_notice',
]); ]);
} }
if ($this->db->get_where('settings', ['name' => 'cookie_notice_content'])->num_rows()) { if ($this->db->get_where('settings', ['name' => 'cookie_notice_content'])->num_rows()) {
$this->db->delete('settings', [ $this->db->delete('settings', [
'name' => 'cookie_notice_content' 'name' => 'cookie_notice_content',
]); ]);
} }
if ($this->db->get_where('settings', ['name' => 'display_terms_and_conditions'])->num_rows()) { if ($this->db->get_where('settings', ['name' => 'display_terms_and_conditions'])->num_rows()) {
$this->db->delete('settings', [ $this->db->delete('settings', [
'name' => 'display_terms_and_conditions' 'name' => 'display_terms_and_conditions',
]); ]);
} }
if ($this->db->get_where('settings', ['name' => 'terms_and_conditions_content'])->num_rows()) { if ($this->db->get_where('settings', ['name' => 'terms_and_conditions_content'])->num_rows()) {
$this->db->delete('settings', [ $this->db->delete('settings', [
'name' => 'terms_and_conditions_content' 'name' => 'terms_and_conditions_content',
]); ]);
} }
if ($this->db->get_where('settings', ['name' => 'display_privacy_policy'])->num_rows()) { if ($this->db->get_where('settings', ['name' => 'display_privacy_policy'])->num_rows()) {
$this->db->delete('settings', [ $this->db->delete('settings', [
'name' => 'display_privacy_policy' 'name' => 'display_privacy_policy',
]); ]);
} }
if ($this->db->get_where('settings', ['name' => 'privacy_policy_content'])->num_rows()) { if ($this->db->get_where('settings', ['name' => 'privacy_policy_content'])->num_rows()) {
$this->db->delete('settings', [ $this->db->delete('settings', [
'name' => 'privacy_policy_content' 'name' => 'privacy_policy_content',
]); ]);
} }

View file

@ -21,7 +21,7 @@ class Migration_Add_weekday_start_setting extends EA_Migration
if (!$this->db->get_where('settings', ['name' => 'first_weekday'])->num_rows()) { if (!$this->db->get_where('settings', ['name' => 'first_weekday'])->num_rows()) {
$this->db->insert('settings', [ $this->db->insert('settings', [
'name' => 'first_weekday', 'name' => 'first_weekday',
'value' => 'sunday' 'value' => 'sunday',
]); ]);
} }
} }

View file

@ -23,8 +23,8 @@ class Migration_Create_appointment_location_column extends EA_Migration
'location' => [ 'location' => [
'type' => 'TEXT', 'type' => 'TEXT',
'null' => true, 'null' => true,
'after' => 'end_datetime' 'after' => 'end_datetime',
] ],
]; ];
$this->dbforge->add_column('appointments', $fields); $this->dbforge->add_column('appointments', $fields);
@ -35,8 +35,8 @@ class Migration_Create_appointment_location_column extends EA_Migration
'location' => [ 'location' => [
'type' => 'TEXT', 'type' => 'TEXT',
'null' => true, 'null' => true,
'after' => 'description' 'after' => 'description',
] ],
]; ];
$this->dbforge->add_column('services', $fields); $this->dbforge->add_column('services', $fields);

View file

@ -23,8 +23,8 @@ class Migration_Add_working_plan_exceptions_to_user_settings extends EA_Migratio
'working_plan_exceptions' => [ 'working_plan_exceptions' => [
'type' => 'TEXT', 'type' => 'TEXT',
'null' => true, 'null' => true,
'after' => 'working_plan' 'after' => 'working_plan',
] ],
]; ];
$this->dbforge->add_column('user_settings', $fields); $this->dbforge->add_column('user_settings', $fields);

View file

@ -21,7 +21,7 @@ class Migration_Add_require_phone_number_setting extends EA_Migration
if (!$this->db->get_where('settings', ['name' => 'require_phone_number'])->num_rows()) { if (!$this->db->get_where('settings', ['name' => 'require_phone_number'])->num_rows()) {
$this->db->insert('settings', [ $this->db->insert('settings', [
'name' => 'require_phone_number', 'name' => 'require_phone_number',
'value' => '1' 'value' => '1',
]); ]);
} }
} }

View file

@ -23,7 +23,7 @@ class Migration_Add_api_token_setting extends EA_Migration
if (!$this->db->get_where('settings', ['name' => 'api_token'])->num_rows()) { if (!$this->db->get_where('settings', ['name' => 'api_token'])->num_rows()) {
$this->db->insert('settings', [ $this->db->insert('settings', [
'name' => 'api_token', 'name' => 'api_token',
'value' => '' 'value' => '',
]); ]);
} }
} }

View file

@ -24,8 +24,8 @@ class Migration_Add_timezone_to_users extends EA_Migration
'type' => 'VARCHAR', 'type' => 'VARCHAR',
'constraint' => '256', 'constraint' => '256',
'default' => 'UTC', 'default' => 'UTC',
'after' => 'notes' 'after' => 'notes',
] ],
]; ];
$this->dbforge->add_column('users', $fields); $this->dbforge->add_column('users', $fields);

View file

@ -21,7 +21,7 @@ class Migration_Add_display_any_provider_setting extends EA_Migration
if (!$this->db->get_where('settings', ['name' => 'display_any_provider'])->num_rows()) { if (!$this->db->get_where('settings', ['name' => 'display_any_provider'])->num_rows()) {
$this->db->insert('settings', [ $this->db->insert('settings', [
'name' => 'display_any_provider', 'name' => 'display_any_provider',
'value' => '1' 'value' => '1',
]); ]);
} }
} }

View file

@ -24,8 +24,8 @@ class Migration_Add_language_to_users extends EA_Migration
'type' => 'VARCHAR', 'type' => 'VARCHAR',
'constraint' => '256', 'constraint' => '256',
'default' => 'english', 'default' => 'english',
'after' => 'timezone' 'after' => 'timezone',
] ],
]; ];
$this->dbforge->add_column('users', $fields); $this->dbforge->add_column('users', $fields);

View file

@ -23,14 +23,14 @@ class Migration_Modify_sync_period_columns extends EA_Migration
'type' => 'INT', 'type' => 'INT',
'constraint' => '11', 'constraint' => '11',
'null' => true, 'null' => true,
'default' => '30' 'default' => '30',
], ],
'sync_future_days' => [ 'sync_future_days' => [
'type' => 'INT', 'type' => 'INT',
'constraint' => '11', 'constraint' => '11',
'null' => true, 'null' => true,
'default' => '90' 'default' => '90',
] ],
]; ];
$this->dbforge->modify_column('user_settings', $fields); $this->dbforge->modify_column('user_settings', $fields);
@ -38,21 +38,21 @@ class Migration_Modify_sync_period_columns extends EA_Migration
$this->db->update( $this->db->update(
'user_settings', 'user_settings',
[ [
'sync_past_days' => '30' 'sync_past_days' => '30',
], ],
[ [
'sync_past_days' => '5' 'sync_past_days' => '5',
] ],
); );
$this->db->update( $this->db->update(
'user_settings', 'user_settings',
[ [
'sync_future_days' => '90' 'sync_future_days' => '90',
], ],
[ [
'sync_future_days' => '5' 'sync_future_days' => '5',
] ],
); );
} }
@ -66,14 +66,14 @@ class Migration_Modify_sync_period_columns extends EA_Migration
'type' => 'INT', 'type' => 'INT',
'constraint' => '11', 'constraint' => '11',
'null' => true, 'null' => true,
'default' => '5' 'default' => '5',
], ],
'sync_future_days' => [ 'sync_future_days' => [
'type' => 'INT', 'type' => 'INT',
'constraint' => '11', 'constraint' => '11',
'null' => true, 'null' => true,
'default' => '5' 'default' => '5',
] ],
]; ];
$this->dbforge->modify_column('user_settings', $fields); $this->dbforge->modify_column('user_settings', $fields);
@ -81,21 +81,21 @@ class Migration_Modify_sync_period_columns extends EA_Migration
$this->db->update( $this->db->update(
'user_settings', 'user_settings',
[ [
'sync_past_days' => '5' 'sync_past_days' => '5',
], ],
[ [
'sync_past_days' => '30' 'sync_past_days' => '30',
] ],
); );
$this->db->update( $this->db->update(
'user_settings', 'user_settings',
[ [
'sync_future_days' => '5' 'sync_future_days' => '5',
], ],
[ [
'sync_future_days' => '90' 'sync_future_days' => '90',
] ],
); );
} }
} }

View file

@ -19,36 +19,36 @@ class Migration_Add_booking_field_settings extends EA_Migration
private $fields = [ private $fields = [
'first_name' => [ 'first_name' => [
'display' => '1', 'display' => '1',
'require' => '1' 'require' => '1',
], ],
'last_name' => [ 'last_name' => [
'display' => '1', 'display' => '1',
'require' => '1' 'require' => '1',
], ],
'email' => [ 'email' => [
'display' => '1', 'display' => '1',
'require' => '1' 'require' => '1',
], ],
'phone_number' => [ 'phone_number' => [
'display' => '1', 'display' => '1',
'require' => '1' 'require' => '1',
], ],
'address' => [ 'address' => [
'display' => '1', 'display' => '1',
'require' => '0' 'require' => '0',
], ],
'city' => [ 'city' => [
'display' => '1', 'display' => '1',
'require' => '0' 'require' => '0',
], ],
'zip_code' => [ 'zip_code' => [
'display' => '1', 'display' => '1',
'require' => '0' 'require' => '0',
], ],
'notes' => [ 'notes' => [
'display' => '1', 'display' => '1',
'require' => '0' 'require' => '0',
] ],
]; ];
/** /**
@ -71,7 +71,7 @@ class Migration_Add_booking_field_settings extends EA_Migration
if (!$this->db->get_where('settings', ['name' => $setting_name])->num_rows()) { if (!$this->db->get_where('settings', ['name' => $setting_name])->num_rows()) {
$this->db->insert('settings', [ $this->db->insert('settings', [
'name' => $setting_name, 'name' => $setting_name,
'value' => $value 'value' => $value,
]); ]);
} }
} }

View file

@ -20,15 +20,15 @@ class Migration_Rename_id_service_categories_column_of_services_table extends EA
{ {
if ($this->db->field_exists('id_service_categories', 'services')) { if ($this->db->field_exists('id_service_categories', 'services')) {
$this->db->query( $this->db->query(
'ALTER TABLE `' . $this->db->dbprefix('services') . '` DROP FOREIGN KEY `services_service_categories`' 'ALTER TABLE `' . $this->db->dbprefix('services') . '` DROP FOREIGN KEY `services_service_categories`',
); );
$fields = [ $fields = [
'id_service_categories' => [ 'id_service_categories' => [
'name' => 'id_categories', 'name' => 'id_categories',
'type' => 'INT', 'type' => 'INT',
'constraint' => '11' 'constraint' => '11',
] ],
]; ];
$this->dbforge->modify_column('services', $fields); $this->dbforge->modify_column('services', $fields);
@ -43,7 +43,7 @@ class Migration_Rename_id_service_categories_column_of_services_table extends EA
'` (`id`) '` (`id`)
ON DELETE SET NULL ON DELETE SET NULL
ON UPDATE CASCADE ON UPDATE CASCADE
' ',
); );
} }
} }
@ -55,15 +55,15 @@ class Migration_Rename_id_service_categories_column_of_services_table extends EA
{ {
if ($this->db->field_exists('id_categories', 'services')) { if ($this->db->field_exists('id_categories', 'services')) {
$this->db->query( $this->db->query(
'ALTER TABLE `' . $this->db->dbprefix('services') . '` DROP FOREIGN KEY `services_categories`' 'ALTER TABLE `' . $this->db->dbprefix('services') . '` DROP FOREIGN KEY `services_categories`',
); );
$fields = [ $fields = [
'id_categories' => [ 'id_categories' => [
'name' => 'id_service_categories', 'name' => 'id_service_categories',
'type' => 'INT', 'type' => 'INT',
'constraint' => '11' 'constraint' => '11',
] ],
]; ];
$this->dbforge->modify_column('services', $fields); $this->dbforge->modify_column('services', $fields);
@ -78,7 +78,7 @@ class Migration_Rename_id_service_categories_column_of_services_table extends EA
'` (`id`) '` (`id`)
ON DELETE SET NULL ON DELETE SET NULL
ON UPDATE CASCADE ON UPDATE CASCADE
' ',
); );
} }
} }

View file

@ -24,8 +24,8 @@ class Migration_Rename_is_unavailable_column_of_appointments_table extends EA_Mi
'name' => 'is_unavailability', 'name' => 'is_unavailability',
'type' => 'TINYINT', 'type' => 'TINYINT',
'constraint' => '4', 'constraint' => '4',
'default' => '0' 'default' => '0',
] ],
]; ];
$this->dbforge->modify_column('appointments', $fields); $this->dbforge->modify_column('appointments', $fields);
@ -43,8 +43,8 @@ class Migration_Rename_is_unavailable_column_of_appointments_table extends EA_Mi
'name' => 'is_unavailable', 'name' => 'is_unavailable',
'type' => 'TINYINT', 'type' => 'TINYINT',
'constraint' => '4', 'constraint' => '4',
'default' => '0' 'default' => '0',
] ],
]; ];
$this->dbforge->modify_column('appointments', $fields); $this->dbforge->modify_column('appointments', $fields);

View file

@ -24,8 +24,8 @@ class Migration_Add_color_column_to_services_table extends EA_Migration
'type' => 'VARCHAR', 'type' => 'VARCHAR',
'constraint' => '256', 'constraint' => '256',
'default' => '#7cbae8', 'default' => '#7cbae8',
'after' => 'description' 'after' => 'description',
] ],
]; ];
$this->dbforge->add_column('services', $fields); $this->dbforge->add_column('services', $fields);

View file

@ -24,8 +24,8 @@ class Migration_Add_color_column_to_appointments_table extends EA_Migration
'type' => 'VARCHAR', 'type' => 'VARCHAR',
'constraint' => '256', 'constraint' => '256',
'default' => '#7cbae8', 'default' => '#7cbae8',
'after' => 'hash' 'after' => 'hash',
] ],
]; ];
$this->dbforge->add_column('appointments', $fields); $this->dbforge->add_column('appointments', $fields);

View file

@ -21,7 +21,7 @@ class Migration_Add_matomo_analytics_url_setting extends EA_Migration
if (!$this->db->get_where('settings', ['name' => 'matomo_analytics_url'])->num_rows()) { if (!$this->db->get_where('settings', ['name' => 'matomo_analytics_url'])->num_rows()) {
$this->db->insert('settings', [ $this->db->insert('settings', [
'name' => 'matomo_analytics_url', 'name' => 'matomo_analytics_url',
'value' => '' 'value' => '',
]); ]);
} }
} }

View file

@ -21,7 +21,7 @@ class Migration_Add_display_delete_personal_information_setting extends EA_Migra
if (!$this->db->get_where('settings', ['name' => 'display_delete_personal_information'])->num_rows()) { if (!$this->db->get_where('settings', ['name' => 'display_delete_personal_information'])->num_rows()) {
$this->db->insert('settings', [ $this->db->insert('settings', [
'name' => 'display_delete_personal_information', 'name' => 'display_delete_personal_information',
'value' => '0' 'value' => '0',
]); ]);
} }
} }

View file

@ -21,7 +21,7 @@ class Migration_Add_disable_booking_setting extends EA_Migration
if (!$this->db->get_where('settings', ['name' => 'disable_booking'])->num_rows()) { if (!$this->db->get_where('settings', ['name' => 'disable_booking'])->num_rows()) {
$this->db->insert('settings', [ $this->db->insert('settings', [
'name' => 'disable_booking', 'name' => 'disable_booking',
'value' => '0' 'value' => '0',
]); ]);
} }
} }

View file

@ -22,7 +22,7 @@ class Migration_Add_disable_booking_message_setting extends EA_Migration
$this->db->insert('settings', [ $this->db->insert('settings', [
'name' => 'disable_booking_message', 'name' => 'disable_booking_message',
'value' => 'value' =>
'<p style="text-align: center;">Thanks for stopping by!</p><p style="text-align: center;">We are not accepting new appointments at the moment, please check back again later.</p>' '<p style="text-align: center;">Thanks for stopping by!</p><p style="text-align: center;">We are not accepting new appointments at the moment, please check back again later.</p>',
]); ]);
} }
} }

View file

@ -21,7 +21,7 @@ class Migration_Add_company_logo_setting extends EA_Migration
if (!$this->db->get_where('settings', ['name' => 'company_logo'])->num_rows()) { if (!$this->db->get_where('settings', ['name' => 'company_logo'])->num_rows()) {
$this->db->insert('settings', [ $this->db->insert('settings', [
'name' => 'company_logo', 'name' => 'company_logo',
'value' => '' 'value' => '',
]); ]);
} }
} }

View file

@ -21,7 +21,7 @@ class Migration_Add_company_color_setting extends EA_Migration
if (!$this->db->get_where('settings', ['name' => 'company_color'])->num_rows()) { if (!$this->db->get_where('settings', ['name' => 'company_color'])->num_rows()) {
$this->db->insert('settings', [ $this->db->insert('settings', [
'name' => 'company_color', 'name' => 'company_color',
'value' => '#ffffff' 'value' => '#ffffff',
]); ]);
} }
} }

View file

@ -21,7 +21,7 @@ class Migration_Add_display_login_button_setting extends EA_Migration
if (!$this->db->get_where('settings', ['name' => 'display_login_button'])->num_rows()) { if (!$this->db->get_where('settings', ['name' => 'display_login_button'])->num_rows()) {
$this->db->insert('settings', [ $this->db->insert('settings', [
'name' => 'display_login_button', 'name' => 'display_login_button',
'value' => '1' 'value' => '1',
]); ]);
} }
} }

View file

@ -24,8 +24,8 @@ class Migration_Add_is_private_column_to_services_table extends EA_Migration
'type' => 'TINYINT', 'type' => 'TINYINT',
'constraint' => '4', 'constraint' => '4',
'default' => '0', 'default' => '0',
'after' => 'attendants_number' 'after' => 'attendants_number',
] ],
]; ];
$this->dbforge->add_column('services', $fields); $this->dbforge->add_column('services', $fields);

View file

@ -24,8 +24,8 @@ class Migration_Add_is_private_column_to_users_table extends EA_Migration
'type' => 'TINYINT', 'type' => 'TINYINT',
'constraint' => '4', 'constraint' => '4',
'default' => '0', 'default' => '0',
'after' => 'language' 'after' => 'language',
] ],
]; ];
$this->dbforge->add_column('users', $fields); $this->dbforge->add_column('users', $fields);

View file

@ -35,8 +35,8 @@ class Migration_Add_timestamp_columns extends EA_Migration
$column => [ $column => [
'type' => 'DATETIME', 'type' => 'DATETIME',
'null' => true, 'null' => true,
'after' => 'id' 'after' => 'id',
] ],
]; ];
$this->dbforge->add_column($table, $fields); $this->dbforge->add_column($table, $fields);

View file

@ -21,7 +21,7 @@ class Migration_Add_theme_setting extends EA_Migration
if (!$this->db->get_where('settings', ['name' => 'theme'])->num_rows()) { if (!$this->db->get_where('settings', ['name' => 'theme'])->num_rows()) {
$this->db->insert('settings', [ $this->db->insert('settings', [
'name' => 'theme', 'name' => 'theme',
'value' => 'default' 'value' => 'default',
]); ]);
} }
} }

View file

@ -23,7 +23,7 @@ class Migration_Add_limit_customer_access_setting extends EA_Migration
'create_datetime' => date('Y-m-d H:i:s'), 'create_datetime' => date('Y-m-d H:i:s'),
'update_datetime' => date('Y-m-d H:i:s'), 'update_datetime' => date('Y-m-d H:i:s'),
'name' => 'limit_customer_access', 'name' => 'limit_customer_access',
'value' => '0' 'value' => '0',
]); ]);
} }
} }

Some files were not shown because too many files have changed in this diff Show more