Proyectos de Subversion Moodle

Rev

| Ultima modificación | Ver Log |

Rev Autor Línea Nro. Línea
1 efrain 1
<?php
2
// This file is part of Moodle - http://moodle.org/
3
//
4
// Moodle is free software: you can redistribute it and/or modify
5
// it under the terms of the GNU General Public License as published by
6
// the Free Software Foundation, either version 3 of the License, or
7
// (at your option) any later version.
8
//
9
// Moodle is distributed in the hope that it will be useful,
10
// but WITHOUT ANY WARRANTY; without even the implied warranty of
11
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12
// GNU General Public License for more details.
13
//
14
// You should have received a copy of the GNU General Public License
15
// along with Moodle.  If not, see <http://www.gnu.org/licenses/>.
16
 
17
/**
18
 * This file keeps track of upgrades to the h5pactivity module
19
 *
20
 * Sometimes, changes between versions involve
21
 * alterations to database structures and other
22
 * major things that may break installations.
23
 *
24
 * The upgrade function in this file will attempt
25
 * to perform all the necessary actions to upgrade
26
 * your older installation to the current version.
27
 *
28
 * If there's something it cannot do itself, it
29
 * will tell you what you need to do.
30
 *
31
 * The commands in here will all be database-neutral,
32
 * using the methods of database_manager class
33
 *
34
 * Please do not forget to use upgrade_set_timeout()
35
 * before any action that may take longer time to finish.
36
 *
37
 * @package   mod_h5pactivity
38
 * @copyright 2020 Ferran Recio <ferran@moodle.com>
39
 * @license   http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
40
 */
41
 
42
/**
43
 * Function to upgrade mod_h5pactivity.
44
 * @param int $oldversion the version we are upgrading from
45
 * @return bool result
46
 */
47
function xmldb_h5pactivity_upgrade($oldversion) {
48
    global $DB;
49
 
50
    // Automatically generated Moodle v4.1.0 release upgrade line.
51
    // Put any upgrade step following this.
52
 
53
    // Automatically generated Moodle v4.2.0 release upgrade line.
54
    // Put any upgrade step following this.
55
 
56
    if ($oldversion < 2023042401) {
57
        // Remove any orphaned attempt/result records (pointing to non-existing activities).
58
        $DB->delete_records_select('h5pactivity_attempts', 'NOT EXISTS (
59
            SELECT 1 FROM {h5pactivity} h5p WHERE h5p.id = {h5pactivity_attempts}.h5pactivityid
60
        )');
61
 
62
        $DB->delete_records_select('h5pactivity_attempts_results', 'NOT EXISTS (
63
            SELECT 1 FROM {h5pactivity_attempts} attempt WHERE attempt.id = {h5pactivity_attempts_results}.attemptid
64
        )');
65
 
66
        // H5pactivity savepoint reached.
67
        upgrade_mod_savepoint(true, 2023042401, 'h5pactivity');
68
    }
69
 
70
    // Automatically generated Moodle v4.3.0 release upgrade line.
71
    // Put any upgrade step following this.
72
 
73
    // Automatically generated Moodle v4.4.0 release upgrade line.
74
    // Put any upgrade step following this.
75
 
76
    return true;
77
}