| Moodle PHP Documentation 4.5
    Moodle 4.5.5+ (Build: 20250711) (ce34e8ff087) | 
restore plugin class that provides the necessary information needed to restore one random qtype plugin More...
 
  
| Public Member Functions | |
| after_execute_question () | |
| After restoring, make sure questiontext is set properly. | |
| define_plugin_structure ($connectionpoint) | |
| get_excluded_identity_hash_fields () | |
| Return fields to be excluded from hashing during restores. | |
| launch_after_execute_methods () | |
| after_execute dispatcher for any restore_plugin class | |
| launch_after_restore_methods () | |
| after_restore dispatcher for any restore_plugin class | |
| process_donothing ($data) | |
| Required function to process path. | |
| process_question_answer ($data) | |
| Processes the answer element (question answers). | |
| process_question_dataset_definition ($data) | |
| Processes the dataset_definition element (question dataset definitions). | |
| process_question_dataset_item ($data) | |
| Processes the dataset_item element (question dataset items). | |
| process_question_numerical_option ($data) | |
| Processes the numerical_option element (question numerical options). | |
| process_question_numerical_unit ($data) | |
| Processes the numerical_unit element (question numerical units). | |
| recode_legacy_state_answer ($state) | |
| Given one question_states record, return the answer recoded pointing to all the restored stuff for random questions. | |
| recode_response ($questionid, $sequencenumber, array $response) | |
| Do any re-coding necessary in the student response. | |
| Static Public Member Functions | |
| static | convert_backup_to_questiondata (array $backupdata) | 
| Convert the backup structure of this question type into a structure matching its question data. | |
| static | define_plugin_decode_contents () | 
| Return the contents of the questions stuff that must be processed by the links decoder. | |
| static | get_restore_decode_contents ($plugintype) | 
| Returns one array with all the decode contents to be processed by the links decoder. | |
| static | remove_excluded_question_data (stdClass $questiondata, array $excludefields=[]) | 
| Remove excluded fields from the questiondata structure. | |
| Protected Member Functions | |
| add_question_datasets (&$paths) | |
| Add to $paths the restore_path_elements needed to handle question_datasets (defs and items) for a given question Used by various qtypes (calculated, numerical) | |
| add_question_numerical_options (&$paths) | |
| Add to $paths the restore_path_elements needed to handle question_numerical_options for a given question Used by various qtypes (calculated, numerical) | |
| add_question_numerical_units (&$paths) | |
| Add to $paths the restore_path_elements needed to handle question_numerical_units for a given question Used by various qtypes (calculated, numerical) | |
| add_question_question_answers (&$paths) | |
| Add to $paths the restore_path_elements needed to handle question_answers for a given question Used by various qtypes (calculated, essay, multianswer, multichoice, numerical, shortanswer, truefalse) | |
| add_related_files ($component, $filearea, $mappingitemname, $filesctxid=null, $olditemid=null) | |
| Add all the existing file, given their component and filearea and one backup_ids itemname to match with. | |
| apply_date_offset ($value) | |
| Apply course startdate offset based in original course startdate and course_offset_startdate setting Note we are using one static cache here, but by restoreid, so it's ok for concurrence/multiple executions in the same request. | |
| define_excluded_identity_hash_fields () | |
| Return a list of paths to fields to be removed from questiondata before creating an identity hash. | |
| define_question_plugin_structure () | |
| Define the plugin structure. | |
| get_mapping ($itemname, $oldid) | |
| Return the complete mapping from the given itemname, itemid. | |
| get_mappingid ($itemname, $oldid, $ifnotfound=false) | |
| Return the new id of a mapping for the given itemname. | |
| get_namefor ($name='') | |
| Simple helper function that returns the name for the restore_path_element It's not mandatory to use it but recommended ;-) | |
| get_new_parentid ($itemname) | |
| Returns the latest (parent) new id mapped by one pathelement. | |
| get_old_parentid ($itemname) | |
| Returns the latest (parent) old id mapped by one pathelement. | |
| get_pathfor ($path='') | |
| Simple helper function that returns the base (prefix) of the path for the restore_path_element Useful if we used get_recommended_name() in backup. | |
| get_restoreid () | |
| get_setting_value ($name) | |
| Returns the value of one (task/plan) setting. | |
| get_task () | |
| Get the task we are part of. | |
| set_mapping ($itemname, $oldid, $newid, $restorefiles=false, $filesctxid=null, $parentid=null) | |
| To send ids pairs to backup_ids_table and to store them into paths. | |
| Protected Attributes | |
| restore_path_element | $connectionpoint | 
| array array | $excludedhashfields = [] | 
| List of fields to exclude form hashing during restore. | |
| string | $pluginname | 
| string | $plugintype | 
| restore_structure_step | $step | 
| restore_course_task restore_activity_task | $task | 
restore plugin class that provides the necessary information needed to restore one random qtype plugin
| 
 | staticinherited | 
Convert the backup structure of this question type into a structure matching its question data.
This should take the hierarchical array of tags from the question's backup structure, and return a structure that matches that returned when calling {
This data will then be used to produce an identity hash for comparison with questions in the database.
This base implementation deals with all common backup elements created by the add_question_*_options() methods in this class, plus elements added by define_question_plugin_structure() named for the qtype. The question type will need to extend this function if define_question_plugin_structure() adds any other elements to the backup.
| array | $backupdata | The hierarchical array of tags from the backup. | 
| stdClass | The questiondata object. | 
Reimplemented in restore_qtype_calculated_plugin, restore_qtype_ddimageortext_plugin, restore_qtype_ddmarker_plugin, restore_qtype_match_plugin, restore_qtype_multichoice_plugin, and restore_qtype_numerical_plugin.
| 
 | protectedinherited | 
