Merge branch 'wip-MDL-60241-33' of git://github.com/marinaglancy/moodle into MOODLE_3...
[moodle.git] / backup / restorefile.php
blob7b0fcd29690b1199d2658a708686acff15caa8bf
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 switch ($context->contextlevel) {
52 case CONTEXT_MODULE:
53 $heading = get_string('restoreactivity', 'backup');
54 break;
55 case CONTEXT_COURSE:
56 default:
57 $heading = get_string('restorecourse', 'backup');
61 require_login($course, false, $cm);
62 require_capability('moodle/restore:restorecourse', $context);
64 if (is_null($course)) {
65 $courseid = 0;
66 $coursefullname = $SITE->fullname;
67 } else {
68 $courseid = $course->id;
69 $coursefullname = $course->fullname;
72 $browser = get_file_browser();
74 // check if tmp dir exists
75 $tmpdir = $CFG->tempdir . '/backup';
76 if (!check_dir_exists($tmpdir, true, true)) {
77 throw new restore_controller_exception('cannot_create_backup_temp_dir');
80 // choose the backup file from backup files tree
81 if ($action == 'choosebackupfile') {
82 if ($fileinfo = $browser->get_file_info($filecontext, $component, $filearea, $itemid, $filepath, $filename)) {
83 if (is_a($fileinfo, 'file_info_stored')) {
84 // Use the contenthash rather than copying the file where possible,
85 // to improve performance and avoid timeouts with large files.
86 $fs = get_file_storage();
87 $params = $fileinfo->get_params();
88 $file = $fs->get_file($params['contextid'], $params['component'], $params['filearea'],
89 $params['itemid'], $params['filepath'], $params['filename']);
90 $restore_url = new moodle_url('/backup/restore.php', array('contextid' => $contextid,
91 'pathnamehash' => $file->get_pathnamehash(), 'contenthash' => $file->get_contenthash()));
92 } else {
93 // If it's some weird other kind of file then use old code.
94 $filename = restore_controller::get_tempdir_name($courseid, $USER->id);
95 $pathname = $tmpdir . '/' . $filename;
96 if (!$fileinfo->copy_to_pathname($pathname)) {
97 throw new restore_ui_exception('errorcopyingbackupfile', null, $pathname);
99 $restore_url = new moodle_url('/backup/restore.php', array(
100 'contextid' => $contextid, 'filename' => $filename));
102 redirect($restore_url);
103 } else {
104 redirect($url, get_string('filenotfound', 'error'));
106 die;
109 $PAGE->set_url($url);
110 $PAGE->set_context($context);
111 $PAGE->set_title(get_string('course') . ': ' . $coursefullname);
112 $PAGE->set_heading($heading);
113 $PAGE->set_pagelayout('admin');
115 $form = new course_restore_form(null, array('contextid'=>$contextid));
116 $data = $form->get_data();
117 if ($data && has_capability('moodle/restore:uploadfile', $context)) {
118 $filename = restore_controller::get_tempdir_name($courseid, $USER->id);
119 $pathname = $tmpdir . '/' . $filename;
120 if (!$form->save_file('backupfile', $pathname)) {
121 throw new restore_ui_exception('errorcopyingbackupfile', null, $pathname);
123 $restore_url = new moodle_url('/backup/restore.php', array('contextid'=>$contextid, 'filename'=>$filename));
124 redirect($restore_url);
125 die;
130 echo $OUTPUT->header();
132 // require uploadfile cap to use file picker
133 if (has_capability('moodle/restore:uploadfile', $context)) {
134 echo $OUTPUT->heading(get_string('importfile', 'backup'));
135 echo $OUTPUT->container_start();
136 $form->display();
137 echo $OUTPUT->container_end();
140 if ($context->contextlevel == CONTEXT_MODULE) {
141 echo $OUTPUT->heading_with_help(get_string('choosefilefromactivitybackup', 'backup'), 'choosefilefromuserbackup', 'backup');
142 echo $OUTPUT->container_start();
143 $treeview_options = array();
144 $user_context = context_user::instance($USER->id);
145 $treeview_options['filecontext'] = $context;
146 $treeview_options['currentcontext'] = $context;
147 $treeview_options['component'] = 'backup';
148 $treeview_options['context'] = $context;
149 $treeview_options['filearea'] = 'activity';
150 $renderer = $PAGE->get_renderer('core', 'backup');
151 echo $renderer->backup_files_viewer($treeview_options);
152 echo $OUTPUT->container_end();
155 echo $OUTPUT->heading_with_help(get_string('choosefilefromcoursebackup', 'backup'), 'choosefilefromcoursebackup', 'backup');
156 echo $OUTPUT->container_start();
157 $treeview_options = array();
158 $treeview_options['filecontext'] = $context;
159 $treeview_options['currentcontext'] = $context;
160 $treeview_options['component'] = 'backup';
161 $treeview_options['context'] = $context;
162 $treeview_options['filearea'] = 'course';
163 $renderer = $PAGE->get_renderer('core', 'backup');
164 echo $renderer->backup_files_viewer($treeview_options);
165 echo $OUTPUT->container_end();
167 echo $OUTPUT->heading_with_help(get_string('choosefilefromuserbackup', 'backup'), 'choosefilefromuserbackup', 'backup');
168 echo $OUTPUT->container_start();
169 $treeview_options = array();
170 $user_context = context_user::instance($USER->id);
171 $treeview_options['filecontext'] = $user_context;
172 $treeview_options['currentcontext'] = $context;
173 $treeview_options['component'] = 'user';
174 $treeview_options['context'] = 'backup';
175 $treeview_options['filearea'] = 'backup';
176 $renderer = $PAGE->get_renderer('core', 'backup');
177 echo $renderer->backup_files_viewer($treeview_options);
178 echo $OUTPUT->container_end();
180 $automatedbackups = get_config('backup', 'backup_auto_active');
181 if (!empty($automatedbackups)) {
182 echo $OUTPUT->heading_with_help(get_string('choosefilefromautomatedbackup', 'backup'), 'choosefilefromautomatedbackup', 'backup');
183 echo $OUTPUT->container_start();
184 $treeview_options = array();
185 $user_context = context_user::instance($USER->id);
186 $treeview_options['filecontext'] = $context;
187 $treeview_options['currentcontext'] = $context;
188 $treeview_options['component'] = 'backup';
189 $treeview_options['context'] = $context;
190 $treeview_options['filearea'] = 'automated';
191 $renderer = $PAGE->get_renderer('core', 'backup');
192 echo $renderer->backup_files_viewer($treeview_options);
193 echo $OUTPUT->container_end();
196 echo $OUTPUT->footer();