130 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			130 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| declare(strict_types=1);
 | |
| 
 | |
| namespace PhpMyAdmin\Controllers\Table;
 | |
| 
 | |
| use PhpMyAdmin\Charsets;
 | |
| use PhpMyAdmin\Charsets\Charset;
 | |
| use PhpMyAdmin\Config\PageSettings;
 | |
| use PhpMyAdmin\Core;
 | |
| use PhpMyAdmin\DatabaseInterface;
 | |
| use PhpMyAdmin\DbTableExists;
 | |
| use PhpMyAdmin\Encoding;
 | |
| use PhpMyAdmin\Import;
 | |
| use PhpMyAdmin\Import\Ajax;
 | |
| use PhpMyAdmin\Message;
 | |
| use PhpMyAdmin\Plugins;
 | |
| use PhpMyAdmin\Response;
 | |
| use PhpMyAdmin\Template;
 | |
| use PhpMyAdmin\Url;
 | |
| use PhpMyAdmin\Util;
 | |
| use function intval;
 | |
| 
 | |
| final class ImportController extends AbstractController
 | |
| {
 | |
|     /** @var DatabaseInterface */
 | |
|     private $dbi;
 | |
| 
 | |
|     /**
 | |
|      * @param Response          $response
 | |
|      * @param string            $db       Database name.
 | |
|      * @param string            $table    Table name.
 | |
|      * @param DatabaseInterface $dbi
 | |
|      */
 | |
|     public function __construct($response, Template $template, $db, $table, $dbi)
 | |
|     {
 | |
|         parent::__construct($response, $template, $db, $table);
 | |
|         $this->dbi = $dbi;
 | |
|     }
 | |
| 
 | |
|     public function index(): void
 | |
|     {
 | |
|         global $db, $max_upload_size, $table, $url_params, $SESSION_KEY, $cfg, $PMA_Theme, $err_url;
 | |
| 
 | |
|         $pageSettings = new PageSettings('Import');
 | |
|         $pageSettingsErrorHtml = $pageSettings->getErrorHTML();
 | |
|         $pageSettingsHtml = $pageSettings->getHTML();
 | |
| 
 | |
|         $this->addScriptFiles(['import.js']);
 | |
| 
 | |
|         Util::checkParameters(['db', 'table']);
 | |
| 
 | |
|         $url_params = ['db' => $db, 'table' => $table];
 | |
|         $err_url = Util::getScriptNameForOption($cfg['DefaultTabTable'], 'table');
 | |
|         $err_url .= Url::getCommon($url_params, '&');
 | |
| 
 | |
|         DbTableExists::check();
 | |
| 
 | |
|         $url_params['goto'] = Url::getFromRoute('/table/import');
 | |
|         $url_params['back'] = Url::getFromRoute('/table/import');
 | |
| 
 | |
|         [$SESSION_KEY, $uploadId] = Ajax::uploadProgressSetup();
 | |
| 
 | |
|         $importList = Plugins::getImport('table');
 | |
| 
 | |
|         if (empty($importList)) {
 | |
|             $this->response->addHTML(Message::error(__(
 | |
|                 'Could not load import plugins, please check your installation!'
 | |
|             ))->getDisplay());
 | |
| 
 | |
|             return;
 | |
|         }
 | |
| 
 | |
|         $offset = null;
 | |
|         if (Core::isValid($_REQUEST['offset'], 'numeric')) {
 | |
|             $offset = intval($_REQUEST['offset']);
 | |
|         }
 | |
| 
 | |
|         $timeoutPassed = $_REQUEST['timeout_passed'] ?? null;
 | |
|         $localImportFile = $_REQUEST['local_import_file'] ?? null;
 | |
|         $compressions = Import::getCompressions();
 | |
| 
 | |
|         $allCharsets = Charsets::getCharsets($this->dbi, $cfg['Server']['DisableIS']);
 | |
|         $charsets = [];
 | |
|         /** @var Charset $charset */
 | |
|         foreach ($allCharsets as $charset) {
 | |
|             $charsets[] = [
 | |
|                 'name' => $charset->getName(),
 | |
|                 'description' => $charset->getDescription(),
 | |
|             ];
 | |
|         }
 | |
| 
 | |
|         $idKey = $_SESSION[$SESSION_KEY]['handler']::getIdKey();
 | |
|         $hiddenInputs = [
 | |
|             $idKey => $uploadId,
 | |
|             'import_type' => 'table',
 | |
|             'db' => $db,
 | |
|             'table' => $table,
 | |
|         ];
 | |
| 
 | |
|         $this->render('table/import/index', [
 | |
|             'page_settings_error_html' => $pageSettingsErrorHtml,
 | |
|             'page_settings_html' => $pageSettingsHtml,
 | |
|             'upload_id' => $uploadId,
 | |
|             'handler' => $_SESSION[$SESSION_KEY]['handler'],
 | |
|             'theme_image_path' => $PMA_Theme->getImgPath(),
 | |
|             'hidden_inputs' => $hiddenInputs,
 | |
|             'db' => $db,
 | |
|             'table' => $table,
 | |
|             'max_upload_size' => $max_upload_size,
 | |
|             'import_list' => $importList,
 | |
|             'local_import_file' => $localImportFile,
 | |
|             'is_upload' => $GLOBALS['is_upload'],
 | |
|             'upload_dir' => $cfg['UploadDir'] ?? null,
 | |
|             'timeout_passed_global' => $GLOBALS['timeout_passed'] ?? null,
 | |
|             'compressions' => $compressions,
 | |
|             'is_encoding_supported' => Encoding::isSupported(),
 | |
|             'encodings' => Encoding::listEncodings(),
 | |
|             'import_charset' => $cfg['Import']['charset'] ?? null,
 | |
|             'timeout_passed' => $timeoutPassed,
 | |
|             'offset' => $offset,
 | |
|             'can_convert_kanji' => Encoding::canConvertKanji(),
 | |
|             'charsets' => $charsets,
 | |
|             'is_foreign_key_check' => Util::isForeignKeyCheck(),
 | |
|             'user_upload_dir' => Util::userDir($cfg['UploadDir'] ?? ''),
 | |
|             'local_files' => Import::getLocalFiles($importList),
 | |
|         ]);
 | |
|     }
 | |
| }
 |