forked from mirrors/easyappointments
Merge branch 'local-original-dev' into develop
This commit is contained in:
commit
9c58c12c79
219 changed files with 2815 additions and 2646 deletions
|
@ -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"]
|
||||||
}
|
}
|
||||||
|
|
|
@ -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 */
|
||||||
|
|
|
@ -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 */
|
||||||
|
|
|
@ -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;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|--------------------------------------------------------------------------
|
|--------------------------------------------------------------------------
|
||||||
|
|
|
@ -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',
|
||||||
];
|
];
|
||||||
|
|
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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 */
|
||||||
|
|
|
@ -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');
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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');
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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');
|
||||||
|
|
|
@ -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');
|
||||||
|
|
|
@ -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');
|
||||||
|
|
|
@ -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');
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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));
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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');
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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');
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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');
|
||||||
|
|
|
@ -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');
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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');
|
||||||
|
|
|
@ -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');
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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'),
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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,
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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,
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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),
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -69,8 +69,8 @@ if (!function_exists('extend')) {
|
||||||
'layout' => [
|
'layout' => [
|
||||||
'filename' => $layout,
|
'filename' => $layout,
|
||||||
'sections' => [],
|
'sections' => [],
|
||||||
'tmp' => []
|
'tmp' => [],
|
||||||
]
|
],
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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,
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -53,7 +53,7 @@ if (!function_exists('setting')) {
|
||||||
|
|
||||||
if (empty($setting)) {
|
if (empty($setting)) {
|
||||||
$setting = [
|
$setting = [
|
||||||
'name' => $name
|
'name' => $name,
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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'],
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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'])) {
|
||||||
|
|
|
@ -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']);
|
||||||
|
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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']);
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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));
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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 {
|
||||||
|
|
|
@ -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());
|
||||||
}
|
}
|
||||||
|
|
|
@ -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)',
|
||||||
]
|
],
|
||||||
];
|
];
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -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());
|
||||||
}
|
}
|
||||||
|
|
|
@ -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');
|
||||||
|
|
|
@ -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' => '',
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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',
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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',
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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',
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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',
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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',
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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',
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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',
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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',
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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',
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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' => '',
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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',
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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',
|
||||||
]
|
],
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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,
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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
|
||||||
'
|
',
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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' => '',
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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',
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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',
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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>',
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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' => '',
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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',
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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',
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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',
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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
Loading…
Reference in a new issue