%PDF- %PDF-
Direktori : /var/www/projetos/admin.iigd.com.br/libraries/classes/Plugins/Export/ |
Current File : /var/www/projetos/admin.iigd.com.br/libraries/classes/Plugins/Export/README.md |
# Export plugin creation This directory holds export plugins for phpMyAdmin. Any new plugin should basically follow the structure presented here. Official plugins need to have str* messages with their definition in language files, but if you build some plugins for your use, you can directly use texts in plugin. ```php <?php /** * [Name] export plugin for phpMyAdmin */ declare(strict_types=1); /** * Handles the export for the [Name] format */ class Export[Name] extends PhpMyAdmin\Plugins\ExportPlugin { /** * optional - declare variables and descriptions * * @var VariableType */ private $myOptionalVariable; /** * optional - declare global variables and descriptions * * @var VariableType */ private $globalVariableName; /** * Constructor */ public function __construct() { $this->setProperties(); } // optional - declare global variables and use getters later /** * Initialize the local variables that are used specific for export SQL * * @return void * * @global VariableType $global_variable_name * [..] */ protected function initSpecificVariables() { global $global_variable_name; $this->setGlobalVariableName($global_variable_name); } /** * Sets the export plugin properties. * Called in the constructor. * * @return void */ protected function setProperties() { $exportPluginProperties = new PhpMyAdmin\Properties\Plugins\ExportPluginProperties(); $exportPluginProperties->setText('[name]'); // the name of your plug-in $exportPluginProperties->setExtension('[ext]'); // extension this plug-in can handle $exportPluginProperties->setOptionsText(__('Options')); // create the root group that will be the options field for // $exportPluginProperties // this will be shown as "Format specific options" $exportSpecificOptions = new PhpMyAdmin\Properties\Options\Groups\OptionsPropertyRootGroup( 'Format Specific Options' ); // general options main group $generalOptions = new PhpMyAdmin\Properties\Options\Groups\OptionsPropertyMainGroup( 'general_opts' ); // optional : // create primary items and add them to the group // type - one of the classes listed in libraries/properties/options/items/ // name - form element name // text - description in GUI // size - size of text element // len - maximal size of input // values - possible values of the item $leaf = new PhpMyAdmin\Properties\Options\Items\RadioPropertyItem( 'structure_or_data' ); $leaf->setValues( [ 'structure' => __('structure'), 'data' => __('data'), 'structure_and_data' => __('structure and data'), ] ); $generalOptions->addProperty($leaf); // add the main group to the root group $exportSpecificOptions->addProperty($generalOptions); // set the options for the export plugin property item $exportPluginProperties->setOptions($exportSpecificOptions); $this->properties = $exportPluginProperties; } /** * Outputs export header * * @return bool Whether it succeeded */ public function exportHeader() { // implementation return true; } /** * Outputs export footer * * @return bool Whether it succeeded */ public function exportFooter() { // implementation return true; } /** * Outputs database header * * @param string $db Database name * @param string $dbAlias Aliases of db * * @return bool Whether it succeeded */ public function exportDBHeader($db, $dbAlias = '') { // implementation return true; } /** * Outputs database footer * * @param string $db Database name * * @return bool Whether it succeeded */ public function exportDBFooter($db) { // implementation return true; } /** * Outputs CREATE DATABASE statement * * @param string $db Database name * @param string $exportType 'server', 'database', 'table' * @param string $dbAlias Aliases of db * * @return bool Whether it succeeded */ public function exportDBCreate($db, $exportType, $dbAlias = '') { // implementation return true; } /** * Outputs the content of a table in [Name] format * * @param string $db database name * @param string $table table name * @param string $crlf the end of line sequence * @param string $errorUrl the url to go back in case of error * @param string $sqlQuery SQL query for obtaining data * @param array $aliases Aliases of db/table/columns * * @return bool Whether it succeeded */ public function exportData( $db, $table, $crlf, $errorUrl, $sqlQuery, array $aliases = [] ) { // implementation; return true; } // optional - implement other methods defined in PhpMyAdmin\Plugins\ExportPlugin.php: // - exportRoutines() // - exportStructure() // - getTableDefStandIn() // - getTriggers() // optional - implement other private methods in order to avoid // having huge methods or avoid duplicate code. Make use of them // as well as of the getters and setters declared both here // and in the PhpMyAdmin\Plugins\ExportPlugin class // optional: /* ~~~~~~~~~~~~~~~~~~~~ Getters and Setters ~~~~~~~~~~~~~~~~~~~~ */ /** * Getter description */ private function getMyOptionalVariable(): VariableType { return $this->myOptionalVariable; } /** * Setter description */ private function setMyOptionalVariable(VariableType $my_optional_variable): void { $this->myOptionalVariable = $my_optional_variable; } /** * Getter description */ private function getGlobalVariableName(): VariableType { return $this->globalVariableName; } /** * Setter description */ private function setGlobalVariableName(VariableType $global_variable_name): void { $this->globalVariableName = $global_variable_name; } } ```