gl-website-deployer/admin/phpMyAdmin/libraries/classes/Plugins/ImportPlugin.php
2025-03-24 09:27:39 +01:00

88 lines
1.9 KiB
PHP

<?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,
];
}
}