<?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 */ /** * Abstract class defining the needed stuf for one restore task (a collection of steps) * * TODO: Finish phpdocs */ abstract class restore_task extends base_task { /** * Constructor - instantiates one object of this class */ public function __construct($name, $plan = null) { if (!is_null($plan) && !($plan instanceof restore_plan)) { throw new restore_task_exception('wrong_restore_plan_specified'); } parent::__construct($name, $plan); } public function get_restoreid() { return $this->plan->get_restoreid(); } public function get_info() { return $this->plan->get_info(); } public function get_target() { return $this->plan->get_target(); } public function get_userid() { return $this->plan->get_userid(); } public function get_decoder() { return $this->plan->get_decoder(); } public function is_samesite() { return $this->plan->is_samesite(); } public function is_missing_modules() { return $this->plan->is_missing_modules(); } public function is_excluding_activities() { return $this->plan->is_excluding_activities(); } public function set_preloaded_information() { $this->plan->set_preloaded_information(); } public function get_preloaded_information() { return $this->plan->get_preloaded_information(); } public function get_tempdir() { return $this->plan->get_tempdir(); } public function get_old_courseid() { return $this->plan->get_info()->original_course_id; } public function get_old_contextid() { return $this->plan->get_info()->original_course_contextid; } public function get_old_system_contextid() { return $this->plan->get_info()->original_system_contextid; } /**> * Given a commment area, return the itemname that contains the itemid mappings * If the task has been executed, launch its after_restore() > * * method if available > * By default, both are the same (commentarea = itemname), so return it. If some */ > * plugins use a different approach, this method can be overriden in its task. public function execute_after_restore() { > * if ($this->executed) { > * @param string $commentarea area defined for this comment foreach ($this->steps as $step) { > * @return string itemname that contains the related itemid mapping if (method_exists($step, 'launch_after_restore_methods')) { > */ $step->launch_after_restore_methods(); > public function get_comment_mapping_itemname($commentarea) { } > return $commentarea; } > } } > if ($this->executed && method_exists($this, 'after_restore')) { > /**$this->after_restore(); }> } } > } > /** > * Compares the provided moodle version with the one the backup was taken from. /* > * * Exception class used by all the @restore_task stuff > * @param int $version Moodle version number (YYYYMMDD or YYYYMMDDXX) */ > * @param string $operator Operator to compare the provided version to the backup version. {@see version_compare()} class restore_task_exception extends base_task_exception { > * @return bool True if the comparison passes. > */ public function __construct($errorcode, $a=NULL, $debuginfo=null) { > public function backup_version_compare(int $version, string $operator) { parent::__construct($errorcode, $a, $debuginfo); > return $this->plan->backup_version_compare($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) { > return $this->plan->backup_release_compare($release, $operator);