.
/**
* 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;
}
}