. /** * This file contains the backup tasks that provides all the settings and steps to perform a backup of the activity. * * @package mod_htmlcert * @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/htmlcert/backup/moodle2/backup_htmlcert_stepslib.php'); /** * Handles creating tasks to peform in order to create the backup. * * @package mod_htmlcert * @copyright 2013 Mark Nelson , 2021 Klaus-Uwe Mitterer * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ class backup_htmlcert_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 htmlcert only has one structure step. $this->add_step(new backup_htmlcert_activity_structure_step('htmlcert_structure', 'htmlcert.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 the list of htmlcerts. $search = "/(".$base."\/mod\/htmlcert\/index.php\?id\=)([0-9]+)/"; $content = preg_replace($search, '$@HTMLCERTINDEX*$2@$', $content); // Link to htmlcert view by moduleid. $search = "/(".$base."\/mod\/htmlcert\/view.php\?id\=)([0-9]+)/"; $content = preg_replace($search, '$@HTMLCERTVIEWBYID*$2@$', $content); return $content; } }