Ir a la última revisión | Autoría | Comparar con el anterior | Ultima modificación | Ver Log |
<?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/>./*** Base class with shared stuff between backup controller and restore* controller.** @package core_backup* @copyright 2013 The Open University* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later*/abstract class base_controller extends backup implements loggable {/*** @var \core\progress\base Progress reporting object.*/protected $progress;/*** @var base_logger Logging chain object (moodle, inline, fs, db, syslog)*/protected $logger;/** @var bool Whether this backup should release the session. */protected $releasesession = backup::RELEASESESSION_NO;/*** Holds the relevant destination information for course copy operations.** @var \stdClass.*/protected $copy;/** @var int Backup mode. */protected $mode;/*** 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->progress;}/*** Sets the progress reporter.** @param \core\progress\base $progress Progress reporting object*/public function set_progress(\core\progress\base $progress) {$this->progress = $progress;}/*** Gets first logger in logging chain.** @return base_logger Logger*/public function get_logger() {return $this->logger;}/*** Inserts a new logger at end of logging chain.** @param base_logger $logger New logger to add*/public function add_logger(base_logger $logger) {$existing = $this->logger;while ($existing->get_next()) {$existing = $existing->get_next();}$existing->set_next($logger);}/*** Logs data to the logger chain.** @see loggable::log()*/public function log($message, $level, $a = null, $depth = null, $display = false) {backup_helper::log($message, $level, $a, $depth, $display, $this->logger);}/*** Returns the set value of releasesession.* This is used to indicate if the session should be closed during the backup/restore.** @return bool Indicates whether the session should be released.*/public function get_releasesession() {return $this->releasesession;}/*** Store extra data for course copy operations.** For a course copying these is data required to be passed to the restore step.* We store this data in its own section of the backup controller** @param \stdClass $data The course copy data.* @throws backup_controller_exception* @deprecated since Moodle 4.1 MDL-74548 - please do not use this method anymore.* @todo MDL-75025 This method will be deleted in Moodle 4.5* @see restore_controller::__construct()*/public function set_copy(\stdClass $data): void {debugging('The method base_controller::set_copy() is deprecated.Please use the restore_controller class instead.', DEBUG_DEVELOPER);// Only allow setting of copy data when controller is in copy mode.if ($this->mode != backup::MODE_COPY) {throw new backup_controller_exception('cannot_set_copy_vars_wrong_mode');}$this->copy = $data;}/*** Get the course copy data.** @return \stdClass* @deprecated since Moodle 4.1 MDL-74548 - please do not use this method anymore.* @todo MDL-75026 This method will be deleted in Moodle 4.5* @see restore_controller::get_copy()*/public function get_copy(): \stdClass {debugging('The method base_controller::get_copy() is deprecated.Please use restore_controller::get_copy() instead.', DEBUG_DEVELOPER);return $this->copy;}}