. /** * This file contains the backup tasks that provides all the settings and steps to perform a backup of the activity. * * @package mod_expcontent * @copyright 2013 Mark Nelson , 2021 Klaus-Uwe Mitterer * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ defined('MOODLE_INTERNAL') || die('Direct access to this script is forbidden.'); require_once($CFG->dirroot . '/mod/expcontent/backup/moodle2/backup_expcontent_stepslib.php'); /** * Handles creating tasks to peform in order to create the backup. * * @package mod_expcontent * @copyright 2013 Mark Nelson , 2021 Klaus-Uwe Mitterer * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ class backup_expcontent_activity_task extends backup_activity_task { /** * Define particular settings this activity can have. */ protected function define_my_settings() { // No particular settings for this activity. } /** * Define particular steps this activity can have. */ protected function define_my_steps() { // The expcontent only has one structure step. $this->add_step(new backup_expcontent_activity_structure_step('expcontent_structure', 'expcontent.xml')); } /** * Code the transformations to perform in the activity in order to get transportable (encoded) links. * * @param string $content * @return mixed|string */ public static function encode_content_links($content) { global $CFG; $base = preg_quote($CFG->wwwroot, "/"); // Link to expcontent view by moduleid. $search = "/(".$base."\/mod\/expcontent\/view.php\?id\=)([0-9]+)/"; $content = preg_replace($search, '$@EXPCONTENTVIEWBYID*$2@$', $content); return $content; } }