. /** * @package tool_xmldb * @copyright 2003 onwards Eloy Lafuente (stronk7) {@link http://stronk7.com} * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ /** * @package tool_xmldb * @copyright 2003 onwards Eloy Lafuente (stronk7) {@link http://stronk7.com} * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ class create_xml_file extends XMLDBAction { /** * Init method, every subclass will have its own */ function init() { parent::init(); // Set own core attributes $this->can_subaction = ACTION_NONE; //$this->can_subaction = ACTION_HAVE_SUBACTIONS; // Set own custom attributes // Get needed strings $this->loadStrings(array( // 'key' => 'module', )); } /** * Invoke method, every class will have its own * returns true/false on completion, setting both * errormsg and output as necessary */ function invoke() { parent::invoke(); $result = true; // Set own core attributes $this->does_generate = ACTION_NONE; //$this->does_generate = ACTION_GENERATE_HTML; // These are always here global $CFG, $XMLDB; // Do the job, setting result as needed // Get the dir containing the file $dirpath = required_param('dir', PARAM_PATH); $plugintype = $this->get_plugin_type($dirpath); $dirpath = $CFG->dirroot . $dirpath; $file = $dirpath . '/install.xml'; // Some variables $xmlpath = dirname(str_replace($CFG->dirroot . '/', '', $file)); $xmlversion = userdate(time(), '%Y%m%d', 99, false); $xmlcomment = 'XMLDB file for Moodle ' . dirname($xmlpath); $xmltable = strtolower(basename(dirname($xmlpath))); if ($plugintype && $plugintype != 'mod') { $xmltable = $plugintype.'_'.$xmltable; } // Initial contents $c = '' . "\n"; $c.= ' ' . "\n"; $c.= ' ' . "\n"; $c.= ' ' . "\n"; $c.= ' ' . "\n"; $c.= ' ' . "\n"; $c.= ' ' . "\n"; $c.= ' ' . "\n"; $c.= ' ' . "\n"; $c.= ' ' . "\n"; $c.= '
' . "\n"; $c.= '
' . "\n"; $c.= '
'; if (!file_put_contents($file, $c)) { $errormsg = 'Error creando fichero ' . $file; $result = false; } // Launch postaction if exists if ($this->getPostAction() && $result) { return $this->launch($this->getPostAction()); } // Return ok if arrived here return $result; } /** * From a given path, work out what type of plugin * this belongs to * @param string $dirpath Path to the db file for this plugin * @return string the type of the plugin or null if not found */ function get_plugin_type($dirpath) { global $CFG; $dirpath = $CFG->dirroot.$dirpath; // Reverse order so that we get subplugin matches. $plugintypes = array_reverse(core_component::get_plugin_types()); foreach ($plugintypes as $plugintype => $pluginbasedir) { if (substr($dirpath, 0, strlen($pluginbasedir)) == $pluginbasedir) { return $plugintype; } } return null; } }