Portions created by the Initial Developer are Copyright (C) 2008 - 2024 the Initial Developer. All Rights Reserved. Contributor(s): Mark J Crane */ //includes files require_once dirname(__DIR__, 2) . "/resources/require.php"; require_once "resources/check_auth.php"; //check permissions if (permission_exists('default_setting_view')) { //access granted } else { echo "access denied"; exit; } //set permissions $permission = array(); $permission['default_setting_add'] = permission_exists('default_setting_add'); $permission['default_setting_all'] = permission_exists('default_setting_all'); $permission['default_setting_edit'] = permission_exists('default_setting_edit'); $permission['default_setting_delete'] = permission_exists('default_setting_delete'); $permission['domain_select'] = permission_exists('domain_select'); $permission['domain_setting_add'] = permission_exists('domain_setting_add'); //add multi-lingual support $language = new text; $text = $language->get(); //get the http post data $search = $_REQUEST['search'] ?? ''; $default_setting_category = $_REQUEST['default_setting_category'] ?? ''; if (!empty($_POST['default_settings'])) { $action = $_POST['action']; $domain_uuid = $_POST['domain_uuid']; $default_settings = $_POST['default_settings']; } else { $action = ''; $domain_uuid = ''; $default_settings = ''; } //set additional variables $search = !empty($_GET["search"]) ? $_GET["search"] : ''; $show = !empty($_GET["show"]) ? $_GET["show"] : ''; //sanitize the variables $action = preg_replace('#[^a-zA-Z0-9_\-\.]#', '', $action); $search = preg_replace('#[^a-zA-Z0-9_\-\. ]#', '', $search); $default_setting_category = preg_replace('#[^a-zA-Z0-9_\-\.]#', '', $default_setting_category); //determine whether to non-default (custom) settings only if (!empty($default_setting_category) && $default_setting_category == 'custom') { $custom_settings = true; $default_setting_category = null; } else { $custom_settings = false; } //set from session variables $list_row_edit_button = filter_var($_SESSION['theme']['list_row_edit_button']['boolean'] ?? false, FILTER_VALIDATE_BOOL); //build the query string $query_string = ''; if (!empty($search)) { $query_string .= 'search='.urlencode($search); } if (!empty($default_setting_category)) { if ($query_string == '') { $query_string = ''; } else { $query_string .= '&'; } $query_string .= 'default_setting_category='.urlencode($default_setting_category); } //process the http post data by action if (!empty($action) && !empty($default_settings)) { switch ($action) { case 'copy': if ($permission['default_setting_add']) { $obj = new default_settings; $obj->domain_uuid = $domain_uuid; $obj->copy($default_settings); } break; case 'toggle': if ($permission['default_setting_edit']) { $obj = new default_settings; $obj->toggle($default_settings); } break; case 'delete': if ($permission['default_setting_delete']) { $obj = new default_settings; $obj->delete($default_settings); } break; } header('Location: default_settings.php?'.(!empty($query_string) ? $query_string : null)); exit; } //get order and order by and sanitize the values $order_by = (!empty($_GET["order_by"])) ? $_GET["order_by"] : ''; $order = (!empty($_GET["order"])) ? $_GET["order"] : ''; //get the count $sql = "select count(default_setting_uuid) from v_default_settings "; if (!empty($search)) { $sql .= "where ("; $sql .= " lower(default_setting_category) like :search "; $sql .= " or lower(default_setting_subcategory) like :search "; $sql .= " or lower(default_setting_name) like :search "; $sql .= " or lower(default_setting_value) like :search "; $sql .= " or lower(default_setting_description) like :search "; $sql .= ") "; $parameters['search'] = '%'.$search.'%'; } if (!empty($default_setting_category) && !empty($default_setting_category)) { $sql .= (stripos($sql,'WHERE') === false) ? 'where ' : 'and '; $sql .= "lower(default_setting_category) = :default_setting_category "; $parameters['default_setting_category'] = strtolower($default_setting_category); } $database = database::new(); $num_rows = $database->select($sql, $parameters ?? null, 'column'); //get the list $sql = "select default_setting_uuid, default_setting_category, default_setting_subcategory, default_setting_name, "; $sql .= "default_setting_value, default_setting_order, cast(default_setting_enabled as text), default_setting_description "; $sql .= "from v_default_settings "; if (!empty($search)) { $sql .= "where ("; $sql .= " lower(default_setting_category) like :search "; $sql .= " or lower(default_setting_subcategory) like :search "; $sql .= " or lower(default_setting_name) like :search "; $sql .= " or lower(default_setting_value) like :search "; $sql .= " or lower(default_setting_description) like :search "; $sql .= ") "; $parameters['search'] = '%'.$search.'%'; } if (!empty($default_setting_category) && !empty($default_setting_category)) { $sql .= (stripos($sql,'WHERE') === false) ? 'where ' : 'and '; $sql .= "lower(default_setting_category) = :default_setting_category "; $parameters['default_setting_category'] = strtolower($default_setting_category); } $sql .= order_by($order_by, $order, 'default_setting_category, default_setting_subcategory, default_setting_order', 'asc'); //$sql .= limit_offset($rows_per_page, $offset ?? ''); //$offset is always null $default_settings = $database->select($sql, $parameters ?? null, 'all'); unset($sql, $parameters); //get default setting categories $sql = "select "; $sql .= "distinct(d1.default_setting_category), "; $sql .= "( "; $sql .= " select "; $sql .= " count(d2.default_setting_category) "; $sql .= " from v_default_settings as d2 "; $sql .= " where d2.default_setting_category = d1.default_setting_category "; if (!empty($search)) { $sql .= " and ("; $sql .= " lower(d2.default_setting_category) like :search "; $sql .= " or lower(d2.default_setting_subcategory) like :search "; $sql .= " or lower(d2.default_setting_name) like :search "; $sql .= " or lower(d2.default_setting_value) like :search "; $sql .= " or lower(d2.default_setting_description) like :search "; $sql .= " ) "; $parameters['search'] = '%'.$search.'%'; } $sql .= ") as quantity "; $sql .= "from v_default_settings as d1 "; $sql .= "order by d1.default_setting_category asc "; $rows = $database->select($sql, $parameters ?? null, 'all'); if (!empty($rows) && @sizeof($rows) != 0) { foreach ($rows as $row) { if (!empty($row['default_setting_category']) && !empty($row['quantity'])) { $default_setting_categories[$row['default_setting_category']] = $row['quantity']; } } } unset($sql, $rows, $row); //get the list of categories if (!empty($default_setting_categories)) { //show the array $categories = []; //add custom to the list of categories $categories['custom']['formatted'] = $text['label-custom']; $categories['custom']['count'] = null; //add the other catefories to the array foreach ($default_setting_categories as $default_setting_category => $quantity) { $category = strtolower($default_setting_category); switch ($category) { case "api" : $category = "API"; break; case "cdr" : $category = "CDR"; break; case "ldap" : $category = "LDAP"; break; case "ivr_menu" : $category = "IVR Menu"; break; default: $category = str_replace("_", " ", $category); $category = str_replace("-", " ", $category); $category = ucwords($category); } $categories[$default_setting_category]['formatted'] = $category; $categories[$default_setting_category]['count'] = $quantity; } //unset variables unset($default_setting_categories, $default_setting_category, $category); } //get the list of installed apps from the core and mod directories $config_list = glob($_SERVER["DOCUMENT_ROOT"] . PROJECT_PATH . "/*/*/app_config.php"); $x=0; foreach ($config_list as $config_path) { include($config_path); $x++; } $x = 0; foreach ($apps as $app) { if (!empty($app['default_settings'])) { foreach ($app['default_settings'] as $setting) { $setting_array[$x] = ($setting); $setting_array[$x]['app_uuid'] = $app['uuid'] ?? null; $x++; } } } //create a function to find matching row in array and return the row or boolean function find_in_array($search_array, $field, $value, $type = 'boolean') { foreach($search_array as $row) { if ($row[$field] == $value) { if ($type == 'boolean') { return true; } if ($type == 'row') { return $row; } break; } } if ($type == 'boolean') { return false; } } //create token $object = new token; $token = $object->create($_SERVER['PHP_SELF']); //include the header $document['title'] = $text['title-default_settings']; require_once "resources/header.php"; //copy settings javascript if ($permission['domain_select'] && $permission['domain_setting_add']) { echo ""; } //show the content echo "
\n"; echo "
".$text['title-default_settings']."
".number_format($num_rows)."
\n"; echo "
\n"; echo button::create(['type'=>'button','label'=>$text['label-domain'],'icon'=>$_SESSION['theme']['button_icon_domain'],'style'=>'','link'=>PROJECT_PATH.'/core/domain_settings/domain_settings.php?id='.$domain_uuid]); echo button::create(['label'=>$text['button-reload'],'icon'=>$_SESSION['theme']['button_icon_reload'],'type'=>'button','id'=>'button_reload','link'=>'default_settings_reload.php'.(!empty($search) ? '?search='.urlencode($search) : null),'style'=>'margin-right: 15px;']); if ($permission['default_setting_add']) { echo button::create(['type'=>'button','label'=>$text['button-add'],'icon'=>$_SESSION['theme']['button_icon_add'],'id'=>'btn_add','link'=>'default_setting_edit.php?'.$query_string]); } if ($permission['default_setting_add'] && !empty($default_settings)) { if ($permission['domain_select'] && $permission['domain_setting_add']) { echo button::create(['type'=>'button','label'=>$text['button-copy'],'id'=>'btn_copy','name'=>'btn_copy','style'=>'display: none;','icon'=>$_SESSION['theme']['button_icon_copy'],'id'=>'btn_copy','onclick'=>'show_domains();']); echo button::create(['type'=>'button','label'=>$text['button-cancel'],'id'=>'btn_copy_cancel','icon'=>$_SESSION['theme']['button_icon_cancel'],'style'=>'display: none;','onclick'=>'hide_domains();']); echo ""; echo button::create(['type'=>'button','label'=>$text['button-paste'],'icon'=>$_SESSION['theme']['button_icon_paste'],'id'=>'btn_paste','style'=>'display: none;','onclick'=>"if (confirm('".$text['confirm-copy']."')) { list_action_set('copy'); list_form_submit('form_list'); } else { this.blur(); return false; }"]); } } if ($permission['default_setting_edit'] && $default_settings) { echo button::create(['type'=>'button','label'=>$text['button-toggle'],'icon'=>$_SESSION['theme']['button_icon_toggle'],'id'=>'btn_toggle','name'=>'btn_toggle','style'=>'display: none;','onclick'=>"modal_open('modal-toggle','btn_toggle');"]); } if ($permission['default_setting_delete'] && $default_settings) { echo button::create(['type'=>'button','label'=>$text['button-delete'],'icon'=>$_SESSION['theme']['button_icon_delete'],'id'=>'btn_delete','name'=>'btn_delete','style'=>'display: none;','onclick'=>"modal_open('modal-delete','btn_delete');"]); } echo "\n"; echo "
\n"; echo "
\n"; echo "
\n"; if ($permission['default_setting_edit'] && $default_settings) { echo modal::create(['id'=>'modal-toggle','type'=>'toggle','actions'=>button::create(['type'=>'button','label'=>$text['button-continue'],'icon'=>'check','id'=>'btn_toggle','style'=>'float: right; margin-left: 15px;','collapse'=>'never','onclick'=>"modal_close(); list_action_set('toggle'); list_form_submit('form_list');"])]); } if ($permission['default_setting_delete'] && $default_settings) { echo modal::create(['id'=>'modal-delete','type'=>'delete','actions'=>button::create(['type'=>'button','label'=>$text['button-continue'],'icon'=>'check','id'=>'btn_delete','style'=>'float: right; margin-left: 15px;','collapse'=>'never','onclick'=>"modal_close(); list_action_set('delete'); list_form_submit('form_list');"])]); } echo $text['description-default_settings']."\n"; echo "

