337eb7fe878004c1773f1eedf5d23b571538161b
[moodle.git] / mod / choice / backup / moodle2 / restore_choice_stepslib.php
1 <?php
3 // This file is part of Moodle - http://moodle.org/
4 //
5 // Moodle is free software: you can redistribute it and/or modify
6 // it under the terms of the GNU General Public License as published by
7 // the Free Software Foundation, either version 3 of the License, or
8 // (at your option) any later version.
9 //
10 // Moodle is distributed in the hope that it will be useful,
11 // but WITHOUT ANY WARRANTY; without even the implied warranty of
12 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13 // GNU General Public License for more details.
14 //
15 // You should have received a copy of the GNU General Public License
16 // along with Moodle.  If not, see <http://www.gnu.org/licenses/>.
18 /**
19  * @package moodlecore
20  * @subpackage backup-moodle2
21  * @copyright 2010 onwards Eloy Lafuente (stronk7) {@link http://stronk7.com}
22  * @license   http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
23  */
25 /**
26  * Define all the restore steps that will be used by the restore_choice_activity_task
27  */
29 /**
30  * Structure step to restore one choice activity
31  */
32 class restore_choice_activity_structure_step extends restore_activity_structure_step {
34     protected function define_structure() {
36         $paths = array();
37         $userinfo = $this->get_setting_value('userinfo');
39         $paths[] = new restore_path_element('choice', '/activity/choice');
40         $paths[] = new restore_path_element('choice_option', '/activity/choice/options/option');
41         if ($userinfo) {
42             $paths[] = new restore_path_element('choice_answer', '/activity/choice/answers/answer');
43         }
45         // Return the paths wrapped into standard activity structure
46         return $this->prepare_activity_structure($paths);
47     }
49     protected function process_choice($data) {
50         global $DB;
52         $data = (object)$data;
53         $oldid = $data->id;
54         $data->course = $this->get_courseid();
56         $data->timeopen = $this->apply_date_offset($data->timeopen);
57         $data->timeclose = $this->apply_date_offset($data->timeclose);
58         $data->timemodified = $this->apply_date_offset($data->timemodified);
60         // insert the choice record
61         $newitemid = $DB->insert_record('choice', $data);
62         // immediately after inserting "activity" record, call this
63         $this->apply_activity_instance($newitemid);
64     }
66     protected function process_choice_option($data) {
67         global $DB;
69         $data = (object)$data;
70         $oldid = $data->id;
72         $data->choiceid = $this->get_new_parentid('choice');
73         $data->timemodified = $this->apply_date_offset($data->timemodified);
75         $newitemid = $DB->insert_record('choice_options', $data);
76         $this->set_mapping('choice_option', $oldid, $newitemid);
77     }
79     protected function process_choice_answer($data) {
80         global $DB;
82         $data = (object)$data;
84         $data->choiceid = $this->get_new_parentid('choice');
85         $data->optionid = $this->get_mappingid('choice_option', $data->optionid);
86         $data->userid = $this->get_mappingid('user', $data->userid);
87         $data->timemodified = $this->apply_date_offset($data->timemodified);
89         $newitemid = $DB->insert_record('choice_answers', $data);
90         // No need to save this mapping as far as nothing depend on it
91         // (child paths, file areas nor links decoder)
92     }
94     protected function after_execute() {
95         // Add choice related files, no need to match by itemname (just internally handled context)
96         $this->add_related_files('mod_choice', 'intro', null);
97     }
98 }