MDL-27121 fix incorrect check_moodle_environment() version parameter
[moodle.git] / admin / index.php
1 <?php
3 // This file is part of Moodle - http://moodle.org/
4 //
5 // Moodle is free software: you can redistribute it and/or modify
6 // it under the terms of the GNU General Public License as published by
7 // the Free Software Foundation, either version 3 of the License, or
8 // (at your option) any later version.
9 //
10 // Moodle is distributed in the hope that it will be useful,
11 // but WITHOUT ANY WARRANTY; without even the implied warranty of
12 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13 // GNU General Public License for more details.
14 //
15 // You should have received a copy of the GNU General Public License
16 // along with Moodle.  If not, see <http://www.gnu.org/licenses/>.
18 /**
19  * Main administration script.
20  *
21  * @package    core
22  * @copyright  1999 onwards Martin Dougiamas (http://dougiamas.com)
23  * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
24  */
26 // Check that config.php exists, if not then call the install script
27 if (!file_exists('../config.php')) {
28     header('Location: ../install.php');
29     die;
30 }
32 // Check that PHP is of a sufficient version as soon as possible
33 if (version_compare(phpversion(), '5.2.0') < 0) {
34     $phpversion = phpversion();
35     // do NOT localise - lang strings would not work here and we CAN NOT move it to later place
36     echo "Sorry, Moodle 2.0 requires PHP 5.2.8 or later (currently using version $phpversion). ";
37     echo "Please upgrade your server software or use latest Moodle 1.9.x instead.";
38     die;
39 }
41 define('NO_OUTPUT_BUFFERING', true);
43 require('../config.php');
44 require_once($CFG->libdir.'/adminlib.php');    // various admin-only functions
45 require_once($CFG->libdir.'/upgradelib.php');  // general upgrade/install related functions
47 $id             = optional_param('id', '', PARAM_TEXT);
48 $confirmupgrade = optional_param('confirmupgrade', 0, PARAM_BOOL);
49 $confirmrelease = optional_param('confirmrelease', 0, PARAM_BOOL);
50 $confirmplugins = optional_param('confirmplugincheck', 0, PARAM_BOOL);
51 $showallplugins = optional_param('showallplugins', 0, PARAM_BOOL);
52 $agreelicense   = optional_param('agreelicense', 0, PARAM_BOOL);
54 // Check some PHP server settings
56 $PAGE->set_url('/admin/index.php');
57 $PAGE->set_pagelayout('admin'); // Set a default pagelayout
59 $documentationlink = '<a href="http://docs.moodle.org/en/Installation">Installation docs</a>';
61 if (ini_get_bool('session.auto_start')) {
62     print_error('phpvaroff', 'debug', '', (object)array('name'=>'session.auto_start', 'link'=>$documentationlink));
63 }
65 if (ini_get_bool('magic_quotes_runtime')) {
66     print_error('phpvaroff', 'debug', '', (object)array('name'=>'magic_quotes_runtime', 'link'=>$documentationlink));
67 }
69 if (!ini_get_bool('file_uploads')) {
70     print_error('phpvaron', 'debug', '', (object)array('name'=>'file_uploads', 'link'=>$documentationlink));
71 }
73 if (is_float_problem()) {
74     print_error('phpfloatproblem', 'admin', '', $documentationlink);
75 }
77 // Set some necessary variables during set-up to avoid PHP warnings later on this page
78 if (!isset($CFG->framename)) {
79     $CFG->framename = '_top';
80 }
81 if (!isset($CFG->release)) {
82     $CFG->release = '';
83 }
84 if (!isset($CFG->version)) {
85     $CFG->version = '';
86 }
88 $version = null;
89 $release = null;
90 require("$CFG->dirroot/version.php");       // defines $version, $release and $maturity
91 $CFG->target_release = $release;            // used during installation and upgrades
93 if (!$version or !$release) {
94     print_error('withoutversion', 'debug'); // without version, stop
95 }
97 // Turn off xmlstrictheaders during upgrade.
98 $origxmlstrictheaders = !empty($CFG->xmlstrictheaders);
99 $CFG->xmlstrictheaders = false;
101 if (!core_tables_exist()) {
102     $PAGE->set_pagelayout('maintenance');
103     $PAGE->set_popup_notification_allowed(false);
105     // fake some settings
106     $CFG->docroot = 'http://docs.moodle.org';
108     $strinstallation = get_string('installation', 'install');
110     // remove current session content completely
111     session_get_instance()->terminate_current();
113     if (empty($agreelicense)) {
114         $strlicense = get_string('license');
115         $PAGE->navbar->add($strlicense);
116         $PAGE->set_title($strinstallation.' - Moodle '.$CFG->target_release);
117         $PAGE->set_heading($strinstallation);
118         $PAGE->set_cacheable(false);
119         echo $OUTPUT->header();
120         echo $OUTPUT->heading('<a href="http://moodle.org">Moodle</a> - Modular Object-Oriented Dynamic Learning Environment');
121         echo $OUTPUT->heading(get_string('copyrightnotice'));
122         $copyrightnotice = text_to_html(get_string('gpl3'));
123         $copyrightnotice = str_replace('target="_blank"', 'onclick="this.target=\'_blank\'"', $copyrightnotice); // extremely ugly validation hack
124         echo $OUTPUT->box($copyrightnotice, 'copyrightnotice');
125         echo '<br />';
126         $continue = new single_button(new moodle_url('/admin/index.php', array('lang'=>$CFG->lang, 'agreelicense'=>1)), get_string('continue'), 'get');
127         echo $OUTPUT->confirm(get_string('doyouagree'), $continue, "http://docs.moodle.org/en/License");
128         echo $OUTPUT->footer();
129         die;
130     }
131     if (empty($confirmrelease)) {
132         $strcurrentrelease = get_string('currentrelease');
133         $PAGE->navbar->add($strcurrentrelease);
134         $PAGE->set_title($strinstallation);
135         $PAGE->set_heading($strinstallation . ' - Moodle ' . $CFG->target_release);
136         $PAGE->set_cacheable(false);
137         echo $OUTPUT->header();
138         echo $OUTPUT->heading("Moodle $release");
140         if (isset($maturity)) {
141             // main version.php declares moodle code maturity
142             if ($maturity < MATURITY_STABLE) {
143                 $maturitylevel = get_string('maturity'.$maturity, 'admin');
144                 echo $OUTPUT->box(
145                     $OUTPUT->container(get_string('maturitycorewarning', 'admin', $maturitylevel)) .
146                     $OUTPUT->container($OUTPUT->doc_link('admin/versions', get_string('morehelp'))),
147                     'generalbox maturitywarning');
148             }
149         }
151         $releasenoteslink = get_string('releasenoteslink', 'admin', 'http://docs.moodle.org/en/Release_Notes');
152         $releasenoteslink = str_replace('target="_blank"', 'onclick="this.target=\'_blank\'"', $releasenoteslink); // extremely ugly validation hack
153         echo $OUTPUT->box($releasenoteslink, 'generalbox releasenoteslink');
155         require_once($CFG->libdir.'/environmentlib.php');
156         if (!check_moodle_environment(normalize_version($release), $environment_results, true, ENV_SELECT_RELEASE)) {
157             print_upgrade_reload("index.php?agreelicense=1&amp;lang=$CFG->lang");
158         } else {
159             echo $OUTPUT->notification(get_string('environmentok', 'admin'), 'notifysuccess');
160             echo $OUTPUT->continue_button(new moodle_url('/admin/index.php', array('agreelicense'=>1, 'confirmrelease'=>1, 'lang'=>$CFG->lang)));
161         }
163         echo $OUTPUT->footer();
164         die;
165     }
167     $strdatabasesetup = get_string('databasesetup');
168     upgrade_init_javascript();
169     $PAGE->navbar->add($strdatabasesetup);
170     $PAGE->set_title($strinstallation.' - Moodle '.$CFG->target_release);
171     $PAGE->set_heading($strinstallation);
172     $PAGE->set_cacheable(false);
173     echo $OUTPUT->header();
175     if (!$DB->setup_is_unicodedb()) {
176         if (!$DB->change_db_encoding()) {
177             // If could not convert successfully, throw error, and prevent installation
178             print_error('unicoderequired', 'admin');
179         }
180     }
182     install_core($version, true);
186 // Check version of Moodle code on disk compared with database
187 // and upgrade if possible.
189 $stradministration = get_string('administration');
190 $PAGE->set_context(get_context_instance(CONTEXT_SYSTEM));
192 if (empty($CFG->version)) {
193     print_error('missingconfigversion', 'debug');
196 if ($version > $CFG->version) {  // upgrade
197     $PAGE->set_pagelayout('maintenance');
198     $PAGE->set_popup_notification_allowed(false);
200     $a->oldversion = "$CFG->release ($CFG->version)";
201     $a->newversion = "$release ($version)";
202     $strdatabasechecking = get_string('databasechecking', '', $a);
204     if (empty($confirmupgrade)) {
205         $PAGE->set_title($stradministration);
206         $PAGE->set_heading($strdatabasechecking);
207         $PAGE->set_cacheable(false);
208         echo $OUTPUT->header();
209         if (isset($maturity)) {
210             // main version.php declares moodle code maturity
211             if ($maturity < MATURITY_STABLE) {
212                 $maturitylevel = get_string('maturity'.$maturity, 'admin');
213                 echo $OUTPUT->box(
214                     $OUTPUT->container(get_string('maturitycorewarning', 'admin', $maturitylevel)) .
215                     $OUTPUT->container($OUTPUT->doc_link('admin/versions', get_string('morehelp'))),
216                     'generalbox maturitywarning');
218         }
219         $continueurl = new moodle_url('index.php', array('confirmupgrade' => 1));
220         $cancelurl = new moodle_url('index.php');
221         echo $OUTPUT->confirm(get_string('upgradesure', 'admin', $a->newversion), $continueurl, $cancelurl);
222         echo $OUTPUT->footer();
223         exit;
225     } else if (empty($confirmrelease)){
226         $strcurrentrelease = get_string('currentrelease');
227         $PAGE->navbar->add($strcurrentrelease);
228         $PAGE->set_title($strcurrentrelease);
229         $PAGE->set_heading($strcurrentrelease);
230         $PAGE->set_cacheable(false);
231         echo $OUTPUT->header();
232         echo $OUTPUT->heading("Moodle $release");
233         $releasenoteslink = get_string('releasenoteslink', 'admin', 'http://docs.moodle.org/en/Release_Notes');
234         $releasenoteslink = str_replace('target="_blank"', 'onclick="this.target=\'_blank\'"', $releasenoteslink); // extremely ugly validation hack
235         echo $OUTPUT->box($releasenoteslink);
237         require_once($CFG->libdir.'/environmentlib.php');
238         if (!check_moodle_environment($release, $environment_results, true, ENV_SELECT_RELEASE)) {
239             print_upgrade_reload('index.php?confirmupgrade=1');
240         } else {
241             echo $OUTPUT->notification(get_string('environmentok', 'admin'), 'notifysuccess');
242             if (empty($CFG->skiplangupgrade)) {
243                 echo $OUTPUT->box_start('generalbox', 'notice');
244                 print_string('langpackwillbeupdated', 'admin');
245                 echo $OUTPUT->box_end();
246             }
247             echo $OUTPUT->continue_button('index.php?confirmupgrade=1&confirmrelease=1');
248         }
250         echo $OUTPUT->footer();
251         die;
253     } elseif (empty($confirmplugins)) {
254         $strplugincheck = get_string('plugincheck');
255         $PAGE->navbar->add($strplugincheck);
256         $PAGE->set_title($strplugincheck);
257         $PAGE->set_heading($strplugincheck);
258         $PAGE->set_cacheable(false);
259         $output = $PAGE->get_renderer('core', 'admin');
260         $pluginman = plugin_manager::instance();
262         echo $output->header();
263         echo $output->box_start('generalbox');
264         echo $output->container(get_string('pluginchecknotice', 'core_plugin'), 'generalbox', 'notice');
265         echo $output->plugins_check($pluginman->get_plugins(), array('full' => $showallplugins));
266         echo $output->box_end();
267         print_upgrade_reload('index.php?confirmupgrade=1&amp;confirmrelease=1');
268         $button = new single_button(new moodle_url('index.php', array('confirmupgrade'=>1, 'confirmrelease'=>1, 'confirmplugincheck'=>1)), get_string('upgradestart', 'admin'), 'get');
269         $button->class = 'continuebutton';
270         echo $output->render($button);
271         echo $output->footer();
272         die();
274     } else {
275         // Launch main upgrade
276         upgrade_core($version, true);
277     }
278 } else if ($version < $CFG->version) {
279     // better stop here, we can not continue with plugin upgrades or anything else
280     throw new moodle_exception('downgradedcore', 'error', new moodle_url('/admin/'));
283 // Updated human-readable release version if necessary
284 if ($release <> $CFG->release) {  // Update the release version
285     set_config('release', $release);
288 if (moodle_needs_upgrading()) {
289     if (!$PAGE->headerprinted) {
290         // means core upgrade or installation was not already done
291         if (!$confirmplugins) {
292             $PAGE->set_pagelayout('maintenance');
293             $PAGE->set_popup_notification_allowed(false);
294             $strplugincheck = get_string('plugincheck');
295             $PAGE->navbar->add($strplugincheck);
296             $PAGE->set_title($strplugincheck);
297             $PAGE->set_heading($strplugincheck);
298             $PAGE->set_cacheable(false);
299             $output = $PAGE->get_renderer('core', 'admin');
300             $pluginman = plugin_manager::instance();
302             echo $output->header();
303             echo $output->box_start('generalbox');
304             echo $output->container(get_string('pluginchecknotice', 'core_plugin'), 'generalbox', 'notice');
305             echo $output->plugins_check($pluginman->get_plugins(), array('full' => $showallplugins));
306             echo $output->box_end();
307             print_upgrade_reload('index.php');
308             $button = new single_button(new moodle_url('index.php', array('confirmplugincheck'=>1)), get_string('upgradestart', 'admin'), 'get');
309             $button->class = 'continuebutton';
310             echo $output->render($button);
311             echo $output->footer();
312             die();
313         }
314     }
315     // install/upgrade all plugins and other parts
316     upgrade_noncore(true);
319 // If this is the first install, indicate that this site is fully configured
320 // except the admin password
321 if (during_initial_install()) {
322     set_config('rolesactive', 1); // after this, during_initial_install will return false.
323     set_config('adminsetuppending', 1);
324     // we need this redirect to setup proper session
325     upgrade_finished("index.php?sessionstarted=1&amp;lang=$CFG->lang");
328 // make sure admin user is created - this is the last step because we need
329 // session to be working properly in order to edit admin account
330  if (!empty($CFG->adminsetuppending)) {
331     $sessionstarted = optional_param('sessionstarted', 0, PARAM_BOOL);
332     if (!$sessionstarted) {
333         redirect("index.php?sessionstarted=1&lang=$CFG->lang");
334     } else {
335         $sessionverify = optional_param('sessionverify', 0, PARAM_BOOL);
336         if (!$sessionverify) {
337             $SESSION->sessionverify = 1;
338             redirect("index.php?sessionstarted=1&sessionverify=1&lang=$CFG->lang");
339         } else {
340             if (empty($SESSION->sessionverify)) {
341                 print_error('installsessionerror', 'admin', "index.php?sessionstarted=1&lang=$CFG->lang");
342             }
343             unset($SESSION->sessionverify);
344         }
345     }
347     // at this stage there can be only one admin - users may change username, so do not rely on that
348     $adminuser = get_complete_user_data('id', $CFG->siteadmins);
350     if ($adminuser->password === 'adminsetuppending') {
351         // prevent installation hijacking
352         if ($adminuser->lastip !== getremoteaddr()) {
353             print_error('installhijacked', 'admin');
354         }
355         // login user and let him set password and admin details
356         $adminuser->newadminuser = 1;
357         message_set_default_message_preferences($adminuser);
358         complete_user_login($adminuser, false);
359         redirect("$CFG->wwwroot/user/editadvanced.php?id=$adminuser->id"); // Edit thyself
361     } else {
362         unset_config('adminsetuppending');
363     }
365 } else {
366     // just make sure upgrade logging is properly terminated
367     upgrade_finished('upgradesettings.php');
370 // Turn xmlstrictheaders back on now.
371 $CFG->xmlstrictheaders = $origxmlstrictheaders;
372 unset($origxmlstrictheaders);
374 // Check for valid admin user - no guest autologin
375 require_login(0, false);
376 $context = get_context_instance(CONTEXT_SYSTEM);
377 require_capability('moodle/site:config', $context);
379 // check that site is properly customized
380 $site = get_site();
381 if (empty($site->shortname)) {
382     // probably new installation - lets return to frontpage after this step
383     // remove settings that we want uninitialised
384     unset_config('registerauth');
385     redirect('upgradesettings.php?return=site');
388 // Check if we are returning from moodle.org registration and if so, we mark that fact to remove reminders
389 if (!empty($id) and $id == $CFG->siteidentifier) {
390     set_config('registered', time());
393 // setup critical warnings before printing admin tree block
394 $insecuredataroot = is_dataroot_insecure(true);
395 $SESSION->admin_critical_warning = ($insecuredataroot==INSECURE_DATAROOT_ERROR);
397 $adminroot = admin_get_root();
399 // Check if there are any new admin settings which have still yet to be set
400 if (any_new_admin_settings($adminroot)){
401     redirect('upgradesettings.php');
404 // Everything should now be set up, and the user is an admin
406 // Print default admin page with notifications.
407 admin_externalpage_setup('adminnotifications');
408 echo $OUTPUT->header();
410 if ($insecuredataroot == INSECURE_DATAROOT_WARNING) {
411     echo $OUTPUT->box(get_string('datarootsecuritywarning', 'admin', $CFG->dataroot), 'generalbox adminwarning');
412 } else if ($insecuredataroot == INSECURE_DATAROOT_ERROR) {
413     echo $OUTPUT->box(get_string('datarootsecurityerror', 'admin', $CFG->dataroot), 'generalbox adminerror');
417 if (defined('WARN_DISPLAY_ERRORS_ENABLED')) {
418     echo $OUTPUT->box(get_string('displayerrorswarning', 'admin'), 'generalbox adminwarning');
421 // If no recently cron run
422 $lastcron = $DB->get_field_sql('SELECT MAX(lastcron) FROM {modules}');
423 if (time() - $lastcron > 3600 * 24) {
424     $helpbutton = $OUTPUT->help_icon('cron', 'admin');
425     echo $OUTPUT->box(get_string('cronwarning', 'admin').'&nbsp;'.$helpbutton, 'generalbox adminwarning');
428 // Hidden bloglevel upgrade
429 $showbloglevelupgrade = ($CFG->bloglevel == BLOG_COURSE_LEVEL || $CFG->bloglevel == BLOG_GROUP_LEVEL) && empty($CFG->bloglevel_upgrade_complete);
430 if ($showbloglevelupgrade) {
431     echo $OUTPUT->box(get_string('bloglevelupgradenotice', 'admin'), 'generalbox adminwarning');
434 // diagnose DB, especially the sloppy MyISAM tables
435 $diagnose = $DB->diagnose();
436 if ($diagnose !== NULL) {
437     echo $OUTPUT->box($diagnose, 'generalbox adminwarning');
440 // Alert if we are currently in maintenance mode
441 if (!empty($CFG->maintenance_enabled)) {
442     echo $OUTPUT->box(get_string('sitemaintenancewarning2', 'admin', "$CFG->wwwroot/$CFG->admin/settings.php?section=maintenancemode"), 'generalbox adminwarning');
445 //////////////////////////////////////////////////////////////////////////////////////////////////
446 ////  IT IS ILLEGAL AND A VIOLATION OF THE GPL TO HIDE, REMOVE OR MODIFY THIS COPYRIGHT NOTICE ///
447 $copyrighttext = '<a href="http://moodle.org/">Moodle</a> '.
448                  '<a href="http://docs.moodle.org/en/Release" title="'.$CFG->version.'">'.$CFG->release.'</a><br />'.
449                  'Copyright &copy; 1999 onwards, Martin Dougiamas<br />'.
450                  'and <a href="http://docs.moodle.org/en/Credits">many other contributors</a>.<br />'.
451                  '<a href="http://docs.moodle.org/en/License">GNU Public License</a>';
452 echo $OUTPUT->box($copyrighttext, 'copyright');
453 //////////////////////////////////////////////////////////////////////////////////////////////////
455 echo $OUTPUT->footer();