diff --git a/data/component-spelling.txt b/data/component-spelling.txt index 314cbcc9c5..49d70ef7ae 100644 --- a/data/component-spelling.txt +++ b/data/component-spelling.txt @@ -23,6 +23,7 @@ cohort comment competency completion +configdata contentbank contenttype countries @@ -94,6 +95,8 @@ repository role rss search +settingslib +stepslib table tag theme diff --git a/data/migratedPages.yml b/data/migratedPages.yml index 5e93063fa2..ef97f9a1f8 100644 --- a/data/migratedPages.yml +++ b/data/migratedPages.yml @@ -40,6 +40,9 @@ Automated_Manipulation_of_Strings_2.0: Automated_code_review: - filePath: "/general/development/tools/cibot.md" slug: "/general/development/tools/cibot" +Backup_API: +- filePath: "/docs/apis/subsystems/backup/index.md" + slug: "/docs/apis/subsystems/backup/" Behat_integration: - filePath: "/general/development/tools/behat/index.md" slug: "/general/development/tools/behat/" @@ -1464,6 +1467,9 @@ Repository_API: Repository_plugins: - filePath: "/docs/apis/plugintypes/repository/index" slug: "/docs/apis/plugintypes/repository" +Restore_API: +- filePath: "/docs/apis/subsystems/backup/restore.md" + slug: "/docs/apis/subsystems/backup/restore" Roadmap: - filePath: "/general/community/roadmap.md" slug: "/general/community/roadmap" diff --git a/docs/apis.md b/docs/apis.md index 548ff1e88c..c7565beba8 100644 --- a/docs/apis.md +++ b/docs/apis.md @@ -74,7 +74,7 @@ The [Availability API](https://docs.moodle.org/dev/Availability_API) controls ac ### Backup API (backup) -The [Backup API](https://docs.moodle.org/dev/Backup_API) defines exactly how to convert course data into XML for backup purposes, and the [Restore API](https://docs.moodle.org/dev/Restore_API) describes how to convert it back the other way. +The [Backup API](./apis/subsystems/backup/index.md) defines exactly how to convert course data into XML for backup purposes, and the [Restore API](./apis/subsystems/backup/restore.md) describes how to convert it back the other way. ### Cache API (cache) diff --git a/docs/apis/subsystems/backup/index.md b/docs/apis/subsystems/backup/index.md new file mode 100644 index 0000000000..3e1198eedd --- /dev/null +++ b/docs/apis/subsystems/backup/index.md @@ -0,0 +1,119 @@ +--- +title: Backup API +tags: + - Subsystem + - API + - Backup +--- +The Backup API provides a way to include your plugin's in the course backup. See [Restore API](./restore.md) for the part that takes care of restoring data. + +## Overview + +This page provides just a quick reference to the backup machinery in Moodle 2.0 and higher. There is a detailed documentation available at [Backup 2.0](https://docs.moodle.org/dev/Backup_2.0) page - see especially the tutorial for plugin authors at [Backup 2.0 for developers](https://docs.moodle.org/dev/Backup_2.0_for_developers) page. + +Moodle creates backups of courses or their parts by executing so called *backup plan*. The backup plan consists of a set of *backup tasks* and finally each backup task consists of one or more *backup steps*. You as the developer of a plugin will have to implement one backup task that deals with your plugin data. Most plugins have their backup tasks consisting of a single backup step - the one that creates the XML file with data from your plugin's tables. Some activities may need two or more steps to finish their backup task though (for example the backup task of the Quiz module consists of three steps as it needs to write not just the Quiz setting itself but also the questions used by that particular quiz). + +There are subtle differences in how the backup code is organised in various supported plugin types (activity modules, blocks, themes, course reports). + +## API for activity modules + +### Files + +The files that implement the backup support in your activity module must be located in the subdirectory backup/moodle2/ in your plugin's folder. So, if you are developing the activity module called *foobar* then the backup files will be located in mod/foobar/backup/moodle2/ folder. + +The following two files are supposed to exist in that location (replace *foobar* with the name of your module): + +- **backup_foobar_activity_task.class.php**
+Provides the activity task class +- **backup_foobar_stepslib.php**
+Provides all the backup steps classes + +If your module declares its own backup setting (apart from the ones common for all activity modules provided by the core), you will also want to create the backup_foobar_settingslib.php file to provide the setting classes. However most modules do not need this feature. + +### Backup task class + +The file backup_foobar_activity_task.class.php must provide a single class called **backup_foobar_activity_task**. All activity tasks extend the backup_activity_task class. + +There are three methods that your class must define. + +- **protected function define_my_settings()**
+If your module declares own backup settings defined in the file backup_foobar_settingslib.php, add them here. Most modules just leave the method body empty. +- **protected function define_my_steps()**
+This method typically consists of one or more `$this->add_step()` calls. This is the place where you define the task as a sequence of steps to execute. +- **static public function encode_content_links($content)**
+The current instance of the activity may be referenced from other places in the course by URLs like `http://my.moodle.site/mod/foobar/view.php?id=42` Obviously, such URLs are not valid any more once the course is restored elsewhere. For this reason the backup file does not store the original URLs but encodes them into a transportable form. During the restore, the reverse process is applied and the encoded URLs are replaced with the new ones valid for the target site. + +### Backup structure step class + +The classes that represent the backup steps added in define_my_steps() are implemented in the file backup_foobar_stepslib.php. Most plugins define just a single step in the class called **backup_foobar_activity_structure_step** that extends the backup_activity_structure_step class. This class defines the structure step - that is the step where the structure of your plugin's instance data is described and linked with the data sources. + +You have to implement a single method `protected function define_structure()` in this class class. There are three main things that the method must do. + +- Create a set of backup_nested_element instances that describe the required data of your plugin +- Connect these instances into a hierarchy using their `add_child()` method +- Set data sources for the elements, using their methods like `set_source_table()` or `set_source_sql()` + +The method must return the root backup_nested_element instance processed by the `prepare_activity_structure()` method (which just wraps your structures with a common envelope). + +## API for blocks + +### Files + +The files that implement the backup support in your block must be located in the subdirectory backup/moodle2/ in your plugin's folder. So, if you are developing the block called *foobar* then the backup files will be located in blocks/foobar/backup/moodle2/ folder. + +At least the file backup_foobar_block_task.class.php is supposed to exist in that location (replace *foobar* with the name of your block). + +If your block defines its own database tables, data from which must be included in the backup, you will want to create a file backup_foobar_stepslib.php, too. Additionally, if your block declares its own backup setting, you will also want to create the backup_foobar_settingslib.php file to provide the setting classes. However most blocks do not need this feature. + +### Backup task class + +The file backup_foobar_block_task.class.php must provide a single class called **backup_foobar_block_task**. All block tasks extend the backup_block_task class. + +There are five methods that your class must define. + +- **protected function define_my_settings()**
+If your block declares own backup settings defined in the file backup_foobar_settingslib.php, add them here. Most blocks just leave the method body empty. +- **protected function define_my_steps()**
+Blocks that do not have their own database tables usually leave this method empty. Otherwise this method consists of one or more `$this->add_step()` calls where you define the task as a sequence of steps to execute. +- **public function get_fileareas()**
+Returns the array of file area names within the block context. +- **public function get_configdata_encoded_attributes()**
+Instead of using their own tables, blocks usually use the configuration tables to hold their data (see the instance_config_save() of the block class). This method returns the array of all config elements that must be processed before they are stored in the backup. This is typically used when the stored config elements holds links to embedded media. Most blocks just return empty array here. +- **static public function encode_content_links($content)**
+If the current instance of the block may be referenced from other places in the course by URLs, it must be encoded into a transportable form. Most blocks just return unmodified $content parameter. + +## API for admin tools + +The files that implement the backup support in your plugin must be located in the subdirectory *backup/moodle2/* in your plugin's folder. So, if you are developing *tool_foobar* then the backup files will be located in *admin/tool/foobar/backup/moodle2/*. + +### Task class + +The file backup_tool_foobar_plugin.class.php must provide a single class called *backup_tool_foobar_task* extending *backup_tool_plugin*. + +Here is a minimalistic task: + +```php +require_once($CFG->dirroot . '/backup/moodle2/backup_tool_plugin.class.php'); + +class backup_tool_foobar_plugin extends backup_tool_plugin { + + protected function define_course_plugin_structure() { + $this->step->log('Yay, backup!', backup::LOG_DEBUG); + return $plugin; + } + +} +``` + +## API for themes + +See [Backup 2.0 theme data](https://docs.moodle.org/dev/Backup_2.0_theme_data) + +## API for reports + +See [Backup 2.0 course report data](https://docs.moodle.org/dev/Backup_2.0_course_report_data) + +## See also + +- [Restore API](./restore.md) +- [Core APIs](../../../apis.md) diff --git a/docs/apis/subsystems/backup/restore.md b/docs/apis/subsystems/backup/restore.md new file mode 100644 index 0000000000..10539c31dc --- /dev/null +++ b/docs/apis/subsystems/backup/restore.md @@ -0,0 +1,58 @@ +--- +title: Restore API +tags: + - Subsystem + - API + - Backup +--- +The Restore API provides a way to restore your plugin's data from a backup file created in Moodle 2.0 or later. For the information on how backup files are created, see [Backup API](./index.md). For the information on how to support restoring data from backup files created in Moodle 1.x, see [Backup conversion API](https://docs.moodle.org/dev/Backup_conversion_API). + +## Overview + +This page provides just a quick reference to the restore machinery in Moodle 2.0 and higher. There is a detailed documentation available at [Backup 2.0](https://docs.moodle.org/dev/Backup_2.0) page - see especially the tutorial for plugin authors at [Restore 2.0 for developers](https://docs.moodle.org/dev/Restore_2.0_for_developers) page. + +Moodle restores data from course backups by executing so called *restore plan*. The restore plan consists of a set of *restore tasks* and finally each restore task consists of one or more *restore steps*. You as the developer of a plugin will have to implement one restore task that deals with your plugin data. Most plugins have their restore tasks consisting of a single restore step - the one that parses the plugin XML file and puts the data into its tables. + +## API for activity modules + +### Files + +The files that implement the restore support in your activity module must be located in the subdirectory `backup/moodle2/` in your plugin's folder (yes, it's the same folder where the backup related files are located). So, if you are developing the activity module called *foobar* then the restore files will be located in `mod/foobar/backup/moodle2/` folder. + +The following two files are supposed to exist in that location (replace *foobar* with the name of your module): + +- **restore_foobar_activity_task.class.php**
+Provides the activity task class +- **restore_foobar_stepslib.php**
+Provides all the restore steps classes + +(to be continued) + +## API for admin tools + +The files that implement the backup support in your plugin must be located in the subdirectory `backup/moodle2/` in your plugin's folder. So, if you are developing `tool_foobar` then the backup files will be located in `admin/tool/foobar/backup/moodle2/`. + +### Task class + +The file `backup_tool_foobar_plugin.class.php` must provide a single class called `restore_tool_foobar_task` extending `restore_tool_plugin`. + +Here is a minimalistic task: + +```php +require_once($CFG->dirroot . '/backup/moodle2/restore_tool_plugin.class.php'); + +class restore_tool_foobar_plugin extends restore_tool_plugin { + + protected function define_course_plugin_structure() { + $paths = array(); + $this->step->log('Yay, restore!', backup::LOG_DEBUG); + return $paths; + } + +} +``` + +## See also + +- [Core APIs](../../../apis.md) +- [Backup API](../backup)