Return a list of paths to fields to be removed from questiondata before creating an identity hash.
Fields that should be excluded from common elements such as answers or numerical units that are used by the plugin will be excluded automatically. This method just needs to define any specific to this plugin, such as foreign keys used in the plugin's tables.
The returned array should be a list of slash-delimited paths to locate the fields to be removed from the questiondata object. For example, if you want to remove the field $questiondata->options->questionid, the path would be '/options/questionid'. If a field in the path is an array, the rest of the path will be applied to each object in the array. So if you have $questiondata->options->answers[], the path '/options/answers/id' will remove the 'id' field from each element of the 'answers' array.
| array | 
Reimplemented in restore_qtype_calculated_plugin, restore_qtype_calculatedmulti_plugin, restore_qtype_ddimageortext_plugin, restore_qtype_ddmarker_plugin, restore_qtype_match_plugin, restore_qtype_multianswer_plugin, and restore_qtype_truefalse_plugin.
| 
 | staticinherited | 
Return the contents of the questions stuff that must be processed by the links decoder.
Only common stuff to all plugins, in this case:
Note each qtype will have, if needed, its own define_decode_contents method
Reimplemented from restore_plugin.
| 
 | protected | 
Define the plugin structure.
| array | Array of restore_path_elements. | 
| 
 | finalinherited | 
Return fields to be excluded from hashing during restores.
| array | 
| 
 | protectedinherited | 
Return the new id of a mapping for the given itemname.
| string | $itemname | the type of item | 
| int | $oldid | the item ID from the backup | 
| mixed | $ifnotfound | what to return if $oldid wasnt found. Defaults to false | 
| 
 | protectedinherited | 
Simple helper function that returns the base (prefix) of the path for the restore_path_element Useful if we used get_recommended_name() in backup.
It's not mandatory to use it but recommended ;-)
| 
 | staticinherited | 
Returns one array with all the decode contents to be processed by the links decoder.
This method, given one plugin type, returns one array of restore_decode_content objects that will be added to the restore decoder in order to perform modifications under the plugin contents.
The objects are retrieved by calling to the define_decode_contents method (when available), first in the main restore_xxxx_plugin class and later on each of the available subclasses
| 
 | protectedinherited | 
Get the task we are part of.
| restore_activity_task|restore_course_task | the task. | 
| 
 | inherited | 
after_execute dispatcher for any restore_plugin class
This method will dispatch execution to the corresponding after_execute_xxx() method when available, with xxx being the connection point of the instance, so plugin classes with multiple connection points will support multiple after_execute methods, one for each connection point
| 
 | inherited | 
after_restore dispatcher for any restore_plugin class
This method will dispatch execution to the corresponding after_restore_xxx() method when available, with xxx being the connection point of the instance, so plugin classes with multiple connection points will support multiple after_restore methods, one for each connection point
| restore_qtype_random_plugin::process_donothing | ( | $data | ) | 
Required function to process path.
Should never be called.
| object | $data | Data elements. | 
| 
 | inherited | 
Processes the answer element (question answers).
Common for various qtypes. It handles both creation (if the question is being created) and mapping (if the question already existed and is being reused)
| 
 | inherited | 
Processes the dataset_definition element (question dataset definitions).
Common for various qtypes. It handles both creation (if the question is being created) and mapping (if the question already existed and is being reused)
| 
 | inherited | 
Processes the dataset_item element (question dataset items).
Common for various qtypes. It handles both creation (if the question is being created) and mapping (if the question already existed and is being reused)
| 
 | inherited | 
Processes the numerical_option element (question numerical options).
Common for various qtypes. It handles both creation (if the question is being created) and mapping (if the question already existed and is being reused)
| 
 | inherited | 
Processes the numerical_unit element (question numerical units).
Common for various qtypes. It handles both creation (if the question is being created) and mapping (if the question already existed and is being reused)
| restore_qtype_random_plugin::recode_legacy_state_answer | ( | $state | ) | 
Given one question_states record, return the answer recoded pointing to all the restored stuff for random questions.
answer format is randomxx-yy, with xx being question->id and yy the actual response to the question. We'll delegate the recode to the corresponding qtype
also, some old states can contain, simply, one question->id, support them, just in case
Reimplemented from restore_qtype_plugin.
| 
 | inherited | 
Do any re-coding necessary in the student response.
| int | $questionid | the new id of the question | 
| int | $sequencenumber | of the step within the qusetion attempt. | 
| array | the response data from the backup. | 
| array | the recoded response. | 
Reimplemented in restore_qtype_calculatedmulti_plugin, restore_qtype_match_plugin, restore_qtype_multianswer_plugin, and restore_qtype_multichoice_plugin.
| 
 | staticinherited | 
Remove excluded fields from the questiondata structure.
This removes fields that will not match or not be present in the question data structure produced by {
For plugins, it should be sufficient to override {
| stdClass | $questiondata | |
| array | $excludefields | Paths to the fields to exclude. | 
| stdClass | The $questiondata with excluded fields removed. | 
Reimplemented in restore_qtype_multianswer_plugin.
| 
 | protectedinherited | 
To send ids pairs to backup_ids_table and to store them into paths.
This method will send the given itemname and old/new ids to the backup_ids_temp table, and, at the same time, will save the new id into the corresponding restore_path_element for easier access by children. Also will inject the known old context id for the task in case it's going to be used for restoring files later