Zeile 98 | Zeile 98 |
---|
}
$form_container = new FormContainer($lang->add_new_setting_group);
|
}
$form_container = new FormContainer($lang->add_new_setting_group);
|
$form_container->output_row($lang->title." <em>*</em>", "", $form->generate_text_box('title', $mybb->input['title'], array('id' => 'title')), 'title'); $form_container->output_row($lang->description, "", $form->generate_text_area('description', $mybb->input['description'], array('id' => 'description')), 'description'); $form_container->output_row($lang->display_order, "", $form->generate_numeric_field('disporder', $mybb->input['disporder'], array('id' => 'disporder', 'min' => 0)), 'disporder'); $form_container->output_row($lang->name." <em>*</em>", $lang->group_name_desc, $form->generate_text_box('name', $mybb->input['name'], array('id' => 'name')), 'name');
| $form_container->output_row($lang->title." <em>*</em>", "", $form->generate_text_box('title', $mybb->get_input('title'), array('id' => 'title')), 'title'); $form_container->output_row($lang->description, "", $form->generate_text_area('description', $mybb->get_input('description'), array('id' => 'description')), 'description'); $form_container->output_row($lang->display_order, "", $form->generate_numeric_field('disporder', $mybb->get_input('disporder'), array('id' => 'disporder', 'min' => 0)), 'disporder'); $form_container->output_row($lang->name." <em>*</em>", $lang->group_name_desc, $form->generate_text_box('name', $mybb->get_input('name'), array('id' => 'name')), 'name');
|
$form_container->end();
$buttons[] = $form->generate_submit_button($lang->insert_new_setting_group);
| $form_container->end();
$buttons[] = $form->generate_submit_button($lang->insert_new_setting_group);
|
Zeile 233 | Zeile 233 |
---|
}
// User clicked no
|
}
// User clicked no
|
if($mybb->input['no'])
| if($mybb->get_input('no'))
|
{ admin_redirect("index.php?module=config-settings&action=manage"); }
| { admin_redirect("index.php?module=config-settings&action=manage"); }
|
Zeile 389 | Zeile 389 |
---|
}
$form_container = new FormContainer($lang->add_new_setting);
|
}
$form_container = new FormContainer($lang->add_new_setting);
|
$form_container->output_row($lang->title." <em>*</em>", "", $form->generate_text_box('title', $mybb->input['title'], array('id' => 'title')), 'title'); $form_container->output_row($lang->description, "", $form->generate_text_area('description', $mybb->input['description'], array('id' => 'description')), 'description');
| $form_container->output_row($lang->title." <em>*</em>", "", $form->generate_text_box('title', $mybb->get_input('title'), array('id' => 'title')), 'title'); $form_container->output_row($lang->description, "", $form->generate_text_area('description', $mybb->get_input('description'), array('id' => 'description')), 'description');
|
$query = $db->simple_select("settinggroups", "*", "", array('order_by' => 'disporder')); while($group = $db->fetch_array($query)) { $group_lang_var = "setting_group_{$group['name']}";
|
$query = $db->simple_select("settinggroups", "*", "", array('order_by' => 'disporder')); while($group = $db->fetch_array($query)) { $group_lang_var = "setting_group_{$group['name']}";
|
if($lang->$group_lang_var)
| if(!empty($lang->$group_lang_var))
|
{ $options[$group['gid']] = htmlspecialchars_uni($lang->$group_lang_var); }
| { $options[$group['gid']] = htmlspecialchars_uni($lang->$group_lang_var); }
|
Zeile 405 | Zeile 405 |
---|
$options[$group['gid']] = htmlspecialchars_uni($group['title']); } }
|
$options[$group['gid']] = htmlspecialchars_uni($group['title']); } }
|
$form_container->output_row($lang->group." <em>*</em>", "", $form->generate_select_box("gid", $options, $mybb->input['gid'], array('id' => 'gid')), 'gid'); $form_container->output_row($lang->display_order, "", $form->generate_numeric_field('disporder', $mybb->input['disporder'], array('id' => 'disporder', 'min' => 0)), 'disporder');
| $form_container->output_row($lang->group." <em>*</em>", "", $form->generate_select_box("gid", $options, $mybb->get_input('gid'), array('id' => 'gid')), 'gid'); $form_container->output_row($lang->display_order, "", $form->generate_numeric_field('disporder', $mybb->get_input('disporder'), array('id' => 'disporder', 'min' => 0)), 'disporder');
|
|
|
$form_container->output_row($lang->name." <em>*</em>", $lang->name_desc, $form->generate_text_box('name', $mybb->input['name'], array('id' => 'name')), 'name');
| $form_container->output_row($lang->name." <em>*</em>", $lang->name_desc, $form->generate_text_box('name', $mybb->get_input('name'), array('id' => 'name')), 'name');
|
$setting_types = array( "text" => $lang->text,
| $setting_types = array( "text" => $lang->text,
|
Zeile 425 | Zeile 425 |
---|
"checkbox" => $lang->checkbox, "language" => $lang->language_selection_box, "adminlanguage" => $lang->adminlanguage,
|
"checkbox" => $lang->checkbox, "language" => $lang->language_selection_box, "adminlanguage" => $lang->adminlanguage,
|
"cpstyle" => $lang->cpstyle
| "cpstyle" => $lang->cpstyle, "prefixselect" => $lang->prefix_selection_box
|
//"php" => $lang->php // Internal Use Only );
|
//"php" => $lang->php // Internal Use Only );
|
$form_container->output_row($lang->type." <em>*</em>", "", $form->generate_select_box("type", $setting_types, $mybb->input['type'], array('id' => 'type')), 'type'); $form_container->output_row($lang->extra, $lang->extra_desc, $form->generate_text_area('extra', $mybb->input['extra'], array('id' => 'extra')), 'extra', array(), array('id' => 'row_extra')); $form_container->output_row($lang->value, "", $form->generate_text_area('value', $mybb->input['value'], array('id' => 'value')), 'value');
| $form_container->output_row($lang->type." <em>*</em>", "", $form->generate_select_box("type", $setting_types, $mybb->get_input('type'), array('id' => 'type')), 'type'); $form_container->output_row($lang->extra, $lang->extra_desc, $form->generate_text_area('extra', $mybb->get_input('extra'), array('id' => 'extra')), 'extra', array(), array('id' => 'row_extra')); $form_container->output_row($lang->value, "", $form->generate_text_area('value', $mybb->get_input('value'), array('id' => 'value')), 'value');
|
$form_container->end();
$buttons[] = $form->generate_submit_button($lang->insert_new_setting); $form->output_submit_wrapper($buttons); $form->end();
|
$form_container->end();
$buttons[] = $form->generate_submit_button($lang->insert_new_setting); $form->output_submit_wrapper($buttons); $form->end();
|
echo '<script type="text/javascript" src="./jscripts/peeker.js?ver=1804"></script>
| echo '<script type="text/javascript" src="./jscripts/peeker.js?ver=1821"></script>
|
<script type="text/javascript"> $(function() { new Peeker($("#type"), $("#row_extra"), /^(select|radio|checkbox|php)$/, false);
| <script type="text/javascript"> $(function() { new Peeker($("#type"), $("#row_extra"), /^(select|radio|checkbox|php)$/, false);
|
Zeile 601 | Zeile 602 |
---|
$setting_data = $setting; $type = explode("\n", $setting['optionscode'], 2); $setting_data['type'] = trim($type[0]);
|
$setting_data = $setting; $type = explode("\n", $setting['optionscode'], 2); $setting_data['type'] = trim($type[0]);
|
$setting_data['extra'] = trim($type[1]);
| if(isset($type[1])) { $setting_data['extra'] = trim($type[1]); }
|
}
$form_container = new FormContainer($lang->modify_setting);
| }
$form_container = new FormContainer($lang->modify_setting);
|
Zeile 612 | Zeile 617 |
---|
while($group = $db->fetch_array($query)) { $group_lang_var = "setting_group_{$group['name']}";
|
while($group = $db->fetch_array($query)) { $group_lang_var = "setting_group_{$group['name']}";
|
if($lang->$group_lang_var)
| if(!empty($lang->$group_lang_var))
|
{ $options[$group['gid']] = htmlspecialchars_uni($lang->$group_lang_var); }
| { $options[$group['gid']] = htmlspecialchars_uni($lang->$group_lang_var); }
|
Zeile 643 | Zeile 648 |
---|
"checkbox" => $lang->checkbox, "language" => $lang->language_selection_box, "adminlanguage" => $lang->adminlanguage,
|
"checkbox" => $lang->checkbox, "language" => $lang->language_selection_box, "adminlanguage" => $lang->adminlanguage,
|
"cpstyle" => $lang->cpstyle
| "cpstyle" => $lang->cpstyle, "prefixselect" => $lang->prefix_selection_box
|
//"php" => $lang->php // Internal Use Only );
$form_container->output_row($lang->type." <em>*</em>", "", $form->generate_select_box("type", $setting_types, $setting_data['type'], array('id' => 'type')), 'type');
|
//"php" => $lang->php // Internal Use Only );
$form_container->output_row($lang->type." <em>*</em>", "", $form->generate_select_box("type", $setting_types, $setting_data['type'], array('id' => 'type')), 'type');
|
$form_container->output_row($lang->extra, $lang->extra_desc, $form->generate_text_area('extra', $setting_data['extra'], array('id' => 'extra')), 'extra', array(), array('id' => 'row_extra'));
| $form_container->output_row($lang->extra, $lang->extra_desc, $form->generate_text_area('extra', !empty($setting_data['extra']) ? $setting_data['extra'] : null, array('id' => 'extra')), 'extra', array(), array('id' => 'row_extra'));
|
$form_container->output_row($lang->value, '', $form->generate_text_area('value', $setting_data['value'], array('id' => 'value')), 'value'); $form_container->end();
| $form_container->output_row($lang->value, '', $form->generate_text_area('value', $setting_data['value'], array('id' => 'value')), 'value'); $form_container->end();
|
Zeile 656 | Zeile 662 |
---|
$form->output_submit_wrapper($buttons); $form->end();
|
$form->output_submit_wrapper($buttons); $form->end();
|
echo '<script type="text/javascript" src="./jscripts/peeker.js?ver=1804"></script>
| echo '<script type="text/javascript" src="./jscripts/peeker.js?ver=1821"></script>
|
<script type="text/javascript"> $(function() { new Peeker($("#type"), $("#row_extra"), /^(select|radio|checkbox|php)$/, false);
| <script type="text/javascript"> $(function() { new Peeker($("#type"), $("#row_extra"), /^(select|radio|checkbox|php)$/, false);
|
Zeile 667 | Zeile 673 |
---|
$page->output_footer(); }
|
$page->output_footer(); }
|
|
|
// Delete Setting if($mybb->input['action'] == "delete") {
| // Delete Setting if($mybb->input['action'] == "delete") {
|
Zeile 675 | Zeile 681 |
---|
$setting = $db->fetch_array($query);
// Does the setting not exist?
|
$setting = $db->fetch_array($query);
// Does the setting not exist?
|
if(!$setting['sid'])
| if(empty($setting['sid']))
|
{ flash_message($lang->error_invalid_sid, 'error'); admin_redirect("index.php?module=config-settings&action=manage");
| { flash_message($lang->error_invalid_sid, 'error'); admin_redirect("index.php?module=config-settings&action=manage");
|
Zeile 689 | Zeile 695 |
---|
}
// User clicked no
|
}
// User clicked no
|
if($mybb->input['no']) { admin_redirect("index.php?module=config-settings&action=manage"); }
$plugins->run_hooks("admin_config_settings_delete");
| if($mybb->get_input('no')) { admin_redirect("index.php?module=config-settings&action=manage"); }
$plugins->run_hooks("admin_config_settings_delete");
|
if($mybb->request_method == "post") { // Delete the setting $db->delete_query("settings", "sid='{$setting['sid']}'");
|
if($mybb->request_method == "post") { // Delete the setting $db->delete_query("settings", "sid='{$setting['sid']}'");
|
|
|
rebuild_settings();
|
rebuild_settings();
|
|
|
$plugins->run_hooks("admin_config_settings_delete_commit");
|
$plugins->run_hooks("admin_config_settings_delete_commit");
|
|
|
// Log admin action log_admin_action($setting['sid'], $setting['title']);
flash_message($lang->success_setting_deleted, 'success');
|
// Log admin action log_admin_action($setting['sid'], $setting['title']);
flash_message($lang->success_setting_deleted, 'success');
|
admin_redirect("index.php?module=config-settings&action=manage"); } else
| admin_redirect("index.php?module=config-settings&action=manage"); } else
|
{ $page->output_confirm_action("index.php?module=config-settings&action=delete&sid={$setting['sid']}", $lang->confirm_setting_deletion); }
| { $page->output_confirm_action("index.php?module=config-settings&action=delete&sid={$setting['sid']}", $lang->confirm_setting_deletion); }
|
Zeile 803 | Zeile 809 |
---|
// Make setting group row // Translated? $group_lang_var = "setting_group_{$group['name']}";
|
// Make setting group row // Translated? $group_lang_var = "setting_group_{$group['name']}";
|
if($lang->$group_lang_var)
| if(!empty($lang->$group_lang_var))
|
{ $group_title = htmlspecialchars_uni($lang->$group_lang_var); }
| { $group_title = htmlspecialchars_uni($lang->$group_lang_var); }
|
Zeile 828 | Zeile 834 |
---|
$table->construct_row(array('class' => 'alt_row', 'no_alt_row' => 1));
// Make rows for each setting in the group
|
$table->construct_row(array('class' => 'alt_row', 'no_alt_row' => 1));
// Make rows for each setting in the group
|
if(is_array($settings_cache[$group['gid']]))
| if(isset($settings_cache[$group['gid']]) && is_array($settings_cache[$group['gid']]))
|
{ foreach($settings_cache[$group['gid']] as $setting) { $setting_lang_var = "setting_{$setting['name']}";
|
{ foreach($settings_cache[$group['gid']] as $setting) { $setting_lang_var = "setting_{$setting['name']}";
|
if($lang->$setting_lang_var)
| if(!empty($lang->$setting_lang_var))
|
{ $setting_title = htmlspecialchars_uni($lang->$setting_lang_var); }
| { $setting_title = htmlspecialchars_uni($lang->$setting_lang_var); }
|
Zeile 913 | Zeile 919 |
---|
);
$is_current_hiddencaptcha_wrong = in_array($mybb->settings['hiddencaptchaimagefield'], $disallowed_fields);
|
);
$is_current_hiddencaptcha_wrong = in_array($mybb->settings['hiddencaptchaimagefield'], $disallowed_fields);
|
if(in_array($mybb->input['upsetting']['hiddencaptchaimagefield'], $disallowed_fields) || $is_current_hiddencaptcha_wrong)
| if( (isset($mybb->input['upsetting']['hiddencaptchaimagefield']) && in_array($mybb->input['upsetting']['hiddencaptchaimagefield'], $disallowed_fields)) || $is_current_hiddencaptcha_wrong )
|
{ if(isset($mybb->input['upsetting']['hiddencaptchaimagefield']) && $mybb->input['upsetting']['hiddencaptchaimagefield'] != $mybb->settings['hiddencaptchaimagefield'] && !$is_current_hiddencaptcha_wrong) {
| { if(isset($mybb->input['upsetting']['hiddencaptchaimagefield']) && $mybb->input['upsetting']['hiddencaptchaimagefield'] != $mybb->settings['hiddencaptchaimagefield'] && !$is_current_hiddencaptcha_wrong) {
|
Zeile 924 | Zeile 933 |
---|
{ $wrong_value = $mybb->settings['hiddencaptchaimagefield']; $mybb->input['upsetting']['hiddencaptchaimagefield'] = 'email3';
|
{ $wrong_value = $mybb->settings['hiddencaptchaimagefield']; $mybb->input['upsetting']['hiddencaptchaimagefield'] = 'email3';
|
}
| }
|
$lang->success_settings_updated .= $lang->sprintf($lang->success_settings_updated_hiddencaptchaimage, htmlspecialchars_uni($mybb->input['upsetting']['hiddencaptchaimagefield']), htmlspecialchars_uni($wrong_value)); }
| $lang->success_settings_updated .= $lang->sprintf($lang->success_settings_updated_hiddencaptchaimage, htmlspecialchars_uni($mybb->input['upsetting']['hiddencaptchaimagefield']), htmlspecialchars_uni($wrong_value)); }
|
Zeile 937 | Zeile 946 |
---|
13 => array('memberlistmaxavatarsize') ); if(in_array($gid, array_keys($dimfields)))
|
13 => array('memberlistmaxavatarsize') ); if(in_array($gid, array_keys($dimfields)))
|
{
| {
|
foreach($dimfields[$gid] as $field) { if(isset($mybb->input['upsetting'][$field]))
| foreach($dimfields[$gid] as $field) { if(isset($mybb->input['upsetting'][$field]))
|
Zeile 956 | Zeile 965 |
---|
} }
|
} }
|
// Have we opted for a reCAPTCHA and not set a public/private key? if((isset($mybb->input['upsetting']['captchaimage']) && in_array($mybb->input['upsetting']['captchaimage'], array(4, 5)) && (!$mybb->input['upsetting']['captchaprivatekey'] || !$mybb->input['upsetting']['captchapublickey'])) || (in_array($mybb->settings['captchaimage'], array(4, 5)) && (!$mybb->settings['captchaprivatekey'] || !$mybb->settings['captchapublickey'])))
| // Validate minnamelength, maxnamelength, minpasswordlength (complex and regular) and maxpasswordlength if ($gid == 9)
|
{
|
{
|
$mybb->input['upsetting']['captchaimage'] = 1;
| if ( isset($mybb->input['upsetting']['minnamelength'], $mybb->input['upsetting']['maxnamelength']) && $mybb->input['upsetting']['minnamelength'] > 0 && $mybb->input['upsetting']['maxnamelength'] > 0 && $mybb->input['upsetting']['minnamelength'] > $mybb->input['upsetting']['maxnamelength']) { flash_message($lang->error_field_minnamelength, 'error'); admin_redirect("index.php?module=config-settings&action=change&gid=".$gid); }
if ( isset($mybb->input['upsetting']['minpasswordlength'], $mybb->input['upsetting']['maxpasswordlength']) && $mybb->input['upsetting']['minpasswordlength'] > 0 && $mybb->input['upsetting']['maxpasswordlength'] > 0 && $mybb->input['upsetting']['minpasswordlength'] > $mybb->input['upsetting']['maxpasswordlength'] ) { flash_message($lang->error_field_minpasswordlength, 'error'); admin_redirect("index.php?module=config-settings&action=change&gid=".$gid); }
if ( isset($mybb->input['upsetting']['minpasswordlength'], $mybb->input['upsetting']['requirecomplexpasswords']) && $mybb->input['upsetting']['requirecomplexpasswords'] && $mybb->input['upsetting']['minpasswordlength'] < 3 ) { flash_message($lang->error_field_minpasswordlength_complex, 'error'); admin_redirect("index.php?module=config-settings&action=change&gid=".$gid); } } require_once MYBB_ROOT.'inc/class_captcha.php'; // Have we opted for a reCAPTCHA or hCaptcha and not set a public/private key in input? $set_captcha_image = false; if(isset( $mybb->input['upsetting']['captchaimage'], $mybb->input['upsetting']['recaptchaprivatekey'], $mybb->input['upsetting']['recaptchapublickey'], $mybb->input['upsetting']['recaptchascore'], $mybb->input['upsetting']['hcaptchaprivatekey'], $mybb->input['upsetting']['hcaptchapublickey'] )) { $captchaimage = $mybb->input['upsetting']['captchaimage']; $recaptchaprivatekey = $mybb->input['upsetting']['recaptchaprivatekey']; $recaptchapublickey = $mybb->input['upsetting']['recaptchapublickey']; $recaptchascore = $mybb->input['upsetting']['recaptchascore']; $hcaptchaprivatekey = $mybb->input['upsetting']['hcaptchaprivatekey']; $hcaptchapublickey = $mybb->input['upsetting']['hcaptchapublickey'];
if(in_array($captchaimage, array(captcha::NOCAPTCHA_RECAPTCHA, captcha::RECAPTCHA_INVISIBLE)) && (!$recaptchaprivatekey || !$recaptchapublickey)) { $set_captcha_image = true; } else if(in_array($captchaimage, array(captcha::RECAPTCHA_V3)) && (!$recaptchaprivatekey || !$recaptchapublickey || !$recaptchascore)) { $set_captcha_image = true; } else if(in_array($captchaimage, array(captcha::HCAPTCHA, captcha::HCAPTCHA_INVISIBLE)) && (!$hcaptchaprivatekey || !$hcaptchapublickey)) { $set_captcha_image = true; } }
//Checking settings for reCAPTCHA or hCaptcha and public/private key not set? $captchaimage = $mybb->settings['captchaimage']; $recaptchaprivatekey = $mybb->settings['recaptchaprivatekey']; $recaptchapublickey = $mybb->settings['recaptchapublickey']; $recaptchascore = $mybb->settings['recaptchascore']; $hcaptchaprivatekey = $mybb->settings['hcaptchaprivatekey']; $hcaptchapublickey = $mybb->settings['hcaptchapublickey'];
if(in_array($captchaimage, array(captcha::NOCAPTCHA_RECAPTCHA, captcha::RECAPTCHA_INVISIBLE)) && (!$recaptchaprivatekey || !$recaptchapublickey)) { $set_captcha_image = true; } else if(in_array($captchaimage, array(captcha::RECAPTCHA_V3)) && (!$recaptchaprivatekey || !$recaptchapublickey || !$recaptchascore)) { $set_captcha_image = true; } else if(in_array($captchaimage, array(captcha::HCAPTCHA, captcha::HCAPTCHA_INVISIBLE)) && (!$hcaptchaprivatekey || !$hcaptchapublickey)) { $set_captcha_image = true; } if($set_captcha_image){ $mybb->input['upsetting']['captchaimage'] = captcha::DEFAULT_CAPTCHA;
|
$lang->success_settings_updated .= $lang->success_settings_updated_captchaimage;
|
$lang->success_settings_updated .= $lang->success_settings_updated_captchaimage;
|
| }
// If using fulltext then enforce minimum word length given by database if(isset($mybb->input['upsetting']['minsearchword']) && $mybb->input['upsetting']['minsearchword'] > 0 && $mybb->input['upsetting']['searchtype'] == "fulltext" && $db->supports_fulltext_boolean("posts") && $db->supports_fulltext("threads")) { // Attempt to determine minimum word length from MySQL for fulltext searches $query = $db->query("SHOW VARIABLES LIKE 'ft_min_word_len';"); $min_length = $db->fetch_field($query, 'Value'); if(is_numeric($min_length) && $mybb->input['upsetting']['minsearchword'] < $min_length) { $mybb->input['upsetting']['minsearchword'] = $min_length; $lang->success_settings_updated .= $lang->success_settings_updated_minsearchword; }
|
}
// Get settings which optionscode is a forum/group select, checkbox or numeric // We cannot rely on user input to decide this
|
}
// Get settings which optionscode is a forum/group select, checkbox or numeric // We cannot rely on user input to decide this
|
$checkbox_settings = $forum_group_select = array(); $query = $db->simple_select('settings', 'name, optionscode', "optionscode IN('forumselect', 'groupselect') OR optionscode LIKE 'checkbox%' OR optionscode LIKE 'numeric%'");
while($multisetting = $db->fetch_array($query))
| $checkbox_settings = $forum_group_select = $prefix_select = array(); $query = $db->simple_select('settings', 'name, optionscode', "optionscode IN('forumselect', 'groupselect', 'prefixselect') OR optionscode LIKE 'checkbox%' OR optionscode LIKE 'numeric%'");
while($multisetting = $db->fetch_array($query))
|
{ $options = array();
| { $options = array();
|
Zeile 981 | Zeile 1086 |
---|
if(empty($mybb->input['upsetting'][$multisetting['name']]) && isset($mybb->input["isvisible_{$multisetting['name']}"])) { $mybb->input['upsetting'][$multisetting['name']] = array();
|
if(empty($mybb->input['upsetting'][$multisetting['name']]) && isset($mybb->input["isvisible_{$multisetting['name']}"])) { $mybb->input['upsetting'][$multisetting['name']] = array();
|
} }
| } }
|
elseif(substr($multisetting['optionscode'], 0, 7) == 'numeric') { if(isset($mybb->input['upsetting'][$multisetting['name']]))
| elseif(substr($multisetting['optionscode'], 0, 7) == 'numeric') { if(isset($mybb->input['upsetting'][$multisetting['name']]))
|
Zeile 1007 | Zeile 1112 |
---|
if(isset($options['min'])) { $value = max($value, $options['min']);
|
if(isset($options['min'])) { $value = max($value, $options['min']);
|
}
| }
|
if(isset($options['max'])) { $value = min($value, $options['max']); }
|
if(isset($options['max'])) { $value = min($value, $options['max']); }
|
|
|
$mybb->input['upsetting'][$multisetting['name']] = $value; }
|
$mybb->input['upsetting'][$multisetting['name']] = $value; }
|
}
| }
|
else { $forum_group_select[] = $multisetting['name']; }
|
else { $forum_group_select[] = $multisetting['name']; }
|
| }
// Verify for admin email that can't be empty if(isset($mybb->input['upsetting']['adminemail']) && !validate_email_format($mybb->input['upsetting']['adminemail'])) { unset($mybb->input['upsetting']['adminemail']); $lang->success_settings_updated .= $lang->error_admin_email_settings_empty;
|
}
// Administrator is changing the login method.
|
}
// Administrator is changing the login method.
|
if($mybb->settings['username_method'] == 1 || $mybb->settings['username_method'] == 2 || $mybb->input['upsetting']['username_method'] == 1 || $mybb->input['upsetting']['username_method'] == 2)
| if(isset($mybb->input['upsetting']['username_method']) && (int)$mybb->input['upsetting']['username_method'] > 0)
|
{
|
{
|
$query = $db->simple_select('users', 'email', "email != ''", array('group_by' => 'email HAVING COUNT(email)>1')); if($db->num_rows($query))
| if((int)$mybb->settings['allowmultipleemails'] == 1)
|
{ $mybb->input['upsetting']['username_method'] = 0;
|
{ $mybb->input['upsetting']['username_method'] = 0;
|
$lang->success_settings_updated .= $lang->success_settings_updated_username_method; } else { $mybb->input['upsetting']['allowmultipleemails'] = 0; $lang->success_settings_updated .= $lang->success_settings_updated_allowmultipleemails; } }
| $lang->success_settings_updated .= $lang->success_settings_updated_username_method_conflict; } else { $query = $db->simple_select('users', 'email', "email != ''", array('group_by' => 'email HAVING COUNT(email)>1')); if($db->num_rows($query)) { $mybb->input['upsetting']['username_method'] = 0; $lang->success_settings_updated .= $lang->success_settings_updated_username_method; } } }
if(isset($mybb->input['upsetting']['username_method'], $mybb->input['upsetting']['allowmultipleemails'])) { // Administrator is changing registration email allowance if((int)$mybb->settings['username_method'] > 0 && (int)$mybb->input['upsetting']['allowmultipleemails'] !== 0) { $mybb->input['upsetting']['allowmultipleemails'] = 0; $lang->success_settings_updated .= $lang->success_settings_updated_allowmultipleemails; }
// Reset conflict silently, if by chance if((int)$mybb->settings['username_method'] > 0 && (int)$mybb->settings['allowmultipleemails'] == 1) { $mybb->input['upsetting']['allowmultipleemails'] = 0; } }
// reject dangerous/unsupported upload paths $fields = array( 'uploadspath', 'cdnpath', 'avataruploadpath', );
$dynamic_include_directories = array( MYBB_ROOT.'cache/', MYBB_ROOT.'inc/plugins/', MYBB_ROOT.'inc/languages/', MYBB_ROOT.'inc/tasks/', ); $dynamic_include_directories_realpath = array_map('realpath', $dynamic_include_directories);
foreach($fields as $field) { if(isset($mybb->input['upsetting'][$field])) { if( is_string($mybb->input['upsetting'][$field]) && strpos($mybb->input['upsetting'][$field], '://') !== false) { unset($mybb->input['upsetting'][$field]); continue; }
$realpath = realpath(mk_path_abs($mybb->input['upsetting'][$field]));
if ($realpath === false) { unset($mybb->input['upsetting'][$field]); continue; }
foreach ($dynamic_include_directories_realpath as $forbidden_realpath) { if ($realpath === $forbidden_realpath || strpos($realpath, $forbidden_realpath.DIRECTORY_SEPARATOR) === 0) { unset($mybb->input['upsetting'][$field]); continue 2; } } } }
|
if(is_array($mybb->input['upsetting'])) { foreach($mybb->input['upsetting'] as $name => $value)
| if(is_array($mybb->input['upsetting'])) { foreach($mybb->input['upsetting'] as $name => $value)
|
Zeile 1086 | Zeile 1264 |
---|
}
// Check if we need to create our fulltext index after changing the search mode
|
}
// Check if we need to create our fulltext index after changing the search mode
|
if($mybb->settings['searchtype'] != $mybb->input['upsetting']['searchtype'] && $mybb->input['upsetting']['searchtype'] == "fulltext")
| if( isset($mybb->input['upsetting']['searchtype']) && $mybb->settings['searchtype'] != $mybb->input['upsetting']['searchtype'] && $mybb->input['upsetting']['searchtype'] == "fulltext" )
|
{ if(!$db->is_fulltext("posts") && $db->supports_fulltext_boolean("posts")) { $db->create_fulltext_index("posts", "message");
|
{ if(!$db->is_fulltext("posts") && $db->supports_fulltext_boolean("posts")) { $db->create_fulltext_index("posts", "message");
|
} if(!$db->is_fulltext("posts") && $db->supports_fulltext("threads"))
| } if(!$db->is_fulltext("threads") && $db->supports_fulltext("threads"))
|
{ $db->create_fulltext_index("threads", "subject"); }
| { $db->create_fulltext_index("threads", "subject"); }
|
Zeile 1115 | Zeile 1297 |
---|
if(isset($mybb->input['upsetting']['statstopreferrer']) && $mybb->input['upsetting']['statstopreferrer'] != $mybb->settings['statstopreferrer']) { $cache->update_statistics();
|
if(isset($mybb->input['upsetting']['statstopreferrer']) && $mybb->input['upsetting']['statstopreferrer'] != $mybb->settings['statstopreferrer']) { $cache->update_statistics();
|
}
$statslimit = $mybb->settings['statslimit'];
rebuild_settings();
| }
$statslimit = $mybb->settings['statslimit'];
rebuild_settings();
|
if(isset($mybb->input['upsetting']['statslimit']) && $mybb->input['upsetting']['statslimit'] != $statslimit) {
| if(isset($mybb->input['upsetting']['statslimit']) && $mybb->input['upsetting']['statslimit'] != $statslimit) {
|
Zeile 1131 | Zeile 1313 |
---|
// Log admin action log_admin_action();
|
// Log admin action log_admin_action();
|
|
|
flash_message($lang->success_settings_updated, 'success'); admin_redirect("index.php?module=config-settings"); }
|
flash_message($lang->success_settings_updated, 'success'); admin_redirect("index.php?module=config-settings"); }
|
|
|
// What type of page $cache_groups = $cache_settings = array(); if(isset($mybb->input['search']))
| // What type of page $cache_groups = $cache_settings = array(); if(isset($mybb->input['search']))
|
Zeile 1143 | Zeile 1325 |
---|
// Search
// Search for settings
|
// Search
// Search for settings
|
$search = $db->escape_string_like($mybb->input['search']); $query = $db->query(" SELECT s.* , g.name as gname, g.title as gtitle, g.description as gdescription FROM ".TABLE_PREFIX."settings s LEFT JOIN ".TABLE_PREFIX."settinggroups g ON(s.gid=g.gid) ORDER BY s.disporder "); while($setting = $db->fetch_array($query))
| $search = trim($mybb->input['search']); if(!empty($search))
|
{
|
{
|
$lang_var = "setting_{$setting['name']}"; if(isset($lang->$lang_var))
| $query = $db->query(" SELECT s.* , g.name as gname, g.title as gtitle, g.description as gdescription FROM ".TABLE_PREFIX."settings s LEFT JOIN ".TABLE_PREFIX."settinggroups g ON(s.gid=g.gid) ORDER BY s.disporder "); while($setting = $db->fetch_array($query))
|
{
|
{
|
$setting["title"] = $lang->$lang_var; } $lang_var = "setting_{$setting['name']}_desc"; if(isset($lang->$lang_var)) { $setting["description"] = $lang->$lang_var; } $lang_var = "setting_group_{$setting['gname']}"; if(isset($lang->$lang_var)) { $setting["gtitle"] = $lang->$lang_var; } $lang_var = "setting_group_{$setting['gname']}_desc"; if(isset($lang->$lang_var)) { $setting["gdescription"] = $lang->$lang_var; } $lang_var = $setting["title"] . " " . $setting["description"] . " " . $setting["gtitle"] . " " . $setting["gdescription"]; $search = mb_convert_encoding($search, mb_detect_encoding($setting["title"], "auto")); if (mb_stripos($lang_var, $search)) { $cache_settings[$setting['gid']][$setting['sid']] = $setting;
| $search_in = $setting['name'] . ' ' . $setting['title'] . ' ' . $setting['description'] . ' ' . $setting['gname'] . ' ' . $setting['gtitle'] . ' ' . $setting['gdescription']; foreach(array("setting_{$setting['name']}", "setting_{$setting['name']}_desc", "setting_group_{$setting['gname']}", "setting_group_{$setting['gname']}_desc") as $search_in_lang_key) { if(!empty($lang->$search_in_lang_key)) { $search_in .= ' ' . $lang->$search_in_lang_key; } } if(my_stripos($search_in, $search) !== false) { $cache_settings[$setting['gid']][$setting['sid']] = $setting; }
|
} } if(!count($cache_settings))
| } } if(!count($cache_settings))
|
Zeile 1209 | Zeile 1380 |
---|
$page->output_header($lang->board_settings." - {$lang->settings_search}"); } }
|
$page->output_header($lang->board_settings." - {$lang->settings_search}"); } }
|
elseif($mybb->input['gid'])
| elseif(($mybb->get_input('gid')))
|
{ // Group listing // Cache groups $query = $db->simple_select("settinggroups", "*", "gid = '".$mybb->get_input('gid', MyBB::INPUT_INT)."'"); $groupinfo = $db->fetch_array($query); $cache_groups[$groupinfo['gid']] = $groupinfo;
|
{ // Group listing // Cache groups $query = $db->simple_select("settinggroups", "*", "gid = '".$mybb->get_input('gid', MyBB::INPUT_INT)."'"); $groupinfo = $db->fetch_array($query); $cache_groups[$groupinfo['gid']] = $groupinfo;
|
if(!$db->num_rows($query)) { $page->output_error($lang->error_invalid_gid2); }
| if(!$db->num_rows($query)) { $page->output_error($lang->error_invalid_gid2); }
|
// Cache settings $query = $db->simple_select("settings", "*", "gid='".$mybb->get_input('gid', MyBB::INPUT_INT)."'", array('order_by' => 'disporder'));
| // Cache settings $query = $db->simple_select("settings", "*", "gid='".$mybb->get_input('gid', MyBB::INPUT_INT)."'", array('order_by' => 'disporder'));
|
Zeile 1232 | Zeile 1403 |
---|
if(!$db->num_rows($query)) { flash_message($lang->error_no_settings_found, 'error');
|
if(!$db->num_rows($query)) { flash_message($lang->error_no_settings_found, 'error');
|
admin_redirect("index.php?module=config-settings"); }
| admin_redirect("index.php?module=config-settings"); }
|
$group_lang_var = "setting_group_{$groupinfo['name']}"; if(isset($lang->$group_lang_var))
| $group_lang_var = "setting_group_{$groupinfo['name']}"; if(isset($lang->$group_lang_var))
|
Zeile 1258 | Zeile 1429 |
---|
if(!$db->num_rows($query)) { $page->output_error($lang->error_invalid_gid2);
|
if(!$db->num_rows($query)) { $page->output_error($lang->error_invalid_gid2);
|
}
| }
|
// Cache settings $query = $db->simple_select("settings", "*", "", array('order_by' => 'disporder'));
| // Cache settings $query = $db->simple_select("settings", "*", "", array('order_by' => 'disporder'));
|
Zeile 1266 | Zeile 1437 |
---|
{ $cache_settings[$setting['gid']][$setting['sid']] = $setting; }
|
{ $cache_settings[$setting['gid']][$setting['sid']] = $setting; }
|
|
|
// Page header $page->add_breadcrumb_item($lang->show_all_settings); $page->output_header($lang->board_settings." - {$lang->show_all_settings}"); }
|
// Page header $page->add_breadcrumb_item($lang->show_all_settings); $page->output_header($lang->board_settings." - {$lang->show_all_settings}"); }
|
|
|
// Build individual forms as per settings group foreach($cache_groups as $groupinfo) {
| // Build individual forms as per settings group foreach($cache_groups as $groupinfo) {
|
Zeile 1348 | Zeile 1519 |
---|
$folders = array(); while($folder = readdir($dir)) {
|
$folders = array(); while($folder = readdir($dir)) {
|
if($file != "." && $file != ".." && @file_exists(MYBB_ROOT.$config['admin_dir']."/styles/$folder/main.css"))
| if($folder != "." && $folder != ".." && @file_exists(MYBB_ROOT.$config['admin_dir']."/styles/$folder/main.css"))
|
{ $folders[$folder] = ucfirst($folder); }
| { $folders[$folder] = ucfirst($folder); }
|
Zeile 1481 | Zeile 1652 |
---|
{ $selected_value = (int)$setting['value']; // No need to check if empty, int will give 0 $setting_code = $form->generate_group_select($element_name, $selected_value, array('id' => $element_id, 'main_option' => $lang->none));
|
{ $selected_value = (int)$setting['value']; // No need to check if empty, int will give 0 $setting_code = $form->generate_group_select($element_name, $selected_value, array('id' => $element_id, 'main_option' => $lang->none));
|
| } else if($type[0] == "prefixselect") { $selected_values = ''; if($setting['value'] != '' && $setting['value'] != -1) { $selected_values = explode(',', (string)$setting['value']); foreach($selected_values as &$value) { $value = (int)$value; } unset($value); } $prefix_checked = array('all' => '', 'custom' => '', 'none' => ''); if($setting['value'] == -1) { $prefix_checked['all'] = 'checked="checked"'; } elseif($setting['value'] != '') { $prefix_checked['custom'] = 'checked="checked"'; } else { $prefix_checked['none'] = 'checked="checked"'; } print_selection_javascript(); $setting_code = " <dl style=\"margin-top: 0; margin-bottom: 0; width: 100%\"> <dt><label style=\"display: block;\"><input type=\"radio\" name=\"{$element_name}\" value=\"all\" {$prefix_checked['all']} class=\"{$element_id}_forums_groups_check\" onclick=\"checkAction('{$element_id}');\" style=\"vertical-align: middle;\" /> <strong>{$lang->all_prefix}</strong></label></dt> <dt><label style=\"display: block;\"><input type=\"radio\" name=\"{$element_name}\" value=\"custom\" {$prefix_checked['custom']} class=\"{$element_id}_forums_groups_check\" onclick=\"checkAction('{$element_id}');\" style=\"vertical-align: middle;\" /> <strong>{$lang->select_prefix}</strong></label></dt> <dd style=\"margin-top: 4px;\" id=\"{$element_id}_forums_groups_custom\" class=\"{$element_id}_forums_groups\"> <table cellpadding=\"4\"> <tr> <td valign=\"top\"><small>{$lang->prefix_colon}</small></td> <td>".$form->generate_prefix_select('select['.$setting['name'].'][]', $selected_values, array('id' => $element_id, 'multiple' => true, 'size' => 5))."</td> </tr> </table> </dd> <dt><label style=\"display: block;\"><input type=\"radio\" name=\"{$element_name}\" value=\"none\" {$prefix_checked['none']} class=\"{$element_id}_forums_groups_check\" onclick=\"checkAction('{$element_id}');\" style=\"vertical-align: middle;\" /> <strong>{$lang->none}</strong></label></dt> </dl> <script type=\"text/javascript\"> checkAction('{$element_id}'); </script>";
|
} else {
| } else {
|
Zeile 1715 | Zeile 1930 |
---|
while($group = $db->fetch_array($query)) { $group_lang_var = "setting_group_{$group['name']}";
|
while($group = $db->fetch_array($query)) { $group_lang_var = "setting_group_{$group['name']}";
|
if($lang->$group_lang_var)
| if(isset($lang->$group_lang_var))
|
{ $group_title = htmlspecialchars_uni($lang->$group_lang_var); }
| { $group_title = htmlspecialchars_uni($lang->$group_lang_var); }
|
Zeile 1725 | Zeile 1940 |
---|
}
$group_desc_lang_var = "setting_group_{$group['name']}_desc";
|
}
$group_desc_lang_var = "setting_group_{$group['name']}_desc";
|
if($lang->$group_desc_lang_var)
| if(isset($lang->$group_desc_lang_var))
|
{ $group_desc = htmlspecialchars_uni($lang->$group_desc_lang_var); }
| { $group_desc = htmlspecialchars_uni($lang->$group_desc_lang_var); }
|
Zeile 1744 | Zeile 1959 |
---|
echo '</div>';
echo '
|
echo '</div>';
echo '
|
<script type="text/javascript" src="./jscripts/search.js?ver=1808"></script>
| <script type="text/javascript" src="./jscripts/search.js?ver=1821"></script>
|
<script type="text/javascript"> //<!-- $(function(){
| <script type="text/javascript"> //<!-- $(function(){
|
Zeile 1767 | Zeile 1982 |
---|
$peekers = array( 'new Peeker($(".setting_boardclosed"), $("#row_setting_boardclosed_reason"), 1, true)', 'new Peeker($(".setting_gzipoutput"), $("#row_setting_gziplevel"), 1, true)',
|
$peekers = array( 'new Peeker($(".setting_boardclosed"), $("#row_setting_boardclosed_reason"), 1, true)', 'new Peeker($(".setting_gzipoutput"), $("#row_setting_gziplevel"), 1, true)',
|
'new Peeker($(".setting_useerrorhandling"), $("#row_setting_errorlogmedium, #row_setting_errortypemedium, #row_setting_errorloglocation"), 1, true)',
| 'new Peeker($(".setting_useerrorhandling"), $("#row_setting_errorlogmedium, #row_setting_errorloglocation"), 1, true)',
|
'new Peeker($("#setting_subforumsindex"), $("#row_setting_subforumsstatusicons"), /[^0+|]/, false)', 'new Peeker($(".setting_showsimilarthreads"), $("#row_setting_similarityrating, #row_setting_similarlimit"), 1, true)', 'new Peeker($(".setting_disableregs"), $("#row_setting_regtype, #row_setting_securityquestion, #row_setting_regtime, #row_setting_allowmultipleemails, #row_setting_hiddencaptchaimage, #row_setting_betweenregstime"), 0, true)',
| 'new Peeker($("#setting_subforumsindex"), $("#row_setting_subforumsstatusicons"), /[^0+|]/, false)', 'new Peeker($(".setting_showsimilarthreads"), $("#row_setting_similarityrating, #row_setting_similarlimit"), 1, true)', 'new Peeker($(".setting_disableregs"), $("#row_setting_regtype, #row_setting_securityquestion, #row_setting_regtime, #row_setting_allowmultipleemails, #row_setting_hiddencaptchaimage, #row_setting_betweenregstime"), 0, true)',
|
Zeile 1782 | Zeile 1997 |
---|
'new Peeker($(".setting_smilieinserter"), $("#row_setting_smilieinsertertot, #row_setting_smilieinsertercols"), 1, true)', 'new Peeker($("#setting_mail_handler"), $("#row_setting_smtp_host, #row_setting_smtp_port, #row_setting_smtp_user, #row_setting_smtp_pass, #row_setting_secure_smtp"), "smtp", false)', 'new Peeker($("#setting_mail_handler"), $("#row_setting_mail_parameters"), "mail", false)',
|
'new Peeker($(".setting_smilieinserter"), $("#row_setting_smilieinsertertot, #row_setting_smilieinsertercols"), 1, true)', 'new Peeker($("#setting_mail_handler"), $("#row_setting_smtp_host, #row_setting_smtp_port, #row_setting_smtp_user, #row_setting_smtp_pass, #row_setting_secure_smtp"), "smtp", false)', 'new Peeker($("#setting_mail_handler"), $("#row_setting_mail_parameters"), "mail", false)',
|
'new Peeker($("#setting_captchaimage"), $("#row_setting_captchapublickey, #row_setting_captchaprivatekey"), /(4|5)/, false)',
| 'new Peeker($("#setting_captchaimage"), $("#row_setting_recaptchapublickey, #row_setting_recaptchaprivatekey"), /(4|5|8)/, false)', 'new Peeker($("#setting_captchaimage"), $("#row_setting_recaptchascore"), /(8)/, false)', 'new Peeker($("#setting_captchaimage"), $("#row_setting_hcaptchapublickey, #row_setting_hcaptchaprivatekey"), /(6|7)/, false)', 'new Peeker($("#setting_captchaimage"), $("#row_setting_hcaptchaprivatekey, #row_setting_hcaptchaprivatekey"), /(6|7)/, false)', 'new Peeker($("#setting_captchaimage"), $("#row_setting_hcaptchatheme"), 6, false)', 'new Peeker($("#setting_captchaimage"), $("#row_setting_hcaptchasize"), 6, false)',
|
'new Peeker($(".setting_contact"), $("#row_setting_contact_guests, #row_setting_contact_badwords, #row_setting_contact_maxsubjectlength, #row_setting_contact_minmessagelength, #row_setting_contact_maxmessagelength"), 1, true)', 'new Peeker($(".setting_enablepruning"), $("#row_setting_enableprunebyposts, #row_setting_pruneunactived, #row_setting_prunethreads"), 1, true)', 'new Peeker($(".setting_enableprunebyposts"), $("#row_setting_prunepostcount, #row_setting_dayspruneregistered, #row_setting_prunepostcountall"), 1, true)',
| 'new Peeker($(".setting_contact"), $("#row_setting_contact_guests, #row_setting_contact_badwords, #row_setting_contact_maxsubjectlength, #row_setting_contact_minmessagelength, #row_setting_contact_maxmessagelength"), 1, true)', 'new Peeker($(".setting_enablepruning"), $("#row_setting_enableprunebyposts, #row_setting_pruneunactived, #row_setting_prunethreads"), 1, true)', 'new Peeker($(".setting_enableprunebyposts"), $("#row_setting_prunepostcount, #row_setting_dayspruneregistered, #row_setting_prunepostcountall"), 1, true)',
|
Zeile 1800 | Zeile 2020 |
---|
'new Peeker($(".setting_showbirthdays"), $("#row_setting_showbirthdayspostlimit"), 1, true)', 'new Peeker($("#setting_betweenregstime"), $("#row_setting_maxregsbetweentime"), /[^0+|]/, false)', 'new Peeker($(".setting_usecdn"), $("#row_setting_cdnurl, #row_setting_cdnpath"), 1, true)',
|
'new Peeker($(".setting_showbirthdays"), $("#row_setting_showbirthdayspostlimit"), 1, true)', 'new Peeker($("#setting_betweenregstime"), $("#row_setting_maxregsbetweentime"), /[^0+|]/, false)', 'new Peeker($(".setting_usecdn"), $("#row_setting_cdnurl, #row_setting_cdnpath"), 1, true)',
|
'new Peeker($("#setting_errorlogmedium"), $("#row_setting_errortypemedium"), /^(log|email|both)/, false)',
| |
'new Peeker($("#setting_errorlogmedium"), $("#row_setting_errorloglocation"), /^(log|both)/, false)', 'new Peeker($(".setting_sigmycode"), $("#row_setting_sigcountmycode, #row_setting_sigimgcode"), 1, true)', 'new Peeker($(".setting_pmsallowmycode"), $("#row_setting_pmsallowimgcode, #row_setting_pmsallowvideocode"), 1, true)',
| 'new Peeker($("#setting_errorlogmedium"), $("#row_setting_errorloglocation"), /^(log|both)/, false)', 'new Peeker($(".setting_sigmycode"), $("#row_setting_sigcountmycode, #row_setting_sigimgcode"), 1, true)', 'new Peeker($(".setting_pmsallowmycode"), $("#row_setting_pmsallowimgcode, #row_setting_pmsallowvideocode"), 1, true)',
|
Zeile 1812 | Zeile 2031 |
---|
$setting_peekers = implode("\n ", $peekers);
|
$setting_peekers = implode("\n ", $peekers);
|
echo '<script type="text/javascript" src="./jscripts/peeker.js?ver=1804"></script>
| echo '<script type="text/javascript" src="./jscripts/peeker.js?ver=1821"></script>
|
<script type="text/javascript"> $(function() { ' . $setting_peekers . '
| <script type="text/javascript"> $(function() { ' . $setting_peekers . '
|