From dd454f4661d2c1dea407f6f7251e895a96955a5f Mon Sep 17 00:00:00 2001 From: danmarsden Date: Wed, 28 Jul 2010 08:31:35 +0000 Subject: [PATCH] MDL-23479 folder Restore code --- .../restore_folder_activity_task.class.php | 75 +++++++++++++++++++ .../moodle2/restore_folder_stepslib.php | 61 +++++++++++++++ 2 files changed, 136 insertions(+) create mode 100644 mod/folder/backup/moodle2/restore_folder_activity_task.class.php create mode 100644 mod/folder/backup/moodle2/restore_folder_stepslib.php diff --git a/mod/folder/backup/moodle2/restore_folder_activity_task.class.php b/mod/folder/backup/moodle2/restore_folder_activity_task.class.php new file mode 100644 index 00000000000..dec8b721d09 --- /dev/null +++ b/mod/folder/backup/moodle2/restore_folder_activity_task.class.php @@ -0,0 +1,75 @@ +. + +/** + * @package moodlecore + * @subpackage backup-moodle2 + * @copyright 2010 onwards Eloy Lafuente (stronk7) {@link http://stronk7.com} + * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later + */ + +defined('MOODLE_INTERNAL') || die(); + +require_once($CFG->dirroot . '/mod/folder/backup/moodle2/restore_folder_stepslib.php'); // Because it exists (must) + +/** + * folder restore task that provides all the settings and steps to perform one + * complete restore of the activity + */ +class restore_folder_activity_task extends restore_activity_task { + + /** + * Define (add) particular settings this activity can have + */ + protected function define_my_settings() { + // No particular settings for this activity + } + + /** + * Define (add) particular steps this activity can have + */ + protected function define_my_steps() { + // folder only has one structure step + $this->add_step(new restore_folder_activity_structure_step('folder_structure', 'folder.xml')); + } + + /** + * Define the contents in the activity that must be + * processed by the link decoder + */ + static public function define_decode_contents() { + $contents = array(); + + $contents[] = new restore_decode_content('folder', array('intro'), 'folder'); + + return $contents; + } + + /** + * Define the decoding rules for links belonging + * to the activity to be executed by the link decoder + */ + static public function define_decode_rules() { + $rules = array(); + + $rules[] = new restore_decode_rule('FOLDERVIEWBYID', '/mod/folder/view.php?id=$1', 'course_module'); + $rules[] = new restore_decode_rule('FOLDERINDEX', '/mod/folder/index.php?id=$1', 'course'); + + return $rules; + + } +} diff --git a/mod/folder/backup/moodle2/restore_folder_stepslib.php b/mod/folder/backup/moodle2/restore_folder_stepslib.php new file mode 100644 index 00000000000..c77d268bfcd --- /dev/null +++ b/mod/folder/backup/moodle2/restore_folder_stepslib.php @@ -0,0 +1,61 @@ +. + +/** + * @package moodlecore + * @subpackage backup-moodle2 + * @copyright 2010 onwards Eloy Lafuente (stronk7) {@link http://stronk7.com} + * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later + */ + +/** + * Define all the restore steps that will be used by the restore_folder_activity_task + */ + +/** + * Structure step to restore one folder activity + */ +class restore_folder_activity_structure_step extends restore_activity_structure_step { + + protected function define_structure() { + + $paths = array(); + $paths[] = new restore_path_element('folder', '/activity/folder'); + + // Return the paths wrapped into standard activity structure + return $this->prepare_activity_structure($paths); + } + + protected function process_folder($data) { + global $DB; + + $data = (object)$data; + $oldid = $data->id; + $data->course = $this->get_courseid(); + + // insert the folder record + $newitemid = $DB->insert_record('folder', $data); + // inmediately after inserting "activity" record, call this + $this->apply_activity_instance($newitemid); + } + + protected function after_execute() { + // Add folder related files, no need to match by itemname (just internally handled context) + $this->add_related_files('mod_folder', 'intro', null); + $this->add_related_files('mod_folder', 'content', null); + } +} -- 2.43.0