\n"; echo "
\n"; echo "\n"; echo "\n"; echo ""; if (!empty($default_settings)) { //define the variable $previous_default_setting_category = ''; $x = 0; foreach ($default_settings as $row) { $default_setting_category = strtolower($row['default_setting_category']); $default_setting_category = preg_replace('#[^a-zA-Z0-9_\-\.]#', '', $default_setting_category); $label_default_setting_category = $row['default_setting_category']; $label_default_setting_category = preg_replace('#[^a-zA-Z0-9_\-\. ]#', '', $label_default_setting_category); //check if the default setting uuid exists in the array $field = find_in_array($setting_array, 'default_setting_uuid', $row['default_setting_uuid'], 'row'); //set default empty string $setting_bold = ''; $enabled_bold = ''; $default_value = ''; $default_enabled = ''; //set empty default setting enabled to false by default if (empty($row['default_setting_enabled'])) { $row['default_setting_enabled'] = 'false'; } //set the font weight, default value and filter for non-custom settings if (!empty($field)) { //check for custom settings filter if ($row['default_setting_value'] !== $field['default_setting_value']) { $setting_bold = 'font-weight:bold;'; } //set the default value if (!empty($field['default_setting_value'])) { $default_value = 'Default: '.$field['default_setting_value']; } else { $default_value = 'Default: null'; } //check if default enabled if ($row['default_setting_enabled'] == $field['default_setting_enabled']) { if ($custom_settings) { continue; } } else { $default_enabled = $field['default_setting_enabled']; $enabled_bold = true; } } else { $default_value = 'Custom'; $setting_bold = 'font-weight:bold;'; } unset($field); switch (strtolower($label_default_setting_category)) { case "api" : $label_default_setting_category = "API"; break; case "cdr" : $label_default_setting_category = "CDR"; break; case "ldap" : $label_default_setting_category = "LDAP"; break; case "ivr_menu" : $label_default_setting_category = "IVR Menu"; break; default: $label_default_setting_category = str_replace("_", " ", $label_default_setting_category); $label_default_setting_category = str_replace("-", " ", $label_default_setting_category); $label_default_setting_category = ucwords($label_default_setting_category); } if ($previous_default_setting_category != $row['default_setting_category']) { if (!empty($previous_default_setting_category)) { echo "\n"; echo "\n"; echo "\n"; } echo "
\n"; echo "".escape($label_default_setting_category)."
\n"; echo "
\n"; echo "\n"; echo "\n"; if ($permission['default_setting_add'] || $permission['default_setting_edit'] || $permission['default_setting_delete']) { echo " \n"; } if ($show == 'all' && $permission['default_setting_all']) { echo th_order_by('domain_name', $text['label-domain'], $order_by, $order); } echo th_order_by('default_setting_subcategory', $text['label-subcategory'], $order_by, $order, null, "class='pct-35'"); echo th_order_by('default_setting_name', $text['label-type'], $order_by, $order, null, "class='pct-10 hide-sm-dn'"); echo th_order_by('default_setting_value', $text['label-value'], $order_by, $order, null, "class='pct-30'"); echo th_order_by('default_setting_enabled', $text['label-enabled'], $order_by, $order, null, "class='center'"); echo " \n"; if ($permission['default_setting_edit'] && $list_row_edit_button) { echo " \n"; } echo "\n"; } if ($permission['default_setting_edit']) { $list_row_url = "default_setting_edit.php?id=".urlencode($row['default_setting_uuid']).'&'.$query_string; } echo "\n"; if ($permission['default_setting_add'] || $permission['default_setting_edit'] || $permission['default_setting_delete']) { echo " \n"; } if ($show == 'all' && $permission['default_setting_all']) { echo " \n"; } echo " \n"; if (isset($_SESSION['default_settings']['display_order']['text']) && $_SESSION['default_settings']['display_order']['text'] == 'inline') { $setting_types = ['Array','Boolean','Code','Dir','Name','Numeric','Text','UUID']; echo " \n"; } else { echo " \n"; echo " \n"; if ($permission['default_setting_edit']) { echo " \n"; echo " \n"; if ($permission['default_setting_edit'] && $list_row_edit_button) { echo " \n"; } echo "\n"; //set the previous category $previous_default_setting_category = $row['default_setting_category']; $x++; } unset($default_settings); } echo "
\n"; echo " \n"; echo " ".$text['label-description']." 
\n"; echo " \n"; echo " \n"; echo " ".escape($_SESSION['domains'][$row['domain_uuid']]['domain_name']).""; if ($permission['default_setting_edit']) { echo "".escape($row['default_setting_subcategory']).""; } else { echo escape($row['default_setting_subcategory']); } echo " ".$setting_types[array_search(strtolower($row['default_setting_name']), array_map('strtolower',$setting_types))].($row['default_setting_name'] == 'array' && isset($row['default_setting_order']) ? ' ('.$row['default_setting_order'].')' : null)."".escape($row['default_setting_name'])."\n"; } $category = $row['default_setting_category'] ?? ''; $subcategory = $row['default_setting_subcategory'] ?? ''; $name = $row['default_setting_name'] ?? ''; if ($category == "domain" && $subcategory == "menu" && $name == "uuid" ) { $sql = "select * from v_menus "; $sql .= "where menu_uuid = :menu_uuid "; $parameters['menu_uuid'] = $row['default_setting_value']; $sub_result = $database->select($sql, $parameters ?? null, 'all'); foreach ($sub_result as $sub_row) { echo $sub_row["menu_language"]." - ".$sub_row["menu_name"]."\n"; } unset($sql, $sub_result, $sub_row); } else if ($category == "domain" && $subcategory == "template" && $name == "name" ) { echo " ".ucwords($row['default_setting_value']); } else if ($category == "domain" && $subcategory == "time_format" && $name == "text" ) { switch ($row['default_setting_value']) { case '12h': echo $text['label-12-hour']; break; case '24h': echo $text['label-24-hour']; break; } } else if ( ( $category == "theme" && $subcategory == "menu_main_icons" && $name == "boolean" ) || ( $category == "theme" && $subcategory == "menu_sub_icons" && $name == "boolean" ) || ( $category == "theme" && $subcategory == "menu_brand_type" && $name == "text" ) || ( $category == "theme" && $subcategory == "menu_style" && $name == "text" ) || ( $category == "theme" && $subcategory == "menu_position" && $name == "text" ) || ( $category == "theme" && $subcategory == "body_header_brand_type" && $name == "text" ) || ( $category == "theme" && $subcategory == "logo_align" && $name == "text" ) ) { echo " ".$text['label-'.$row['default_setting_value']]; } else if ($category == 'theme' && $subcategory == 'custom_css_code' && $name == 'text') { echo " [...]\n"; } else if ($subcategory == 'password' || substr_count($subcategory, '_password') > 0 || substr_count($subcategory, '_key') > 0 || substr_count($subcategory, '_secret') > 0) { echo " ".str_repeat('*', 10); //use the same number of characters to mask the password length } else if ($category == 'theme' && $subcategory == 'button_icons' && $name == 'text') { echo " ".$text['option-button_icons_'.$row['default_setting_value']]."\n"; } else if ($category == 'theme' && $subcategory == 'menu_side_state' && $name == 'text') { echo " ".$text['option-'.$row['default_setting_value']]."\n"; } else if ($category == 'theme' && $subcategory == 'menu_side_toggle' && $name == 'text') { echo " ".$text['option-'.$row['default_setting_value']]."\n"; } else if ($category == 'theme' && $subcategory == 'menu_side_toggle_body_width' && $name == 'text') { echo " ".$text['option-'.$row['default_setting_value']]."\n"; } else if ($category == 'theme' && $subcategory == 'menu_side_item_main_sub_close' && $name == 'text') { echo " ".$text['option-'.$row['default_setting_value']]."\n"; } else if ($category == 'theme' && $subcategory == 'input_toggle_style' && $name == 'text') { echo " ".$text['option-'.$row['default_setting_value']]."\n"; } else if (substr_count($subcategory, "_color") > 0 && ($name == "text" || $name == 'array')) { echo " ".(img_spacer('15px', '15px', 'background: '.escape($row['default_setting_value']).'; margin-right: 4px; vertical-align: middle; border: 1px solid '.(color_adjust($row['default_setting_value'], -0.18)).'; padding: -1px;')); echo "".escape($row['default_setting_value'])."\n"; } else if ($category == 'users' && $subcategory == 'username_format' && $name == 'text') { echo " ".$text['option-username_format_'.$row['default_setting_value']]."\n"; } else if ($category == 'recordings' && $subcategory == 'storage_type' && $name == 'text') { echo " ".$text['label-'.$row['default_setting_value']]."\n"; } else if ($category == 'destinations' && $subcategory == 'dialplan_mode' && $name == 'text') { echo " ".$text['label-'.$row['default_setting_value']]."\n"; } else if ($category == 'destinations' && $subcategory == 'select_mode' && $name == 'text') { echo " ".$text['label-'.$row['default_setting_value']]."\n"; } else if ($category == 'voicemail' && ($subcategory == 'message_caller_id_number' || $subcategory == 'message_date_time') && $name == 'text') { echo " ".$text['label-'.$row['default_setting_value']]."\n"; } else if ($row['default_setting_value'] == 'true' || $row['default_setting_value'] == 'false') { echo " ".$text['label-'.$row['default_setting_value']]."\n"; } else { if (!empty($row['default_setting_value']) && substr_count($row['default_setting_value'], "\n") > 0) { $lines = explode("\n", $row['default_setting_value']); if (!empty($lines) && is_array($lines) && @sizeof($lines) != 0) { foreach ($lines as $i => $line) { $lines[$i] = escape($line); } echo implode("", $lines); } unset($lines, $line); } else { echo escape($row['default_setting_value'])."\n"; } } echo " \n"; echo $text['label-'.$row['default_setting_enabled']]; } echo " ".escape($row['default_setting_description'])."\n"; echo button::create(['type'=>'button','title'=>$text['button-edit'],'icon'=>$_SESSION['theme']['button_icon_edit'],'link'=>$list_row_url]); echo "
\n"; echo "
\n"; echo "
\n"; echo "
\n"; //echo "
".$paging_controls."
\n"; echo "\n"; echo "
\n"; //include the footer require_once "resources/footer.php"; ?>