See Release Notes
Long Term Support Release
<?php // This file is part of Moodle - http://moodle.org/ // // Moodle is free software: you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // // Moodle is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // // You should have received a copy of the GNU General Public License // along with Moodle. If not, see <http://www.gnu.org/licenses/>. /** * @package moodlecore * @subpackage backup-plan * @copyright 2010 onwards Eloy Lafuente (stronk7) {@link http://stronk7.com} * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ /** * Implementable class defining the needed stuf for one restore plan * * TODO: Finish phpdocs */ class restore_plan extends base_plan implements loggable { /** * * @var restore_controller */ protected $controller; // The restore controller building/executing this plan protected $basepath; // Fullpath to dir where backup is available protected $preloaded; // When executing the plan, do we have preloaded (from checks) info protected $decoder; // restore_decode_processor in charge of decoding all the interlinks protected $missingmodules; // to flag if restore has detected some missing module protected $excludingdactivities; // to flag if restore settings are excluding any activity /** * Constructor - instantiates one object of this class */ public function __construct($controller) { global $CFG; if (! $controller instanceof restore_controller) { throw new restore_plan_exception('wrong_restore_controller_specified'); } $backuptempdir = make_backup_temp_directory(''); $this->controller = $controller; $this->basepath = $backuptempdir . '/' . $controller->get_tempdir(); $this->preloaded = false; $this->decoder = new restore_decode_processor($this->get_restoreid(), $this->get_info()->original_wwwroot, $CFG->wwwroot); $this->missingmodules = false; $this->excludingdactivities = false; parent::__construct('restore_plan'); } /** * Destroy all circular references. It helps PHP 5.2 a lot! */ public function destroy() { // No need to destroy anything recursively here, direct reset $this->controller = null; // Delegate to base plan the rest parent::destroy(); } public function build() { restore_plan_builder::build_plan($this->controller); // We are moodle2 always, go straight to builder $this->built = true; } public function get_restoreid() { return $this->controller->get_restoreid(); } public function get_courseid() { return $this->controller->get_courseid(); } public function get_mode() { return $this->controller->get_mode(); } public function get_basepath() { return $this->basepath; } public function get_logger() { return $this->controller->get_logger(); } /** * Gets the progress reporter, which can be used to report progress within * the backup or restore process. * * @return \core\progress\base Progress reporting object */ public function get_progress() { return $this->controller->get_progress(); } public function get_info() { return $this->controller->get_info(); } public function get_target() { return $this->controller->get_target(); } public function get_userid() { return $this->controller->get_userid(); } public function get_decoder() { return $this->decoder; } public function is_samesite() { return $this->controller->is_samesite(); } public function is_missing_modules() { return $this->missingmodules; } public function is_excluding_activities() { return $this->excludingdactivities; } public function set_preloaded_information() { $this->preloaded = true; } public function get_preloaded_information() { return $this->preloaded; } public function get_tempdir() { return $this->controller->get_tempdir(); } public function set_missing_modules() { $this->missingmodules = true; } public function set_excluding_activities() { $this->excludingdactivities = true; } public function log($message, $level, $a = null, $depth = null, $display = false) { backup_helper::log($message, $level, $a, $depth, $display, $this->get_logger()); } /** * Function responsible for executing the tasks of any plan */ public function execute() { if ($this->controller->get_status() != backup::STATUS_AWAITING) { throw new restore_controller_exception('restore_not_executable_awaiting_required', $this->controller->get_status()); } $this->controller->set_status(backup::STATUS_EXECUTING); parent::execute(); $this->controller->set_status(backup::STATUS_FINISHED_OK); // Check if we are restoring a course. if ($this->controller->get_type() === backup::TYPE_1COURSE) { // Check to see if we are on the same site to pass original course info. $issamesite = $this->controller->is_samesite(); $otherarray = array('type' => $this->controller->get_type(), 'target' => $this->controller->get_target(), 'mode' => $this->controller->get_mode(), 'operation' => $this->controller->get_operation(), 'samesite' => $issamesite ); if ($this->controller->is_samesite()) { $otherarray['originalcourseid'] = $this->controller->get_info()->original_course_id; } // Trigger a course restored event. $event = \core\event\course_restored::create(array( 'objectid' => $this->get_courseid(), 'userid' => $this->get_userid(), 'context' => context_course::instance($this->get_courseid()), 'other' => $otherarray )); $event->trigger(); } } /** * Execute the after_restore methods of all the executed tasks in the plan */ public function execute_after_restore() { // Simply iterate over each task in the plan and delegate to them the execution> $progress = $this->get_progress(); foreach ($this->tasks as $task) { > $progress->start_progress($this->get_name() . $task->execute_after_restore(); > ': executing execute_after_restore for all tasks', count($this->tasks)); } > } > /** @var base_task $task */}> $progress->increment_progress();> $progress->end_progress(); /* > } * Exception class used by all the @restore_plan stuff > */ > /** class restore_plan_exception extends base_plan_exception { > * Compares the provided moodle version with the one the backup was taken from. > * public function __construct($errorcode, $a=NULL, $debuginfo=null) { > * @param int $version Moodle version number (YYYYMMDD or YYYYMMDDXX) parent::__construct($errorcode, $a, $debuginfo); > * @param string $operator Operator to compare the provided version to the backup version. {@see version_compare()} } > * @return bool True if the comparison passes. } > */ > public function backup_version_compare(int $version, string $operator): bool { > preg_match('/(\d{' . strlen($version) . '})/', $this->get_info()->moodle_version, $matches); > $backupbuild = (int)$matches[1]; > return version_compare($backupbuild, $version, $operator); > } > > /** > * Compares the provided moodle release with the one the backup was taken from. > * > * @param string $release Moodle release (X.Y or X.Y.Z) > * @param string $operator Operator to compare the provided release to the backup release. {@see version_compare()} > * @return bool True if the comparison passes. > */ > public function backup_release_compare(string $release, string $operator): bool { > return version_compare($this->get_info()->backup_release, $release, $operator);