AutorÃa | Ultima modificación | Ver Log |
<?php// This file is part of Moodle - http://moodle.org///// Moodle is free software: you can redistribute it and/or modify// it under the terms of the GNU General Public License as published by// the Free Software Foundation, either version 3 of the License, or// (at your option) any later version.//// Moodle is distributed in the hope that it will be useful,// but WITHOUT ANY WARRANTY; without even the implied warranty of// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the// GNU General Public License for more details.//// You should have received a copy of the GNU General Public License// along with Moodle. If not, see <http://www.gnu.org/licenses/>./*** @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*//*** This class will show the PHP needed (upgrade block) to perform* the desired DDL action with the specified table** @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 view_structure_php extends XMLDBAction {/*** Init method, every subclass will have its own*/function init() {parent::init();// Set own custom attributes$this->sesskey_protected = false; // This action doesn't need sesskey protection// Get needed strings$this->loadStrings(array('selectaction' => 'tool_xmldb','selecttable' => 'tool_xmldb','view' => 'tool_xmldb','back' => 'tool_xmldb'));}/*** 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_GENERATE_HTML;// These are always hereglobal $CFG, $XMLDB, $OUTPUT;// Do the job, setting result as needed// Get the dir containing the file$dirpath = required_param('dir', PARAM_PATH);$dirpath = $CFG->dirroot . $dirpath;// Get the correct dirsif (!empty($XMLDB->dbdirs)) {$dbdir = $XMLDB->dbdirs[$dirpath];} else {return false;}if (!empty($XMLDB->editeddirs)) {$editeddir = $XMLDB->editeddirs[$dirpath];$structure = $editeddir->xml_file->getStructure();}$tables = $structure->getTables();$table = reset($tables);$defaulttable = null;if ($table) {$defaulttable = $table->getName();}// Get parameters$commandparam = optional_param('command', 'create_table', PARAM_PATH);$tableparam = optional_param('table', $defaulttable, PARAM_PATH);// The back to edit xml button$b = ' <p class="centerpara buttons">';$b .= '<a href="index.php?action=edit_xml_file&dir=' . urlencode(str_replace($CFG->dirroot, '', $dirpath)) . '">[' . $this->str['back'] . ']</a>';$b .= '</p>';$o = $b;// Calculate the popup of commands$commands = array('create_table','drop_table','rename_table');foreach ($commands as $command) {$popcommands[$command] = str_replace('_', ' ', $command);}// Calculate the popup of tablesforeach ($tables as $table) {$poptables[$table->getName()] = $table->getName();}// Now build the form$o.= '<form id="form" action="index.php" method="post">';$o.='<div>';$o.= ' <input type="hidden" name ="dir" value="' . str_replace($CFG->dirroot, '', $dirpath) . '" />';$o.= ' <input type="hidden" name ="action" value="view_structure_php" />';$o.= ' <table id="formelements" class="boxaligncenter" cellpadding="5">';$o.= ' <tr><td><label for="menucommand" accesskey="c">' . $this->str['selectaction'] .' </label>' . html_writer::select($popcommands, 'command', $commandparam, false) . ' <label for="menutable" accesskey="t">' . $this->str['selecttable'] . ' </label>' .html_writer::select($poptables, 'table', $tableparam, false) . '</td></tr>';$o.= ' <tr><td colspan="2" align="center"><input type="submit" value="' .$this->str['view'] . '" /></td></tr>';$o.= ' </table>';$o.= '</div></form>';$o.= ' <table id="phpcode" class="boxaligncenter" cellpadding="5">';$o .= ' <tr><td><textarea cols="80" rows="32" class="form-control">';// Based on current params, call the needed functionswitch ($commandparam) {case 'create_table':$o.= s($this->create_table_php($structure, $tableparam));break;case 'drop_table':$o.= s($this->drop_table_php($structure, $tableparam));break;case 'rename_table':$o.= s($this->rename_table_php($structure, $tableparam));break;}$o.= '</textarea></td></tr>';$o.= ' </table>';$this->output = $o;// Launch postaction if exists (leave this here!)if ($this->getPostAction() && $result) {return $this->launch($this->getPostAction());}// Return ok if arrived herereturn $result;}/*** This function will generate all the PHP code needed to* create one table using XMLDB objects and functions** @param xmldb_structure structure object containing all the info* @param string table table code to be created* @return string PHP code to be used to create the table*/function create_table_php($structure, $table) {$result = '';// Validate if we can do itif (!$table = $structure->getTable($table)) {return false;}if ($table->getAllErrors()) {return false;}// Add the standard PHP header$result .= XMLDB_PHP_HEADER;// Add contents$result .= XMLDB_LINEFEED;$result .= ' // Define table ' . $table->getName() . ' to be created.' . XMLDB_LINEFEED;$result .= ' $table = new xmldb_table(' . "'" . $table->getName() . "'" . ');' . XMLDB_LINEFEED;$result .= XMLDB_LINEFEED;$result .= ' // Adding fields to table ' . $table->getName() . '.' . XMLDB_LINEFEED;// Iterate over each fieldforeach ($table->getFields() as $field) {// The field header, with name$result .= ' $table->add_field(' . "'" . $field->getName() . "', ";// The field PHP specs$result .= $field->getPHP(false);// The end of the line$result .= ');' . XMLDB_LINEFEED;}// Iterate over each keyif ($keys = $table->getKeys()) {$result .= XMLDB_LINEFEED;$result .= ' // Adding keys to table ' . $table->getName() . '.' . XMLDB_LINEFEED;foreach ($keys as $key) {// The key header, with name$result .= ' $table->add_key(' . "'" . $key->getName() . "', ";// The key PHP specs$result .= $key->getPHP();// The end of the line$result .= ');' . XMLDB_LINEFEED;}}// Iterate over each indexif ($indexes = $table->getIndexes()) {$result .= XMLDB_LINEFEED;$result .= ' // Adding indexes to table ' . $table->getName() . '.' . XMLDB_LINEFEED;foreach ($indexes as $index) {// The index header, with name$result .= ' $table->add_index(' . "'" . $index->getName() . "', ";// The index PHP specs$result .= $index->getPHP();// The end of the line$result .= ');' . XMLDB_LINEFEED;}}// Launch the proper DDL$result .= XMLDB_LINEFEED;$result .= ' // Conditionally launch create table for ' . $table->getName() . '.' . XMLDB_LINEFEED;$result .= ' if (!$dbman->table_exists($table)) {' . XMLDB_LINEFEED;$result .= ' $dbman->create_table($table);' . XMLDB_LINEFEED;$result .= ' }' . XMLDB_LINEFEED;// Add the proper upgrade_xxxx_savepoint call$result .= $this->upgrade_savepoint_php ($structure);// Add standard PHP footer$result .= XMLDB_PHP_FOOTER;return $result;}/*** This function will generate all the PHP code needed to* drop one table using XMLDB objects and functions** @param xmldb_structure structure object containing all the info* @param string table table code to be dropped* @return string PHP code to be used to drop the table*/function drop_table_php($structure, $table) {$result = '';// Validate if we can do itif (!$table = $structure->getTable($table)) {return false;}if ($table->getAllErrors()) {return false;}// Add the standard PHP header$result .= XMLDB_PHP_HEADER;// Add contents$result .= XMLDB_LINEFEED;$result .= ' // Define table ' . $table->getName() . ' to be dropped.' . XMLDB_LINEFEED;$result .= ' $table = new xmldb_table(' . "'" . $table->getName() . "'" . ');' . XMLDB_LINEFEED;// Launch the proper DDL$result .= XMLDB_LINEFEED;$result .= ' // Conditionally launch drop table for ' . $table->getName() . '.' . XMLDB_LINEFEED;$result .= ' if ($dbman->table_exists($table)) {' . XMLDB_LINEFEED;$result .= ' $dbman->drop_table($table);' . XMLDB_LINEFEED;$result .= ' }' . XMLDB_LINEFEED;// Add the proper upgrade_xxxx_savepoint call$result .= $this->upgrade_savepoint_php ($structure);// Add standard PHP footer$result .= XMLDB_PHP_FOOTER;return $result;}/*** This function will generate all the PHP code needed to* rename one table using XMLDB objects and functions** @param xmldb_structure structure object containing all the info* @param string table table code to be renamed* @return string PHP code to be used to rename the table*/function rename_table_php($structure, $table) {$result = '';// Validate if we can do itif (!$table = $structure->getTable($table)) {return false;}if ($table->getAllErrors()) {return false;}// Add the standard PHP header$result .= XMLDB_PHP_HEADER;// Add contents$result .= XMLDB_LINEFEED;$result .= ' // Define table ' . $table->getName() . ' to be renamed to NEWNAMEGOESHERE.' . XMLDB_LINEFEED;$result .= ' $table = new xmldb_table(' . "'" . $table->getName() . "'" . ');' . XMLDB_LINEFEED;// Launch the proper DDL$result .= XMLDB_LINEFEED;$result .= ' // Launch rename table for ' . $table->getName() . '.' . XMLDB_LINEFEED;$result .= ' $dbman->rename_table($table, ' . "'NEWNAMEGOESHERE'" . ');' . XMLDB_LINEFEED;// Add the proper upgrade_xxxx_savepoint call$result .= $this->upgrade_savepoint_php ($structure);// Add standard PHP footer$result .= XMLDB_PHP_FOOTER;return $result;}}