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