. /** * Defines backup_qtype_extrafields_plugin class * * @package core_backup * @copyright 2012 Oleg Sychev, Volgograd State Technical University * @author Valeriy Streltsov * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ defined('MOODLE_INTERNAL') || die(); global $CFG; require_once($CFG->dirroot . '/question/engine/bank.php'); /** * Class extending backup_qtype_plugin in order to use extra fields method * * See qtype_shortanswer for an example * * @copyright 2012 Oleg Sychev, Volgograd State Technical University * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ class backup_qtype_extrafields_plugin extends backup_qtype_plugin { /** * Returns the qtype information to attach to question element. */ protected function define_question_plugin_structure() { $qtypeobj = question_bank::get_qtype($this->pluginname); // Define the virtual plugin element with the condition to fulfill. $plugin = $this->get_plugin_element(null, '../../qtype', $qtypeobj->name()); // Create one standard named plugin element (the visible container). $pluginwrapper = new backup_nested_element($this->get_recommended_name()); // Connect the visible container ASAP. $plugin->add_child($pluginwrapper); // This qtype uses standard question_answers, add them here // to the tree before any other information that will use them. $this->add_question_question_answers($pluginwrapper); $answers = $pluginwrapper->get_child('answers'); $answer = $answers->get_child('answer'); // Extra question fields. $extraquestionfields = $qtypeobj->extra_question_fields(); if (!empty($extraquestionfields)) { $tablename = array_shift($extraquestionfields); $child = new backup_nested_element($qtypeobj->name(), array('id'), $extraquestionfields); $pluginwrapper->add_child($child); $child->set_source_table($tablename, array($qtypeobj->questionid_column_name() => backup::VAR_PARENTID)); } // Extra answer fields. $extraanswerfields = $qtypeobj->extra_answer_fields(); if (!empty($extraanswerfields)) { $tablename = array_shift($extraanswerfields); $child = new backup_nested_element('extraanswerdata', array('id'), $extraanswerfields); $answer->add_child($child); $child->set_source_table($tablename, array('answerid' => backup::VAR_PARENTID)); } // Don't need to annotate ids nor files. return $plugin; } }