Viewing file: ImportPlugin.php (1.91 KB) -rw-r--r-- Select action/file-type: (+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php /** * Abstract class for the import plugins */
declare(strict_types=1);
namespace PhpMyAdmin\Plugins;
use PhpMyAdmin\File; use PhpMyAdmin\Import; use PhpMyAdmin\Properties\Plugins\ImportPluginProperties; use function strlen;
/** * Provides a common interface that will have to be implemented by all of the * import plugins. */ abstract class ImportPlugin { /** * ImportPluginProperties object containing the import plugin properties * * @var ImportPluginProperties */ protected $properties;
/** @var Import */ protected $import;
public function __construct() { $this->import = new Import(); }
/** * Handles the whole import logic * * @param array $sql_data 2-element array with sql data * * @return void */ abstract public function doImport(?File $importHandle = null, array &$sql_data = []);
/* ~~~~~~~~~~~~~~~~~~~~ Getters and Setters ~~~~~~~~~~~~~~~~~~~~ */
/** * Gets the import specific format plugin properties * * @return ImportPluginProperties */ public function getProperties() { return $this->properties; }
/** * Sets the export plugins properties and is implemented by each import * plugin * * @return void */ abstract protected function setProperties();
/** * Define DB name and options * * @param string $currentDb DB * @param string $defaultDb Default DB name * * @return array DB name and options (an associative array of options) */ protected function getDbnameAndOptions($currentDb, $defaultDb) { if (strlen((string) $currentDb) > 0) { $db_name = $currentDb; $options = ['create_db' => false]; } else { $db_name = $defaultDb; $options = null; }
return [ $db_name, $options, ]; } }
|