2010-08-03 08:07:49 +00:00
|
|
|
<?php
|
|
|
|
// This file is part of Moodle - http://moodle.org/
|
2006-10-04 09:47:05 +00:00
|
|
|
//
|
2010-08-03 08:07:49 +00:00
|
|
|
// Moodle is free software: you can redistribute it and/or modify
|
|
|
|
// it under the terms of the GNU General Public License as published by
|
|
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
|
|
// (at your option) any later version.
|
2006-10-04 09:47:05 +00:00
|
|
|
//
|
2010-08-03 08:07:49 +00:00
|
|
|
// Moodle is distributed in the hope that it will be useful,
|
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
// GNU General Public License for more details.
|
2006-10-04 09:47:05 +00:00
|
|
|
//
|
2010-08-03 08:07:49 +00:00
|
|
|
// You should have received a copy of the GNU General Public License
|
|
|
|
// along with Moodle. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This file keeps track of upgrades to Moodle.
|
|
|
|
*
|
|
|
|
* Sometimes, changes between versions involve
|
|
|
|
* alterations to database structures and other
|
|
|
|
* major things that may break installations.
|
|
|
|
*
|
|
|
|
* The upgrade function in this file will attempt
|
|
|
|
* to perform all the necessary actions to upgrade
|
|
|
|
* your older installation to the current version.
|
|
|
|
*
|
|
|
|
* If there's something it cannot do itself, it
|
|
|
|
* will tell you what you need to do.
|
|
|
|
*
|
|
|
|
* The commands in here will all be database-neutral,
|
|
|
|
* using the methods of database_manager class
|
|
|
|
*
|
|
|
|
* Please do not forget to use upgrade_set_timeout()
|
|
|
|
* before any action that may take longer time to finish.
|
|
|
|
*
|
2012-04-01 22:48:17 +02:00
|
|
|
* @package core_install
|
|
|
|
* @category upgrade
|
|
|
|
* @copyright 2006 onwards Martin Dougiamas http://dougiamas.com
|
|
|
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
2010-08-03 08:07:49 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
defined('MOODLE_INTERNAL') || die();
|
2006-10-04 09:47:05 +00:00
|
|
|
|
2010-04-19 06:30:30 +00:00
|
|
|
/**
|
2012-04-01 22:48:17 +02:00
|
|
|
* Main upgrade tasks to be executed on Moodle version bump
|
|
|
|
*
|
|
|
|
* This function is automatically executed after one bump in the Moodle core
|
2012-04-02 12:27:23 +12:00
|
|
|
* version is detected. It's in charge of performing the required tasks
|
2012-04-01 22:48:17 +02:00
|
|
|
* to raise core from the previous version to the next one.
|
|
|
|
*
|
|
|
|
* It's a collection of ordered blocks of code, named "upgrade steps",
|
2012-04-02 12:27:23 +12:00
|
|
|
* each one performing one isolated (from the rest of steps) task. Usually
|
2012-04-01 22:48:17 +02:00
|
|
|
* tasks involve creating new DB objects or performing manipulation of the
|
|
|
|
* information for cleanup/fixup purposes.
|
|
|
|
*
|
|
|
|
* Each upgrade step has a fixed structure, that can be summarised as follows:
|
|
|
|
*
|
|
|
|
* if ($oldversion < XXXXXXXXXX.XX) {
|
2012-04-02 12:27:23 +12:00
|
|
|
* // Explanation of the update step, linking to issue in the Tracker if necessary
|
2012-04-01 22:48:17 +02:00
|
|
|
* upgrade_set_timeout(XX); // Optional for big tasks
|
|
|
|
* // Code to execute goes here, usually the XMLDB Editor will
|
|
|
|
* // help you here. See {@link http://docs.moodle.org/dev/XMLDB_editor}.
|
|
|
|
* upgrade_main_savepoint(true, XXXXXXXXXX.XX);
|
|
|
|
* }
|
|
|
|
*
|
|
|
|
* All plugins within Moodle (modules, blocks, reports...) support the existence of
|
|
|
|
* their own upgrade.php file, using the "Frankenstyle" component name as
|
|
|
|
* defined at {@link http://docs.moodle.org/dev/Frankenstyle}, for example:
|
|
|
|
* - {@link xmldb_page_upgrade($oldversion)}. (modules don't require the plugintype ("mod_") to be used.
|
|
|
|
* - {@link xmldb_auth_manual_upgrade($oldversion)}.
|
|
|
|
* - {@link xmldb_workshopform_accumulative_upgrade($oldversion)}.
|
|
|
|
* - ....
|
|
|
|
*
|
|
|
|
* In order to keep the contents of this file reduced, it's allowed to create some helper
|
|
|
|
* functions to be used here in the {@link upgradelib.php} file at the same directory. Note
|
2012-04-02 12:27:23 +12:00
|
|
|
* that such a file must be manually included from upgrade.php, and there are some restrictions
|
2012-04-01 22:48:17 +02:00
|
|
|
* about what can be used within it.
|
|
|
|
*
|
|
|
|
* For more information, take a look to the documentation available:
|
|
|
|
* - Data definition API: {@link http://docs.moodle.org/dev/Data_definition_API}
|
|
|
|
* - Upgrade API: {@link http://docs.moodle.org/dev/Upgrade_API}
|
2010-04-19 06:30:30 +00:00
|
|
|
*
|
|
|
|
* @param int $oldversion
|
2010-08-03 08:07:49 +00:00
|
|
|
* @return bool always true
|
2010-04-19 06:30:30 +00:00
|
|
|
*/
|
2008-08-16 12:16:01 +00:00
|
|
|
function xmldb_main_upgrade($oldversion) {
|
2016-02-06 12:33:09 +01:00
|
|
|
global $CFG, $DB;
|
2006-10-04 09:47:05 +00:00
|
|
|
|
2016-02-06 12:33:09 +01:00
|
|
|
require_once($CFG->libdir.'/db/upgradelib.php'); // Core Upgrade-related functions.
|
2009-07-10 05:58:59 +00:00
|
|
|
|
2016-02-06 12:33:09 +01:00
|
|
|
$dbman = $DB->get_manager(); // Loads ddl manager and xmldb classes.
|
2008-05-15 21:40:00 +00:00
|
|
|
|
2016-02-06 12:33:09 +01:00
|
|
|
// Always keep this upgrade step with version being the minimum
|
MDL-74905 upgrade: remove all the < 3.11.0 upgrade steps
Note that, despite the commit message, this is not possible. Moodle
3.11.0 (and 3.10.0) were developed in parallel with Moodle 4.0, and
when they were released, the master branch had already diverged, so
the master branch does not contain the comment lines:
"// Automatically generated Moodle v3.11.0 release upgrade line"
And they are needed to know which parts of the upgrade are safe to delete.
So we only proceed to delete all those steps from lib/db/upgrade.php
which version is known to be < 2021051708 (v3.11.8), master ones will
be, always bigger than that. We don't touch plugin upgrade scripts
because they may have different versions, not 100% matching the
2021051708 rule, so there will be an excess of steps there.
Note this is not a big problem, just a few more steps will be skipped and
that's all. Whenever we bump the Moodle requirements again (to Moodle
4.0 or up), the lines will be back and we'll be able to safely remove
all the steps before them. See previous Moodle requirements issues as
example.
The upgrade steps deleted by this commit weren't using any stuff from
upgradelib, tasks..., so there isn't anything else to be removed but
the core steps themselves.
Also includes an upgrade step to prevent upgrading from any
version < 2021051708 (v3.11.8) as anti-cheating measure.
2023-01-02 17:16:47 +01:00
|
|
|
// allowed version to upgrade from (v3.11.8 right now).
|
|
|
|
if ($oldversion < 2021051708) {
|
2016-02-06 12:33:09 +01:00
|
|
|
// Just in case somebody hacks upgrade scripts or env, we really can not continue.
|
MDL-74905 upgrade: remove all the < 3.11.0 upgrade steps
Note that, despite the commit message, this is not possible. Moodle
3.11.0 (and 3.10.0) were developed in parallel with Moodle 4.0, and
when they were released, the master branch had already diverged, so
the master branch does not contain the comment lines:
"// Automatically generated Moodle v3.11.0 release upgrade line"
And they are needed to know which parts of the upgrade are safe to delete.
So we only proceed to delete all those steps from lib/db/upgrade.php
which version is known to be < 2021051708 (v3.11.8), master ones will
be, always bigger than that. We don't touch plugin upgrade scripts
because they may have different versions, not 100% matching the
2021051708 rule, so there will be an excess of steps there.
Note this is not a big problem, just a few more steps will be skipped and
that's all. Whenever we bump the Moodle requirements again (to Moodle
4.0 or up), the lines will be back and we'll be able to safely remove
all the steps before them. See previous Moodle requirements issues as
example.
The upgrade steps deleted by this commit weren't using any stuff from
upgradelib, tasks..., so there isn't anything else to be removed but
the core steps themselves.
Also includes an upgrade step to prevent upgrading from any
version < 2021051708 (v3.11.8) as anti-cheating measure.
2023-01-02 17:16:47 +01:00
|
|
|
echo("You need to upgrade to 3.11.8 or higher first!\n");
|
2011-12-06 10:04:19 +01:00
|
|
|
exit(1);
|
2016-02-06 12:33:09 +01:00
|
|
|
// Note this savepoint is 100% unreachable, but needed to pass the upgrade checks.
|
MDL-74905 upgrade: remove all the < 3.11.0 upgrade steps
Note that, despite the commit message, this is not possible. Moodle
3.11.0 (and 3.10.0) were developed in parallel with Moodle 4.0, and
when they were released, the master branch had already diverged, so
the master branch does not contain the comment lines:
"// Automatically generated Moodle v3.11.0 release upgrade line"
And they are needed to know which parts of the upgrade are safe to delete.
So we only proceed to delete all those steps from lib/db/upgrade.php
which version is known to be < 2021051708 (v3.11.8), master ones will
be, always bigger than that. We don't touch plugin upgrade scripts
because they may have different versions, not 100% matching the
2021051708 rule, so there will be an excess of steps there.
Note this is not a big problem, just a few more steps will be skipped and
that's all. Whenever we bump the Moodle requirements again (to Moodle
4.0 or up), the lines will be back and we'll be able to safely remove
all the steps before them. See previous Moodle requirements issues as
example.
The upgrade steps deleted by this commit weren't using any stuff from
upgradelib, tasks..., so there isn't anything else to be removed but
the core steps themselves.
Also includes an upgrade step to prevent upgrading from any
version < 2021051708 (v3.11.8) as anti-cheating measure.
2023-01-02 17:16:47 +01:00
|
|
|
upgrade_main_savepoint(true, 2021051708);
|
2020-07-24 11:08:25 +08:00
|
|
|
}
|
|
|
|
|
2020-08-20 08:45:27 +08:00
|
|
|
if ($oldversion < 2021052500.01) {
|
2020-05-22 16:20:53 +08:00
|
|
|
// Delete all user evidence files from users that have been deleted.
|
|
|
|
$sql = "SELECT DISTINCT f.*
|
|
|
|
FROM {files} f
|
|
|
|
LEFT JOIN {context} c ON f.contextid = c.id
|
|
|
|
WHERE f.component = :component
|
|
|
|
AND f.filearea = :filearea
|
2020-08-20 08:54:05 +08:00
|
|
|
AND c.id IS NULL";
|
2020-05-22 16:20:53 +08:00
|
|
|
$stalefiles = $DB->get_records_sql($sql, ['component' => 'core_competency', 'filearea' => 'userevidence']);
|
|
|
|
|
|
|
|
$fs = get_file_storage();
|
|
|
|
foreach ($stalefiles as $stalefile) {
|
|
|
|
$fs->get_file_instance($stalefile)->delete();
|
|
|
|
}
|
|
|
|
|
2020-10-26 10:48:53 +01:00
|
|
|
upgrade_main_savepoint(true, 2021052500.01);
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($oldversion < 2021052500.02) {
|
|
|
|
|
|
|
|
// Define field timecreated to be added to task_adhoc.
|
|
|
|
$table = new xmldb_table('task_adhoc');
|
|
|
|
$field = new xmldb_field('timecreated', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, '0', 'blocking');
|
|
|
|
|
|
|
|
// Conditionally launch add field timecreated.
|
|
|
|
if (!$dbman->field_exists($table, $field)) {
|
|
|
|
$dbman->add_field($table, $field);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
2020-08-20 09:54:48 +08:00
|
|
|
upgrade_main_savepoint(true, 2021052500.02);
|
2020-05-22 16:20:53 +08:00
|
|
|
}
|
|
|
|
|
2020-08-25 00:48:02 +01:00
|
|
|
if ($oldversion < 2021052500.04) {
|
|
|
|
// Define field metadatasettings to be added to h5p_libraries.
|
|
|
|
$table = new xmldb_table('h5p_libraries');
|
|
|
|
$field = new xmldb_field('metadatasettings', XMLDB_TYPE_TEXT, null, null, null, null, null, 'coreminor');
|
|
|
|
|
|
|
|
// Conditionally launch add field metadatasettings.
|
|
|
|
if (!$dbman->field_exists($table, $field)) {
|
|
|
|
$dbman->add_field($table, $field);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Get installed library files that have no metadata settings value.
|
|
|
|
$params = [
|
|
|
|
'component' => 'core_h5p',
|
|
|
|
'filearea' => 'libraries',
|
|
|
|
'filename' => 'library.json',
|
|
|
|
];
|
|
|
|
$sql = "SELECT l.id, f.id as fileid
|
|
|
|
FROM {files} f
|
|
|
|
LEFT JOIN {h5p_libraries} l ON f.itemid = l.id
|
|
|
|
WHERE f.component = :component
|
|
|
|
AND f.filearea = :filearea
|
|
|
|
AND f.filename = :filename";
|
|
|
|
$libraries = $DB->get_records_sql($sql, $params);
|
|
|
|
|
|
|
|
// Update metadatasettings field when the attribute is present in the library.json file.
|
|
|
|
$fs = get_file_storage();
|
|
|
|
foreach ($libraries as $library) {
|
|
|
|
$jsonfile = $fs->get_file_by_id($library->fileid);
|
|
|
|
$jsoncontent = json_decode($jsonfile->get_content());
|
|
|
|
if (isset($jsoncontent->metadataSettings)) {
|
|
|
|
unset($library->fileid);
|
|
|
|
$library->metadatasettings = json_encode($jsoncontent->metadataSettings);
|
|
|
|
$DB->update_record('h5p_libraries', $library);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2021052500.04);
|
|
|
|
}
|
|
|
|
|
2020-08-26 09:37:16 +08:00
|
|
|
if ($oldversion < 2021052500.05) {
|
2020-08-25 17:08:03 +10:00
|
|
|
// Define fields to be added to task_scheduled.
|
|
|
|
$table = new xmldb_table('task_scheduled');
|
|
|
|
$field = new xmldb_field('timestarted', XMLDB_TYPE_INTEGER, '10', null, null, null, null, 'disabled');
|
|
|
|
if (!$dbman->field_exists($table, $field)) {
|
|
|
|
$dbman->add_field($table, $field);
|
|
|
|
}
|
|
|
|
$field = new xmldb_field('hostname', XMLDB_TYPE_CHAR, '255', null, null, null, null, 'timestarted');
|
|
|
|
if (!$dbman->field_exists($table, $field)) {
|
|
|
|
$dbman->add_field($table, $field);
|
|
|
|
}
|
|
|
|
$field = new xmldb_field('pid', XMLDB_TYPE_INTEGER, '10', null, null, null, null, 'hostname');
|
|
|
|
if (!$dbman->field_exists($table, $field)) {
|
|
|
|
$dbman->add_field($table, $field);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Define fields to be added to task_adhoc.
|
|
|
|
$table = new xmldb_table('task_adhoc');
|
|
|
|
$field = new xmldb_field('timestarted', XMLDB_TYPE_INTEGER, '10', null, null, null, null, 'blocking');
|
|
|
|
if (!$dbman->field_exists($table, $field)) {
|
|
|
|
$dbman->add_field($table, $field);
|
|
|
|
}
|
|
|
|
$field = new xmldb_field('hostname', XMLDB_TYPE_CHAR, '255', null, null, null, null, 'timestarted');
|
|
|
|
if (!$dbman->field_exists($table, $field)) {
|
|
|
|
$dbman->add_field($table, $field);
|
|
|
|
}
|
|
|
|
$field = new xmldb_field('pid', XMLDB_TYPE_INTEGER, '10', null, null, null, null, 'hostname');
|
|
|
|
if (!$dbman->field_exists($table, $field)) {
|
|
|
|
$dbman->add_field($table, $field);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Define fields to be added to task_log.
|
|
|
|
$table = new xmldb_table('task_log');
|
|
|
|
$field = new xmldb_field('hostname', XMLDB_TYPE_CHAR, '255', null, null, null, null, 'output');
|
|
|
|
if (!$dbman->field_exists($table, $field)) {
|
|
|
|
$dbman->add_field($table, $field);
|
|
|
|
}
|
|
|
|
$field = new xmldb_field('pid', XMLDB_TYPE_INTEGER, '10', null, null, null, null, 'hostname');
|
|
|
|
if (!$dbman->field_exists($table, $field)) {
|
|
|
|
$dbman->add_field($table, $field);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
2020-08-26 09:37:16 +08:00
|
|
|
upgrade_main_savepoint(true, 2021052500.05);
|
2020-08-25 17:08:03 +10:00
|
|
|
}
|
|
|
|
|
2020-08-27 09:34:37 +08:00
|
|
|
if ($oldversion < 2021052500.06) {
|
2020-03-15 20:09:48 +11:00
|
|
|
// Define table to store virus infected details.
|
|
|
|
$table = new xmldb_table('infected_files');
|
|
|
|
|
2020-05-27 10:57:33 +10:00
|
|
|
// Adding fields to table infected_files.
|
2020-03-15 20:09:48 +11:00
|
|
|
$table->add_field('id', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, XMLDB_SEQUENCE, null);
|
|
|
|
$table->add_field('filename', XMLDB_TYPE_TEXT, null, null, XMLDB_NOTNULL, null, null);
|
2020-05-27 10:57:33 +10:00
|
|
|
$table->add_field('quarantinedfile', XMLDB_TYPE_TEXT, null, null, null, null, null);
|
|
|
|
$table->add_field('userid', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, null);
|
2020-03-15 20:09:48 +11:00
|
|
|
$table->add_field('reason', XMLDB_TYPE_TEXT, null, null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('timecreated', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, '0');
|
|
|
|
|
2020-05-27 10:57:33 +10:00
|
|
|
// Adding keys to table infected_files.
|
2020-03-15 20:09:48 +11:00
|
|
|
$table->add_key('primary', XMLDB_KEY_PRIMARY, ['id']);
|
2020-05-27 10:57:33 +10:00
|
|
|
$table->add_key('userid', XMLDB_KEY_FOREIGN, ['userid'], 'user', ['id']);
|
2020-03-15 20:09:48 +11:00
|
|
|
|
2020-05-27 10:57:33 +10:00
|
|
|
// Conditionally launch create table for infected_files.
|
2020-03-15 20:09:48 +11:00
|
|
|
if (!$dbman->table_exists($table)) {
|
|
|
|
$dbman->create_table($table);
|
|
|
|
}
|
2020-08-27 09:34:37 +08:00
|
|
|
upgrade_main_savepoint(true, 2021052500.06);
|
2020-03-15 20:09:48 +11:00
|
|
|
}
|
2020-08-27 09:34:37 +08:00
|
|
|
|
2020-08-21 17:45:41 +02:00
|
|
|
if ($oldversion < 2021052500.13) {
|
|
|
|
// Remove all the files with component='core_h5p' and filearea='editor' because they won't be used anymore.
|
|
|
|
$fs = get_file_storage();
|
|
|
|
$syscontext = context_system::instance();
|
|
|
|
$fs->delete_area_files($syscontext->id, 'core_h5p', 'editor');
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2021052500.13);
|
|
|
|
}
|
|
|
|
|
2020-08-24 14:19:46 -04:00
|
|
|
if ($oldversion < 2021052500.15) {
|
|
|
|
// Copy From id captures the id of the source course when a new course originates from a restore
|
|
|
|
// of another course on the same site.
|
|
|
|
$table = new xmldb_table('course');
|
|
|
|
$field = new xmldb_field('originalcourseid', XMLDB_TYPE_INTEGER, '10', null, null, null, null);
|
|
|
|
|
|
|
|
if (!$dbman->field_exists($table, $field)) {
|
|
|
|
$dbman->add_field($table, $field);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2021052500.15);
|
|
|
|
}
|
|
|
|
|
2020-09-16 10:50:48 +08:00
|
|
|
if ($oldversion < 2021052500.19) {
|
|
|
|
// Define table oauth2_refresh_token to be created.
|
|
|
|
$table = new xmldb_table('oauth2_refresh_token');
|
|
|
|
|
|
|
|
// Adding fields to table oauth2_refresh_token.
|
|
|
|
$table->add_field('id', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, XMLDB_SEQUENCE, null);
|
|
|
|
$table->add_field('timecreated', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('timemodified', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('userid', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('issuerid', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('token', XMLDB_TYPE_TEXT, null, null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('scopehash', XMLDB_TYPE_CHAR, 40, null, XMLDB_NOTNULL, null, null);
|
|
|
|
|
|
|
|
// Adding keys to table oauth2_refresh_token.
|
|
|
|
$table->add_key('primary', XMLDB_KEY_PRIMARY, ['id']);
|
|
|
|
$table->add_key('issueridkey', XMLDB_KEY_FOREIGN, ['issuerid'], 'oauth2_issuer', ['id']);
|
|
|
|
$table->add_key('useridkey', XMLDB_KEY_FOREIGN, ['userid'], 'user', ['id']);
|
|
|
|
|
|
|
|
// Adding indexes to table oauth2_refresh_token.
|
|
|
|
$table->add_index('userid-issuerid-scopehash', XMLDB_INDEX_UNIQUE, array('userid', 'issuerid', 'scopehash'));
|
|
|
|
|
|
|
|
// Conditionally launch create table for oauth2_refresh_token.
|
|
|
|
if (!$dbman->table_exists($table)) {
|
|
|
|
$dbman->create_table($table);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2021052500.19);
|
|
|
|
}
|
|
|
|
|
2020-10-07 10:05:29 -04:00
|
|
|
if ($oldversion < 2021052500.20) {
|
|
|
|
|
|
|
|
// Define index modulename-instance-eventtype (not unique) to be added to event.
|
|
|
|
$table = new xmldb_table('event');
|
|
|
|
$index = new xmldb_index('modulename-instance-eventtype', XMLDB_INDEX_NOTUNIQUE, ['modulename', 'instance', 'eventtype']);
|
|
|
|
|
|
|
|
// Conditionally launch add index modulename-instance-eventtype.
|
|
|
|
if (!$dbman->index_exists($table, $index)) {
|
|
|
|
$dbman->add_index($table, $index);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Define index modulename-instance (not unique) to be dropped form event.
|
|
|
|
$table = new xmldb_table('event');
|
|
|
|
$index = new xmldb_index('modulename-instance', XMLDB_INDEX_NOTUNIQUE, ['modulename', 'instance']);
|
|
|
|
|
|
|
|
// Conditionally launch drop index modulename-instance.
|
|
|
|
if ($dbman->index_exists($table, $index)) {
|
|
|
|
$dbman->drop_index($table, $index);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2021052500.20);
|
|
|
|
}
|
|
|
|
|
2020-09-24 14:03:04 +02:00
|
|
|
if ($oldversion < 2021052500.24) {
|
|
|
|
// Define fields tutorial and example to be added to h5p_libraries.
|
|
|
|
$table = new xmldb_table('h5p_libraries');
|
|
|
|
|
|
|
|
// Add tutorial field.
|
|
|
|
$field = new xmldb_field('tutorial', XMLDB_TYPE_TEXT, null, null, null, null, null, 'metadatasettings');
|
|
|
|
if (!$dbman->field_exists($table, $field)) {
|
|
|
|
$dbman->add_field($table, $field);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Add example field.
|
|
|
|
$field = new xmldb_field('example', XMLDB_TYPE_TEXT, null, null, null, null, null, 'tutorial');
|
2020-09-18 18:52:13 +08:00
|
|
|
|
2020-09-24 14:03:04 +02:00
|
|
|
if (!$dbman->field_exists($table, $field)) {
|
|
|
|
$dbman->add_field($table, $field);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2021052500.24);
|
|
|
|
}
|
|
|
|
|
2020-10-19 10:14:09 +01:00
|
|
|
if ($oldversion < 2021052500.26) {
|
|
|
|
// Delete orphaned course_modules_completion rows; these were not deleted properly
|
|
|
|
// by remove_course_contents function.
|
2020-11-23 20:45:46 +00:00
|
|
|
$DB->delete_records_select('course_modules_completion', "
|
|
|
|
NOT EXISTS (
|
|
|
|
SELECT 1
|
|
|
|
FROM {course_modules} cm
|
|
|
|
WHERE cm.id = {course_modules_completion}.coursemoduleid
|
|
|
|
)");
|
2020-10-19 10:14:09 +01:00
|
|
|
upgrade_main_savepoint(true, 2021052500.26);
|
|
|
|
}
|
|
|
|
|
2020-10-20 08:48:05 +08:00
|
|
|
if ($oldversion < 2021052500.27) {
|
2020-08-24 11:40:49 +10:00
|
|
|
// Script to fix incorrect records of "hidden" field in existing grade items.
|
|
|
|
$sql = "SELECT cm.instance, cm.course
|
|
|
|
FROM {course_modules} cm
|
|
|
|
JOIN {modules} m ON m.id = cm.module
|
|
|
|
WHERE m.name = :module AND cm.visible = :visible";
|
|
|
|
$hidequizlist = $DB->get_recordset_sql($sql, ['module' => 'quiz', 'visible' => 0]);
|
|
|
|
|
|
|
|
foreach ($hidequizlist as $hidequiz) {
|
|
|
|
$params = [
|
|
|
|
'itemmodule' => 'quiz',
|
|
|
|
'courseid' => $hidequiz->course,
|
|
|
|
'iteminstance' => $hidequiz->instance,
|
|
|
|
];
|
|
|
|
|
|
|
|
$DB->set_field('grade_items', 'hidden', 1, $params);
|
|
|
|
}
|
|
|
|
$hidequizlist->close();
|
|
|
|
|
2020-10-20 08:48:05 +08:00
|
|
|
upgrade_main_savepoint(true, 2021052500.27);
|
2020-08-24 11:40:49 +10:00
|
|
|
}
|
|
|
|
|
2020-10-21 09:59:48 +08:00
|
|
|
if ($oldversion < 2021052500.29) {
|
2020-10-06 13:30:45 +08:00
|
|
|
// Get the current guest user which is also set as 'deleted'.
|
|
|
|
$guestuser = $DB->get_record('user', ['id' => $CFG->siteguest, 'deleted' => 1]);
|
|
|
|
// If there is a deleted guest user, reset the user to not be deleted and make sure the related
|
|
|
|
// user context exists.
|
|
|
|
if ($guestuser) {
|
|
|
|
$guestuser->deleted = 0;
|
|
|
|
$DB->update_record('user', $guestuser);
|
|
|
|
|
|
|
|
// Get the guest user context.
|
|
|
|
$guestusercontext = $DB->get_record('context',
|
|
|
|
['contextlevel' => CONTEXT_USER, 'instanceid' => $guestuser->id]);
|
|
|
|
|
|
|
|
// If the guest user context does not exist, create it.
|
|
|
|
if (!$guestusercontext) {
|
|
|
|
$record = new stdClass();
|
|
|
|
$record->contextlevel = CONTEXT_USER;
|
|
|
|
$record->instanceid = $guestuser->id;
|
|
|
|
$record->depth = 0;
|
|
|
|
// The path is not known before insert.
|
|
|
|
$record->path = null;
|
|
|
|
$record->locked = 0;
|
|
|
|
|
|
|
|
$record->id = $DB->insert_record('context', $record);
|
|
|
|
|
|
|
|
// Update the path.
|
|
|
|
$record->path = '/' . SYSCONTEXTID . '/' . $record->id;
|
|
|
|
$record->depth = substr_count($record->path, '/');
|
|
|
|
$DB->update_record('context', $record);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
2020-10-21 09:59:48 +08:00
|
|
|
upgrade_main_savepoint(true, 2021052500.29);
|
2020-10-06 13:30:45 +08:00
|
|
|
}
|
|
|
|
|
2020-10-21 19:43:13 +02:00
|
|
|
if ($oldversion < 2021052500.30) {
|
2020-09-29 08:57:56 +01:00
|
|
|
// Reset analytics model output dir if it's the default value.
|
|
|
|
$modeloutputdir = get_config('analytics', 'modeloutputdir');
|
|
|
|
if (strcasecmp($modeloutputdir, $CFG->dataroot . DIRECTORY_SEPARATOR . 'models') == 0) {
|
|
|
|
set_config('modeloutputdir', '', 'analytics');
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
2020-10-21 19:43:13 +02:00
|
|
|
upgrade_main_savepoint(true, 2021052500.30);
|
2020-09-29 08:57:56 +01:00
|
|
|
}
|
|
|
|
|
2020-09-18 18:52:13 +08:00
|
|
|
if ($oldversion < 2021052500.32) {
|
|
|
|
// Define field downloadcontent to be added to course.
|
|
|
|
$table = new xmldb_table('course');
|
|
|
|
$field = new xmldb_field('downloadcontent', XMLDB_TYPE_INTEGER, '1', null, null, null, null, 'visibleold');
|
|
|
|
|
|
|
|
if (!$dbman->field_exists($table, $field)) {
|
|
|
|
$dbman->add_field($table, $field);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2021052500.32);
|
|
|
|
}
|
|
|
|
|
2020-10-26 22:39:28 +01:00
|
|
|
if ($oldversion < 2021052500.33) {
|
2020-02-28 13:00:15 +08:00
|
|
|
$table = new xmldb_table('badge_backpack');
|
|
|
|
|
2020-10-26 23:32:10 +01:00
|
|
|
// There is no key_exists, so test the equivalent index.
|
|
|
|
$oldindex = new xmldb_index('backpackcredentials', XMLDB_KEY_UNIQUE, ['userid', 'externalbackpackid']);
|
|
|
|
if (!$dbman->index_exists($table, $oldindex)) {
|
|
|
|
// All external backpack providers/hosts are now exclusively stored in badge_external_backpack.
|
|
|
|
// All credentials are stored in badge_backpack and are unique per user, backpack.
|
|
|
|
$uniquekey = new xmldb_key('backpackcredentials', XMLDB_KEY_UNIQUE, ['userid', 'externalbackpackid']);
|
2020-02-28 13:00:15 +08:00
|
|
|
$dbman->add_key($table, $uniquekey);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Drop the password field as this is moved to badge_backpack.
|
2019-09-25 12:38:53 +08:00
|
|
|
$table = new xmldb_table('badge_external_backpack');
|
2020-02-28 13:00:15 +08:00
|
|
|
$field = new xmldb_field('password', XMLDB_TYPE_CHAR, '50');
|
|
|
|
if ($dbman->field_exists($table, $field)) {
|
2020-10-26 23:32:10 +01:00
|
|
|
// If there is a current backpack set then copy it across to the new structure.
|
|
|
|
if ($CFG->badges_defaultissuercontact) {
|
|
|
|
// Get the currently used site backpacks.
|
|
|
|
$records = $DB->get_records_select('badge_external_backpack', "password IS NOT NULL AND password != ''");
|
|
|
|
$backpack = [
|
|
|
|
'userid' => '0',
|
|
|
|
'email' => $CFG->badges_defaultissuercontact,
|
|
|
|
'backpackuid' => -1
|
|
|
|
];
|
|
|
|
|
|
|
|
// Create records corresponding to the site backpacks.
|
|
|
|
foreach ($records as $record) {
|
|
|
|
$backpack['password'] = $record->password;
|
|
|
|
$backpack['externalbackpackid'] = $record->id;
|
|
|
|
$DB->insert_record('badge_backpack', (object) $backpack);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-02-28 13:00:15 +08:00
|
|
|
$dbman->drop_field($table, $field);
|
2020-10-27 12:47:50 +08:00
|
|
|
}
|
2020-11-02 10:17:30 +08:00
|
|
|
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2021052500.33);
|
2020-10-27 12:47:50 +08:00
|
|
|
}
|
|
|
|
|
2020-10-27 13:12:59 +08:00
|
|
|
if ($oldversion < 2021052500.36) {
|
2020-09-29 19:27:37 +02:00
|
|
|
// Define table payment_accounts to be created.
|
|
|
|
$table = new xmldb_table('payment_accounts');
|
|
|
|
|
|
|
|
// Adding fields to table payment_accounts.
|
|
|
|
$table->add_field('id', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, XMLDB_SEQUENCE, null);
|
|
|
|
$table->add_field('name', XMLDB_TYPE_CHAR, '255', null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('idnumber', XMLDB_TYPE_CHAR, '100', null, null, null, null);
|
|
|
|
$table->add_field('contextid', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('enabled', XMLDB_TYPE_INTEGER, '1', null, XMLDB_NOTNULL, null, '0');
|
2020-10-07 21:56:13 +11:00
|
|
|
$table->add_field('archived', XMLDB_TYPE_INTEGER, '1', null, XMLDB_NOTNULL, null, '0');
|
2020-09-29 19:27:37 +02:00
|
|
|
$table->add_field('timecreated', XMLDB_TYPE_INTEGER, '10', null, null, null, null);
|
|
|
|
$table->add_field('timemodified', XMLDB_TYPE_INTEGER, '10', null, null, null, null);
|
|
|
|
|
|
|
|
// Adding keys to table payment_accounts.
|
|
|
|
$table->add_key('primary', XMLDB_KEY_PRIMARY, ['id']);
|
|
|
|
|
|
|
|
// Conditionally launch create table for payment_accounts.
|
|
|
|
if (!$dbman->table_exists($table)) {
|
|
|
|
$dbman->create_table($table);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Define table payment_gateways to be created.
|
|
|
|
$table = new xmldb_table('payment_gateways');
|
|
|
|
|
|
|
|
// Adding fields to table payment_gateways.
|
|
|
|
$table->add_field('id', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, XMLDB_SEQUENCE, null);
|
|
|
|
$table->add_field('accountid', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('gateway', XMLDB_TYPE_CHAR, '100', null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('enabled', XMLDB_TYPE_INTEGER, '1', null, XMLDB_NOTNULL, null, '1');
|
|
|
|
$table->add_field('config', XMLDB_TYPE_TEXT, null, null, null, null, null);
|
|
|
|
$table->add_field('timecreated', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('timemodified', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, null);
|
|
|
|
|
|
|
|
// Adding keys to table payment_gateways.
|
|
|
|
$table->add_key('primary', XMLDB_KEY_PRIMARY, ['id']);
|
|
|
|
$table->add_key('accountid', XMLDB_KEY_FOREIGN, ['accountid'], 'payment_accounts', ['id']);
|
|
|
|
|
|
|
|
// Conditionally launch create table for payment_gateways.
|
|
|
|
if (!$dbman->table_exists($table)) {
|
|
|
|
$dbman->create_table($table);
|
|
|
|
}
|
|
|
|
|
2020-10-07 21:56:13 +11:00
|
|
|
// Define table payments to be created.
|
2020-10-02 20:23:53 +10:00
|
|
|
$table = new xmldb_table('payments');
|
|
|
|
|
2020-10-07 21:56:13 +11:00
|
|
|
// Adding fields to table payments.
|
|
|
|
$table->add_field('id', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, XMLDB_SEQUENCE, null);
|
|
|
|
$table->add_field('component', XMLDB_TYPE_CHAR, '100', null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('paymentarea', XMLDB_TYPE_CHAR, '50', null, XMLDB_NOTNULL, null, null);
|
2020-10-17 05:05:54 +11:00
|
|
|
$table->add_field('itemid', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, null);
|
2020-10-07 21:56:13 +11:00
|
|
|
$table->add_field('userid', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('amount', XMLDB_TYPE_CHAR, '20', null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('currency', XMLDB_TYPE_CHAR, '3', null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('accountid', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('gateway', XMLDB_TYPE_CHAR, '100', null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('timecreated', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, '0');
|
|
|
|
$table->add_field('timemodified', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, '0');
|
2020-10-02 20:23:53 +10:00
|
|
|
|
2020-10-07 21:56:13 +11:00
|
|
|
// Adding keys to table payments.
|
|
|
|
$table->add_key('primary', XMLDB_KEY_PRIMARY, ['id']);
|
|
|
|
$table->add_key('userid', XMLDB_KEY_FOREIGN, ['userid'], 'user', ['id']);
|
|
|
|
$table->add_key('accountid', XMLDB_KEY_FOREIGN, ['accountid'], 'payment_accounts', ['id']);
|
2020-10-02 20:23:53 +10:00
|
|
|
|
2020-10-07 21:56:13 +11:00
|
|
|
// Adding indexes to table payments.
|
|
|
|
$table->add_index('gateway', XMLDB_INDEX_NOTUNIQUE, ['gateway']);
|
2020-10-17 05:05:54 +11:00
|
|
|
$table->add_index('component-paymentarea-itemid', XMLDB_INDEX_NOTUNIQUE, ['component', 'paymentarea', 'itemid']);
|
2020-10-02 20:23:53 +10:00
|
|
|
|
2020-10-07 21:56:13 +11:00
|
|
|
// Conditionally launch create table for payments.
|
|
|
|
if (!$dbman->table_exists($table)) {
|
|
|
|
$dbman->create_table($table);
|
2019-09-25 12:38:53 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
2020-10-27 12:47:50 +08:00
|
|
|
upgrade_main_savepoint(true, 2021052500.36);
|
2019-09-25 12:38:53 +08:00
|
|
|
}
|
|
|
|
|
2020-10-07 10:55:25 +08:00
|
|
|
if ($oldversion < 2021052500.42) {
|
|
|
|
// Get all lessons that are set with a completion criteria of 'requires grade' but with no grade type set.
|
|
|
|
$sql = "SELECT cm.id
|
|
|
|
FROM {course_modules} cm
|
|
|
|
JOIN {lesson} l ON l.id = cm.instance
|
|
|
|
JOIN {modules} m ON m.id = cm.module
|
|
|
|
WHERE m.name = :name AND cm.completiongradeitemnumber IS NOT NULL AND l.grade = :grade";
|
|
|
|
|
|
|
|
do {
|
|
|
|
if ($invalidconfigrations = $DB->get_records_sql($sql, ['name' => 'lesson', 'grade' => 0], 0, 1000)) {
|
|
|
|
list($insql, $inparams) = $DB->get_in_or_equal(array_keys($invalidconfigrations), SQL_PARAMS_NAMED);
|
|
|
|
$DB->set_field_select('course_modules', 'completiongradeitemnumber', null, "id $insql", $inparams);
|
|
|
|
}
|
|
|
|
} while ($invalidconfigrations);
|
|
|
|
|
|
|
|
upgrade_main_savepoint(true, 2021052500.42);
|
|
|
|
}
|
|
|
|
|
2021-02-01 19:13:47 +01:00
|
|
|
if ($oldversion < 2021052500.55) {
|
2021-01-20 03:38:10 +08:00
|
|
|
$DB->delete_records_select('event', "eventtype = 'category' AND categoryid = 0 AND userid <> 0");
|
|
|
|
|
2021-02-01 19:13:47 +01:00
|
|
|
upgrade_main_savepoint(true, 2021052500.55);
|
2021-01-20 03:38:10 +08:00
|
|
|
}
|
|
|
|
|
2020-09-23 13:49:57 -04:00
|
|
|
if ($oldversion < 2021052500.59) {
|
|
|
|
// Define field visibility to be added to contentbank_content.
|
|
|
|
$table = new xmldb_table('contentbank_content');
|
|
|
|
$field = new xmldb_field('visibility', XMLDB_TYPE_INTEGER, '1', null, XMLDB_NOTNULL, null, '1', 'contextid');
|
|
|
|
|
|
|
|
// Conditionally launch add field visibility.
|
|
|
|
if (!$dbman->field_exists($table, $field)) {
|
|
|
|
$dbman->add_field($table, $field);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2021052500.59);
|
|
|
|
}
|
|
|
|
|
2021-02-16 19:45:44 +01:00
|
|
|
if ($oldversion < 2021052500.60) {
|
2014-11-06 16:46:50 +08:00
|
|
|
|
|
|
|
// We are going to remove the field 'hidepicture' from the groups
|
|
|
|
// so we need to remove the pictures from those groups. But we prevent
|
|
|
|
// the execution twice because this could be executed again when upgrading
|
|
|
|
// to different versions.
|
|
|
|
if ($dbman->field_exists('groups', 'hidepicture')) {
|
|
|
|
|
|
|
|
$sql = "SELECT g.id, g.courseid, ctx.id AS contextid
|
|
|
|
FROM {groups} g
|
|
|
|
JOIN {context} ctx
|
|
|
|
ON ctx.instanceid = g.courseid
|
|
|
|
AND ctx.contextlevel = :contextlevel
|
|
|
|
WHERE g.hidepicture = 1";
|
|
|
|
|
|
|
|
// Selecting all the groups that have hide picture enabled, and organising them by context.
|
|
|
|
$groupctx = [];
|
|
|
|
$records = $DB->get_recordset_sql($sql, ['contextlevel' => CONTEXT_COURSE]);
|
|
|
|
foreach ($records as $record) {
|
|
|
|
if (!isset($groupctx[$record->contextid])) {
|
|
|
|
$groupctx[$record->contextid] = [];
|
|
|
|
}
|
|
|
|
$groupctx[$record->contextid][] = $record->id;
|
|
|
|
}
|
|
|
|
$records->close();
|
|
|
|
|
|
|
|
// Deleting the group files.
|
|
|
|
$fs = get_file_storage();
|
|
|
|
foreach ($groupctx as $contextid => $groupids) {
|
|
|
|
list($in, $inparams) = $DB->get_in_or_equal($groupids, SQL_PARAMS_NAMED);
|
|
|
|
$fs->delete_area_files_select($contextid, 'group', 'icon', $in, $inparams);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Updating the database to remove picture from all those groups.
|
|
|
|
$sql = "UPDATE {groups} SET picture = :pic WHERE hidepicture = :hide";
|
|
|
|
$DB->execute($sql, ['pic' => 0, 'hide' => 1]);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Define field hidepicture to be dropped from groups.
|
|
|
|
$table = new xmldb_table('groups');
|
|
|
|
$field = new xmldb_field('hidepicture');
|
|
|
|
|
|
|
|
// Conditionally launch drop field hidepicture.
|
|
|
|
if ($dbman->field_exists($table, $field)) {
|
|
|
|
$dbman->drop_field($table, $field);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
2021-02-16 19:45:44 +01:00
|
|
|
upgrade_main_savepoint(true, 2021052500.60);
|
2014-11-06 16:46:50 +08:00
|
|
|
}
|
|
|
|
|
2021-02-16 12:39:35 +01:00
|
|
|
if ($oldversion < 2021052500.64) {
|
|
|
|
// Get all the external backpacks and update the sortorder column, to avoid repeated/wrong values. As sortorder was not
|
|
|
|
// used since now, the id column will be the criteria to follow for re-ordering them with a valid value.
|
|
|
|
$i = 1;
|
|
|
|
$records = $DB->get_records('badge_external_backpack', null, 'id ASC');
|
|
|
|
foreach ($records as $record) {
|
|
|
|
$record->sortorder = $i++;
|
|
|
|
$DB->update_record('badge_external_backpack', $record);
|
|
|
|
}
|
|
|
|
|
|
|
|
upgrade_main_savepoint(true, 2021052500.64);
|
|
|
|
}
|
|
|
|
|
2021-02-17 16:33:20 +01:00
|
|
|
if ($oldversion < 2021052500.67) {
|
|
|
|
// The $CFG->badges_site_backpack setting has been removed because it's not required anymore. From now, the default backpack
|
|
|
|
// will be the one with lower sortorder value.
|
|
|
|
unset_config('badges_site_backpack');
|
|
|
|
|
|
|
|
upgrade_main_savepoint(true, 2021052500.67);
|
|
|
|
}
|
|
|
|
|
2021-01-20 17:23:18 +01:00
|
|
|
if ($oldversion < 2021052500.69) {
|
|
|
|
|
|
|
|
// Define field type to be added to oauth2_issuer.
|
|
|
|
$table = new xmldb_table('oauth2_issuer');
|
|
|
|
$field = new xmldb_field('servicetype', XMLDB_TYPE_CHAR, '255', null, null, null, null, 'requireconfirmation');
|
|
|
|
|
|
|
|
// Conditionally launch add field type.
|
|
|
|
if (!$dbman->field_exists($table, $field)) {
|
|
|
|
$dbman->add_field($table, $field);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Set existing values to the proper servicetype value.
|
|
|
|
// It's not critical if the servicetype column doesn't contain the proper value for Google, Microsoft, Facebook or
|
|
|
|
// Nextcloud services because, for now, this value is used for services using different discovery method.
|
|
|
|
// However, let's try to upgrade it using the default value for the baseurl or image. If any of these default values
|
|
|
|
// have been changed, the servicetype column will remain NULL.
|
|
|
|
$recordset = $DB->get_recordset('oauth2_issuer');
|
|
|
|
foreach ($recordset as $record) {
|
|
|
|
if ($record->baseurl == 'https://accounts.google.com/') {
|
|
|
|
$record->servicetype = 'google';
|
|
|
|
$DB->update_record('oauth2_issuer', $record);
|
|
|
|
} else if ($record->image == 'https://www.microsoft.com/favicon.ico') {
|
|
|
|
$record->servicetype = 'microsoft';
|
|
|
|
$DB->update_record('oauth2_issuer', $record);
|
|
|
|
} else if ($record->image == 'https://facebookbrand.com/wp-content/uploads/2016/05/flogo_rgb_hex-brc-site-250.png') {
|
|
|
|
$record->servicetype = 'facebook';
|
|
|
|
$DB->update_record('oauth2_issuer', $record);
|
|
|
|
} else if ($record->image == 'https://nextcloud.com/wp-content/themes/next/assets/img/common/favicon.png?x16328') {
|
|
|
|
$record->servicetype = 'nextcloud';
|
|
|
|
$DB->update_record('oauth2_issuer', $record);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
$recordset->close();
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2021052500.69);
|
|
|
|
}
|
|
|
|
|
2021-03-08 20:46:52 +08:00
|
|
|
if ($oldversion < 2021052500.74) {
|
|
|
|
// Define field 'showactivitydates' to be added to course table.
|
|
|
|
$table = new xmldb_table('course');
|
|
|
|
$field = new xmldb_field('showactivitydates', XMLDB_TYPE_INTEGER, '1', null,
|
|
|
|
XMLDB_NOTNULL, null, '0', 'originalcourseid');
|
|
|
|
|
|
|
|
if (!$dbman->field_exists($table, $field)) {
|
|
|
|
$dbman->add_field($table, $field);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2021052500.74);
|
|
|
|
}
|
|
|
|
|
2021-03-09 06:42:09 +08:00
|
|
|
if ($oldversion < 2021052500.75) {
|
|
|
|
// Define field 'showcompletionconditions' to be added to course.
|
|
|
|
$table = new xmldb_table('course');
|
|
|
|
$field = new xmldb_field('showcompletionconditions', XMLDB_TYPE_INTEGER, '1', null,
|
|
|
|
XMLDB_NOTNULL, null, '1', 'completionnotify');
|
|
|
|
|
|
|
|
if (!$dbman->field_exists($table, $field)) {
|
|
|
|
$dbman->add_field($table, $field);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2021052500.75);
|
|
|
|
}
|
|
|
|
|
2021-02-24 16:11:12 +01:00
|
|
|
if ($oldversion < 2021052500.78) {
|
|
|
|
|
|
|
|
// Define field enabled to be added to h5p_libraries.
|
|
|
|
$table = new xmldb_table('h5p_libraries');
|
|
|
|
$field = new xmldb_field('enabled', XMLDB_TYPE_INTEGER, '1', null, null, null, '1', 'example');
|
|
|
|
|
|
|
|
// Conditionally launch add field enabled.
|
|
|
|
if (!$dbman->field_exists($table, $field)) {
|
|
|
|
$dbman->add_field($table, $field);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2021052500.78);
|
|
|
|
}
|
|
|
|
|
2021-04-21 14:58:06 +08:00
|
|
|
if ($oldversion < 2021052500.83) {
|
2021-03-01 15:33:57 +01:00
|
|
|
|
|
|
|
// Define field loginpagename to be added to oauth2_issuer.
|
|
|
|
$table = new xmldb_table('oauth2_issuer');
|
|
|
|
$field = new xmldb_field('loginpagename', XMLDB_TYPE_CHAR, '255', null, null, null, null, 'servicetype');
|
|
|
|
|
|
|
|
// Conditionally launch add field loginpagename.
|
|
|
|
if (!$dbman->field_exists($table, $field)) {
|
|
|
|
$dbman->add_field($table, $field);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
2021-04-21 14:58:06 +08:00
|
|
|
upgrade_main_savepoint(true, 2021052500.83);
|
2021-03-01 15:33:57 +01:00
|
|
|
}
|
|
|
|
|
2021-04-22 09:38:50 +08:00
|
|
|
if ($oldversion < 2021052500.84) {
|
MDL-28452 core_user: migrate social profile fields
Create a new profile field type, move all existing content of the fields
'icq', 'skype', 'aim', 'yahoo', 'msn' and 'url' in the mdl_user table to
theses new profile fields if needed.
AMOS BEGIN
MOV [aimid,core],[aimid,courseimage,profilefield_social]
MOV [yahooid,core],[yahooid,profilefield_social]
MOV [skypeid,core],[skypeid,profilefield_social]
MOV [icqnumber,core],[icqnumber,profilefield_social]
MOV [msnid,core],[msnid,profilefield_social]
MOV [webpage,core],[webpage,profilefield_social]
AMOS END
2020-11-17 19:43:49 +01:00
|
|
|
require_once($CFG->dirroot . '/user/profile/field/social/upgradelib.php');
|
|
|
|
$table = new xmldb_table('user');
|
|
|
|
$tablecolumns = ['icq', 'skype', 'aim', 'yahoo', 'msn', 'url'];
|
|
|
|
|
|
|
|
foreach ($tablecolumns as $column) {
|
|
|
|
$field = new xmldb_field($column);
|
|
|
|
if ($dbman->field_exists($table, $field)) {
|
|
|
|
user_profile_social_moveto_profilefield($column);
|
|
|
|
$dbman->drop_field($table, $field);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Update all module availability if it relies on the old user fields.
|
|
|
|
user_profile_social_update_module_availability();
|
|
|
|
|
|
|
|
// Remove field mapping for oauth2.
|
|
|
|
$DB->delete_records('oauth2_user_field_mapping', array('internalfield' => 'url'));
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
2021-04-22 09:38:50 +08:00
|
|
|
upgrade_main_savepoint(true, 2021052500.84);
|
MDL-28452 core_user: migrate social profile fields
Create a new profile field type, move all existing content of the fields
'icq', 'skype', 'aim', 'yahoo', 'msn' and 'url' in the mdl_user table to
theses new profile fields if needed.
AMOS BEGIN
MOV [aimid,core],[aimid,courseimage,profilefield_social]
MOV [yahooid,core],[yahooid,profilefield_social]
MOV [skypeid,core],[skypeid,profilefield_social]
MOV [icqnumber,core],[icqnumber,profilefield_social]
MOV [msnid,core],[msnid,profilefield_social]
MOV [webpage,core],[webpage,profilefield_social]
AMOS END
2020-11-17 19:43:49 +01:00
|
|
|
}
|
|
|
|
|
MDL-71156 core: machinery to recover orphaned calendar events
The machinery to fix orphaned calendar events that were broken by MDL-67494.
The solution consists of:
1) Upgrade step that checks if this site has executed the problematic upgrade steps and
if positive, it will schedule a new run for calendar_fix_orphaned_events adhoc task.
2) Adhoc task that will self-spawn calling the recovery machinery, running until
all the orphaned calendar events are fixed. It also sets the maximum runtime of
60 seconds. It is also possible to override that number by specifing the desired
number setting the ->calendareventsmaxseconds in your config.php
3) CLI script that will look for all the calendar events which userids
where broken by a wrong upgrade step, affecting to Moodle 3.9.5
and up.
It performs checks to both:
a) Detect if the site was affected (ran the wrong upgrade step).
b) Look for orphaned calendar events, categorising them as:
- standard: site / category / course / group / user events
- subscription: events created via subscriptions.
- action: normal action events, created to show common important dates.
- override: user and group override events, particular, that some activities support.
- custom: other events, not being any of the above, common or particular.
By specifying it (--fix) try to recover as many broken events (missing userid) as
possible. Standard, subscription, action, override events in core are fully supported but
override or custom events should be fixed by each plugin as far as there isn't any standard
API (plugin-wise) to launch a rebuild of the calendar events.
4) Unit tests and helper functions to generate calendar events. We have decided to
keep the tests simple, testing only true and false and not using data generators because
the code is purely to recover the calendar events and won't turn into an API or something
and also due to the urgency of this issue.
The helpers have been created in calendar/tests/helpers.php since there are no data generators
for calendar.
2021-04-16 11:42:33 +08:00
|
|
|
if ($oldversion < 2021052500.85) {
|
|
|
|
require_once($CFG->libdir . '/db/upgradelib.php');
|
|
|
|
|
|
|
|
// Check if this site has executed the problematic upgrade steps.
|
|
|
|
$needsfixing = upgrade_calendar_site_status(false);
|
|
|
|
|
|
|
|
// Only queue the task if this site has been affected by the problematic upgrade step.
|
|
|
|
if ($needsfixing) {
|
|
|
|
|
|
|
|
// Create adhoc task to search and recover orphaned calendar events.
|
|
|
|
$record = new \stdClass();
|
|
|
|
$record->classname = '\core\task\calendar_fix_orphaned_events';
|
|
|
|
|
|
|
|
// Next run time based from nextruntime computation in \core\task\manager::queue_adhoc_task().
|
|
|
|
$nextruntime = time() - 1;
|
|
|
|
$record->nextruntime = $nextruntime;
|
|
|
|
$DB->insert_record('task_adhoc', $record);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2021052500.85);
|
|
|
|
}
|
|
|
|
|
2021-04-22 22:41:03 +08:00
|
|
|
if ($oldversion < 2021052500.87) {
|
|
|
|
// Changing the default of field showcompletionconditions on table course to 0.
|
|
|
|
$table = new xmldb_table('course');
|
|
|
|
$field = new xmldb_field('showcompletionconditions', XMLDB_TYPE_INTEGER, '1', null, null, null, null, 'showactivitydates');
|
|
|
|
|
|
|
|
// Launch change of nullability for field showcompletionconditions.
|
|
|
|
$dbman->change_field_notnull($table, $field);
|
|
|
|
|
|
|
|
// Launch change of default for field showcompletionconditions.
|
|
|
|
$dbman->change_field_default($table, $field);
|
|
|
|
|
|
|
|
// Set showcompletionconditions to null for courses which don't track completion.
|
|
|
|
$sql = "UPDATE {course}
|
|
|
|
SET showcompletionconditions = null
|
|
|
|
WHERE enablecompletion <> 1";
|
|
|
|
$DB->execute($sql);
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2021052500.87);
|
|
|
|
}
|
|
|
|
|
2021-03-30 14:03:34 +02:00
|
|
|
if ($oldversion < 2021052500.90) {
|
|
|
|
// Remove usemodchooser user preference for every user.
|
|
|
|
$DB->delete_records('user_preferences', ['name' => 'usemodchooser']);
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2021052500.90);
|
|
|
|
}
|
|
|
|
|
2021-06-02 23:50:23 +02:00
|
|
|
if ($oldversion < 2021060200.00) {
|
2021-06-02 22:10:37 +10:00
|
|
|
|
|
|
|
// Define index name (not unique) to be added to user_preferences.
|
|
|
|
$table = new xmldb_table('user_preferences');
|
|
|
|
$index = new xmldb_index('name', XMLDB_INDEX_NOTUNIQUE, ['name']);
|
|
|
|
|
|
|
|
// Conditionally launch add index name.
|
|
|
|
if (!$dbman->index_exists($table, $index)) {
|
|
|
|
$dbman->add_index($table, $index);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
2021-06-02 23:50:23 +02:00
|
|
|
upgrade_main_savepoint(true, 2021060200.00);
|
2021-06-02 22:10:37 +10:00
|
|
|
}
|
|
|
|
|
2021-06-09 13:22:49 +08:00
|
|
|
if ($oldversion < 2021060900.00) {
|
2021-05-26 09:58:21 +08:00
|
|
|
// Update the externalfield to be larger.
|
|
|
|
$table = new xmldb_table('oauth2_user_field_mapping');
|
|
|
|
$field = new xmldb_field('externalfield', XMLDB_TYPE_CHAR, '500', null, XMLDB_NOTNULL, false, null, 'issuerid');
|
|
|
|
$dbman->change_field_type($table, $field);
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
2021-06-09 13:22:49 +08:00
|
|
|
upgrade_main_savepoint(true, 2021060900.00);
|
2021-05-26 09:58:21 +08:00
|
|
|
}
|
|
|
|
|
2020-11-10 09:24:12 +00:00
|
|
|
if ($oldversion < 2021072800.01) {
|
|
|
|
// Define table reportbuilder_report to be created.
|
|
|
|
$table = new xmldb_table('reportbuilder_report');
|
|
|
|
|
|
|
|
// Adding fields to table reportbuilder_report.
|
|
|
|
$table->add_field('id', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, XMLDB_SEQUENCE, null);
|
|
|
|
$table->add_field('source', XMLDB_TYPE_CHAR, '255', null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('type', XMLDB_TYPE_INTEGER, '2', null, XMLDB_NOTNULL, null, '0');
|
|
|
|
$table->add_field('contextid', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('component', XMLDB_TYPE_CHAR, '100', null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('area', XMLDB_TYPE_CHAR, '100', null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('itemid', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, '0');
|
|
|
|
$table->add_field('usercreated', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, '0');
|
|
|
|
$table->add_field('usermodified', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, '0');
|
|
|
|
$table->add_field('timecreated', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, '0');
|
|
|
|
$table->add_field('timemodified', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, '0');
|
|
|
|
|
|
|
|
// Adding keys to table reportbuilder_report.
|
|
|
|
$table->add_key('primary', XMLDB_KEY_PRIMARY, ['id']);
|
|
|
|
$table->add_key('usercreated', XMLDB_KEY_FOREIGN, ['usercreated'], 'user', ['id']);
|
|
|
|
$table->add_key('usermodified', XMLDB_KEY_FOREIGN, ['usermodified'], 'user', ['id']);
|
|
|
|
$table->add_key('contextid', XMLDB_KEY_FOREIGN, ['contextid'], 'context', ['id']);
|
|
|
|
|
|
|
|
// Conditionally launch create table for reportbuilder_report.
|
|
|
|
if (!$dbman->table_exists($table)) {
|
|
|
|
$dbman->create_table($table);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2021072800.01);
|
|
|
|
}
|
|
|
|
|
2021-08-11 09:44:27 +02:00
|
|
|
if ($oldversion < 2021090200.01) {
|
|
|
|
// Remove qformat_webct (unless it has manually been added back).
|
|
|
|
if (!file_exists($CFG->dirroot . '/question/format/webct/format.php')) {
|
|
|
|
unset_all_config_for_plugin('qformat_webct');
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2021090200.01);
|
|
|
|
}
|
|
|
|
|
2021-08-16 13:10:48 +02:00
|
|
|
if ($oldversion < 2021091100.01) {
|
|
|
|
// If message_jabber is no longer present, remove it.
|
|
|
|
if (!file_exists($CFG->dirroot . '/message/output/jabber/message_output_jabber.php')) {
|
|
|
|
// Remove Jabber from the notification plugins list.
|
|
|
|
$DB->delete_records('message_processors', ['name' => 'jabber']);
|
|
|
|
|
|
|
|
// Remove user preference settings.
|
|
|
|
$DB->delete_records('user_preferences', ['name' => 'message_processor_jabber_jabberid']);
|
|
|
|
$sql = 'SELECT *
|
|
|
|
FROM {user_preferences} up
|
|
|
|
WHERE ' . $DB->sql_like('up.name', ':name', false, false) . ' AND ' .
|
|
|
|
$DB->sql_like('up.value', ':value', false, false);
|
|
|
|
$params = [
|
|
|
|
'name' => 'message_provider_%',
|
|
|
|
'value' => '%jabber%',
|
|
|
|
];
|
|
|
|
$jabbersettings = $DB->get_recordset_sql($sql, $params);
|
|
|
|
foreach ($jabbersettings as $jabbersetting) {
|
|
|
|
// Remove 'jabber' from the value.
|
|
|
|
$jabbersetting->value = implode(',', array_diff(explode(',', $jabbersetting->value), ['jabber']));
|
|
|
|
$DB->update_record('user_preferences', $jabbersetting);
|
|
|
|
}
|
|
|
|
$jabbersettings->close();
|
|
|
|
|
|
|
|
// Clean config settings.
|
|
|
|
unset_config('jabberhost');
|
|
|
|
unset_config('jabberserver');
|
|
|
|
unset_config('jabberusername');
|
|
|
|
unset_config('jabberpassword');
|
|
|
|
unset_config('jabberport');
|
|
|
|
|
|
|
|
// Remove default notification preferences.
|
|
|
|
$like = $DB->sql_like('name', '?', true, true, false, '|');
|
|
|
|
$params = [$DB->sql_like_escape('jabber_provider_', '|') . '%'];
|
|
|
|
$DB->delete_records_select('config_plugins', $like, $params);
|
|
|
|
|
|
|
|
// Clean config config settings.
|
|
|
|
unset_all_config_for_plugin('message_jabber');
|
|
|
|
}
|
|
|
|
|
|
|
|
upgrade_main_savepoint(true, 2021091100.01);
|
|
|
|
}
|
|
|
|
|
2021-09-14 22:42:15 +02:00
|
|
|
if ($oldversion < 2021091100.02) {
|
2021-08-11 16:07:34 +02:00
|
|
|
// Set the description field to HTML format for the Default course category.
|
|
|
|
$category = $DB->get_record('course_categories', ['id' => 1]);
|
|
|
|
|
2022-03-18 15:30:19 -04:00
|
|
|
if (!empty($category) && $category->descriptionformat == FORMAT_MOODLE) {
|
2021-08-11 16:07:34 +02:00
|
|
|
// Format should be changed only if it's still set to FORMAT_MOODLE.
|
|
|
|
if (!is_null($category->description)) {
|
|
|
|
// If description is not empty, format the content to HTML.
|
|
|
|
$category->description = format_text($category->description, FORMAT_MOODLE);
|
|
|
|
}
|
|
|
|
$category->descriptionformat = FORMAT_HTML;
|
|
|
|
$DB->update_record('course_categories', $category);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
2021-09-14 22:42:15 +02:00
|
|
|
upgrade_main_savepoint(true, 2021091100.02);
|
2021-08-11 16:07:34 +02:00
|
|
|
}
|
|
|
|
|
2021-08-23 18:04:18 +02:00
|
|
|
if ($oldversion < 2021091700.01) {
|
|
|
|
// Default 'off' for existing sites as this is the behaviour they had earlier.
|
|
|
|
set_config('enroladminnewcourse', false);
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2021091700.01);
|
|
|
|
}
|
|
|
|
|
2021-09-21 10:38:11 +08:00
|
|
|
if ($oldversion < 2021091700.02) {
|
2021-08-10 16:41:35 +02:00
|
|
|
// If portfolio_picasa is no longer present, remove it.
|
|
|
|
if (!file_exists($CFG->dirroot . '/portfolio/picasa/version.php')) {
|
|
|
|
$instance = $DB->get_record('portfolio_instance', ['plugin' => 'picasa']);
|
|
|
|
if (!empty($instance)) {
|
|
|
|
// Remove all records from portfolio_instance_config.
|
|
|
|
$DB->delete_records('portfolio_instance_config', ['instance' => $instance->id]);
|
|
|
|
// Remove all records from portfolio_instance_user.
|
|
|
|
$DB->delete_records('portfolio_instance_user', ['instance' => $instance->id]);
|
|
|
|
// Remove all records from portfolio_log.
|
|
|
|
$DB->delete_records('portfolio_log', ['portfolio' => $instance->id]);
|
|
|
|
// Remove all records from portfolio_tempdata.
|
|
|
|
$DB->delete_records('portfolio_tempdata', ['instance' => $instance->id]);
|
|
|
|
// Remove the record from the portfolio_instance table.
|
|
|
|
$DB->delete_records('portfolio_instance', ['id' => $instance->id]);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Clean config.
|
|
|
|
unset_all_config_for_plugin('portfolio_picasa');
|
|
|
|
}
|
|
|
|
|
2021-09-21 10:38:11 +08:00
|
|
|
upgrade_main_savepoint(true, 2021091700.02);
|
2021-08-10 16:41:35 +02:00
|
|
|
}
|
|
|
|
|
2021-09-21 10:38:11 +08:00
|
|
|
if ($oldversion < 2021091700.03) {
|
2021-08-10 17:37:59 +02:00
|
|
|
// If repository_picasa is no longer present, remove it.
|
|
|
|
if (!file_exists($CFG->dirroot . '/repository/picasa/version.php')) {
|
|
|
|
$instance = $DB->get_record('repository', ['type' => 'picasa']);
|
|
|
|
if (!empty($instance)) {
|
|
|
|
// Remove all records from repository_instance_config table.
|
|
|
|
$DB->delete_records('repository_instance_config', ['instanceid' => $instance->id]);
|
|
|
|
// Remove all records from repository_instances table.
|
|
|
|
$DB->delete_records('repository_instances', ['typeid' => $instance->id]);
|
|
|
|
// Remove the record from the repository table.
|
|
|
|
$DB->delete_records('repository', ['id' => $instance->id]);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Clean config.
|
|
|
|
unset_all_config_for_plugin('picasa');
|
|
|
|
|
|
|
|
// Remove orphaned files.
|
|
|
|
upgrade_delete_orphaned_file_records();
|
|
|
|
}
|
|
|
|
|
2021-09-21 10:38:11 +08:00
|
|
|
upgrade_main_savepoint(true, 2021091700.03);
|
2021-08-10 17:37:59 +02:00
|
|
|
}
|
|
|
|
|
2021-09-22 13:34:28 +02:00
|
|
|
if ($oldversion < 2021091700.04) {
|
2021-08-11 12:16:38 +02:00
|
|
|
// Remove media_swf (unless it has manually been added back).
|
|
|
|
if (!file_exists($CFG->dirroot . '/media/player/swf/classes/plugin.php')) {
|
|
|
|
unset_all_config_for_plugin('media_swf');
|
|
|
|
}
|
|
|
|
|
2021-09-22 13:34:28 +02:00
|
|
|
upgrade_main_savepoint(true, 2021091700.04);
|
2021-08-11 12:16:38 +02:00
|
|
|
}
|
|
|
|
|
2021-09-02 17:45:18 +02:00
|
|
|
if ($oldversion < 2021092400.01) {
|
|
|
|
// If tool_health is no longer present, remove it.
|
|
|
|
if (!file_exists($CFG->dirroot . '/admin/tool/health/version.php')) {
|
|
|
|
// Clean config.
|
|
|
|
unset_all_config_for_plugin('tool_health');
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2021092400.01);
|
|
|
|
}
|
|
|
|
|
2021-09-28 15:51:58 +02:00
|
|
|
if ($oldversion < 2021092400.03) {
|
2021-09-24 12:35:03 +01:00
|
|
|
// Remove repository_picasa configuration (unless it has manually been added back).
|
|
|
|
if (!file_exists($CFG->dirroot . '/repository/picasa/version.php')) {
|
|
|
|
unset_all_config_for_plugin('repository_picasa');
|
|
|
|
}
|
|
|
|
|
2021-09-28 15:51:58 +02:00
|
|
|
upgrade_main_savepoint(true, 2021092400.03);
|
2021-09-24 12:35:03 +01:00
|
|
|
}
|
|
|
|
|
2021-09-20 15:47:51 +02:00
|
|
|
if ($oldversion < 2021100300.01) {
|
|
|
|
// Remove repository_skydrive (unless it has manually been added back).
|
|
|
|
if (!file_exists($CFG->dirroot . '/repository/skydrive/lib.php')) {
|
|
|
|
unset_all_config_for_plugin('repository_skydrive');
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2021100300.01);
|
|
|
|
}
|
|
|
|
|
2021-10-05 11:14:51 +08:00
|
|
|
if ($oldversion < 2021100300.02) {
|
2021-09-17 11:45:36 +02:00
|
|
|
// Remove filter_censor (unless it has manually been added back).
|
|
|
|
if (!file_exists($CFG->dirroot . '/filter/censor/filter.php')) {
|
|
|
|
unset_all_config_for_plugin('filter_censor');
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
2021-10-05 11:14:51 +08:00
|
|
|
upgrade_main_savepoint(true, 2021100300.02);
|
2021-09-17 11:45:36 +02:00
|
|
|
}
|
|
|
|
|
2021-09-13 11:53:54 +02:00
|
|
|
if ($oldversion < 2021100600.01) {
|
|
|
|
// Remove qformat_examview (unless it has manually been added back).
|
|
|
|
if (!file_exists($CFG->dirroot . '/question/format/examview/format.php')) {
|
|
|
|
unset_all_config_for_plugin('qformat_examview');
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2021100600.01);
|
|
|
|
}
|
|
|
|
|
2021-10-07 12:55:12 +07:00
|
|
|
if ($oldversion < 2021100600.02) {
|
2019-11-29 13:26:40 +08:00
|
|
|
$table = new xmldb_table('course_completion_defaults');
|
|
|
|
|
|
|
|
// Adding fields to table course_completion_defaults.
|
|
|
|
$field = new xmldb_field('completionpassgrade', XMLDB_TYPE_INTEGER, '1', null,
|
|
|
|
XMLDB_NOTNULL, null, '0', 'completionusegrade');
|
|
|
|
|
|
|
|
// Conditionally launch add field for course_completion_defaults.
|
|
|
|
if (!$dbman->field_exists($table, $field)) {
|
|
|
|
$dbman->add_field($table, $field);
|
|
|
|
}
|
|
|
|
|
2021-10-07 12:55:12 +07:00
|
|
|
upgrade_main_savepoint(true, 2021100600.02);
|
2019-11-29 13:26:40 +08:00
|
|
|
}
|
|
|
|
|
2021-10-07 12:55:12 +07:00
|
|
|
if ($oldversion < 2021100600.03) {
|
2019-12-04 10:14:31 +08:00
|
|
|
$table = new xmldb_table('course_modules');
|
|
|
|
|
|
|
|
// Adding new fields to table course_module table.
|
|
|
|
$field = new xmldb_field('completionpassgrade', XMLDB_TYPE_INTEGER, '1', null,
|
|
|
|
XMLDB_NOTNULL, null, '0', 'completionexpected');
|
|
|
|
// Conditionally launch create table for course_completion_defaults.
|
|
|
|
if (!$dbman->field_exists($table, $field)) {
|
|
|
|
$dbman->add_field($table, $field);
|
|
|
|
}
|
|
|
|
|
2021-10-07 12:55:12 +07:00
|
|
|
upgrade_main_savepoint(true, 2021100600.03);
|
2019-12-04 10:14:31 +08:00
|
|
|
}
|
|
|
|
|
2021-10-07 16:02:52 +01:00
|
|
|
if ($oldversion < 2021100600.04) {
|
2021-09-24 15:25:09 +10:00
|
|
|
// Define index itemtype-mod-inst-course (not unique) to be added to grade_items.
|
|
|
|
$table = new xmldb_table('grade_items');
|
|
|
|
$index = new xmldb_index('itemtype-mod-inst-course', XMLDB_INDEX_NOTUNIQUE,
|
|
|
|
['itemtype', 'itemmodule', 'iteminstance', 'courseid']);
|
|
|
|
|
|
|
|
// Conditionally launch add index itemtype-mod-inst-course.
|
|
|
|
if (!$dbman->index_exists($table, $index)) {
|
|
|
|
$dbman->add_index($table, $index);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
2021-10-07 16:02:52 +01:00
|
|
|
upgrade_main_savepoint(true, 2021100600.04);
|
2021-09-24 15:25:09 +10:00
|
|
|
}
|
|
|
|
|
2021-07-05 11:51:20 +01:00
|
|
|
if ($oldversion < 2021101900.01) {
|
|
|
|
$table = new xmldb_table('reportbuilder_report');
|
|
|
|
|
|
|
|
// Define field name to be added to reportbuilder_report.
|
|
|
|
$field = new xmldb_field('name', XMLDB_TYPE_CHAR, '255', null, null, null, null, 'id');
|
|
|
|
if (!$dbman->field_exists($table, $field)) {
|
|
|
|
$dbman->add_field($table, $field);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Define field conditiondata to be added to reportbuilder_report.
|
|
|
|
$field = new xmldb_field('conditiondata', XMLDB_TYPE_TEXT, null, null, null, null, null, 'type');
|
|
|
|
if (!$dbman->field_exists($table, $field)) {
|
|
|
|
$dbman->add_field($table, $field);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Define table reportbuilder_column to be created.
|
|
|
|
$table = new xmldb_table('reportbuilder_column');
|
|
|
|
|
|
|
|
// Adding fields to table reportbuilder_column.
|
|
|
|
$table->add_field('id', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, XMLDB_SEQUENCE, null);
|
|
|
|
$table->add_field('reportid', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, '0');
|
|
|
|
$table->add_field('uniqueidentifier', XMLDB_TYPE_CHAR, '255', null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('aggregation', XMLDB_TYPE_CHAR, '32', null, null, null, null);
|
|
|
|
$table->add_field('heading', XMLDB_TYPE_CHAR, '255', null, null, null, null);
|
|
|
|
$table->add_field('columnorder', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('sortenabled', XMLDB_TYPE_INTEGER, '1', null, XMLDB_NOTNULL, null, '0');
|
|
|
|
$table->add_field('sortdirection', XMLDB_TYPE_INTEGER, '1', null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('sortorder', XMLDB_TYPE_INTEGER, '10', null, null, null, null);
|
|
|
|
$table->add_field('usercreated', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, '0');
|
|
|
|
$table->add_field('usermodified', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, '0');
|
|
|
|
$table->add_field('timecreated', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, '0');
|
|
|
|
$table->add_field('timemodified', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, '0');
|
|
|
|
|
|
|
|
// Adding keys to table reportbuilder_column.
|
|
|
|
$table->add_key('primary', XMLDB_KEY_PRIMARY, ['id']);
|
|
|
|
$table->add_key('reportid', XMLDB_KEY_FOREIGN, ['reportid'], 'reportbuilder_report', ['id']);
|
|
|
|
$table->add_key('usercreated', XMLDB_KEY_FOREIGN, ['usercreated'], 'user', ['id']);
|
|
|
|
$table->add_key('usermodified', XMLDB_KEY_FOREIGN, ['usermodified'], 'user', ['id']);
|
|
|
|
|
|
|
|
// Conditionally launch create table for reportbuilder_column.
|
|
|
|
if (!$dbman->table_exists($table)) {
|
|
|
|
$dbman->create_table($table);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Define table reportbuilder_filter to be created.
|
|
|
|
$table = new xmldb_table('reportbuilder_filter');
|
|
|
|
|
|
|
|
// Adding fields to table reportbuilder_filter.
|
|
|
|
$table->add_field('id', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, XMLDB_SEQUENCE, null);
|
|
|
|
$table->add_field('reportid', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, '0');
|
|
|
|
$table->add_field('uniqueidentifier', XMLDB_TYPE_CHAR, '255', null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('heading', XMLDB_TYPE_CHAR, '255', null, null, null, null);
|
|
|
|
$table->add_field('iscondition', XMLDB_TYPE_INTEGER, '1', null, XMLDB_NOTNULL, null, '0');
|
|
|
|
$table->add_field('filterorder', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('usercreated', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, '0');
|
|
|
|
$table->add_field('usermodified', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, '0');
|
|
|
|
$table->add_field('timecreated', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, '0');
|
|
|
|
$table->add_field('timemodified', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, '0');
|
|
|
|
|
|
|
|
// Adding keys to table reportbuilder_filter.
|
|
|
|
$table->add_key('primary', XMLDB_KEY_PRIMARY, ['id']);
|
|
|
|
$table->add_key('reportid', XMLDB_KEY_FOREIGN, ['reportid'], 'reportbuilder_report', ['id']);
|
|
|
|
$table->add_key('usercreated', XMLDB_KEY_FOREIGN, ['usercreated'], 'user', ['id']);
|
|
|
|
$table->add_key('usermodified', XMLDB_KEY_FOREIGN, ['usermodified'], 'user', ['id']);
|
|
|
|
|
|
|
|
// Conditionally launch create table for reportbuilder_filter.
|
|
|
|
if (!$dbman->table_exists($table)) {
|
|
|
|
$dbman->create_table($table);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2021101900.01);
|
|
|
|
}
|
|
|
|
|
2021-09-30 07:42:14 +02:00
|
|
|
if ($oldversion < 2021102600.01) {
|
|
|
|
// Remove block_quiz_results (unless it has manually been added back).
|
|
|
|
if (!file_exists($CFG->dirroot . '/blocks/quiz_result/block_quiz_results.php')) {
|
|
|
|
// Delete instances.
|
|
|
|
$instances = $DB->get_records_list('block_instances', 'blockname', ['quiz_results']);
|
|
|
|
$instanceids = array_keys($instances);
|
|
|
|
|
|
|
|
if (!empty($instanceids)) {
|
|
|
|
blocks_delete_instances($instanceids);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Delete the block from the block table.
|
|
|
|
$DB->delete_records('block', array('name' => 'quiz_results'));
|
|
|
|
|
|
|
|
// Remove capabilities.
|
|
|
|
capabilities_cleanup('block_quiz_results');
|
|
|
|
// Clean config.
|
|
|
|
unset_all_config_for_plugin('block_quiz_results');
|
|
|
|
|
|
|
|
// Remove Moodle-level quiz_results based capabilities.
|
|
|
|
$capabilitiestoberemoved = ['block/quiz_results:addinstance'];
|
|
|
|
// Delete any role_capabilities for the old roles.
|
|
|
|
$DB->delete_records_list('role_capabilities', 'capability', $capabilitiestoberemoved);
|
|
|
|
// Delete the capability itself.
|
|
|
|
$DB->delete_records_list('capabilities', 'name', $capabilitiestoberemoved);
|
|
|
|
}
|
|
|
|
|
|
|
|
upgrade_main_savepoint(true, 2021102600.01);
|
|
|
|
}
|
|
|
|
|
2021-10-29 14:58:11 +08:00
|
|
|
if ($oldversion < 2021102900.02) {
|
2021-10-08 12:58:46 +02:00
|
|
|
// If portfolio_boxnet is no longer present, remove it.
|
|
|
|
if (!file_exists($CFG->dirroot . '/portfolio/boxnet/version.php')) {
|
|
|
|
$instance = $DB->get_record('portfolio_instance', ['plugin' => 'boxnet']);
|
|
|
|
if (!empty($instance)) {
|
|
|
|
// Remove all records from portfolio_instance_config.
|
|
|
|
$DB->delete_records('portfolio_instance_config', ['instance' => $instance->id]);
|
|
|
|
// Remove all records from portfolio_instance_user.
|
|
|
|
$DB->delete_records('portfolio_instance_user', ['instance' => $instance->id]);
|
|
|
|
// Remove all records from portfolio_log.
|
|
|
|
$DB->delete_records('portfolio_log', ['portfolio' => $instance->id]);
|
|
|
|
// Remove all records from portfolio_tempdata.
|
|
|
|
$DB->delete_records('portfolio_tempdata', ['instance' => $instance->id]);
|
|
|
|
// Remove the record from the portfolio_instance table.
|
|
|
|
$DB->delete_records('portfolio_instance', ['id' => $instance->id]);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Clean config.
|
|
|
|
unset_all_config_for_plugin('portfolio_boxnet');
|
|
|
|
}
|
|
|
|
|
|
|
|
// If repository_boxnet is no longer present, remove it.
|
|
|
|
if (!file_exists($CFG->dirroot . '/repository/boxnet/version.php')) {
|
|
|
|
$instance = $DB->get_record('repository', ['type' => 'boxnet']);
|
|
|
|
if (!empty($instance)) {
|
|
|
|
// Remove all records from repository_instance_config table.
|
|
|
|
$DB->delete_records('repository_instance_config', ['instanceid' => $instance->id]);
|
|
|
|
// Remove all records from repository_instances table.
|
|
|
|
$DB->delete_records('repository_instances', ['typeid' => $instance->id]);
|
|
|
|
// Remove the record from the repository table.
|
|
|
|
$DB->delete_records('repository', ['id' => $instance->id]);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Clean config.
|
|
|
|
unset_all_config_for_plugin('repository_boxnet');
|
|
|
|
|
2021-10-29 14:58:11 +08:00
|
|
|
// The boxnet repository plugin stores some config in 'boxnet' incorrectly.
|
|
|
|
unset_all_config_for_plugin('boxnet');
|
|
|
|
|
2021-10-08 12:58:46 +02:00
|
|
|
// Remove orphaned files.
|
|
|
|
upgrade_delete_orphaned_file_records();
|
|
|
|
}
|
|
|
|
|
2021-10-29 14:58:11 +08:00
|
|
|
upgrade_main_savepoint(true, 2021102900.02);
|
2021-10-08 12:58:46 +02:00
|
|
|
}
|
|
|
|
|
2021-11-01 11:22:48 +08:00
|
|
|
if ($oldversion < 2021110100.00) {
|
2021-09-27 12:27:09 +02:00
|
|
|
|
|
|
|
// Define table reportbuilder_audience to be created.
|
|
|
|
$table = new xmldb_table('reportbuilder_audience');
|
|
|
|
|
|
|
|
// Adding fields to table reportbuilder_audience.
|
|
|
|
$table->add_field('id', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, XMLDB_SEQUENCE, null);
|
|
|
|
$table->add_field('reportid', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('classname', XMLDB_TYPE_CHAR, '255', null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('configdata', XMLDB_TYPE_TEXT, null, null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('usercreated', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, '0');
|
|
|
|
$table->add_field('usermodified', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, '0');
|
|
|
|
$table->add_field('timecreated', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, '0');
|
|
|
|
$table->add_field('timemodified', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, '0');
|
|
|
|
|
|
|
|
// Adding keys to table reportbuilder_audience.
|
|
|
|
$table->add_key('primary', XMLDB_KEY_PRIMARY, ['id']);
|
|
|
|
$table->add_key('reportid', XMLDB_KEY_FOREIGN, ['reportid'], 'reportbuilder_report', ['id']);
|
|
|
|
$table->add_key('usercreated', XMLDB_KEY_FOREIGN, ['usercreated'], 'user', ['id']);
|
|
|
|
$table->add_key('usermodified', XMLDB_KEY_FOREIGN, ['usermodified'], 'user', ['id']);
|
|
|
|
|
|
|
|
// Conditionally launch create table for reportbuilder_audience.
|
|
|
|
if (!$dbman->table_exists($table)) {
|
|
|
|
$dbman->create_table($table);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
2021-11-01 11:22:48 +08:00
|
|
|
upgrade_main_savepoint(true, 2021110100.00);
|
2021-09-27 12:27:09 +02:00
|
|
|
}
|
|
|
|
|
2021-11-11 12:42:09 +01:00
|
|
|
if ($oldversion < 2021110800.02) {
|
2020-11-24 13:00:38 +08:00
|
|
|
// Define a field 'downloadcontent' in the 'course_modules' table.
|
|
|
|
$table = new xmldb_table('course_modules');
|
|
|
|
$field = new xmldb_field('downloadcontent', XMLDB_TYPE_INTEGER, '1', null, null, null, 1, 'deletioninprogress');
|
|
|
|
|
|
|
|
// Conditionally launch add field 'downloadcontent'.
|
|
|
|
if (!$dbman->field_exists($table, $field)) {
|
|
|
|
$dbman->add_field($table, $field);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
2021-11-11 12:42:09 +01:00
|
|
|
upgrade_main_savepoint(true, 2021110800.02);
|
2020-11-24 13:00:38 +08:00
|
|
|
}
|
|
|
|
|
2021-10-05 16:49:56 +02:00
|
|
|
if ($oldversion < 2021110800.03) {
|
|
|
|
|
|
|
|
// Define field settingsdata to be added to reportbuilder_report.
|
|
|
|
$table = new xmldb_table('reportbuilder_report');
|
|
|
|
$field = new xmldb_field('settingsdata', XMLDB_TYPE_TEXT, null, null, null, null, null, 'conditiondata');
|
|
|
|
|
|
|
|
// Conditionally launch add field settingsdata.
|
|
|
|
if (!$dbman->field_exists($table, $field)) {
|
|
|
|
$dbman->add_field($table, $field);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2021110800.03);
|
|
|
|
}
|
|
|
|
|
2021-11-17 12:41:32 +08:00
|
|
|
if ($oldversion < 2021111700.00) {
|
2021-10-21 12:13:36 +08:00
|
|
|
$mycoursespage = new stdClass();
|
|
|
|
$mycoursespage->userid = null;
|
|
|
|
$mycoursespage->name = '__courses';
|
|
|
|
$mycoursespage->private = 0;
|
|
|
|
$mycoursespage->sortorder = 0;
|
|
|
|
$DB->insert_record('my_pages', $mycoursespage);
|
|
|
|
|
2021-11-17 12:41:32 +08:00
|
|
|
upgrade_main_savepoint(true, 2021111700.00);
|
2021-10-21 12:13:36 +08:00
|
|
|
}
|
|
|
|
|
2021-11-19 11:07:03 +08:00
|
|
|
if ($oldversion < 2021111700.01) {
|
2021-11-12 15:57:01 +00:00
|
|
|
|
|
|
|
// Define field uniquerows to be added to reportbuilder_report.
|
|
|
|
$table = new xmldb_table('reportbuilder_report');
|
|
|
|
$field = new xmldb_field('uniquerows', XMLDB_TYPE_INTEGER, '1', null, XMLDB_NOTNULL, null, '0', 'type');
|
|
|
|
|
|
|
|
// Conditionally launch add field uniquerows.
|
|
|
|
if (!$dbman->field_exists($table, $field)) {
|
|
|
|
$dbman->add_field($table, $field);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
2021-11-19 11:07:03 +08:00
|
|
|
upgrade_main_savepoint(true, 2021111700.01);
|
2021-11-12 15:57:01 +00:00
|
|
|
}
|
|
|
|
|
2021-12-01 08:59:47 +01:00
|
|
|
if ($oldversion < 2021120100.01) {
|
2021-11-17 10:44:24 +07:00
|
|
|
|
|
|
|
// Get current configuration data.
|
|
|
|
$currentcustomusermenuitems = str_replace(["\r\n", "\r"], "\n", $CFG->customusermenuitems);
|
|
|
|
$lines = explode("\n", $currentcustomusermenuitems);
|
|
|
|
$lines = array_map('trim', $lines);
|
|
|
|
$calendarcustomusermenu = 'calendar,core_calendar|/calendar/view.php?view=month|i/calendar';
|
|
|
|
|
|
|
|
if (!in_array($calendarcustomusermenu, $lines)) {
|
|
|
|
// Add Calendar item to the menu.
|
|
|
|
array_splice($lines, 1, 0, [$calendarcustomusermenu]);
|
|
|
|
set_config('customusermenuitems', implode("\n", $lines));
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
2021-12-01 08:59:47 +01:00
|
|
|
upgrade_main_savepoint(true, 2021120100.01);
|
2021-11-17 10:44:24 +07:00
|
|
|
}
|
|
|
|
|
2021-10-27 14:14:54 +08:00
|
|
|
if ($oldversion < 2021121400.01) {
|
|
|
|
// The $CFG->grade_navmethod setting has been removed because it's not required anymore. This setting was used
|
|
|
|
// to set the type of navigation (tabs or dropdown box) which will be displayed in gradebook. However, these
|
|
|
|
// navigation methods are no longer used and replaced with tertiary navigation.
|
|
|
|
unset_config('grade_navmethod');
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2021121400.01);
|
|
|
|
}
|
|
|
|
|
2021-11-12 09:44:02 +08:00
|
|
|
if ($oldversion < 2021121700.01) {
|
|
|
|
// Get current support email setting value.
|
|
|
|
$config = get_config('moodle', 'supportemail');
|
|
|
|
|
|
|
|
// Check if support email setting is empty and then set it to null.
|
|
|
|
// We must do that so the setting is displayed during the upgrade.
|
|
|
|
if (empty($config)) {
|
|
|
|
set_config('supportemail', null);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2021121700.01);
|
|
|
|
}
|
|
|
|
|
2021-12-21 11:23:09 +08:00
|
|
|
if ($oldversion < 2021122100.00) {
|
2021-11-24 10:11:14 +07:00
|
|
|
// Get current configuration data.
|
|
|
|
$currentcustomusermenuitems = str_replace(["\r\n", "\r"], "\n", $CFG->customusermenuitems);
|
|
|
|
|
|
|
|
// The old default customusermenuitems config for 3.11 and below.
|
|
|
|
$oldcustomusermenuitems = 'grades,grades|/grade/report/mygrades.php|t/grades
|
|
|
|
calendar,core_calendar|/calendar/view.php?view=month|i/calendar
|
|
|
|
messages,message|/message/index.php|t/message
|
|
|
|
preferences,moodle|/user/preferences.php|t/preferences';
|
|
|
|
|
|
|
|
// Check if the current customusermenuitems config matches the old customusermenuitems config.
|
|
|
|
$samecustomusermenuitems = $currentcustomusermenuitems == $oldcustomusermenuitems;
|
|
|
|
if ($samecustomusermenuitems) {
|
|
|
|
// If the site is still using the old defaults, upgrade to the new default.
|
|
|
|
$newcustomusermenuitems = 'profile,moodle|/user/profile.php
|
|
|
|
grades,grades|/grade/report/mygrades.php
|
|
|
|
calendar,core_calendar|/calendar/view.php?view=month
|
|
|
|
privatefiles,moodle|/user/files.php';
|
|
|
|
// Set the new configuration back.
|
|
|
|
set_config('customusermenuitems', $newcustomusermenuitems);
|
|
|
|
} else {
|
|
|
|
// If the site is not using the old defaults, only add necessary entries.
|
2022-05-24 23:50:36 +01:00
|
|
|
$lines = preg_split('/\n/', $currentcustomusermenuitems, -1, PREG_SPLIT_NO_EMPTY);
|
|
|
|
$lines = array_map(static function(string $line): string {
|
|
|
|
// Previous format was "<langstring>|<url>[|<pixicon>]" - pix icon is no longer supported.
|
|
|
|
$lineparts = explode('|', trim($line), 3);
|
|
|
|
// Return first two parts of line.
|
|
|
|
return implode('|', array_slice($lineparts, 0, 2));
|
|
|
|
}, $lines);
|
2021-11-24 10:11:14 +07:00
|
|
|
|
|
|
|
// Remove the Preference entry from the menu to prevent duplication
|
|
|
|
// since it will be added again in user_get_user_navigation_info().
|
|
|
|
$lines = array_filter($lines, function($value) {
|
|
|
|
return strpos($value, 'preferences,moodle|/user/preferences.php') === false;
|
|
|
|
});
|
|
|
|
|
|
|
|
$matches = preg_grep('/\|\/user\/files.php/i', $lines);
|
|
|
|
if (!$matches) {
|
|
|
|
// Add the Private files entry to the menu.
|
|
|
|
$lines[] = 'privatefiles,moodle|/user/files.php';
|
|
|
|
}
|
|
|
|
|
|
|
|
$matches = preg_grep('/\|\/user\/profile.php/i', $lines);
|
|
|
|
if (!$matches) {
|
|
|
|
// Add the Profile entry to top of the menu.
|
|
|
|
array_unshift($lines, 'profile,moodle|/user/profile.php');
|
|
|
|
}
|
|
|
|
|
|
|
|
// Set the new configuration back.
|
|
|
|
set_config('customusermenuitems', implode("\n", $lines));
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
2021-12-21 11:23:09 +08:00
|
|
|
upgrade_main_savepoint(true, 2021122100.00);
|
2021-11-24 10:11:14 +07:00
|
|
|
}
|
|
|
|
|
2021-12-22 14:54:03 +01:00
|
|
|
|
|
|
|
if ($oldversion < 2021122100.01) {
|
2021-11-04 09:21:30 +00:00
|
|
|
|
|
|
|
// Define field heading to be added to reportbuilder_audience.
|
|
|
|
$table = new xmldb_table('reportbuilder_audience');
|
|
|
|
$field = new xmldb_field('heading', XMLDB_TYPE_CHAR, '255', null, null, null, null, 'reportid');
|
|
|
|
|
|
|
|
// Conditionally launch add field heading.
|
|
|
|
if (!$dbman->field_exists($table, $field)) {
|
|
|
|
$dbman->add_field($table, $field);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
2021-12-22 14:54:03 +01:00
|
|
|
upgrade_main_savepoint(true, 2021122100.01);
|
2021-11-04 09:21:30 +00:00
|
|
|
}
|
|
|
|
|
2021-12-22 14:54:03 +01:00
|
|
|
if ($oldversion < 2021122100.02) {
|
2021-11-04 09:21:30 +00:00
|
|
|
|
|
|
|
// Define table reportbuilder_schedule to be created.
|
|
|
|
$table = new xmldb_table('reportbuilder_schedule');
|
|
|
|
|
|
|
|
// Adding fields to table reportbuilder_schedule.
|
|
|
|
$table->add_field('id', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, XMLDB_SEQUENCE, null);
|
|
|
|
$table->add_field('reportid', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, '0');
|
|
|
|
$table->add_field('name', XMLDB_TYPE_CHAR, '255', null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('enabled', XMLDB_TYPE_INTEGER, '1', null, XMLDB_NOTNULL, null, '1');
|
|
|
|
$table->add_field('audiences', XMLDB_TYPE_TEXT, null, null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('format', XMLDB_TYPE_CHAR, '255', null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('subject', XMLDB_TYPE_CHAR, '255', null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('message', XMLDB_TYPE_TEXT, null, null, XMLDB_NOTNULL, null, null);
|
2021-12-22 15:22:35 +01:00
|
|
|
$table->add_field('messageformat', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, null);
|
2021-11-04 09:21:30 +00:00
|
|
|
$table->add_field('userviewas', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, '0');
|
|
|
|
$table->add_field('timescheduled', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, '0');
|
|
|
|
$table->add_field('recurrence', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, '0');
|
|
|
|
$table->add_field('reportempty', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, '0');
|
|
|
|
$table->add_field('timelastsent', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, '0');
|
|
|
|
$table->add_field('timenextsend', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, '0');
|
|
|
|
$table->add_field('usercreated', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, '0');
|
|
|
|
$table->add_field('usermodified', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, '0');
|
|
|
|
$table->add_field('timecreated', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, '0');
|
|
|
|
$table->add_field('timemodified', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, '0');
|
|
|
|
|
|
|
|
// Adding keys to table reportbuilder_schedule.
|
|
|
|
$table->add_key('primary', XMLDB_KEY_PRIMARY, ['id']);
|
|
|
|
$table->add_key('reportid', XMLDB_KEY_FOREIGN, ['reportid'], 'reportbuilder_report', ['id']);
|
|
|
|
$table->add_key('userviewas', XMLDB_KEY_FOREIGN, ['userviewas'], 'user', ['id']);
|
|
|
|
$table->add_key('usercreated', XMLDB_KEY_FOREIGN, ['usercreated'], 'user', ['id']);
|
|
|
|
$table->add_key('usermodified', XMLDB_KEY_FOREIGN, ['usermodified'], 'user', ['id']);
|
|
|
|
|
|
|
|
// Conditionally launch create table for reportbuilder_schedule.
|
|
|
|
if (!$dbman->table_exists($table)) {
|
|
|
|
$dbman->create_table($table);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
2021-12-22 14:54:03 +01:00
|
|
|
upgrade_main_savepoint(true, 2021122100.02);
|
2021-11-04 09:21:30 +00:00
|
|
|
}
|
|
|
|
|
2021-12-21 18:08:05 +01:00
|
|
|
if ($oldversion < 2021123000.01) {
|
|
|
|
// The tool_admin_presets tables have been moved to core, because core_adminpresets component has been created, so
|
|
|
|
// it can interact with the rest of core.
|
|
|
|
// So the tool_admin_presetsXXX tables will be renamed to adminipresetsXXX if they exists; otherwise, they will be created.
|
|
|
|
|
|
|
|
$tooltable = new xmldb_table('tool_admin_presets');
|
|
|
|
$table = new xmldb_table('adminpresets');
|
|
|
|
if ($dbman->table_exists($tooltable)) {
|
|
|
|
$dbman->rename_table($tooltable, 'adminpresets');
|
|
|
|
} else if (!$dbman->table_exists($table)) {
|
|
|
|
// Adding fields to table adminpresets.
|
|
|
|
$table->add_field('id', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, XMLDB_SEQUENCE, null);
|
|
|
|
$table->add_field('userid', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('name', XMLDB_TYPE_CHAR, '255', null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('comments', XMLDB_TYPE_TEXT, null, null, null, null, null);
|
|
|
|
$table->add_field('site', XMLDB_TYPE_CHAR, '255', null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('author', XMLDB_TYPE_CHAR, '255', null, null, null, null);
|
|
|
|
$table->add_field('moodleversion', XMLDB_TYPE_CHAR, '20', null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('moodlerelease', XMLDB_TYPE_CHAR, '255', null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('iscore', XMLDB_TYPE_INTEGER, '1', null, XMLDB_NOTNULL, null, '0');
|
|
|
|
$table->add_field('timecreated', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, '0');
|
|
|
|
$table->add_field('timeimported', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, '0');
|
|
|
|
|
|
|
|
// Adding keys to table adminpresets.
|
|
|
|
$table->add_key('primary', XMLDB_KEY_PRIMARY, ['id']);
|
|
|
|
|
|
|
|
// Launch create table for adminpresets.
|
|
|
|
$dbman->create_table($table);
|
|
|
|
}
|
|
|
|
|
|
|
|
$tooltable = new xmldb_table('tool_admin_presets_it');
|
|
|
|
$table = new xmldb_table('adminpresets_it');
|
|
|
|
if ($dbman->table_exists($tooltable)) {
|
|
|
|
$dbman->rename_table($tooltable, 'adminpresets_it');
|
|
|
|
} else if (!$dbman->table_exists($table)) {
|
|
|
|
// Adding fields to table adminpresets_it.
|
|
|
|
$table->add_field('id', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, XMLDB_SEQUENCE, null);
|
|
|
|
$table->add_field('adminpresetid', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('plugin', XMLDB_TYPE_CHAR, '100', null, null, null, null);
|
|
|
|
$table->add_field('name', XMLDB_TYPE_CHAR, '100', null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('value', XMLDB_TYPE_TEXT, null, null, null, null, null);
|
|
|
|
|
|
|
|
// Adding keys to table adminpresets_it.
|
|
|
|
$table->add_key('primary', XMLDB_KEY_PRIMARY, ['id']);
|
|
|
|
|
|
|
|
// Adding indexes to table adminpresets_it.
|
|
|
|
$table->add_index('adminpresetid', XMLDB_INDEX_NOTUNIQUE, ['adminpresetid']);
|
|
|
|
|
|
|
|
// Launch create table for adminpresets_it.
|
|
|
|
$dbman->create_table($table);
|
|
|
|
}
|
|
|
|
|
|
|
|
$tooltable = new xmldb_table('tool_admin_presets_it_a');
|
|
|
|
$table = new xmldb_table('adminpresets_it_a');
|
|
|
|
if ($dbman->table_exists($tooltable)) {
|
|
|
|
$dbman->rename_table($tooltable, 'adminpresets_it_a');
|
|
|
|
} else if (!$dbman->table_exists($table)) {
|
|
|
|
// Adding fields to table adminpresets_it_a.
|
|
|
|
$table->add_field('id', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, XMLDB_SEQUENCE, null);
|
|
|
|
$table->add_field('itemid', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('name', XMLDB_TYPE_CHAR, '100', null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('value', XMLDB_TYPE_TEXT, null, null, null, null, null);
|
|
|
|
|
|
|
|
// Adding keys to table adminpresets_it_a.
|
|
|
|
$table->add_key('primary', XMLDB_KEY_PRIMARY, ['id']);
|
|
|
|
|
|
|
|
// Adding indexes to table adminpresets_it_a.
|
|
|
|
$table->add_index('itemid', XMLDB_INDEX_NOTUNIQUE, ['itemid']);
|
|
|
|
|
|
|
|
// Launch create table for adminpresets_it_a.
|
|
|
|
$dbman->create_table($table);
|
|
|
|
}
|
|
|
|
|
|
|
|
$tooltable = new xmldb_table('tool_admin_presets_app');
|
|
|
|
$table = new xmldb_table('adminpresets_app');
|
|
|
|
if ($dbman->table_exists($tooltable)) {
|
|
|
|
$dbman->rename_table($tooltable, 'adminpresets_app');
|
|
|
|
} else if (!$dbman->table_exists($table)) {
|
|
|
|
// Adding fields to table adminpresets_app.
|
|
|
|
$table->add_field('id', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, XMLDB_SEQUENCE, null);
|
|
|
|
$table->add_field('adminpresetid', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('userid', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('time', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, null);
|
|
|
|
|
|
|
|
// Adding keys to table adminpresets_app.
|
|
|
|
$table->add_key('primary', XMLDB_KEY_PRIMARY, ['id']);
|
|
|
|
|
|
|
|
// Adding indexes to table adminpresets_app.
|
|
|
|
$table->add_index('adminpresetid', XMLDB_INDEX_NOTUNIQUE, ['adminpresetid']);
|
|
|
|
|
|
|
|
// Launch create table for adminpresets_app.
|
|
|
|
$dbman->create_table($table);
|
|
|
|
}
|
|
|
|
|
|
|
|
$tooltable = new xmldb_table('tool_admin_presets_app_it');
|
|
|
|
$table = new xmldb_table('adminpresets_app_it');
|
|
|
|
if ($dbman->table_exists($tooltable)) {
|
|
|
|
$dbman->rename_table($tooltable, 'adminpresets_app_it');
|
|
|
|
} else if (!$dbman->table_exists($table)) {
|
|
|
|
// Adding fields to table adminpresets_app_it.
|
|
|
|
$table->add_field('id', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, XMLDB_SEQUENCE, null);
|
|
|
|
$table->add_field('adminpresetapplyid', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('configlogid', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, null);
|
|
|
|
|
|
|
|
// Adding keys to table adminpresets_app_it.
|
|
|
|
$table->add_key('primary', XMLDB_KEY_PRIMARY, ['id']);
|
|
|
|
|
|
|
|
// Adding indexes to table adminpresets_app_it.
|
|
|
|
$table->add_index('configlogid', XMLDB_INDEX_NOTUNIQUE, ['configlogid']);
|
|
|
|
$table->add_index('adminpresetapplyid', XMLDB_INDEX_NOTUNIQUE, ['adminpresetapplyid']);
|
|
|
|
|
|
|
|
// Launch create table for adminpresets_app_it.
|
|
|
|
$dbman->create_table($table);
|
|
|
|
}
|
|
|
|
|
|
|
|
$tooltable = new xmldb_table('tool_admin_presets_app_it_a');
|
|
|
|
$table = new xmldb_table('adminpresets_app_it_a');
|
|
|
|
if ($dbman->table_exists($tooltable)) {
|
|
|
|
$dbman->rename_table($tooltable, 'adminpresets_app_it_a');
|
|
|
|
} else if (!$dbman->table_exists($table)) {
|
|
|
|
// Adding fields to table adminpresets_app_it_a.
|
|
|
|
$table->add_field('id', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, XMLDB_SEQUENCE, null);
|
|
|
|
$table->add_field('adminpresetapplyid', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('configlogid', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('itemname', XMLDB_TYPE_CHAR, '100', null, null, null, null);
|
|
|
|
|
|
|
|
// Adding keys to table adminpresets_app_it_a.
|
|
|
|
$table->add_key('primary', XMLDB_KEY_PRIMARY, ['id']);
|
|
|
|
|
|
|
|
// Adding indexes to table adminpresets_app_it_a.
|
|
|
|
$table->add_index('configlogid', XMLDB_INDEX_NOTUNIQUE, ['configlogid']);
|
|
|
|
$table->add_index('adminpresetapplyid', XMLDB_INDEX_NOTUNIQUE, ['adminpresetapplyid']);
|
|
|
|
|
|
|
|
// Launch create table for adminpresets_app_it_a.
|
|
|
|
$dbman->create_table($table);
|
|
|
|
}
|
|
|
|
|
|
|
|
$tooltable = new xmldb_table('tool_admin_presets_plug');
|
|
|
|
$table = new xmldb_table('adminpresets_plug');
|
|
|
|
if ($dbman->table_exists($tooltable)) {
|
|
|
|
$dbman->rename_table($tooltable, 'adminpresets_plug');
|
|
|
|
} else if (!$dbman->table_exists($table)) {
|
|
|
|
// Adding fields to table adminpresets_plug.
|
|
|
|
$table->add_field('id', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, XMLDB_SEQUENCE, null);
|
|
|
|
$table->add_field('adminpresetid', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('plugin', XMLDB_TYPE_CHAR, '100', null, null, null, null);
|
|
|
|
$table->add_field('name', XMLDB_TYPE_CHAR, '100', null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('enabled', XMLDB_TYPE_INTEGER, '4', null, XMLDB_NOTNULL, null, '0');
|
|
|
|
|
|
|
|
// Adding keys to table adminpresets_plug.
|
|
|
|
$table->add_key('primary', XMLDB_KEY_PRIMARY, ['id']);
|
|
|
|
|
|
|
|
// Adding indexes to table adminpresets_plug.
|
|
|
|
$table->add_index('adminpresetid', XMLDB_INDEX_NOTUNIQUE, ['adminpresetid']);
|
|
|
|
|
|
|
|
// Launch create table for adminpresets_plug.
|
|
|
|
$dbman->create_table($table);
|
|
|
|
}
|
|
|
|
|
|
|
|
$tooltable = new xmldb_table('tool_admin_presets_app_plug');
|
|
|
|
$table = new xmldb_table('adminpresets_app_plug');
|
|
|
|
if ($dbman->table_exists($tooltable)) {
|
|
|
|
$dbman->rename_table($tooltable, 'adminpresets_app_plug');
|
|
|
|
} else if (!$dbman->table_exists($table)) {
|
|
|
|
// Adding fields to table adminpresets_app_plug.
|
|
|
|
$table->add_field('id', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, XMLDB_SEQUENCE, null);
|
|
|
|
$table->add_field('adminpresetapplyid', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('plugin', XMLDB_TYPE_CHAR, '100', null, null, null, null);
|
|
|
|
$table->add_field('name', XMLDB_TYPE_CHAR, '100', null, XMLDB_NOTNULL, null, null);
|
|
|
|
$table->add_field('value', XMLDB_TYPE_INTEGER, '4', null, XMLDB_NOTNULL, null, '0');
|
|
|
|
$table->add_field('oldvalue', XMLDB_TYPE_INTEGER, '4', null, XMLDB_NOTNULL, null, '0');
|
|
|
|
|
|
|
|
// Adding keys to table adminpresets_app_plug.
|
|
|
|
$table->add_key('primary', XMLDB_KEY_PRIMARY, ['id']);
|
|
|
|
|
|
|
|
// Adding indexes to table adminpresets_app_plug.
|
|
|
|
$table->add_index('adminpresetapplyid', XMLDB_INDEX_NOTUNIQUE, ['adminpresetapplyid']);
|
|
|
|
|
|
|
|
// Launch create table for adminpresets_app_plug.
|
|
|
|
if (!$dbman->table_exists($table)) {
|
|
|
|
$dbman->create_table($table);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($DB->count_records('adminpresets', ['iscore' => 1]) == 0) {
|
|
|
|
// Create default core site admin presets.
|
2022-02-02 10:40:40 +08:00
|
|
|
require_once($CFG->dirroot . '/admin/presets/classes/helper.php');
|
2021-12-21 18:08:05 +01:00
|
|
|
\core_adminpresets\helper::create_default_presets();
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2021123000.01);
|
|
|
|
}
|
|
|
|
|
2021-12-23 12:10:00 +01:00
|
|
|
if ($oldversion < 2021123000.02) {
|
|
|
|
// If exists, migrate sensiblesettings admin settings from tool_admin_preset to adminpresets.
|
|
|
|
if (get_config('tool_admin_presets', 'sensiblesettings') !== false) {
|
|
|
|
set_config('sensiblesettings', get_config('tool_admin_presets', 'sensiblesettings'), 'adminpresets');
|
|
|
|
unset_config('sensiblesettings', 'tool_admin_presets');
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2021123000.02);
|
|
|
|
}
|
|
|
|
|
2021-12-30 13:40:49 +01:00
|
|
|
if ($oldversion < 2021123000.03) {
|
|
|
|
// If exists, migrate lastpresetapplied setting from tool_admin_preset to adminpresets.
|
|
|
|
if (get_config('tool_admin_presets', 'lastpresetapplied') !== false) {
|
|
|
|
set_config('lastpresetapplied', get_config('tool_admin_presets', 'lastpresetapplied'), 'adminpresets');
|
|
|
|
unset_config('lastpresetapplied', 'tool_admin_presets');
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2021123000.03);
|
|
|
|
}
|
|
|
|
|
2021-12-17 08:16:10 +01:00
|
|
|
if ($oldversion < 2022011100.01) {
|
|
|
|
// The following blocks have been hidden by default, so they shouldn't be enabled in the Full core preset: Course/site
|
|
|
|
// summary, RSS feeds, Self completion and Feedback.
|
2022-03-02 13:45:15 +01:00
|
|
|
$params = ['name' => get_string('fullpreset', 'core_adminpresets')];
|
|
|
|
$fullpreset = $DB->get_record_select('adminpresets', 'name = :name and iscore > 0', $params);
|
2021-12-17 08:16:10 +01:00
|
|
|
|
2022-03-01 17:44:30 +01:00
|
|
|
if (!$fullpreset) {
|
|
|
|
// Full admin preset might have been created using the English name.
|
|
|
|
$name = get_string_manager()->get_string('fullpreset', 'core_adminpresets', null, 'en');
|
|
|
|
$params['name'] = $name;
|
2022-03-02 13:45:15 +01:00
|
|
|
$fullpreset = $DB->get_record_select('adminpresets', 'name = :name and iscore > 0', $params);
|
2022-03-01 17:44:30 +01:00
|
|
|
}
|
|
|
|
if (!$fullpreset) {
|
|
|
|
// We tried, but we didn't find full by name. Let's find a core preset that sets 'usecomments' setting to 1.
|
|
|
|
$sql = "SELECT preset.*
|
|
|
|
FROM {adminpresets} preset
|
|
|
|
INNER JOIN {adminpresets_it} it ON preset.id = it.adminpresetid
|
2022-03-02 13:45:15 +01:00
|
|
|
WHERE it.name = :name AND it.value = :value AND preset.iscore > 0";
|
2022-03-01 17:44:30 +01:00
|
|
|
$params = ['name' => 'usecomments', 'value' => '1'];
|
|
|
|
$fullpreset = $DB->get_record_sql($sql, $params);
|
|
|
|
}
|
|
|
|
|
2021-12-17 08:16:10 +01:00
|
|
|
if ($fullpreset) {
|
|
|
|
$blocknames = ['course_summary', 'feedback', 'rss_client', 'selfcompletion'];
|
|
|
|
list($blocksinsql, $blocksinparams) = $DB->get_in_or_equal($blocknames);
|
|
|
|
|
|
|
|
// Remove entries from the adminpresets_app_plug table (in case the preset has been applied).
|
|
|
|
$appliedpresets = $DB->get_records('adminpresets_app', ['adminpresetid' => $fullpreset->id], '', 'id');
|
|
|
|
if ($appliedpresets) {
|
|
|
|
list($appsinsql, $appsinparams) = $DB->get_in_or_equal(array_keys($appliedpresets));
|
|
|
|
$sql = "adminpresetapplyid $appsinsql AND plugin='block' AND name $blocksinsql";
|
|
|
|
$params = array_merge($appsinparams, $blocksinparams);
|
|
|
|
$DB->delete_records_select('adminpresets_app_plug', $sql, $params);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Remove entries for these blocks from the adminpresets_plug table.
|
|
|
|
$sql = "adminpresetid = ? AND plugin='block' AND name $blocksinsql";
|
|
|
|
$params = array_merge([$fullpreset->id], $blocksinparams);
|
|
|
|
$DB->delete_records_select('adminpresets_plug', $sql, $params);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2022011100.01);
|
|
|
|
}
|
|
|
|
|
2022-01-27 16:41:19 +02:00
|
|
|
if ($oldversion < 2022012100.02) {
|
2022-01-25 16:01:10 +01:00
|
|
|
// Migrate default message output config.
|
|
|
|
$preferences = get_config('message');
|
|
|
|
|
|
|
|
$treatedprefs = [];
|
|
|
|
|
|
|
|
foreach ($preferences as $preference => $value) {
|
|
|
|
// Extract provider and preference name from the setting name.
|
|
|
|
// Example name: airnotifier_provider_enrol_imsenterprise_imsenterprise_enrolment_permitted
|
|
|
|
// Provider: airnotifier
|
|
|
|
// Preference: enrol_imsenterprise_imsenterprise_enrolment_permitted.
|
|
|
|
$providerparts = explode('_provider_', $preference);
|
|
|
|
if (count($providerparts) <= 1) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
$provider = $providerparts[0];
|
|
|
|
$preference = $providerparts[1];
|
|
|
|
|
|
|
|
// Extract and remove last part of the preference previously extracted: ie. permitted.
|
|
|
|
$parts = explode('_', $preference);
|
|
|
|
$key = array_pop($parts);
|
|
|
|
|
|
|
|
if (in_array($key, ['permitted', 'loggedin', 'loggedoff'])) {
|
|
|
|
if ($key == 'permitted') {
|
|
|
|
// We will use provider name instead of permitted.
|
|
|
|
$key = $provider;
|
|
|
|
} else {
|
|
|
|
// Logged in and logged off values are a csv of the enabled providers.
|
|
|
|
$value = explode(',', $value);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Join the rest of the parts: ie enrol_imsenterprise_imsenterprise_enrolment.
|
|
|
|
$prefname = implode('_', $parts);
|
|
|
|
|
|
|
|
if (!isset($treatedprefs[$prefname])) {
|
|
|
|
$treatedprefs[$prefname] = [];
|
|
|
|
}
|
|
|
|
|
|
|
|
// Save the value with the selected key.
|
|
|
|
$treatedprefs[$prefname][$key] = $value;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Now take every preference previous treated and its values.
|
|
|
|
foreach ($treatedprefs as $prefname => $values) {
|
|
|
|
$enabled = []; // List of providers enabled for each preference.
|
|
|
|
|
|
|
|
// Enable if one of those is enabled.
|
|
|
|
$loggedin = isset($values['loggedin']) ? $values['loggedin'] : [];
|
|
|
|
foreach ($loggedin as $provider) {
|
|
|
|
$enabled[$provider] = 1;
|
|
|
|
}
|
|
|
|
$loggedoff = isset($values['loggedoff']) ? $values['loggedoff'] : [];
|
|
|
|
foreach ($loggedoff as $provider) {
|
|
|
|
$enabled[$provider] = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Do not treat those values again.
|
|
|
|
unset($values['loggedin']);
|
|
|
|
unset($values['loggedoff']);
|
|
|
|
|
|
|
|
// Translate rest of values coming from permitted "key".
|
|
|
|
foreach ($values as $provider => $value) {
|
|
|
|
$locked = false;
|
|
|
|
|
|
|
|
switch ($value) {
|
|
|
|
case 'forced':
|
|
|
|
// Provider is enabled by force.
|
|
|
|
$enabled[$provider] = 1;
|
|
|
|
$locked = true;
|
|
|
|
break;
|
|
|
|
case 'disallowed':
|
|
|
|
// Provider is disabled by force.
|
|
|
|
unset($enabled[$provider]);
|
|
|
|
$locked = true;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
// Provider is not forced (permitted) or invalid values.
|
|
|
|
}
|
|
|
|
|
|
|
|
// Save locked.
|
|
|
|
if ($locked) {
|
|
|
|
set_config($provider.'_provider_'.$prefname.'_locked', 1, 'message');
|
2022-02-23 09:27:25 +01:00
|
|
|
} else {
|
|
|
|
set_config($provider.'_provider_'.$prefname.'_locked', 0, 'message');
|
2022-01-25 16:01:10 +01:00
|
|
|
}
|
|
|
|
// Remove old value.
|
|
|
|
unset_config($provider.'_provider_'.$prefname.'_permitted', 'message');
|
|
|
|
}
|
|
|
|
|
|
|
|
// Save the new values.
|
|
|
|
$value = implode(',', array_keys($enabled));
|
|
|
|
set_config('message_provider_'.$prefname.'_enabled', $value, 'message');
|
|
|
|
// Remove old values.
|
|
|
|
unset_config('message_provider_'.$prefname.'_loggedin', 'message');
|
|
|
|
unset_config('message_provider_'.$prefname.'_loggedoff', 'message');
|
|
|
|
}
|
|
|
|
|
|
|
|
// Migrate user preferences. ie merging message_provider_moodle_instantmessage_loggedoff with
|
|
|
|
// message_provider_moodle_instantmessage_loggedin to message_provider_moodle_instantmessage_enabled.
|
|
|
|
|
|
|
|
$allrecordsloggedoff = $DB->sql_like('name', ':loggedoff');
|
|
|
|
$total = $DB->count_records_select(
|
|
|
|
'user_preferences',
|
|
|
|
$allrecordsloggedoff,
|
|
|
|
['loggedoff' => 'message_provider_%_loggedoff']
|
|
|
|
);
|
|
|
|
$i = 0;
|
|
|
|
if ($total == 0) {
|
|
|
|
$total = 1; // Avoid division by zero.
|
|
|
|
}
|
|
|
|
|
|
|
|
// Show a progress bar.
|
|
|
|
$pbar = new progress_bar('upgradeusernotificationpreferences', 500, true);
|
|
|
|
$pbar->update($i, $total, "Upgrading user notifications preferences - $i/$total.");
|
|
|
|
|
|
|
|
// We're migrating provider per provider to reduce memory usage.
|
|
|
|
$providers = $DB->get_records('message_providers', null, 'name');
|
|
|
|
foreach ($providers as $provider) {
|
|
|
|
// 60 minutes to migrate each provider.
|
|
|
|
upgrade_set_timeout(3600);
|
|
|
|
$componentproviderbase = 'message_provider_'.$provider->component.'_'.$provider->name;
|
|
|
|
|
|
|
|
$loggedinname = $componentproviderbase.'_loggedin';
|
|
|
|
$loggedoffname = $componentproviderbase.'_loggedoff';
|
|
|
|
|
|
|
|
// Change loggedin to enabled.
|
|
|
|
$enabledname = $componentproviderbase.'_enabled';
|
|
|
|
$DB->set_field('user_preferences', 'name', $enabledname, ['name' => $loggedinname]);
|
|
|
|
|
|
|
|
$selectparams = [
|
|
|
|
'enabled' => $enabledname,
|
|
|
|
'loggedoff' => $loggedoffname,
|
|
|
|
];
|
|
|
|
$sql = 'SELECT m1.id loggedoffid, m1.value as loggedoff, m2.value as enabled, m2.id as enabledid
|
|
|
|
FROM
|
|
|
|
(SELECT id, userid, value FROM {user_preferences} WHERE name = :loggedoff) m1
|
|
|
|
LEFT JOIN
|
|
|
|
(SELECT id, userid, value FROM {user_preferences} WHERE name = :enabled) m2
|
|
|
|
ON m1.userid = m2.userid';
|
|
|
|
|
|
|
|
while (($rs = $DB->get_recordset_sql($sql, $selectparams, 0, 1000)) && $rs->valid()) {
|
|
|
|
// 10 minutes for every chunk.
|
|
|
|
upgrade_set_timeout(600);
|
|
|
|
|
|
|
|
$deleterecords = [];
|
|
|
|
$changename = [];
|
|
|
|
$changevalue = []; // Multidimensional array with possible values as key to reduce SQL queries.
|
|
|
|
foreach ($rs as $record) {
|
|
|
|
if (empty($record->enabledid)) {
|
|
|
|
// Enabled does not exists, change the name.
|
|
|
|
$changename[] = $record->loggedoffid;
|
|
|
|
} else if ($record->enabledid != $record->loggedoff) {
|
|
|
|
// Exist and values differ (checked on SQL), update the enabled record.
|
|
|
|
|
|
|
|
if ($record->enabled != 'none' && !empty($record->enabled)) {
|
|
|
|
$enabledvalues = explode(',', $record->enabled);
|
|
|
|
} else {
|
|
|
|
$enabledvalues = [];
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($record->loggedoff != 'none' && !empty($record->loggedoff)) {
|
|
|
|
$loggedoffvalues = explode(',', $record->loggedoff);
|
|
|
|
} else {
|
|
|
|
$loggedoffvalues = [];
|
|
|
|
}
|
|
|
|
|
|
|
|
$values = array_unique(array_merge($enabledvalues, $loggedoffvalues));
|
|
|
|
sort($values);
|
|
|
|
|
|
|
|
$newvalue = empty($values) ? 'none' : implode(',', $values);
|
|
|
|
if (!isset($changevalue[$newvalue])) {
|
|
|
|
$changevalue[$newvalue] = [];
|
|
|
|
}
|
|
|
|
$changevalue[$newvalue][] = $record->enabledid;
|
|
|
|
|
|
|
|
$deleterecords[] = $record->loggedoffid;
|
|
|
|
} else {
|
|
|
|
// They are the same, just delete loggedoff one.
|
|
|
|
$deleterecords[] = $record->loggedoffid;
|
|
|
|
}
|
|
|
|
$i++;
|
|
|
|
}
|
|
|
|
$rs->close();
|
|
|
|
|
|
|
|
// Commit the changes.
|
|
|
|
if (!empty($changename)) {
|
|
|
|
$changenameparams = [
|
|
|
|
'name' => $loggedoffname,
|
|
|
|
];
|
|
|
|
$changenameselect = 'name = :name AND id IN (' . implode(',', $changename) . ')';
|
|
|
|
$DB->set_field_select('user_preferences', 'name', $enabledname, $changenameselect, $changenameparams);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!empty($changevalue)) {
|
|
|
|
$changevalueparams = [
|
|
|
|
'name' => $enabledname,
|
|
|
|
];
|
|
|
|
foreach ($changevalue as $value => $ids) {
|
|
|
|
$changevalueselect = 'name = :name AND id IN (' . implode(',', $ids) . ')';
|
|
|
|
$DB->set_field_select('user_preferences', 'value', $value, $changevalueselect, $changevalueparams);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!empty($deleterecords)) {
|
|
|
|
$deleteparams = [
|
|
|
|
'name' => $loggedoffname,
|
|
|
|
];
|
|
|
|
$deleteselect = 'name = :name AND id IN (' . implode(',', $deleterecords) . ')';
|
|
|
|
$DB->delete_records_select('user_preferences', $deleteselect, $deleteparams);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Update progress.
|
|
|
|
$pbar->update($i, $total, "Upgrading user notifications preferences - $i/$total.");
|
|
|
|
}
|
|
|
|
$rs->close();
|
|
|
|
|
|
|
|
// Delete the rest of loggedoff values (that are equal than enabled).
|
|
|
|
$deleteparams = [
|
|
|
|
'name' => $loggedoffname,
|
|
|
|
];
|
|
|
|
$deleteselect = 'name = :name';
|
|
|
|
$i += $DB->count_records_select('user_preferences', $deleteselect, $deleteparams);
|
|
|
|
$DB->delete_records_select('user_preferences', $deleteselect, $deleteparams);
|
|
|
|
|
|
|
|
// Update progress.
|
|
|
|
$pbar->update($i, $total, "Upgrading user notifications preferences - $i/$total.");
|
|
|
|
}
|
|
|
|
|
|
|
|
core_plugin_manager::reset_caches();
|
|
|
|
|
|
|
|
// Delete the orphan records.
|
|
|
|
$allrecordsparams = ['loggedin' => 'message_provider_%_loggedin', 'loggedoff' => 'message_provider_%_loggedoff'];
|
|
|
|
$allrecordsloggedin = $DB->sql_like('name', ':loggedin');
|
|
|
|
$allrecordsloggedinoffsql = "$allrecordsloggedin OR $allrecordsloggedoff";
|
|
|
|
$DB->delete_records_select('user_preferences', $allrecordsloggedinoffsql, $allrecordsparams);
|
|
|
|
|
|
|
|
// Update progress.
|
|
|
|
$pbar->update($total, $total, "Upgrading user notifications preferences - $total/$total.");
|
|
|
|
|
2022-01-27 16:41:19 +02:00
|
|
|
upgrade_main_savepoint(true, 2022012100.02);
|
2022-01-25 16:01:10 +01:00
|
|
|
}
|
|
|
|
|
2021-06-02 19:16:18 +10:00
|
|
|
// Introduce question versioning to core.
|
|
|
|
// First, create the new tables.
|
|
|
|
if ($oldversion < 2022020200.01) {
|
|
|
|
// Define table question_bank_entries to be created.
|
|
|
|
$table = new xmldb_table('question_bank_entries');
|
|
|
|
|
|
|
|
// Adding fields to table question_bank_entries.
|
|
|
|
$table->add_field('id', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, XMLDB_SEQUENCE, null);
|
|
|
|
$table->add_field('questioncategoryid', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, 0);
|
|
|
|
$table->add_field('idnumber', XMLDB_TYPE_CHAR, '100', null, null, null, null);
|
|
|
|
$table->add_field('ownerid', XMLDB_TYPE_INTEGER, '10', null, null, null, null);
|
|
|
|
|
|
|
|
// Adding keys to table question_bank_entries.
|
|
|
|
$table->add_key('primary', XMLDB_KEY_PRIMARY, ['id']);
|
|
|
|
$table->add_key('questioncategoryid', XMLDB_KEY_FOREIGN, ['questioncategoryid'], 'question_categories', ['id']);
|
|
|
|
$table->add_key('ownerid', XMLDB_KEY_FOREIGN, ['ownerid'], 'user', ['id']);
|
|
|
|
|
|
|
|
// Conditionally launch create table for question_bank_entries.
|
|
|
|
if (!$dbman->table_exists($table)) {
|
|
|
|
$dbman->create_table($table);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Create category id and id number index.
|
|
|
|
$index = new xmldb_index('categoryidnumber', XMLDB_INDEX_UNIQUE, ['questioncategoryid', 'idnumber']);
|
|
|
|
|
|
|
|
// Conditionally launch add index categoryidnumber.
|
|
|
|
if (!$dbman->index_exists($table, $index)) {
|
|
|
|
$dbman->add_index($table, $index);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Define table question_versions to be created.
|
|
|
|
$table = new xmldb_table('question_versions');
|
|
|
|
|
|
|
|
// Adding fields to table question_versions.
|
|
|
|
$table->add_field('id', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, XMLDB_SEQUENCE, null);
|
2022-02-03 15:10:01 +01:00
|
|
|
$table->add_field('questionbankentryid', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, 0);
|
2021-06-02 19:16:18 +10:00
|
|
|
$table->add_field('version', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, 1);
|
|
|
|
$table->add_field('questionid', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, 0);
|
|
|
|
$table->add_field('status', XMLDB_TYPE_CHAR, '10', null, XMLDB_NOTNULL, null, 'ready');
|
|
|
|
|
|
|
|
// Adding keys to table question_versions.
|
|
|
|
$table->add_key('primary', XMLDB_KEY_PRIMARY, ['id']);
|
|
|
|
$table->add_key('questionbankentryid', XMLDB_KEY_FOREIGN, ['questionbankentryid'], 'question_bank_entries', ['id']);
|
|
|
|
$table->add_key('questionid', XMLDB_KEY_FOREIGN, ['questionid'], 'question', ['id']);
|
|
|
|
|
|
|
|
// Conditionally launch create table for question_versions.
|
|
|
|
if (!$dbman->table_exists($table)) {
|
|
|
|
$dbman->create_table($table);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Define table question_references to be created.
|
|
|
|
$table = new xmldb_table('question_references');
|
|
|
|
|
|
|
|
// Adding fields to table question_references.
|
|
|
|
$table->add_field('id', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, XMLDB_SEQUENCE, null);
|
|
|
|
$table->add_field('usingcontextid', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, 0);
|
|
|
|
$table->add_field('component', XMLDB_TYPE_CHAR, '100', null, null, null, null);
|
|
|
|
$table->add_field('questionarea', XMLDB_TYPE_CHAR, '50', null, null, null, null);
|
2022-02-03 15:10:01 +01:00
|
|
|
$table->add_field('itemid', XMLDB_TYPE_INTEGER, '10', null, null, null, null);
|
|
|
|
$table->add_field('questionbankentryid', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, 0);
|
2021-06-02 19:16:18 +10:00
|
|
|
$table->add_field('version', XMLDB_TYPE_INTEGER, '10', null, null, null, null);
|
|
|
|
|
|
|
|
// Adding keys to table question_references.
|
|
|
|
$table->add_key('primary', XMLDB_KEY_PRIMARY, ['id']);
|
|
|
|
$table->add_key('usingcontextid', XMLDB_KEY_FOREIGN, ['usingcontextid'], 'context', ['id']);
|
|
|
|
$table->add_key('questionbankentryid', XMLDB_KEY_FOREIGN, ['questionbankentryid'], 'question_bank_entries', ['id']);
|
|
|
|
|
|
|
|
// Conditionally launch create table for question_references.
|
|
|
|
if (!$dbman->table_exists($table)) {
|
|
|
|
$dbman->create_table($table);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Define table question_set_references to be created.
|
|
|
|
$table = new xmldb_table('question_set_references');
|
|
|
|
|
|
|
|
// Adding fields to table question_set_references.
|
|
|
|
$table->add_field('id', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, XMLDB_SEQUENCE, null);
|
|
|
|
$table->add_field('usingcontextid', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, 0);
|
|
|
|
$table->add_field('component', XMLDB_TYPE_CHAR, '100', null, null, null, null);
|
|
|
|
$table->add_field('questionarea', XMLDB_TYPE_CHAR, '50', null, null, null, null);
|
2022-02-03 15:10:01 +01:00
|
|
|
$table->add_field('itemid', XMLDB_TYPE_INTEGER, '10', null, null, null, null);
|
2021-06-02 19:16:18 +10:00
|
|
|
$table->add_field('questionscontextid', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, 0);
|
|
|
|
$table->add_field('filtercondition', XMLDB_TYPE_TEXT, null, null, null, null, null);
|
|
|
|
|
|
|
|
// Adding keys to table question_set_references.
|
|
|
|
$table->add_key('primary', XMLDB_KEY_PRIMARY, ['id']);
|
|
|
|
$table->add_key('usingcontextid', XMLDB_KEY_FOREIGN, ['usingcontextid'], 'context', ['id']);
|
|
|
|
$table->add_key('questionscontextid', XMLDB_KEY_FOREIGN, ['questionscontextid'], 'context', ['id']);
|
|
|
|
|
|
|
|
// Conditionally launch create table for question_set_references.
|
|
|
|
if (!$dbman->table_exists($table)) {
|
|
|
|
$dbman->create_table($table);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2022020200.01);
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($oldversion < 2022020200.02) {
|
2022-02-11 17:01:18 +11:00
|
|
|
// Define a new temporary field in the question_bank_entries tables.
|
|
|
|
// Creating temporary field questionid to populate the data in question version table.
|
|
|
|
// This will make sure the appropriate question id is inserted the version table without making any complex joins.
|
|
|
|
$table = new xmldb_table('question_bank_entries');
|
2023-01-09 17:21:52 +00:00
|
|
|
$field = new xmldb_field('questionid', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL);
|
2022-02-11 17:01:18 +11:00
|
|
|
if (!$dbman->field_exists($table, $field)) {
|
|
|
|
$dbman->add_field($table, $field);
|
|
|
|
}
|
|
|
|
|
|
|
|
$transaction = $DB->start_delegated_transaction();
|
|
|
|
upgrade_set_timeout(3600);
|
|
|
|
// Create the data for the question_bank_entries table with, including the new temporary field.
|
|
|
|
$sql = <<<EOF
|
|
|
|
INSERT INTO {question_bank_entries}
|
|
|
|
(questionid, questioncategoryid, idnumber, ownerid)
|
|
|
|
SELECT id, category, idnumber, createdby
|
|
|
|
FROM {question} q
|
|
|
|
EOF;
|
|
|
|
|
|
|
|
// Inserting question_bank_entries data.
|
|
|
|
$DB->execute($sql);
|
|
|
|
|
|
|
|
$transaction->allow_commit();
|
|
|
|
|
2021-06-02 19:16:18 +10:00
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2022020200.02);
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($oldversion < 2022020200.03) {
|
2022-02-11 17:01:18 +11:00
|
|
|
$transaction = $DB->start_delegated_transaction();
|
|
|
|
upgrade_set_timeout(3600);
|
|
|
|
// Create the question_versions using that temporary field.
|
|
|
|
$sql = <<<EOF
|
|
|
|
INSERT INTO {question_versions}
|
|
|
|
(questionbankentryid, questionid, status)
|
|
|
|
SELECT
|
|
|
|
qbe.id,
|
|
|
|
q.id,
|
|
|
|
CASE
|
|
|
|
WHEN q.hidden > 0 THEN 'hidden'
|
|
|
|
ELSE 'ready'
|
|
|
|
END
|
|
|
|
FROM {question_bank_entries} qbe
|
|
|
|
INNER JOIN {question} q ON qbe.questionid = q.id
|
|
|
|
EOF;
|
|
|
|
|
|
|
|
// Inserting question_versions data.
|
|
|
|
$DB->execute($sql);
|
|
|
|
|
|
|
|
$transaction->allow_commit();
|
|
|
|
|
|
|
|
// Dropping temporary field questionid.
|
|
|
|
$table = new xmldb_table('question_bank_entries');
|
2023-01-09 17:21:52 +00:00
|
|
|
$field = new xmldb_field('questionid', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL);
|
2022-02-11 17:01:18 +11:00
|
|
|
if ($dbman->field_exists($table, $field)) {
|
|
|
|
$dbman->drop_field($table, $field);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2022020200.03);
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($oldversion < 2022020200.04) {
|
|
|
|
$transaction = $DB->start_delegated_transaction();
|
|
|
|
upgrade_set_timeout(3600);
|
|
|
|
// Create the base data for the random questions in the set_references table.
|
|
|
|
// This covers most of the hard work in one go.
|
|
|
|
$concat = $DB->sql_concat("'{\"questioncategoryid\":\"'", 'q.category', "'\",\"includingsubcategories\":\"'",
|
|
|
|
'qs.includingsubcategories', "'\"}'");
|
|
|
|
$sql = <<<EOF
|
|
|
|
INSERT INTO {question_set_references}
|
|
|
|
(usingcontextid, component, questionarea, itemid, questionscontextid, filtercondition)
|
|
|
|
SELECT
|
|
|
|
c.id,
|
|
|
|
'mod_quiz',
|
|
|
|
'slot',
|
|
|
|
qs.id,
|
|
|
|
qc.contextid,
|
|
|
|
$concat
|
|
|
|
FROM {question} q
|
|
|
|
INNER JOIN {quiz_slots} qs on q.id = qs.questionid
|
|
|
|
INNER JOIN {course_modules} cm ON cm.instance = qs.quizid AND cm.module = :quizmoduleid
|
|
|
|
INNER JOIN {context} c ON cm.id = c.instanceid AND c.contextlevel = :contextmodule
|
|
|
|
INNER JOIN {question_categories} qc ON qc.id = q.category
|
|
|
|
WHERE q.qtype = :random
|
|
|
|
EOF;
|
|
|
|
|
|
|
|
// Inserting question_set_references data.
|
|
|
|
$DB->execute($sql, [
|
|
|
|
'quizmoduleid' => $DB->get_field('modules', 'id', ['name' => 'quiz']),
|
|
|
|
'contextmodule' => CONTEXT_MODULE,
|
|
|
|
'random' => 'random',
|
|
|
|
]);
|
|
|
|
|
|
|
|
$transaction->allow_commit();
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2022020200.04);
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($oldversion < 2022020200.05) {
|
|
|
|
$transaction = $DB->start_delegated_transaction();
|
|
|
|
upgrade_set_timeout(3600);
|
|
|
|
|
|
|
|
// Count all the slot tags to be migrated (for progress bar).
|
|
|
|
$total = $DB->count_records('quiz_slot_tags');
|
|
|
|
$pbar = new progress_bar('migratequestiontags', 1000, true);
|
|
|
|
$i = 0;
|
|
|
|
// Updating slot_tags for random question tags.
|
|
|
|
// Now fetch any quiz slot tags and update those slot details into the question_set_references.
|
|
|
|
$slottags = $DB->get_recordset('quiz_slot_tags', [], 'slotid ASC');
|
|
|
|
|
|
|
|
$tagstrings = [];
|
|
|
|
$lastslot = null;
|
|
|
|
$runinsert = function (int $lastslot, array $tagstrings) use ($DB) {
|
|
|
|
$conditiondata = $DB->get_field('question_set_references', 'filtercondition',
|
|
|
|
['itemid' => $lastslot, 'component' => 'mod_quiz', 'questionarea' => 'slot']);
|
2022-12-09 13:44:48 +11:00
|
|
|
|
|
|
|
// It is possible to have leftover tags in the database, without a corresponding
|
|
|
|
// slot, because of an old bugs (e.g. MDL-76193). Therefore, if the slot is not found,
|
|
|
|
// we can safely discard these tags.
|
|
|
|
if (!empty($conditiondata)) {
|
|
|
|
$condition = json_decode($conditiondata);
|
|
|
|
$condition->tags = $tagstrings;
|
|
|
|
$DB->set_field('question_set_references', 'filtercondition', json_encode($condition),
|
|
|
|
['itemid' => $lastslot, 'component' => 'mod_quiz', 'questionarea' => 'slot']);
|
|
|
|
}
|
2022-02-11 17:01:18 +11:00
|
|
|
};
|
|
|
|
|
|
|
|
foreach ($slottags as $tag) {
|
|
|
|
upgrade_set_timeout(3600);
|
|
|
|
if ($lastslot && $tag->slotid != $lastslot) {
|
|
|
|
if (!empty($tagstrings)) {
|
|
|
|
// Insert the data.
|
|
|
|
$runinsert($lastslot, $tagstrings);
|
|
|
|
}
|
|
|
|
// Prepare for the next slot id.
|
|
|
|
$tagstrings = [];
|
|
|
|
}
|
|
|
|
|
|
|
|
$lastslot = $tag->slotid;
|
|
|
|
$tagstrings[] = "{$tag->tagid},{$tag->tagname}";
|
|
|
|
// Update progress.
|
|
|
|
$i++;
|
|
|
|
$pbar->update($i, $total, "Migrating question tags - $i/$total.");
|
|
|
|
}
|
|
|
|
if ($tagstrings) {
|
|
|
|
$runinsert($lastslot, $tagstrings);
|
|
|
|
}
|
|
|
|
$slottags->close();
|
|
|
|
|
|
|
|
$transaction->allow_commit();
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2022020200.05);
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($oldversion < 2022020200.06) {
|
|
|
|
$transaction = $DB->start_delegated_transaction();
|
|
|
|
upgrade_set_timeout(3600);
|
|
|
|
// Create question_references record for each question.
|
|
|
|
// Except if qtype is random. That case is handled by question_set_reference.
|
|
|
|
$sql = "INSERT INTO {question_references}
|
|
|
|
(usingcontextid, component, questionarea, itemid, questionbankentryid)
|
|
|
|
SELECT c.id, 'mod_quiz', 'slot', qs.id, qv.questionbankentryid
|
|
|
|
FROM {question} q
|
|
|
|
JOIN {question_versions} qv ON q.id = qv.questionid
|
|
|
|
JOIN {quiz_slots} qs ON q.id = qs.questionid
|
|
|
|
JOIN {modules} m ON m.name = 'quiz'
|
|
|
|
JOIN {course_modules} cm ON cm.module = m.id AND cm.instance = qs.quizid
|
|
|
|
JOIN {context} c ON c.instanceid = cm.id AND c.contextlevel = " . CONTEXT_MODULE . "
|
|
|
|
WHERE q.qtype <> 'random'";
|
|
|
|
|
|
|
|
// Inserting question_references data.
|
|
|
|
$DB->execute($sql);
|
|
|
|
|
|
|
|
$transaction->allow_commit();
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2022020200.06);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Finally, drop fields from question table.
|
|
|
|
if ($oldversion < 2022020200.07) {
|
2021-06-02 19:16:18 +10:00
|
|
|
// Define fields to be dropped from questions.
|
|
|
|
$table = new xmldb_table('question');
|
|
|
|
|
|
|
|
$field = new xmldb_field('version');
|
|
|
|
// Conditionally launch drop field version.
|
|
|
|
if ($dbman->field_exists($table, $field)) {
|
|
|
|
$dbman->drop_field($table, $field);
|
|
|
|
}
|
|
|
|
|
|
|
|
$field = new xmldb_field('hidden');
|
|
|
|
// Conditionally launch drop field hidden.
|
|
|
|
if ($dbman->field_exists($table, $field)) {
|
|
|
|
$dbman->drop_field($table, $field);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Define index categoryidnumber (not unique) to be dropped form question.
|
|
|
|
$index = new xmldb_index('categoryidnumber', XMLDB_INDEX_UNIQUE, ['category', 'idnumber']);
|
|
|
|
|
|
|
|
// Conditionally launch drop index categoryidnumber.
|
|
|
|
if ($dbman->index_exists($table, $index)) {
|
|
|
|
$dbman->drop_index($table, $index);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Define key category (foreign) to be dropped form questions.
|
|
|
|
$key = new xmldb_key('category', XMLDB_KEY_FOREIGN, ['category'], 'question_categories', ['id']);
|
|
|
|
|
|
|
|
// Launch drop key category.
|
|
|
|
$dbman->drop_key($table, $key);
|
|
|
|
|
|
|
|
$field = new xmldb_field('idnumber');
|
|
|
|
// Conditionally launch drop field idnumber.
|
|
|
|
if ($dbman->field_exists($table, $field)) {
|
|
|
|
$dbman->drop_field($table, $field);
|
|
|
|
}
|
|
|
|
|
|
|
|
$field = new xmldb_field('category');
|
|
|
|
// Conditionally launch drop field category.
|
|
|
|
if ($dbman->field_exists($table, $field)) {
|
|
|
|
$dbman->drop_field($table, $field);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
2022-02-11 17:01:18 +11:00
|
|
|
upgrade_main_savepoint(true, 2022020200.07);
|
2021-06-02 19:16:18 +10:00
|
|
|
}
|
|
|
|
|
2022-02-11 13:18:05 +01:00
|
|
|
if ($oldversion < 2022021100.01) {
|
2022-03-01 17:44:30 +01:00
|
|
|
$sql = "SELECT preset.*
|
|
|
|
FROM {adminpresets} preset
|
|
|
|
INNER JOIN {adminpresets_it} it ON preset.id = it.adminpresetid
|
2022-03-02 13:45:15 +01:00
|
|
|
WHERE it.name = :name AND it.value = :value AND preset.iscore > 0";
|
2022-02-11 13:18:05 +01:00
|
|
|
// Some settings and plugins have been added/removed to the Starter and Full preset. Add them to the core presets if
|
|
|
|
// they haven't been included yet.
|
|
|
|
$params = ['name' => get_string('starterpreset', 'core_adminpresets'), 'iscore' => 1];
|
|
|
|
$starterpreset = $DB->get_record('adminpresets', $params);
|
2022-03-01 17:44:30 +01:00
|
|
|
if (!$starterpreset) {
|
|
|
|
// Starter admin preset might have been created using the English name.
|
|
|
|
$name = get_string_manager()->get_string('starterpreset', 'core_adminpresets', null, 'en');
|
|
|
|
$params['name'] = $name;
|
|
|
|
$starterpreset = $DB->get_record('adminpresets', $params);
|
|
|
|
}
|
|
|
|
if (!$starterpreset) {
|
|
|
|
// We tried, but we didn't find starter by name. Let's find a core preset that sets 'usecomments' setting to 0.
|
|
|
|
$params = ['name' => 'usecomments', 'value' => '0'];
|
|
|
|
$starterpreset = $DB->get_record_sql($sql, $params);
|
|
|
|
}
|
|
|
|
|
2022-03-02 13:45:15 +01:00
|
|
|
$params = ['name' => get_string('fullpreset', 'core_adminpresets')];
|
|
|
|
$fullpreset = $DB->get_record_select('adminpresets', 'name = :name and iscore > 0', $params);
|
2022-03-01 17:44:30 +01:00
|
|
|
if (!$fullpreset) {
|
|
|
|
// Full admin preset might have been created using the English name.
|
|
|
|
$name = get_string_manager()->get_string('fullpreset', 'core_adminpresets', null, 'en');
|
|
|
|
$params['name'] = $name;
|
2022-03-02 13:45:15 +01:00
|
|
|
$fullpreset = $DB->get_record_select('adminpresets', 'name = :name and iscore > 0', $params);
|
2022-03-01 17:44:30 +01:00
|
|
|
}
|
|
|
|
if (!$fullpreset) {
|
|
|
|
// We tried, but we didn't find full by name. Let's find a core preset that sets 'usecomments' setting to 1.
|
|
|
|
$params = ['name' => 'usecomments', 'value' => '1'];
|
|
|
|
$fullpreset = $DB->get_record_sql($sql, $params);
|
|
|
|
}
|
2022-02-11 13:18:05 +01:00
|
|
|
|
|
|
|
$settings = [
|
|
|
|
// Settings. Hide Guest login button for Starter preset (and back to show for Full).
|
|
|
|
[
|
|
|
|
'presetid' => $starterpreset->id,
|
|
|
|
'plugin' => 'none',
|
|
|
|
'name' => 'guestloginbutton',
|
|
|
|
'value' => '0',
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'presetid' => $fullpreset->id,
|
|
|
|
'plugin' => 'none',
|
|
|
|
'name' => 'guestloginbutton',
|
|
|
|
'value' => '1',
|
|
|
|
],
|
|
|
|
// Settings. Set Activity chooser tabs to "Starred, All, Recommended"(1) for Starter and back it to default(0) for Full.
|
|
|
|
[
|
|
|
|
'presetid' => $starterpreset->id,
|
|
|
|
'plugin' => 'none',
|
|
|
|
'name' => 'activitychoosertabmode',
|
|
|
|
'value' => '1',
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'presetid' => $fullpreset->id,
|
|
|
|
'plugin' => 'none',
|
|
|
|
'name' => 'activitychoosertabmode',
|
|
|
|
'value' => '0',
|
|
|
|
],
|
|
|
|
];
|
|
|
|
foreach ($settings as $notused => $setting) {
|
|
|
|
$params = ['adminpresetid' => $setting['presetid'], 'plugin' => $setting['plugin'], 'name' => $setting['name']];
|
|
|
|
if (!$DB->record_exists('adminpresets_it', $params)) {
|
|
|
|
$record = new \stdClass();
|
|
|
|
$record->adminpresetid = $setting['presetid'];
|
|
|
|
$record->plugin = $setting['plugin'];
|
|
|
|
$record->name = $setting['name'];
|
|
|
|
$record->value = $setting['value'];
|
|
|
|
$DB->insert_record('adminpresets_it', $record);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$plugins = [
|
|
|
|
// Plugins. Blocks. Disable/enable Online users, Recently accessed courses and Starred courses.
|
|
|
|
[
|
|
|
|
'presetid' => $starterpreset->id,
|
|
|
|
'plugin' => 'block',
|
|
|
|
'name' => 'online_users',
|
|
|
|
'enabled' => '0',
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'presetid' => $fullpreset->id,
|
|
|
|
'plugin' => 'block',
|
|
|
|
'name' => 'online_users',
|
|
|
|
'enabled' => '1',
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'presetid' => $starterpreset->id,
|
|
|
|
'plugin' => 'block',
|
|
|
|
'name' => 'recentlyaccessedcourses',
|
|
|
|
'enabled' => '0',
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'presetid' => $fullpreset->id,
|
|
|
|
'plugin' => 'block',
|
|
|
|
'name' => 'recentlyaccessedcourses',
|
|
|
|
'enabled' => '1',
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'presetid' => $starterpreset->id,
|
|
|
|
'plugin' => 'block',
|
|
|
|
'name' => 'starredcourses',
|
|
|
|
'enabled' => '0',
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'presetid' => $fullpreset->id,
|
|
|
|
'plugin' => 'block',
|
|
|
|
'name' => 'starredcourses',
|
|
|
|
'enabled' => '1',
|
|
|
|
],
|
|
|
|
// Plugins. Enrolments. Disable/enable Guest access.
|
|
|
|
[
|
|
|
|
'presetid' => $starterpreset->id,
|
|
|
|
'plugin' => 'enrol',
|
|
|
|
'name' => 'guest',
|
|
|
|
'enabled' => '0',
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'presetid' => $fullpreset->id,
|
|
|
|
'plugin' => 'enrol',
|
|
|
|
'name' => 'guest',
|
|
|
|
'enabled' => '1',
|
|
|
|
],
|
|
|
|
];
|
|
|
|
foreach ($plugins as $notused => $plugin) {
|
|
|
|
$params = ['adminpresetid' => $plugin['presetid'], 'plugin' => $plugin['plugin'], 'name' => $plugin['name']];
|
|
|
|
if (!$DB->record_exists('adminpresets_plug', $params)) {
|
|
|
|
$record = new \stdClass();
|
|
|
|
$record->adminpresetid = $plugin['presetid'];
|
|
|
|
$record->plugin = $plugin['plugin'];
|
|
|
|
$record->name = $plugin['name'];
|
|
|
|
$record->enabled = $plugin['enabled'];
|
|
|
|
$DB->insert_record('adminpresets_plug', $record);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Settings: Remove customusermenuitems setting from Starter and Full presets.
|
|
|
|
$sql = "(adminpresetid = ? OR adminpresetid = ?) AND plugin = 'none' AND name = 'customusermenuitems'";
|
|
|
|
$params = [$starterpreset->id, $fullpreset->id];
|
|
|
|
$DB->delete_records_select('adminpresets_it', $sql, $params);
|
|
|
|
|
|
|
|
// Plugins. Question types. Re-enable Description and Essay for Starter.
|
|
|
|
$sql = "(adminpresetid = ? OR adminpresetid = ?) AND plugin = 'qtype' AND (name = 'description' OR name = 'essay')";
|
|
|
|
$DB->delete_records_select('adminpresets_plug', $sql, $params);
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2022021100.01);
|
2022-02-17 15:02:01 +02:00
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($oldversion < 2022021100.02) {
|
2021-04-20 20:32:54 +02:00
|
|
|
$table = new xmldb_table('task_scheduled');
|
|
|
|
|
|
|
|
// Changing precision of field minute on table task_scheduled to (200).
|
|
|
|
$field = new xmldb_field('minute', XMLDB_TYPE_CHAR, '200', null, XMLDB_NOTNULL, null, null, 'blocking');
|
|
|
|
$dbman->change_field_precision($table, $field);
|
|
|
|
// Changing precision of field hour on table task_scheduled to (70).
|
|
|
|
$field = new xmldb_field('hour', XMLDB_TYPE_CHAR, '70', null, XMLDB_NOTNULL, null, null, 'minute');
|
|
|
|
$dbman->change_field_precision($table, $field);
|
|
|
|
// Changing precision of field day on table task_scheduled to (90).
|
|
|
|
$field = new xmldb_field('day', XMLDB_TYPE_CHAR, '90', null, XMLDB_NOTNULL, null, null, 'hour');
|
|
|
|
$dbman->change_field_precision($table, $field);
|
|
|
|
// Changing precision of field month on table task_scheduled to (30).
|
|
|
|
$field = new xmldb_field('month', XMLDB_TYPE_CHAR, '30', null, XMLDB_NOTNULL, null, null, 'day');
|
|
|
|
$dbman->change_field_precision($table, $field);
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
2022-02-17 15:02:01 +02:00
|
|
|
upgrade_main_savepoint(true, 2022021100.02);
|
2022-02-11 13:18:05 +01:00
|
|
|
}
|
|
|
|
|
2022-02-23 09:27:25 +01:00
|
|
|
if ($oldversion < 2022022600.01) {
|
|
|
|
// Get all processor and existing preferences.
|
|
|
|
$processors = $DB->get_records('message_processors');
|
|
|
|
$providers = $DB->get_records('message_providers', null, '', 'id, name, component');
|
|
|
|
$existingpreferences = get_config('message');
|
|
|
|
|
|
|
|
foreach ($processors as $processor) {
|
|
|
|
foreach ($providers as $provider) {
|
|
|
|
// Setting default preference name.
|
|
|
|
$componentproviderbase = $provider->component . '_' . $provider->name;
|
|
|
|
$preferencename = $processor->name.'_provider_'.$componentproviderbase.'_locked';
|
|
|
|
// If we do not have this setting yet, set it to 0.
|
|
|
|
if (!isset($existingpreferences->{$preferencename})) {
|
|
|
|
set_config($preferencename, 0, 'message');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
upgrade_main_savepoint(true, 2022022600.01);
|
|
|
|
}
|
|
|
|
|
2022-03-01 17:43:07 +01:00
|
|
|
if ($oldversion < 2022030100.00) {
|
|
|
|
$sql = "SELECT preset.*
|
|
|
|
FROM {adminpresets} preset
|
|
|
|
INNER JOIN {adminpresets_it} it ON preset.id = it.adminpresetid
|
2022-03-02 13:45:15 +01:00
|
|
|
WHERE it.name = :name AND it.value = :value AND preset.iscore > 0";
|
2022-03-01 17:43:07 +01:00
|
|
|
|
|
|
|
$name = get_string('starterpreset', 'core_adminpresets');
|
|
|
|
$params = ['name' => $name, 'iscore' => 1];
|
|
|
|
$starterpreset = $DB->get_record('adminpresets', $params);
|
|
|
|
if (!$starterpreset) {
|
|
|
|
// Starter admin preset might have been created using the English name. Let's change it to current language.
|
|
|
|
$englishname = get_string_manager()->get_string('starterpreset', 'core_adminpresets', null, 'en');
|
|
|
|
$params['name'] = $englishname;
|
|
|
|
$starterpreset = $DB->get_record('adminpresets', $params);
|
|
|
|
}
|
|
|
|
if (!$starterpreset) {
|
|
|
|
// We tried, but we didn't find starter by name. Let's find a core preset that sets 'usecomments' setting to 0.
|
|
|
|
$params = ['name' => 'usecomments', 'value' => '0'];
|
|
|
|
$starterpreset = $DB->get_record_sql($sql, $params);
|
|
|
|
}
|
|
|
|
// The iscore field is already 1 for starterpreset, so we don't need to change it.
|
|
|
|
// We only need to update the name and comment in case they are different to current language strings.
|
|
|
|
if ($starterpreset && $starterpreset->name != $name) {
|
|
|
|
$starterpreset->name = $name;
|
|
|
|
$starterpreset->comments = get_string('starterpresetdescription', 'core_adminpresets');
|
|
|
|
$DB->update_record('adminpresets', $starterpreset);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Let's mark Full admin presets with current FULL_PRESETS value and change the name to current language.
|
|
|
|
$name = get_string('fullpreset', 'core_adminpresets');
|
2022-03-02 13:45:15 +01:00
|
|
|
$params = ['name' => $name];
|
|
|
|
$fullpreset = $DB->get_record_select('adminpresets', 'name = :name and iscore > 0', $params);
|
2022-03-01 17:43:07 +01:00
|
|
|
if (!$fullpreset) {
|
|
|
|
// Full admin preset might have been created using the English name.
|
|
|
|
$englishname = get_string_manager()->get_string('fullpreset', 'core_adminpresets', null, 'en');
|
|
|
|
$params['name'] = $englishname;
|
2022-03-02 13:45:15 +01:00
|
|
|
$fullpreset = $DB->get_record_select('adminpresets', 'name = :name and iscore > 0', $params);
|
2022-03-01 17:43:07 +01:00
|
|
|
}
|
|
|
|
if (!$fullpreset) {
|
|
|
|
// We tried, but we didn't find full by name. Let's find a core preset that sets 'usecomments' setting to 1.
|
|
|
|
$params = ['name' => 'usecomments', 'value' => '1'];
|
|
|
|
$fullpreset = $DB->get_record_sql($sql, $params);
|
|
|
|
}
|
|
|
|
if ($fullpreset) {
|
|
|
|
// We need to update iscore field value, whether the name is the same or not.
|
|
|
|
$fullpreset->name = $name;
|
|
|
|
$fullpreset->comments = get_string('fullpresetdescription', 'core_adminpresets');
|
|
|
|
$fullpreset->iscore = 2;
|
|
|
|
$DB->update_record('adminpresets', $fullpreset);
|
2022-03-01 17:46:15 +01:00
|
|
|
|
|
|
|
// We are applying again changes made on 2022011100.01 upgrading step because of MDL-73953 bug.
|
|
|
|
$blocknames = ['course_summary', 'feedback', 'rss_client', 'selfcompletion'];
|
|
|
|
list($blocksinsql, $blocksinparams) = $DB->get_in_or_equal($blocknames);
|
|
|
|
|
|
|
|
// Remove entries from the adminpresets_app_plug table (in case the preset has been applied).
|
|
|
|
$appliedpresets = $DB->get_records('adminpresets_app', ['adminpresetid' => $fullpreset->id], '', 'id');
|
|
|
|
if ($appliedpresets) {
|
|
|
|
list($appsinsql, $appsinparams) = $DB->get_in_or_equal(array_keys($appliedpresets));
|
|
|
|
$sql = "adminpresetapplyid $appsinsql AND plugin='block' AND name $blocksinsql";
|
|
|
|
$params = array_merge($appsinparams, $blocksinparams);
|
|
|
|
$DB->delete_records_select('adminpresets_app_plug', $sql, $params);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Remove entries for these blocks from the adminpresets_plug table.
|
|
|
|
$sql = "adminpresetid = ? AND plugin='block' AND name $blocksinsql";
|
|
|
|
$params = array_merge([$fullpreset->id], $blocksinparams);
|
|
|
|
$DB->delete_records_select('adminpresets_plug', $sql, $params);
|
2022-03-01 17:43:07 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2022030100.00);
|
|
|
|
}
|
|
|
|
|
2022-03-14 20:55:58 +00:00
|
|
|
if ($oldversion < 2022031100.01) {
|
2022-03-02 09:30:19 +01:00
|
|
|
$reportsusermenuitem = 'reports,core_reportbuilder|/reportbuilder/index.php';
|
|
|
|
upgrade_add_item_to_usermenu($reportsusermenuitem);
|
|
|
|
// Main savepoint reached.
|
2022-03-14 20:55:58 +00:00
|
|
|
upgrade_main_savepoint(true, 2022031100.01);
|
2022-03-02 09:30:19 +01:00
|
|
|
}
|
|
|
|
|
2022-03-24 13:14:03 +06:00
|
|
|
if ($oldversion < 2022032200.01) {
|
2022-02-25 16:42:26 -05:00
|
|
|
|
|
|
|
// Define index to be added to question_references.
|
|
|
|
$table = new xmldb_table('question_references');
|
|
|
|
$index = new xmldb_index('context-component-area-itemid', XMLDB_INDEX_UNIQUE,
|
|
|
|
['usingcontextid', 'component', 'questionarea', 'itemid']);
|
|
|
|
|
|
|
|
// Conditionally launch add field id.
|
|
|
|
if (!$dbman->index_exists($table, $index)) {
|
|
|
|
$dbman->add_index($table, $index);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
2022-03-24 13:14:03 +06:00
|
|
|
upgrade_main_savepoint(true, 2022032200.01);
|
2022-02-25 16:42:26 -05:00
|
|
|
}
|
|
|
|
|
2022-03-24 13:14:03 +06:00
|
|
|
if ($oldversion < 2022032200.02) {
|
2022-02-25 16:42:26 -05:00
|
|
|
|
|
|
|
// Define index to be added to question_references.
|
|
|
|
$table = new xmldb_table('question_set_references');
|
|
|
|
$index = new xmldb_index('context-component-area-itemid', XMLDB_INDEX_UNIQUE,
|
|
|
|
['usingcontextid', 'component', 'questionarea', 'itemid']);
|
|
|
|
|
|
|
|
// Conditionally launch add field id.
|
|
|
|
if (!$dbman->index_exists($table, $index)) {
|
|
|
|
$dbman->add_index($table, $index);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
2022-03-24 13:14:03 +06:00
|
|
|
upgrade_main_savepoint(true, 2022032200.02);
|
2022-02-25 16:42:26 -05:00
|
|
|
}
|
|
|
|
|
2022-04-12 16:18:35 +01:00
|
|
|
if ($oldversion < 2022041200.01) {
|
|
|
|
|
|
|
|
// The original default admin presets "sensible settings" (those that should be treated as sensitive).
|
|
|
|
$originalsensiblesettings = 'recaptchapublickey@@none, recaptchaprivatekey@@none, googlemapkey3@@none, ' .
|
|
|
|
'secretphrase@@url, cronremotepassword@@none, smtpuser@@none, smtppass@none, proxypassword@@none, ' .
|
|
|
|
'quizpassword@@quiz, allowedip@@none, blockedip@@none, dbpass@@logstore_database, messageinbound_hostpass@@none, ' .
|
|
|
|
'bind_pw@@auth_cas, pass@@auth_db, bind_pw@@auth_ldap, dbpass@@enrol_database, bind_pw@@enrol_ldap, ' .
|
|
|
|
'server_password@@search_solr, ssl_keypassword@@search_solr, alternateserver_password@@search_solr, ' .
|
|
|
|
'alternatessl_keypassword@@search_solr, test_password@@cachestore_redis, password@@mlbackend_python';
|
|
|
|
|
|
|
|
// Check if the current config matches the original default, upgrade to new default if so.
|
|
|
|
if (get_config('adminpresets', 'sensiblesettings') === $originalsensiblesettings) {
|
|
|
|
$newsensiblesettings = "{$originalsensiblesettings}, badges_badgesalt@@none, calendar_exportsalt@@none";
|
|
|
|
set_config('sensiblesettings', $newsensiblesettings, 'adminpresets');
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2022041200.01);
|
|
|
|
}
|
|
|
|
|
2022-04-17 18:35:25 +02:00
|
|
|
// Automatically generated Moodle v4.0.0 release upgrade line.
|
|
|
|
// Put any upgrade step following this.
|
|
|
|
|
2022-04-21 14:07:54 +02:00
|
|
|
if ($oldversion < 2022042900.01) {
|
|
|
|
// Social custom fields could had been created linked to category id = 1. Let's check category 1 exists.
|
|
|
|
if (!$DB->get_record('user_info_category', ['id' => 1])) {
|
|
|
|
// Let's check if we have any custom field linked to category id = 1.
|
|
|
|
$fields = $DB->get_records('user_info_field', ['categoryid' => 1]);
|
|
|
|
if (!empty($fields)) {
|
|
|
|
$categoryid = $DB->get_field_sql('SELECT min(id) from {user_info_category}');
|
|
|
|
foreach ($fields as $field) {
|
|
|
|
$field->categoryid = $categoryid;
|
|
|
|
$DB->update_record('user_info_field', $field);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2022042900.01);
|
|
|
|
}
|
|
|
|
|
2021-03-26 11:54:34 +00:00
|
|
|
if ($oldversion < 2022051000.00) {
|
|
|
|
// Add index to the sid field in the external_tokens table.
|
|
|
|
$table = new xmldb_table('external_tokens');
|
|
|
|
$index = new xmldb_index('sid', XMLDB_INDEX_NOTUNIQUE, ['sid']);
|
|
|
|
|
|
|
|
if (!$dbman->index_exists($table, $index)) {
|
|
|
|
$dbman->add_index($table, $index);
|
|
|
|
}
|
|
|
|
|
|
|
|
upgrade_main_savepoint(true, 2022051000.00);
|
|
|
|
}
|
|
|
|
|
2021-03-30 15:39:07 +10:00
|
|
|
if ($oldversion < 2022052500.00) {
|
|
|
|
// Start an adhoc task to fix the file timestamps of restored files.
|
|
|
|
$task = new core\task\fix_file_timestamps_task();
|
|
|
|
\core\task\manager::queue_adhoc_task($task);
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2022052500.00);
|
|
|
|
}
|
|
|
|
|
2022-05-27 15:41:29 +06:00
|
|
|
if ($oldversion < 2022052700.01) {
|
2021-12-13 15:52:09 +08:00
|
|
|
|
|
|
|
// Define index timestarted_idx (not unique) to be added to task_adhoc.
|
|
|
|
$table = new xmldb_table('task_adhoc');
|
|
|
|
$index = new xmldb_index('timestarted_idx', XMLDB_INDEX_NOTUNIQUE, ['timestarted']);
|
|
|
|
|
|
|
|
// Conditionally launch add index timestarted_idx.
|
|
|
|
if (!$dbman->index_exists($table, $index)) {
|
|
|
|
$dbman->add_index($table, $index);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
2022-05-27 15:41:29 +06:00
|
|
|
upgrade_main_savepoint(true, 2022052700.01);
|
2021-12-13 15:52:09 +08:00
|
|
|
}
|
|
|
|
|
2022-06-01 08:41:36 +02:00
|
|
|
if ($oldversion < 2022052700.02) {
|
2022-04-28 13:35:28 +10:00
|
|
|
|
|
|
|
// Define index filename (not unique) to be added to files.
|
|
|
|
$table = new xmldb_table('files');
|
|
|
|
$index = new xmldb_index('filename', XMLDB_INDEX_NOTUNIQUE, ['filename']);
|
|
|
|
|
|
|
|
// Conditionally launch add index filename.
|
|
|
|
if (!$dbman->index_exists($table, $index)) {
|
|
|
|
$dbman->add_index($table, $index);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
2022-06-01 08:41:36 +02:00
|
|
|
upgrade_main_savepoint(true, 2022052700.02);
|
2022-04-28 13:35:28 +10:00
|
|
|
}
|
|
|
|
|
2022-02-25 17:04:03 +00:00
|
|
|
if ($oldversion < 2022060300.01) {
|
|
|
|
|
|
|
|
// Changing precision of field hidden on table grade_categories to (10).
|
|
|
|
$table = new xmldb_table('grade_categories');
|
|
|
|
$field = new xmldb_field('hidden', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, '0', 'timemodified');
|
|
|
|
|
|
|
|
// Launch change of precision for field hidden.
|
|
|
|
$dbman->change_field_precision($table, $field);
|
|
|
|
|
|
|
|
// Changing precision of field hidden on table grade_categories_history to (10).
|
|
|
|
$table = new xmldb_table('grade_categories_history');
|
|
|
|
$field = new xmldb_field('hidden', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, '0', 'aggregatesubcats');
|
|
|
|
|
|
|
|
// Launch change of precision for field hidden.
|
|
|
|
$dbman->change_field_precision($table, $field);
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2022060300.01);
|
|
|
|
}
|
|
|
|
|
2022-05-24 23:50:36 +01:00
|
|
|
if ($oldversion < 2022061000.01) {
|
|
|
|
// Iterate over custom user menu items configuration, removing pix icon references.
|
|
|
|
$customusermenuitems = str_replace(["\r\n", "\r"], "\n", $CFG->customusermenuitems);
|
|
|
|
|
|
|
|
$lines = preg_split('/\n/', $customusermenuitems, -1, PREG_SPLIT_NO_EMPTY);
|
|
|
|
$lines = array_map(static function(string $line): string {
|
|
|
|
// Previous format was "<langstring>|<url>[|<pixicon>]" - pix icon is no longer supported.
|
|
|
|
$lineparts = explode('|', trim($line), 3);
|
|
|
|
// Return first two parts of line.
|
|
|
|
return implode('|', array_slice($lineparts, 0, 2));
|
|
|
|
}, $lines);
|
|
|
|
|
|
|
|
set_config('customusermenuitems', implode("\n", $lines));
|
|
|
|
|
|
|
|
upgrade_main_savepoint(true, 2022061000.01);
|
|
|
|
}
|
|
|
|
|
2022-06-15 16:42:21 +08:00
|
|
|
if ($oldversion < 2022061500.00) {
|
2022-04-29 18:30:22 +01:00
|
|
|
// Remove drawer-open-nav user preference for every user.
|
|
|
|
$DB->delete_records('user_preferences', ['name' => 'drawer-open-nav']);
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
2022-06-15 16:42:21 +08:00
|
|
|
upgrade_main_savepoint(true, 2022061500.00);
|
2021-06-25 17:06:38 +10:00
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($oldversion < 2022072900.00) {
|
|
|
|
// Call the helper function that updates the foreign keys and indexes in MDL-49795.
|
|
|
|
upgrade_add_foreign_key_and_indexes();
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2022072900.00);
|
2022-04-29 18:30:22 +01:00
|
|
|
}
|
|
|
|
|
2022-04-29 15:37:05 +01:00
|
|
|
if ($oldversion < 2022081200.01) {
|
|
|
|
|
|
|
|
// Define field lang to be added to course_modules.
|
|
|
|
$table = new xmldb_table('course_modules');
|
|
|
|
$field = new xmldb_field('lang', XMLDB_TYPE_CHAR, '30', null, null, null, null, 'downloadcontent');
|
|
|
|
|
|
|
|
// Conditionally launch add field lang.
|
|
|
|
if (!$dbman->field_exists($table, $field)) {
|
|
|
|
$dbman->add_field($table, $field);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2022081200.01);
|
|
|
|
}
|
|
|
|
|
2022-05-19 16:01:57 +02:00
|
|
|
if ($oldversion < 2022091000.01) {
|
|
|
|
$table = new xmldb_table('h5p');
|
|
|
|
$indexpathnamehash = new xmldb_index('pathnamehash_idx', XMLDB_INDEX_NOTUNIQUE, ['pathnamehash']);
|
|
|
|
|
|
|
|
if (!$dbman->index_exists($table, $indexpathnamehash)) {
|
|
|
|
$dbman->add_index($table, $indexpathnamehash);
|
|
|
|
}
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2022091000.01);
|
|
|
|
}
|
|
|
|
|
2022-09-05 22:27:37 +01:00
|
|
|
if ($oldversion < 2022092200.01) {
|
|
|
|
|
|
|
|
// Remove any orphaned tag instance records (pointing to non-existing context).
|
|
|
|
$DB->delete_records_select('tag_instance', 'NOT EXISTS (
|
|
|
|
SELECT ctx.id FROM {context} ctx WHERE ctx.id = {tag_instance}.contextid
|
|
|
|
)');
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2022092200.01);
|
|
|
|
}
|
|
|
|
|
2022-09-20 16:01:52 +10:00
|
|
|
if ($oldversion < 2022101400.01) {
|
|
|
|
$table = new xmldb_table('competency_modulecomp');
|
|
|
|
$field = new xmldb_field('overridegrade', XMLDB_TYPE_INTEGER, '1', null, XMLDB_NOTNULL, null, '0', 'ruleoutcome');
|
|
|
|
|
|
|
|
if (!$dbman->field_exists($table, $field)) {
|
|
|
|
$dbman->add_field($table, $field);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2022101400.01);
|
|
|
|
}
|
|
|
|
|
2022-10-17 14:30:38 +03:00
|
|
|
if ($oldversion < 2022101400.03) {
|
2022-04-26 16:46:26 +07:00
|
|
|
// Define table to store completion viewed.
|
|
|
|
$table = new xmldb_table('course_modules_viewed');
|
|
|
|
|
|
|
|
// Adding fields to table course_modules_viewed.
|
|
|
|
$table->add_field('id', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, XMLDB_SEQUENCE, null);
|
|
|
|
$table->add_field('coursemoduleid', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, null, 'id');
|
|
|
|
$table->add_field('userid', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, null, 'coursemoduleid');
|
2022-10-17 16:40:07 +03:00
|
|
|
$table->add_field('timecreated', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, null, 'userid');
|
2022-04-26 16:46:26 +07:00
|
|
|
|
|
|
|
// Adding keys to table course_modules_viewed.
|
|
|
|
$table->add_key('primary', XMLDB_KEY_PRIMARY, ['id']);
|
|
|
|
|
|
|
|
// Adding indexes to table course_modules_viewed.
|
|
|
|
$table->add_index('coursemoduleid', XMLDB_INDEX_NOTUNIQUE, ['coursemoduleid']);
|
|
|
|
$table->add_index('userid-coursemoduleid', XMLDB_INDEX_UNIQUE, ['userid', 'coursemoduleid']);
|
|
|
|
|
|
|
|
if (!$dbman->table_exists($table)) {
|
|
|
|
$dbman->create_table($table);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
2022-10-17 14:30:38 +03:00
|
|
|
upgrade_main_savepoint(true, 2022101400.03);
|
2022-04-26 16:46:26 +07:00
|
|
|
}
|
|
|
|
|
2022-10-17 14:30:38 +03:00
|
|
|
if ($oldversion < 2022101400.04) {
|
2022-04-26 16:46:26 +07:00
|
|
|
// Add legacy data to the new table.
|
|
|
|
$transaction = $DB->start_delegated_transaction();
|
|
|
|
upgrade_set_timeout(3600);
|
|
|
|
$sql = "INSERT INTO {course_modules_viewed}
|
|
|
|
(userid, coursemoduleid, timecreated)
|
|
|
|
SELECT userid, coursemoduleid, timemodified
|
|
|
|
FROM {course_modules_completion}
|
|
|
|
WHERE viewed = 1";
|
|
|
|
$DB->execute($sql);
|
|
|
|
$transaction->allow_commit();
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
2022-10-17 14:30:38 +03:00
|
|
|
upgrade_main_savepoint(true, 2022101400.04);
|
2022-04-26 16:46:26 +07:00
|
|
|
}
|
|
|
|
|
2022-10-17 14:30:38 +03:00
|
|
|
if ($oldversion < 2022101400.05) {
|
2022-04-26 16:46:26 +07:00
|
|
|
// Define field viewed to be dropped from course_modules_completion.
|
|
|
|
$table = new xmldb_table('course_modules_completion');
|
|
|
|
$field = new xmldb_field('viewed');
|
|
|
|
|
|
|
|
// Conditionally launch drop field viewed.
|
|
|
|
if ($dbman->field_exists($table, $field)) {
|
|
|
|
$dbman->drop_field($table, $field);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
2022-10-17 14:30:38 +03:00
|
|
|
upgrade_main_savepoint(true, 2022101400.05);
|
2022-04-26 16:46:26 +07:00
|
|
|
}
|
|
|
|
|
2022-10-15 00:47:03 +08:00
|
|
|
if ($oldversion < 2022102800.01) {
|
|
|
|
// For sites with "contact site support" already available (4.0.x), maintain existing functionality.
|
|
|
|
if ($oldversion >= 2022041900.00) {
|
|
|
|
set_config('supportavailability', CONTACT_SUPPORT_ANYONE);
|
|
|
|
} else {
|
|
|
|
// Sites which did not previously have the "contact site support" feature default to it requiring authentication.
|
|
|
|
set_config('supportavailability', CONTACT_SUPPORT_AUTHENTICATED);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2022102800.01);
|
|
|
|
}
|
|
|
|
|
2022-10-21 19:30:07 +02:00
|
|
|
if ($oldversion < 2022110600.00) {
|
|
|
|
// If webservice_xmlrpc isn't any longer installed, remove its configuration,
|
|
|
|
// capabilities and presence in other settings.
|
|
|
|
if (!file_exists($CFG->dirroot . '/webservice/xmlrpc/version.php')) {
|
|
|
|
// No DB structures to delete in this plugin.
|
|
|
|
|
|
|
|
// Remove capabilities.
|
|
|
|
capabilities_cleanup('webservice_xmlrpc');
|
|
|
|
|
|
|
|
// Remove own configuration.
|
|
|
|
unset_all_config_for_plugin('webservice_xmlrpc');
|
|
|
|
|
|
|
|
// Remove it from the enabled protocols if it was there.
|
|
|
|
$protos = get_config('core', 'webserviceprotocols');
|
|
|
|
$protoarr = explode(',', $protos);
|
|
|
|
$protoarr = array_filter($protoarr, function($ele) {
|
|
|
|
return trim($ele) !== 'xmlrpc';
|
|
|
|
});
|
|
|
|
$protos = implode(',', $protoarr);
|
|
|
|
set_config('webserviceprotocols', $protos);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2022110600.00);
|
|
|
|
}
|
|
|
|
|
2022-11-28 14:41:32 +08:00
|
|
|
// Automatically generated Moodle v4.1.0 release upgrade line.
|
|
|
|
// Put any upgrade step following this.
|
|
|
|
|
2022-12-01 12:12:59 +00:00
|
|
|
if ($oldversion < 2022120900.01) {
|
|
|
|
|
|
|
|
// Remove any orphaned role assignment records (pointing to non-existing roles).
|
|
|
|
$DB->delete_records_select('role_assignments', 'NOT EXISTS (
|
|
|
|
SELECT r.id FROM {role} r WHERE r.id = {role_assignments}.roleid
|
|
|
|
)');
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2022120900.01);
|
|
|
|
}
|
|
|
|
|
2022-09-21 14:08:56 +05:30
|
|
|
if ($oldversion < 2022121600.01) {
|
|
|
|
// Define index blocknameindex (not unique) to be added to block_instances.
|
|
|
|
$table = new xmldb_table('block_instances');
|
|
|
|
$index = new xmldb_index('blocknameindex', XMLDB_INDEX_NOTUNIQUE, ['blockname']);
|
|
|
|
|
|
|
|
// Conditionally launch add index blocknameindex.
|
|
|
|
if (!$dbman->index_exists($table, $index)) {
|
|
|
|
$dbman->add_index($table, $index);
|
|
|
|
}
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2022121600.01);
|
|
|
|
}
|
|
|
|
|
2022-11-29 21:32:35 +08:00
|
|
|
if ($oldversion < 2023010300.00) {
|
|
|
|
// The useexternalyui setting has been removed.
|
|
|
|
unset_config('useexternalyui');
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
|
|
|
upgrade_main_savepoint(true, 2023010300.00);
|
|
|
|
}
|
|
|
|
|
2023-02-09 11:18:24 +08:00
|
|
|
if ($oldversion < 2023020800.00) {
|
2023-02-07 21:07:06 +08:00
|
|
|
// If cachestore_memcached is no longer present, remove it.
|
|
|
|
if (!file_exists($CFG->dirroot . '/cache/stores/memcached/version.php')) {
|
|
|
|
// Clean config.
|
|
|
|
unset_all_config_for_plugin('cachestore_memcached');
|
|
|
|
}
|
|
|
|
|
|
|
|
// Main savepoint reached.
|
2023-02-09 11:18:24 +08:00
|
|
|
upgrade_main_savepoint(true, 2023020800.00);
|
2023-02-07 21:07:06 +08:00
|
|
|
}
|
|
|
|
|
2010-07-04 10:27:56 +00:00
|
|
|
return true;
|
2012-05-31 09:59:18 +02:00
|
|
|
}
|