upgrade.php 8.49 KB
Newer Older
1 2 3 4 5
<?php
/**
 *
 * @package    mahara
 * @subpackage admin
6
 * @author     Catalyst IT Ltd
7 8
 * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL version 3 or later
 * @copyright  For copyright information on Mahara, please see the README file distributed with this software.
9 10 11
 *
 */

12
define('INTERNAL', 1);
13
define('ADMIN', 1);
14
define('INSTALLER', 1);
15 16

require(dirname(dirname(__FILE__)).'/init.php');
17
require(get_config('libroot') . 'upgrade.php');
18

19
if (param_integer('finished', 0)) {
20
    foreach (site_warnings() as $w) {
21
        $SESSION->add_error_msg($w, FALSE);
22
    }
23 24 25 26 27 28 29 30 31
    if ($missing = check_installed_plugins()) {
        $message = get_string('installedpluginsmissing', 'admin') . ': ';
        $message .= join(', ', $missing) . '.';
        $message .= '  ' . get_string('ensurepluginsexist', 'admin', get_config('docroot'));
        $SESSION->add_error_msg($message);
    }
    redirect();
}

32
$smarty = smarty();
33

34
$upgrades = check_upgrades();
35 36 37
if (!empty($upgrades['core']->install)) {
    define('TITLE', get_string('installation', 'admin'));
    $smarty->assign('upgradeheading', get_string('performinginstallation', 'admin'));
38
    log_info('Starting Mahara installation...');
39 40 41
}
else {
    define('TITLE', get_string('upgrades', 'admin'));
42 43 44 45
    if (!db_is_utf8()) {
        global $SESSION;
        $SESSION->add_error_msg(get_string('dbnotutf8warning', 'admin'));
    }
46
    ensure_upgrade_sanity();
47 48 49
    $smarty->assign('upgradeheading', get_string('performingupgrades', 'admin'));
}

50
if (empty($upgrades['settings']['disablelogin'])) {
51 52
    auth_setup();
}
53 54
// Remove the "settings" component, which is not a real component (see check_upgrades())
unset($upgrades['settings']);
55

56 57 58
if (!$upgrades) {
    die_info(get_string('noupgrades', 'admin'));
}
59

60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87
$start = time();
if (empty($upgrades['core']->install)) {
    // Insert a record into config before the upgrade starts, to prevent subsequent hits
    // on this page from starting a second simultaneous upgrade.

    // But let the admin run a second one if they really want to.
    if (param_integer('rerun', 0)) {
        delete_records('config', 'field', '_upgrade');
    }

    if (!$lastupgrade = get_field('config', 'value', 'field', '_upgrade')) {
        try {
            insert_record('config', (object) array('field' => '_upgrade', 'value' => $start));
        }
        catch (SQLException $e) {
            if (!$lastupgrade = get_field('config', 'value', 'field', '_upgrade')) {
                $lastupgrade = '???';
            }
        }
    }

    if (!empty($lastupgrade)) {
        $laststart = format_date($lastupgrade, 'strftimedatetimeshort');
        log_debug('Not upgrading; unfinished upgrade from ' . $laststart . ' still in progress');
        die_info(get_string('upgradeinprogress', 'admin', $laststart));
    }
}

88 89 90
$loadingicon = $THEME->get_image_url('loading');
$successicon = $THEME->get_image_url('success');
$failureicon = $THEME->get_image_url('failure');
91

92 93
// Remove all files in the smarty and dwoo caches
// TODO post 1.2 remove the smarty part
94 95 96 97 98 99 100 101 102 103
require_once('file.php');
$basedir = get_config('dataroot') . 'smarty/compile/';
$dh = new DirectoryIterator($basedir);
foreach ($dh as $themedir) {
    if ($themedir->isDot()) continue;
    $themedirname = $basedir . $themedir->getFilename();
    rmdirr($themedirname);
    clearstatcache();
    check_dir_exists($themedirname);
}
104 105 106 107 108 109 110 111 112 113
$basedir = get_config('dataroot') . 'dwoo/compile/';
$dh = new DirectoryIterator($basedir);
foreach ($dh as $themedir) {
    if ($themedir->isDot()) continue;
    $themedirname = $basedir . $themedir->getFilename();
    rmdirr($themedirname);
    clearstatcache();
    check_dir_exists($themedirname);
}

114

115 116 117 118 119
$loadingstring = json_encode(get_string('upgradeloading', 'admin'));
$installsuccessstring = json_encode(get_string('installsuccess', 'admin'));
$successstring = json_encode(get_string('upgradesuccesstoversion', 'admin'));
$failurestring = json_encode(get_string('upgradefailure', 'admin'));
$coresuccess   = json_encode(get_string('coredatasuccess', 'admin'));
120
$localsuccess  = json_encode(get_string('localdatasuccess', 'admin'));
121

