Proyectos de Subversion Moodle

Rev

Rev 1 | | Comparar con el anterior | Ultima modificación | Ver Log |

Rev Autor Línea Nro. Línea
1 efrain 1
<?php
2
 
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/>.
17
 
18
/**
19
 * Defines restore_root_task class
20
 * @package     core_backup
21
 * @subpackage  moodle2
22
 * @category    backup
23
 * @copyright   2010 onwards Eloy Lafuente (stronk7) {@link http://stronk7.com}
24
 * @license     http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
25
 */
26
 
27
defined('MOODLE_INTERNAL') || die();
28
 
1441 ariadna 29
use core\di;
30
use core\hook\manager;
31
use core_backup\hook\after_restore_root_define_settings;
32
 
1 efrain 33
/**
34
 * Start task that provides all the settings common to all restores and other initial steps
35
 *
36
 * TODO: Finish phpdocs
37
 */
38
class restore_root_task extends restore_task {
39
 
40
    /**
41
     * Create all the steps that will be part of this task
42
     */
43
    public function build() {
44
 
45
        // Conditionally create the temp table (can exist from prechecks) and delete old stuff
46
        $this->add_step(new restore_create_and_clean_temp_stuff('create_and_clean_temp_stuff'));
47
 
48
        // Now make sure the user that is running the restore can actually access the course
49
        // before executing any other step (potentially performing permission checks)
50
        $this->add_step(new restore_fix_restorer_access_step('fix_restorer_access'));
51
 
52
        // If we haven't preloaded information, load all the included inforef records to temp_ids table
53
        $this->add_step(new restore_load_included_inforef_records('load_inforef_records'));
54
 
55
        // Load all the needed files to temp_ids table
56
        $this->add_step(new restore_load_included_files('load_file_records', 'files.xml'));
57
 
58
        // If we haven't preloaded information, load all the needed roles to temp_ids_table
59
        $this->add_step(new restore_load_and_map_roles('load_and_map_roles'));
60
 
61
        // If we haven't preloaded information and are restoring user info, load all the needed users to temp_ids table
62
        $this->add_step(new restore_load_included_users('load_user_records'));
63
 
64
        // If we haven't preloaded information and are restoring user info, process all those needed users
65
        // marking for create/map them as needed. Any problem here will cause exception as far as prechecks have
66
        // performed the same process so, it's not possible to have errors here
67
        $this->add_step(new restore_process_included_users('process_user_records'));
68
 
69
        // Unconditionally, create all the needed users calculated in the previous step
70
        $this->add_step(new restore_create_included_users('create_users'));
71
 
72
        // Unconditionally, load create all the needed groups and groupings
73
        $this->add_step(new restore_groups_structure_step('create_groups_and_groupings', 'groups.xml'));
74
 
75
        // Unconditionally, load create all the needed scales
76
        $this->add_step(new restore_scales_structure_step('create_scales', 'scales.xml'));
77
 
78
        // Unconditionally, load create all the needed outcomes
79
        $this->add_step(new restore_outcomes_structure_step('create_scales', 'outcomes.xml'));
80
 
81
        // If we haven't preloaded information, load all the needed categories and questions (reduced) to temp_ids_table
82
        $this->add_step(new restore_load_categories_and_questions('load_categories_and_questions'));
83
 
84
        // If we haven't preloaded information, process all the loaded categories and questions
85
        // marking them for creation/mapping as needed. Any problem here will cause exception
86
        // because this same process has been executed and reported by restore prechecks, so
87
        // it is not possible to have errors here.
88
        $this->add_step(new restore_process_categories_and_questions('process_categories_and_questions'));
89
 
90
        // Unconditionally, create and map all the categories and questions
91
        $this->add_step(new restore_create_categories_and_questions('create_categories_and_questions', 'questions.xml'));
92
 
93
        // At the end, mark it as built
94
        $this->built = true;
95
    }
96
 
97
// Protected API starts here
98
 
99
    /**
100
     * Define the common setting that any restore type will have
101
     */
102
    protected function define_settings() {
103
 
104
        // Load all the root settings found in backup file from controller
105
        $rootsettings = $this->get_info()->root_settings;
106
 
107
        // Define users setting (keeping it on hand to define dependencies)
108
        $defaultvalue = false;                      // Safer default
109
        $changeable = false;
110
        if (isset($rootsettings['users']) && $rootsettings['users']) { // Only enabled when available
111
            $defaultvalue = true;
112
            $changeable = true;
113
        }
114
        $users = new restore_users_setting('users', base_setting::IS_BOOLEAN, $defaultvalue);
115
        $users->set_ui(new backup_setting_ui_checkbox($users, get_string('rootsettingusers', 'backup')));
116
        $users->get_ui()->set_changeable($changeable);
117
        $this->add_setting($users);
118
 
119
        // Restore enrolment methods.
120
        if ($changeable) {
121
            $options = [
122
                backup::ENROL_NEVER     => get_string('rootsettingenrolments_never', 'backup'),
123
                backup::ENROL_WITHUSERS => get_string('rootsettingenrolments_withusers', 'backup'),
124
                backup::ENROL_ALWAYS    => get_string('rootsettingenrolments_always', 'backup'),
125
            ];
126
            $enroldefault = backup::ENROL_WITHUSERS;
127
        } else {
128
            // Users can not be restored, simplify the dropdown.
129
            $options = [
130
                backup::ENROL_NEVER     => get_string('no'),
131
                backup::ENROL_ALWAYS    => get_string('yes')
132
            ];
133
            $enroldefault = backup::ENROL_NEVER;
134
        }
135
        $enrolments = new restore_users_setting('enrolments', base_setting::IS_INTEGER, $enroldefault);
136
        $enrolments->set_ui(new backup_setting_ui_select($enrolments, get_string('rootsettingenrolments', 'backup'),
137
            $options));
138
        $this->add_setting($enrolments);
139
 
140
        // Define role_assignments (dependent of users)
141
        $defaultvalue = false;                      // Safer default
142
        $changeable = false;
143
        if (isset($rootsettings['role_assignments']) && $rootsettings['role_assignments']) { // Only enabled when available
144
            $defaultvalue = true;
145
            $changeable = true;
146
        }
147
        $roleassignments = new restore_role_assignments_setting('role_assignments', base_setting::IS_BOOLEAN, $defaultvalue);
148
        $roleassignments->set_ui(new backup_setting_ui_checkbox($roleassignments,get_string('rootsettingroleassignments', 'backup')));
149
        $roleassignments->get_ui()->set_changeable($changeable);
150
        $this->add_setting($roleassignments);
151
        $users->add_dependency($roleassignments);
152
 
153
        // Define permissions.
154
        $defaultvalue = false;                      // Safer default.
155
        $changeable = false;
156
        // Enable when available, or key doesn't exist (backward compatibility).
157
        if (!array_key_exists('permissions', $rootsettings) || !empty($rootsettings['permissions'])) {
158
            $defaultvalue = true;
159
            $changeable = true;
160
        }
161
        $permissions = new restore_permissions_setting('permissions', base_setting::IS_BOOLEAN, $defaultvalue);
162
        $permissions->set_ui(new backup_setting_ui_checkbox($permissions, get_string('rootsettingpermissions', 'backup')));
163
        $permissions->get_ui()->set_changeable($changeable);
164
        $this->add_setting($permissions);
165
 
166
        // Define activitites
167
        $defaultvalue = false;                      // Safer default
168
        $changeable = false;
169
        if (isset($rootsettings['activities']) && $rootsettings['activities']) { // Only enabled when available
170
            $defaultvalue = true;
171
            $changeable = true;
172
        }
173
        $activities = new restore_activities_setting('activities', base_setting::IS_BOOLEAN, $defaultvalue);
174
        $activities->set_ui(new backup_setting_ui_checkbox($activities, get_string('rootsettingactivities', 'backup')));
175
        $activities->get_ui()->set_changeable($changeable);
176
        $this->add_setting($activities);
177
 
178
        // Define blocks
179
        $defaultvalue = false;                      // Safer default
180
        $changeable = false;
181
        if (isset($rootsettings['blocks']) && $rootsettings['blocks']) { // Only enabled when available
182
            $defaultvalue = true;
183
            $changeable = true;
184
        }
185
        $blocks = new restore_generic_setting('blocks', base_setting::IS_BOOLEAN, $defaultvalue);
186
        $blocks->set_ui(new backup_setting_ui_checkbox($blocks, get_string('rootsettingblocks', 'backup')));
187
        $blocks->get_ui()->set_changeable($changeable);
188
        $this->add_setting($blocks);
189
 
190
        // Define filters
191
        $defaultvalue = false;                      // Safer default
192
        $changeable = false;
193
        if (isset($rootsettings['filters']) && $rootsettings['filters']) { // Only enabled when available
194
            $defaultvalue = true;
195
            $changeable = true;
196
        }
197
        $filters = new restore_generic_setting('filters', base_setting::IS_BOOLEAN, $defaultvalue);
198
        $filters->set_ui(new backup_setting_ui_checkbox($filters, get_string('rootsettingfilters', 'backup')));
199
        $filters->get_ui()->set_changeable($changeable);
200
        $this->add_setting($filters);
201
 
202
        // Define comments (dependent of users)
203
        $defaultvalue = false;                      // Safer default
204
        $changeable = false;
205
        if (isset($rootsettings['comments']) && $rootsettings['comments']) { // Only enabled when available
206
            $defaultvalue = true;
207
            $changeable = true;
208
        }
209
        $comments = new restore_comments_setting('comments', base_setting::IS_BOOLEAN, $defaultvalue);
210
        $comments->set_ui(new backup_setting_ui_checkbox($comments, get_string('rootsettingcomments', 'backup')));
211
        $comments->get_ui()->set_changeable($changeable);
212
        $this->add_setting($comments);
213
        $users->add_dependency($comments);
214
 
215
        // Define badges (dependent of activities).
216
        $defaultvalue = false;                      // Safer default.
217
        $changeable = false;
218
        if (isset($rootsettings['badges']) && $rootsettings['badges']) { // Only enabled when available.
219
            $defaultvalue = true;
220
            $changeable = true;
221
        }
222
        $badges = new restore_badges_setting('badges', base_setting::IS_BOOLEAN, $defaultvalue);
223
        $badges->set_ui(new backup_setting_ui_checkbox($badges, get_string('rootsettingbadges', 'backup')));
224
        $badges->get_ui()->set_changeable($changeable);
225
        $this->add_setting($badges);
226
        $activities->add_dependency($badges);
227
        $users->add_dependency($badges);
228
 
229
        // Define Calendar events.
230
        $defaultvalue = false;                      // Safer default
231
        $changeable = false;
232
        if (isset($rootsettings['calendarevents']) && $rootsettings['calendarevents']) { // Only enabled when available
233
            $defaultvalue = true;
234
            $changeable = true;
235
        }
236
        $events = new restore_calendarevents_setting('calendarevents', base_setting::IS_BOOLEAN, $defaultvalue);
237
        $events->set_ui(new backup_setting_ui_checkbox($events, get_string('rootsettingcalendarevents', 'backup')));
238
        $events->get_ui()->set_changeable($changeable);
239
        $this->add_setting($events);
240
 
241
        // Define completion (dependent of users)
242
        $defaultvalue = false;                      // Safer default
243
        $changeable = false;
244
        if (isset($rootsettings['userscompletion']) && $rootsettings['userscompletion']) { // Only enabled when available
245
            $defaultvalue = true;
246
            $changeable = true;
247
        }
248
        $completion = new restore_userscompletion_setting('userscompletion', base_setting::IS_BOOLEAN, $defaultvalue);
249
        $completion->set_ui(new backup_setting_ui_checkbox($completion, get_string('rootsettinguserscompletion', 'backup')));
250
        $completion->get_ui()->set_changeable($changeable);
251
        $this->add_setting($completion);
252
        $users->add_dependency($completion);
253
 
254
        // Define logs (dependent of users)
255
        $defaultvalue = false;                      // Safer default
256
        $changeable = false;
257
        if (isset($rootsettings['logs']) && $rootsettings['logs']) { // Only enabled when available
258
            $defaultvalue = true;
259
            $changeable = true;
260
        }
261
        $logs = new restore_logs_setting('logs', base_setting::IS_BOOLEAN, $defaultvalue);
262
        $logs->set_ui(new backup_setting_ui_checkbox($logs, get_string('rootsettinglogs', 'backup')));
263
        $logs->get_ui()->set_changeable($changeable);
264
        $this->add_setting($logs);
265
        $users->add_dependency($logs);
266
 
267
        // Define grade_histories (dependent of users)
268
        $defaultvalue = false;                      // Safer default
269
        $changeable = false;
270
        if (isset($rootsettings['grade_histories']) && $rootsettings['grade_histories']) { // Only enabled when available
271
            $defaultvalue = true;
272
            $changeable = true;
273
        }
274
        $gradehistories = new restore_grade_histories_setting('grade_histories', base_setting::IS_BOOLEAN, $defaultvalue);
275
        $gradehistories->set_ui(new backup_setting_ui_checkbox($gradehistories, get_string('rootsettinggradehistories', 'backup')));
276
        $gradehistories->get_ui()->set_changeable($changeable);
277
        $this->add_setting($gradehistories);
278
        $users->add_dependency($gradehistories);
279
 
280
        // The restore does not process the grade histories when some activities are ignored.
281
        // So let's define a dependency to prevent false expectations from our users.
282
        $activities->add_dependency($gradehistories);
283
 
284
        // Define groups and groupings.
285
        $defaultvalue = false;
286
        $changeable = false;
287
        if (isset($rootsettings['groups']) && $rootsettings['groups']) { // Only enabled when available.
288
            $defaultvalue = true;
289
            $changeable = true;
290
        } else if (!isset($rootsettings['groups'])) {
291
            // It is likely this is an older backup that does not contain information on the group setting,
292
            // in which case groups should be restored and this setting can be changed.
293
            $defaultvalue = true;
294
            $changeable = true;
295
        }
296
        $groups = new restore_groups_setting('groups', base_setting::IS_BOOLEAN, $defaultvalue);
297
        $groups->set_ui(new backup_setting_ui_checkbox($groups, get_string('rootsettinggroups', 'backup')));
298
        $groups->get_ui()->set_changeable($changeable);
299
        $this->add_setting($groups);
300
 
301
        // Competencies restore setting. Show when competencies is enabled and the setting is available.
302
        $hascompetencies = !empty($rootsettings['competencies']);
303
        $competencies = new restore_competencies_setting($hascompetencies);
304
        $competencies->set_ui(new backup_setting_ui_checkbox($competencies, get_string('rootsettingcompetencies', 'backup')));
305
        $this->add_setting($competencies);
306
 
1441 ariadna 307
        // Custom fields.
308
        $defaultvalue = false;
309
        $changeable = false;
310
        if (isset($rootsettings['customfield']) && $rootsettings['customfield']) { // Only enabled when available.
311
            $defaultvalue = true;
312
            $changeable = true;
313
        }
314
        $customfields = new restore_customfield_setting('customfield', base_setting::IS_BOOLEAN, $defaultvalue);
1 efrain 315
        $customfields->set_ui(new backup_setting_ui_checkbox($customfields, get_string('rootsettingcustomfield', 'backup')));
1441 ariadna 316
        $customfields->get_ui()->set_changeable($changeable);
1 efrain 317
        $this->add_setting($customfields);
318
 
319
        // Define Content bank content.
320
        $defaultvalue = false;
321
        $changeable = false;
322
        if (isset($rootsettings['contentbankcontent']) && $rootsettings['contentbankcontent']) { // Only enabled when available.
323
            $defaultvalue = true;
324
            $changeable = true;
325
        }
326
        $contents = new restore_contentbankcontent_setting('contentbankcontent', base_setting::IS_BOOLEAN, $defaultvalue);
327
        $contents->set_ui(new backup_setting_ui_checkbox($contents, get_string('rootsettingcontentbankcontent', 'backup')));
328
        $contents->get_ui()->set_changeable($changeable);
329
        $this->add_setting($contents);
330
 
331
        // Define xAPI states.
332
        $defaultvalue = false;
333
        $changeable = false;
334
        if (isset($rootsettings['xapistate']) && $rootsettings['xapistate']) { // Only enabled when available.
335
            $defaultvalue = true;
336
            $changeable = true;
337
        }
338
        $xapistate = new restore_xapistate_setting('xapistate', base_setting::IS_BOOLEAN, $defaultvalue);
339
        $xapistate->set_ui(new backup_setting_ui_checkbox($xapistate, get_string('rootsettingxapistate', 'backup')));
340
        $xapistate->get_ui()->set_changeable($changeable);
341
        $this->add_setting($xapistate);
342
 
343
        // Include legacy files.
344
        $defaultvalue = true;
345
        $changeable = true;
346
        $legacyfiles = new restore_generic_setting('legacyfiles', base_setting::IS_BOOLEAN, $defaultvalue);
347
        $legacyfiles->set_ui(new backup_setting_ui_checkbox($legacyfiles, get_string('rootsettinglegacyfiles', 'backup')));
348
        $legacyfiles->get_ui()->set_changeable($changeable);
349
        $this->add_setting($legacyfiles);
1441 ariadna 350
 
351
        // Create and dispatch a hook to allow plugins to add other settings for the restore process.
352
        $hook = new after_restore_root_define_settings($this);
353
        di::get(manager::class)->dispatch($hook);
1 efrain 354
    }
355
}