. /** * @package tool * @subpackage xmldb * @copyright 2003 onwards Eloy Lafuente (stronk7) {@link http://stronk7.com} * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ /** * Main xmldb action clasee * * Main xmldb action class. It implements all the basic * functionalities to be shared by each action. * * @package tool * @subpackage 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 XMLDBAction { var $does_generate; //Type of value returned by the invoke method //ACTION_GENERATE_HTML have contents to show //set by each specialized invoke var $title; //Title of the Action (class name, by default) //set by parent init automatically var $str; //Strings used by the action //set by each specialized init, calling loadStrings var $output; //Output of the action //set by each specialized invoke, get with getOutput var $errormsg; //Last Error produced. Check when any invoke returns false //get with getError var $postaction; //Action to execute at the end of the invoke script var $sesskey_protected; // Actions must be protected by sesskey mechanism /** * Constructor */ function XMLDBAction() { $this->init(); } /** * Constructor to keep PHP5 happy */ function __construct() { $this->XMLDBAction(); } /** * Init method, every subclass will have its own, * always calling the parent one */ function init() { $this->does_generate = ACTION_NONE; $this->title = strtolower(get_class($this)); $this->str = array(); $this->output = NULL; $this->errormsg = NULL; $this->subaction = NULL; $this->sesskey_protected = true; } /** * returns the type of output of the file */ function getDoesGenerate() { return $this->does_generate; } /** * getError method, returns the last error string. * Used if the invoke() methods returns false */ function getError() { return $this->errormsg; } /** * getOutput method, returns the output generated by the action. * Used after execution of the invoke() methods if they return true */ function getOutput() { return $this->output; } /** * getPostAction method, returns the action to launch after executing * another one */ function getPostAction() { return $this->postaction; } /** * getTitle method returns the title of the action (that is part * of the $str array attribute */ function getTitle() { return $this->str['title']; } /** * loadStrings method, loads the required strings specified in the * array parameter */ function loadStrings($strings) { // Load some commonly used strings if (get_string_manager()->string_exists($this->title, 'tool_xmldb')) { $this->str['title'] = get_string($this->title, 'tool_xmldb'); } else { $this->str['title'] = $this->title; } // Now process the $strings array loading it in the $str atribute if ($strings) { foreach ($strings as $key => $module) { $this->str[$key] = get_string($key, $module); } } } /** * main invoke method, it sets the postaction attribute * if possible and checks sesskey_protected if needed */ function invoke() { global $SESSION; // Sesskey protection if ($this->sesskey_protected) { require_sesskey(); } // If we are used any dir, save it in the lastused session object // Some actions can use it to perform positioning if ($lastused = optional_param ('dir', NULL, PARAM_PATH)) { $SESSION->lastused = $lastused; } $this->postaction = optional_param ('postaction', NULL, PARAM_ALPHAEXT); // Avoid being recursive if ($this->title == $this->postaction) { $this->postaction = NULL; } } /** * launch method, used to easily call invoke methods between actions */ function launch($action) { global $CFG; // Get the action path and invoke it $actionsroot = "$CFG->dirroot/$CFG->admin/tool/xmldb/actions"; $actionclass = $action . '.class.php'; $actionpath = "$actionsroot/$action/$actionclass"; // Load and invoke the proper action $result = false; if (file_exists($actionpath) && is_readable($actionpath)) { require_once($actionpath); if ($xmldb_action = new $action) { $result = $xmldb_action->invoke(); if ($result) { if ($xmldb_action->does_generate != ACTION_NONE && $xmldb_action->getOutput()) { $this->does_generate = $xmldb_action->does_generate; $this->title = $xmldb_action->title; $this->str = $xmldb_action->str; $this->output .= $xmldb_action->getOutput(); } } else { $this->errormsg = $xmldb_action->getError(); } } else { $this->errormsg = "Error: cannot instantiate class (actions/$action/$actionclass)"; } } else { $this->errormsg = "Error: wrong action specified ($action)"; } return $result; } /** * This function will generate the PHP code needed to * implement the upgrade_xxxx_savepoint() php calls in * upgrade code generated from the editor. It's used by * the view_structure_php and view_table_php actions * * @param xmldb_structure structure object containing all the info * @return string PHP code to be used to mark a reached savepoint */ function upgrade_savepoint_php($structure) { $path = $structure->getPath(); // Trim "db" from path $path = dirname($path); // Get pluginname, plugindir and plugintype $pluginname = basename($path); if ($path == 'lib') { // exception for lib (not proper plugin) $plugindir = 'lib'; $plugintype = 'lib'; } else { // rest of plugins // TODO: this is not nice and may fail, plugintype should be passed around somehow instead $plugintypes = get_plugin_types(false); $plugindir = dirname($path); $plugindir = str_replace('\\', '/', $plugindir); $plugintype = array_search($plugindir, $plugintypes); } $result = ''; switch ($plugintype ) { case 'lib': // has own savepoint function $result = XMLDB_LINEFEED . ' // Main savepoint reached' . XMLDB_LINEFEED . ' upgrade_main_savepoint(true, XXXXXXXXXX);' . XMLDB_LINEFEED; break; case 'mod': // has own savepoint function $result = XMLDB_LINEFEED . ' // ' . $pluginname . ' savepoint reached' . XMLDB_LINEFEED . ' upgrade_mod_savepoint(true, XXXXXXXXXX, ' . "'$pluginname'" . ');' . XMLDB_LINEFEED; break; case 'block': // has own savepoint function $result = XMLDB_LINEFEED . ' // ' . $pluginname . ' savepoint reached' . XMLDB_LINEFEED . ' upgrade_block_savepoint(true, XXXXXXXXXX, ' . "'$pluginname'" . ');' . XMLDB_LINEFEED; break; default: // rest of plugins $result = XMLDB_LINEFEED . ' // ' . $pluginname . ' savepoint reached' . XMLDB_LINEFEED . ' upgrade_plugin_savepoint(true, XXXXXXXXXX, ' . "'$plugintype'" . ', ' . "'$pluginname'" . ');' . XMLDB_LINEFEED; } return $result; } }