122 123 124
// Check if Mahara is being installed. An extra hook is required to insert core
// data if so.
if (!empty($upgrades['core']->install)) {
125
    $upgrades['firstcoredata'] = true;
126
    $upgrades['localpreinst'] = true;
127
    $upgrades['lastcoredata'] = true;
128
    $upgrades['localpostinst'] = true;
129
    $smarty->assign('install', true);
Aaron Wells's avatar
Aaron Wells committed
130
}
131 132 133 134 135
foreach ($upgrades as $key => $upgrade) {
    if (isset($upgrade->newinstall)) {
        unset($upgrades[$key]);
    }
}
136

137
$js = <<< EOJS
Penny Leach's avatar
Penny Leach committed
138 139 140
            function processNext() {
                var element = todo.shift();

141 142
                if (!element) {
                    $('finished').style.visibility = 'visible';
143
                    window.scrollTo(0, 5000000);
144
                    return; // done
Penny Leach's avatar
Penny Leach committed
145 146
                }

147
                $(element).innerHTML = '<img src="{$loadingicon}" alt="' + {$loadingstring} + '" />';
Penny Leach's avatar
Penny Leach committed
148

149
                sendjsonrequest('upgrade.json.php', { 'name': element, 'last': todo.length == 0 }, 'GET', function (data) {
150
                    if ( !data.error ) {
151
                        var message;
152 153
                        if (data.coredata) {
                            message = {$coresuccess};
154 155
                            $(data.key).innerHTML = '<img src="{$successicon}" alt=":)" />  ' + message;
                        }
156 157
                        else if (data.localdata) {
                            message = {$localsuccess};
158
                            $(data.key).innerHTML = '<img src="{$successicon}" alt=":)" />  ' + message;
159
                        }
160
                        else if (data.install || data.upgrade) {
161 162 163 164
                            if (data.install) {
                                message = {$installsuccessstring};
                            }
                            else {
165 166 167 168 169 170
                                if (data.message) {
                                    message = data.message;
                                }
                                else {
                                    message = {$successstring};
                                }
171
                            }
172
                            message += data.newversion ? data.newversion : '';
173 174 175 176 177
                            $(data.key).innerHTML = '<img src="{$successicon}" alt=":)" />  ' + message;
                        }
                        else {
                            message = data.message;
                            $(data.key).innerHTML = '<img src="{$failureicon}" alt=":(" /> ' + message;
178
                        }
179 180 181 182 183
                        if (data.feedback) {
                            var feedback_element = DIV();
                            feedback_element.innerHTML = data.feedback;
                            appendChildNodes('messages', feedback_element);
                        }
184
                        processNext();
Penny Leach's avatar
Penny Leach committed
185 186
                    }
                    else {
187
                        var message = '';
188 189
                        if (data.errormessage) {
                            message = data.errormessage;
Aaron Wells's avatar
Aaron Wells committed
190
                        }
191
                        else {
192
                            message = {$failurestring};
193
                        }
194
                        $(data.key).innerHTML = '<img src="{$failureicon}" alt=":(" /> ' + message;
Penny Leach's avatar
Penny Leach committed
195
                    }
Aaron Wells's avatar
Aaron Wells committed
196
                },
197
                function () {
198
                    $(element).innerHTML = '<img src="{$failureicon}" alt=":(" /> ' + {$failurestring};
199 200
                },
                true);
Penny Leach's avatar
Penny Leach committed
201 202 203 204 205
            }

            addLoadEvent( processNext );
EOJS;

206 207
uksort($upgrades, 'sort_upgrades');
$js .= "\n" . 'var todo = ' . json_encode(array_keys($upgrades)) . ";\n";
208
$smarty->assign('INLINEJAVASCRIPT', $js);
Penny Leach's avatar
Penny Leach committed
209

210
$smarty->assign_by_ref('upgrades', $upgrades);
211 212 213
if (isset($upgrades['core'])) {
    $smarty->assign('releaseargs', array($upgrades['core']->torelease, $upgrades['core']->to));
}
214 215
$smarty->display('admin/upgrade.tpl');

216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234
function check_installed_plugins() {
    $missing = array();

    foreach (plugin_types() as $plugintype) {
        if ($installed = plugins_installed($plugintype, true)) {
            foreach ($installed as $i) {
                $key = $i->name;
                if ($plugintype == 'blocktype') {
                    $key = blocktype_single_to_namespaced($i->name, $i->artefactplugin);
                }
                try {
                    safe_require($plugintype, $key);
                }
                catch (SystemException $e) {
                    $missing[] = "$plugintype:$key";
                }
            }
        }
    }
235

236 237
    return $missing;
}