Dashboard: Corrected app_defaults to create missing Dashboard entries in Default Settings.

This commit is contained in:
reliberate
2016-03-30 15:42:25 -06:00
parent 9bb6bdb371
commit b90d404ff5

View File

@@ -10,7 +10,34 @@ if ($domains_processed == 1) {
$array[$x]['default_setting_value'] = generate_password('20', '4'); $array[$x]['default_setting_value'] = generate_password('20', '4');
$array[$x]['default_setting_enabled'] = 'false'; $array[$x]['default_setting_enabled'] = 'false';
$array[$x]['default_setting_description'] = 'Reset Password link visible on login page when populated and enabled.'; $array[$x]['default_setting_description'] = 'Reset Password link visible on login page when populated and enabled.';
$x++;
//iterate and add each, if necessary
foreach ($array as $index => $default_settings) {
//add theme default settings
$sql = "select count(*) as num_rows from v_default_settings ";
$sql .= "where default_setting_category = '".$default_settings['default_setting_category']."' ";
$sql .= "and default_setting_subcategory = '".$default_settings['default_setting_subcategory']."' ";
$sql .= "and default_setting_name = '".$default_settings['default_setting_name']."' ";
$prep_statement = $db->prepare($sql);
if ($prep_statement) {
$prep_statement->execute();
$row = $prep_statement->fetch(PDO::FETCH_ASSOC);
unset($prep_statement);
if ($row['num_rows'] == 0) {
$orm = new orm;
$orm->name('default_settings');
$orm->save($array[$index]);
$message = $orm->message;
//print_r($message);
}
unset($row);
}
}
//define array of dashboard settings
$x = 0;
$array[$x]['default_setting_category'] = 'dashboard'; $array[$x]['default_setting_category'] = 'dashboard';
$array[$x]['default_setting_subcategory'] = 'admin'; $array[$x]['default_setting_subcategory'] = 'admin';
$array[$x]['default_setting_name'] = 'array'; $array[$x]['default_setting_name'] = 'array';
@@ -130,31 +157,44 @@ if ($domains_processed == 1) {
$array[$x]['default_setting_enabled'] = 'true'; $array[$x]['default_setting_enabled'] = 'true';
$array[$x]['default_setting_description'] = 'Enable Dashboard Recent Calls block for users in the users group.'; $array[$x]['default_setting_description'] = 'Enable Dashboard Recent Calls block for users in the users group.';
//iterate and add each, if necessary //get an array of the default settings
foreach ($array as $index => $default_settings) { $sql = "select * from v_default_settings ";
$sql .= "where default_setting_category = 'dashboard' ";
$prep_statement = $db->prepare($sql);
$prep_statement->execute();
$default_settings = $prep_statement->fetchAll(PDO::FETCH_NAMED);
unset ($prep_statement, $sql);
//add theme default settings //find the missing default settings
$sql = "select count(*) as num_rows from v_default_settings "; $x = 0;
$sql .= "where default_setting_category = '".$default_settings['default_setting_category']."' "; foreach ($array as $setting) {
$sql .= "and default_setting_subcategory = '".$default_settings['default_setting_subcategory']."' "; $found = false;
$sql .= "and default_setting_name = '".$default_settings['default_setting_name']."' "; $missing[$x] = $setting;
$prep_statement = $db->prepare($sql); foreach ($default_settings as $row) {
if ($prep_statement) { if (trim($row['default_setting_subcategory']) == trim($setting['default_setting_subcategory'])) {
$prep_statement->execute(); $found = true;
$row = $prep_statement->fetch(PDO::FETCH_ASSOC); //remove items from the array that were found
unset($prep_statement); unset($missing[$x]);
if ($row['num_rows'] == 0) {
$orm = new orm;
$orm->name('default_settings');
$orm->save($array[$index]);
$message = $orm->message;
//print_r($message);
} }
unset($row);
} }
$x++;
} }
//add the missing default settings
foreach ($missing as $row) {
//add the default settings
$orm = new orm;
$orm->name('default_settings');
$orm->save($row);
$message = $orm->message;
unset($orm);
//print_r($message);
}
unset($missing);
//unset the array variable
unset($array);
} }
?> ?>