3 // searches for admin settings
5 require_once('../config.php');
6 require_once($CFG->libdir
.'/adminlib.php');
8 $query = trim(optional_param('query', '', PARAM_NOTAGS
)); // Search string
10 $PAGE->set_context(context_system
::instance());
12 admin_externalpage_setup('search', '', array('query' => $query)); // now hidden page
14 $adminroot = admin_get_root(); // need all settings here
15 $adminroot->search
= $query; // So we can reference it in search boxes later in this invocation
20 // now we'll deal with the case that the admin has submitted the form with changed settings
21 if ($data = data_submitted() and confirm_sesskey()) {
22 if (admin_write_settings($data)) {
23 redirect($PAGE->url
, get_string('changessaved'), null, \core\output\notification
::NOTIFY_SUCCESS
);
26 if (!empty($adminroot->errors
)) {
27 $errormsg = get_string('errorwithsettings', 'admin');
28 $firsterror = reset($adminroot->errors
);
29 $focus = $firsterror->id
;
35 // and finally, if we get here, then there are matching settings and we have to print a form
37 echo $OUTPUT->header($focus);
39 if ($errormsg !== '') {
40 echo $OUTPUT->notification($errormsg);
42 } else if ($statusmsg !== '') {
43 echo $OUTPUT->notification($statusmsg, 'notifysuccess');
46 $resultshtml = admin_search_settings_html($query); // case insensitive search only
48 echo '<form action="' . $PAGE->url
->out(true) . '" method="post" id="adminsettings">';
50 echo '<input type="hidden" name="sesskey" value="'.sesskey().'" />';
51 // HACK to prevent browsers from automatically inserting the user's password into the wrong fields.
52 echo prevent_form_autofill_password();
55 echo '<div class="clearer"><!-- --></div>';
56 if ($resultshtml != '') {
59 echo get_string('noresults','admin');
64 echo $OUTPUT->footer();