Merge branch 'MDL-59467-main' of https://github.com/andrewnicols/moodle
[moodle.git] / backup / restorefile.php
blob63c65107e3161c35de9442f8327309e0b9b57952
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.
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 * Import backup file or select existing backup file from moodle
20 * @package moodlecore
21 * @copyright 2010 Dongsheng Cai <dongsheng@moodle.com>
22 * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
25 require_once('../config.php');
26 require_once(__DIR__ . '/restorefile_form.php');
27 require_once($CFG->dirroot . '/backup/util/includes/restore_includes.php');
29 // current context
30 $contextid = required_param('contextid', PARAM_INT);
31 $filecontextid = optional_param('filecontextid', 0, PARAM_INT);
32 // action
33 $action = optional_param('action', '', PARAM_ALPHA);
34 // file parameters
35 // non js interface may require these parameters
36 $component = optional_param('component', null, PARAM_COMPONENT);
37 $filearea = optional_param('filearea', null, PARAM_AREA);
38 $itemid = optional_param('itemid', null, PARAM_INT);
39 $filepath = optional_param('filepath', null, PARAM_PATH);
40 $filename = optional_param('filename', null, PARAM_FILE);
42 list($context, $course, $cm) = get_context_info_array($contextid);
44 // will be used when restore
45 if (!empty($filecontextid)) {
46 $filecontext = context::instance_by_id($filecontextid);
49 $url = new moodle_url('/backup/restorefile.php', array('contextid'=>$contextid));
51 $PAGE->set_url($url);
52 $PAGE->set_context($context);
54 switch ($context->contextlevel) {
55 case CONTEXT_COURSECAT:
56 core_course_category::page_setup();
57 break;
58 case CONTEXT_MODULE:
59 $PAGE->set_heading(get_string('restoreactivity', 'backup'));
60 break;
61 case CONTEXT_COURSE:
62 $course = get_course($context->instanceid);
63 $PAGE->set_heading($course->fullname);
64 $PAGE->set_secondary_active_tab('coursereuse');
65 break;
66 default:
67 $PAGE->set_heading($SITE->fullname);
71 require_login($course, false, $cm);
72 require_capability('moodle/restore:restorecourse', $context);
74 if (is_null($course)) {
75 $courseid = 0;
76 $coursefullname = $SITE->fullname;
77 } else {
78 $courseid = $course->id;
79 $coursefullname = $course->fullname;
82 $browser = get_file_browser();
84 // check if tmp dir exists
85 $tmpdir = make_backup_temp_directory('', false);
86 if (!check_dir_exists($tmpdir, true, true)) {
87 throw new restore_controller_exception('cannot_create_backup_temp_dir');
90 // choose the backup file from backup files tree
91 if ($action == 'choosebackupfile') {
92 if ($filearea == 'automated') {
93 require_capability('moodle/restore:viewautomatedfilearea', $context);
95 if ($fileinfo = $browser->get_file_info($filecontext, $component, $filearea, $itemid, $filepath, $filename)) {
96 if (is_a($fileinfo, 'file_info_stored')) {
97 // Use the contenthash rather than copying the file where possible,
98 // to improve performance and avoid timeouts with large files.
99 $fs = get_file_storage();
100 $params = $fileinfo->get_params();
101 $file = $fs->get_file($params['contextid'], $params['component'], $params['filearea'],
102 $params['itemid'], $params['filepath'], $params['filename']);
103 $restore_url = new moodle_url('/backup/restore.php', array('contextid' => $contextid,
104 'pathnamehash' => $file->get_pathnamehash(), 'contenthash' => $file->get_contenthash()));
105 } else {
106 // If it's some weird other kind of file then use old code.
107 $filename = restore_controller::get_tempdir_name($courseid, $USER->id);
108 $pathname = $tmpdir . '/' . $filename;
109 if (!$fileinfo->copy_to_pathname($pathname)) {
110 throw new restore_ui_exception('errorcopyingbackupfile', null, $pathname);
112 $restore_url = new moodle_url('/backup/restore.php', array(
113 'contextid' => $contextid, 'filename' => $filename));
115 redirect($restore_url);
116 } else {
117 redirect($url, get_string('filenotfound', 'error'));
119 die;
122 $PAGE->set_title(get_string('course') . ': ' . $coursefullname);
123 $PAGE->set_pagelayout('admin');
124 $PAGE->activityheader->disable();
125 $PAGE->requires->js_call_amd('core_backup/async_backup', 'asyncBackupAllStatus', array($context->id));
127 $form = new course_restore_form(null, array('contextid'=>$contextid));
128 $data = $form->get_data();
129 if ($data && has_capability('moodle/restore:uploadfile', $context)) {
130 $filename = restore_controller::get_tempdir_name($courseid, $USER->id);
131 $pathname = $tmpdir . '/' . $filename;
132 if (!$form->save_file('backupfile', $pathname)) {
133 throw new restore_ui_exception('errorcopyingbackupfile', null, $pathname);
135 $restore_url = new moodle_url('/backup/restore.php', array('contextid'=>$contextid, 'filename'=>$filename));
136 redirect($restore_url);
137 die;
140 echo $OUTPUT->header();
141 \backup_helper::print_coursereuse_selector('restore');
142 echo html_writer::tag('div', get_string('restoreinfo'), ['class' => 'pb-3']);
144 // require uploadfile cap to use file picker
145 if (has_capability('moodle/restore:uploadfile', $context)) {
146 echo $OUTPUT->heading(get_string('importfile', 'backup'));
147 echo $OUTPUT->container_start();
148 $form->display();
149 echo $OUTPUT->container_end();
152 // Activity backup area.
153 if ($context->contextlevel == CONTEXT_MODULE) {
154 $treeviewoptions = [
155 'filecontext' => $context,
156 'currentcontext' => $context,
157 'component' => 'backup',
158 'context' => $context,
159 'filearea' => 'activity',
161 $renderer = $PAGE->get_renderer('core', 'backup');
162 echo $renderer->backup_files_viewer($treeviewoptions);
163 // Update the course context with the proper value, because $context contains the module context.
164 $coursecontext = \context_course::instance($course->id);
165 } else {
166 $coursecontext = $context;
169 // Course backup area.
170 $treeviewoptions = [
171 'filecontext' => $coursecontext,
172 'currentcontext' => $context,
173 'component' => 'backup',
174 'context' => $context,
175 'filearea' => 'course',
177 $renderer = $PAGE->get_renderer('core', 'backup');
178 echo $renderer->backup_files_viewer($treeviewoptions);
180 // Private backup area.
181 $usercontext = context_user::instance($USER->id);
182 $treeviewoptions = [
183 'filecontext' => $usercontext,
184 'currentcontext' => $context,
185 'component' => 'user',
186 'context' => 'backup',
187 'filearea' => 'backup',
189 $renderer = $PAGE->get_renderer('core', 'backup');
190 echo $renderer->backup_files_viewer($treeviewoptions);
192 // Automated backup area.
193 $automatedbackups = get_config('backup', 'backup_auto_active');
194 if (!empty($automatedbackups)) {
195 $treeviewoptions = [
196 'filecontext' => $context,
197 'currentcontext' => $context,
198 'component' => 'backup',
199 'context' => $context,
200 'filearea' => 'automated',
202 $renderer = $PAGE->get_renderer('core', 'backup');
203 echo $renderer->backup_files_viewer($treeviewoptions);
206 // In progress course restores.
207 if (async_helper::is_async_enabled()) {
208 echo $OUTPUT->heading_with_help(get_string('asyncrestoreinprogress', 'backup'), 'asyncrestoreinprogress', 'backup');
209 echo $OUTPUT->container_start();
210 $renderer = $PAGE->get_renderer('core', 'backup');
211 echo $renderer->restore_progress_viewer($USER->id, $context);
212 echo $OUTPUT->container_end();
215 echo $OUTPUT->footer();