. /** * This file keeps track of upgrades to * the lesson module * * 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. * * @package mod_lesson * @copyright 1999 onwards Martin Dougiamas {@link http://moodle.com} * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 o */ defined('MOODLE_INTERNAL') || die(); /** * * @global stdClass $CFG * @global moodle_database $DB * @global core_renderer $OUTPUT * @param int $oldversion * @return bool */ function xmldb_lesson_upgrade($oldversion) { global $CFG, $DB, $OUTPUT; $dbman = $DB->get_manager(); // Moodle v2.2.0 release upgrade line // Put any upgrade step following this // Moodle v2.3.0 release upgrade line // Put any upgrade step following this // Moodle v2.4.0 release upgrade line // Put any upgrade step following this // Moodle v2.5.0 release upgrade line. // Put any upgrade step following this. // Moodle v2.6.0 release upgrade line. // Put any upgrade step following this. // Moodle v2.7.0 release upgrade line. // Put any upgrade step following this. if ($oldversion < 2014091001) { $table = new xmldb_table('lesson'); $field = new xmldb_field('intro', XMLDB_TYPE_TEXT, null, null, null, null, null, 'name'); // Conditionally launch add field. if (!$dbman->field_exists($table, $field)) { $dbman->add_field($table, $field); } $field = new xmldb_field('introformat', XMLDB_TYPE_INTEGER, '4', XMLDB_UNSIGNED, XMLDB_NOTNULL, null, '0', 'intro'); if (!$dbman->field_exists($table, $field)) { $dbman->add_field($table, $field); } upgrade_mod_savepoint(true, 2014091001, 'lesson'); } if ($oldversion < 2014100600) { // Previously there was no module intro in lesson so don't require // it to be filled in for upgraded sites. set_config('requiremodintro', 0, 'lesson'); upgrade_mod_savepoint(true, 2014100600, 'lesson'); } // Moodle v2.8.0 release upgrade line. // Put any upgrade step following this. if ($oldversion < 2014112300) { // Define field completionendreached to be added to lesson. $table = new xmldb_table('lesson'); $field = new xmldb_field('completionendreached', XMLDB_TYPE_INTEGER, '1', null, null, null, '0', 'timemodified'); // Conditionally launch add field completionendreached. if (!$dbman->field_exists($table, $field)) { $dbman->add_field($table, $field); } // Define field completed to be added to lesson_timer. $table = new xmldb_table('lesson_timer'); $field = new xmldb_field('completed', XMLDB_TYPE_INTEGER, '1', null, null, null, '0', 'lessontime'); // Conditionally launch add field completed. if (!$dbman->field_exists($table, $field)) { $dbman->add_field($table, $field); } // Lesson savepoint reached. upgrade_mod_savepoint(true, 2014112300, 'lesson'); } if ($oldversion < 2014122900) { // Changing precision of field grade on table lesson to (10). $table = new xmldb_table('lesson'); $field = new xmldb_field('grade', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, '0', 'conditions'); // Launch change of precision for field grade. $dbman->change_field_precision($table, $field); // Lesson savepoint reached. upgrade_mod_savepoint(true, 2014122900, 'lesson'); } if ($oldversion < 2015030300) { // Define field nextpageid to be added to lesson_branch. $table = new xmldb_table('lesson_branch'); $field = new xmldb_field('nextpageid', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, '0', 'timeseen'); // Conditionally launch add field nextpageid. if (!$dbman->field_exists($table, $field)) { $dbman->add_field($table, $field); } // Lesson savepoint reached. upgrade_mod_savepoint(true, 2015030300, 'lesson'); } if ($oldversion < 2015030301) { // Clean lesson answers that should be plain text. // Unfortunately we can't use LESSON_PAGE_XX constants here as we can't include the files. // 1 = LESSON_PAGE_SHORTANSWER, 8 = LESSON_PAGE_NUMERICAL, 20 = LESSON_PAGE_BRANCHTABLE. $sql = 'SELECT a.* FROM {lesson_answers} a JOIN {lesson_pages} p ON p.id = a.pageid WHERE a.answerformat <> :format AND p.qtype IN (1, 8, 20)'; $badanswers = $DB->get_recordset_sql($sql, array('format' => FORMAT_MOODLE)); foreach ($badanswers as $badanswer) { // Strip tags from answer text and convert back the format to FORMAT_MOODLE. $badanswer->answer = strip_tags($badanswer->answer); $badanswer->answerformat = FORMAT_MOODLE; $DB->update_record('lesson_answers', $badanswer); } $badanswers->close(); // Lesson savepoint reached. upgrade_mod_savepoint(true, 2015030301, 'lesson'); } if ($oldversion < 2015030400) { // Creating new field timelimit in lesson table. $table = new xmldb_table('lesson'); $field = new xmldb_field('timelimit', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, '0', 'maxpages'); // Conditionally launch add field timelimit. if (!$dbman->field_exists($table, $field)) { $dbman->add_field($table, $field); } // Lesson savepoint reached. upgrade_mod_savepoint(true, 2015030400, 'lesson'); } if ($oldversion < 2015030401) { // Convert maxtime (minutes) to timelimit (seconds). $table = new xmldb_table('lesson'); $oldfield = new xmldb_field('maxtime'); $newfield = new xmldb_field('timelimit'); if ($dbman->field_exists($table, $oldfield) && $dbman->field_exists($table, $newfield)) { $sql = 'UPDATE {lesson} SET timelimit = 60 * maxtime'; $DB->execute($sql); // Drop field maxtime. $dbman->drop_field($table, $oldfield); } $oldfield = new xmldb_field('timed'); if ($dbman->field_exists($table, $oldfield) && $dbman->field_exists($table, $newfield)) { // Set timelimit to 0 for non timed lessons. $DB->set_field_select('lesson', 'timelimit', 0, 'timed = 0'); // Drop field timed. $dbman->drop_field($table, $oldfield); } // Lesson savepoint reached. upgrade_mod_savepoint(true, 2015030401, 'lesson'); } if ($oldversion < 2015031500) { // Define field completiontimespent to be added to lesson. $table = new xmldb_table('lesson'); $field = new xmldb_field('completiontimespent', XMLDB_TYPE_INTEGER, '11', null, null, null, '0', 'completionendreached'); // Conditionally launch add field completiontimespent. if (!$dbman->field_exists($table, $field)) { $dbman->add_field($table, $field); } // Lesson savepoint reached. upgrade_mod_savepoint(true, 2015031500, 'lesson'); } if ($oldversion < 2015032600) { // Change practice lesson to allow multiple attempts // so that behaviour is not changed by MDL-18966. $DB->set_field('lesson', 'retake', 1, array('practice' => 1)); // Lesson savepoint reached. upgrade_mod_savepoint(true, 2015032600, 'lesson'); } if ($oldversion < 2015032700) { // Delete any orphaned lesson_branch record. if ($DB->get_dbfamily() === 'mysql') { $sql = "DELETE {lesson_branch} FROM {lesson_branch} LEFT JOIN {lesson_pages} ON {lesson_branch}.pageid = {lesson_pages}.id WHERE {lesson_pages}.id IS NULL"; } else { $sql = "DELETE FROM {lesson_branch} WHERE NOT EXISTS ( SELECT 'x' FROM {lesson_pages} WHERE {lesson_branch}.pageid = {lesson_pages}.id)"; } $DB->execute($sql); // Lesson savepoint reached. upgrade_mod_savepoint(true, 2015032700, 'lesson'); } if ($oldversion < 2015033100) { // Define table lesson_overrides to be created. $table = new xmldb_table('lesson_overrides'); // Adding fields to table lesson_overrides. $table->add_field('id', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, XMLDB_SEQUENCE, null); $table->add_field('lessonid', XMLDB_TYPE_INTEGER, '10', null, XMLDB_NOTNULL, null, '0'); $table->add_field('groupid', XMLDB_TYPE_INTEGER, '10', null, null, null, null); $table->add_field('userid', XMLDB_TYPE_INTEGER, '10', null, null, null, null); $table->add_field('available', XMLDB_TYPE_INTEGER, '10', null, null, null, null); $table->add_field('deadline', XMLDB_TYPE_INTEGER, '10', null, null, null, null); $table->add_field('timelimit', XMLDB_TYPE_INTEGER, '10', null, null, null, null); $table->add_field('review', XMLDB_TYPE_INTEGER, '3', null, null, null, null); $table->add_field('maxattempts', XMLDB_TYPE_INTEGER, '3', null, null, null, null); $table->add_field('retake', XMLDB_TYPE_INTEGER, '3', null, null, null, null); $table->add_field('password', XMLDB_TYPE_CHAR, '32', null, null, null, null); // Adding keys to table lesson_overrides. $table->add_key('primary', XMLDB_KEY_PRIMARY, array('id')); $table->add_key('lessonid', XMLDB_KEY_FOREIGN, array('lessonid'), 'lesson', array('id')); $table->add_key('groupid', XMLDB_KEY_FOREIGN, array('groupid'), 'groups', array('id')); $table->add_key('userid', XMLDB_KEY_FOREIGN, array('userid'), 'user', array('id')); // Conditionally launch create table for lesson_overrides. if (!$dbman->table_exists($table)) { $dbman->create_table($table); } // Lesson savepoint reached. upgrade_mod_savepoint(true, 2015033100, 'lesson'); } // Moodle v2.9.0 release upgrade line. // Put any upgrade step following this. if ($oldversion < 2015071800) { // Define table lesson_high_scores to be dropped. $table = new xmldb_table('lesson_high_scores'); // Conditionally launch drop table for lesson_high_scores. if ($dbman->table_exists($table)) { $dbman->drop_table($table); } // Lesson savepoint reached. upgrade_mod_savepoint(true, 2015071800, 'lesson'); } if ($oldversion < 2015071801) { // Define field highscores to be dropped from lesson. $table = new xmldb_table('lesson'); $field = new xmldb_field('highscores'); // Conditionally launch drop field highscores. if ($dbman->field_exists($table, $field)) { $dbman->drop_field($table, $field); } // Lesson savepoint reached. upgrade_mod_savepoint(true, 2015071801, 'lesson'); } if ($oldversion < 2015071802) { // Define field maxhighscores to be dropped from lesson. $table = new xmldb_table('lesson'); $field = new xmldb_field('maxhighscores'); // Conditionally launch drop field maxhighscores. if ($dbman->field_exists($table, $field)) { $dbman->drop_field($table, $field); } // Lesson savepoint reached. upgrade_mod_savepoint(true, 2015071802, 'lesson'); } if ($oldversion < 2015071803) { unset_config('lesson_maxhighscores'); // Lesson savepoint reached. upgrade_mod_savepoint(true, 2015071803, 'lesson'); } // Moodle v3.0.0 release upgrade line. // Put any upgrade step following this. return true; }