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
 * Provides {@see restore_subcourse_activity_structure_step} class
19
 *
20
 * @package     mod_subcourse
21
 * @category    backup
22
 * @copyright   2013 David Mudrak <david@moodle.com>
23
 * @license     http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
24
 */
25
 
26
/**
27
 * Structure step to restore one subcourse activity
28
 *
29
 * @copyright 2017 David Mudrak <david@moodle.com>
30
 * @license   http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
31
 */
32
class restore_subcourse_activity_structure_step extends restore_activity_structure_step {
33
 
34
    /**
35
     * Attaches the handlers of the backup XML tree parts.
36
     *
37
     * @return array of restore_path_element
38
     */
39
    protected function define_structure() {
40
 
41
        $paths = [];
42
 
43
        $paths[] = new restore_path_element('subcourse', '/activity/subcourse');
44
 
45
        return $this->prepare_activity_structure($paths);
46
    }
47
 
48
    /**
49
     * Process the /activity/subcourse path element.
50
     *
51
     * @param object|array $data node contents
52
     */
53
    protected function process_subcourse($data) {
54
        global $DB;
55
 
56
        $data = (object)$data;
57
        $data->course = $this->get_courseid();
58
 
59
        $data->timefetched = 0;
60
 
61
        if (!$this->task->is_samesite() || !$DB->record_exists('course', ['id' => $data->refcourse])) {
62
            $data->refcourse = 0;
63
        }
64
 
65
        $newitemid = $DB->insert_record('subcourse', $data);
66
        // Immediately after inserting "activity" record, call this.
67
        $this->apply_activity_instance($newitemid);
68
    }
69
 
70
    /**
71
     * Callback to be executed after the restore.
72
     */
73
    protected function after_execute() {
74
        // Add subcourse related files, no need to match by itemname (just internally handled context).
75
        $this->add_related_files('mod_subcourse', 'intro', null);
76
    }
77
}