mirror of
https://github.com/werkraum-media/events.git
synced 2024-11-22 15:16:11 +01:00
Daniel Siepmann
3d6bf0ac8a
It is now possible to create "Import" records in TYPO3 system. Those records can then be imported via two new commands. There is no need to configure everything within the command itself. That allows: * To allow editors to maintain import configuration. * Have proper labels, description, csh and UI to create import. It no longer is necessary to copy UIDs, instead proper wizards from TCA are available to select pages. Relates: #9649
97 lines
2.7 KiB
PHP
97 lines
2.7 KiB
PHP
<?php
|
|
|
|
namespace Wrm\Events\Command;
|
|
|
|
use Symfony\Component\Console\Command\Command;
|
|
use Symfony\Component\Console\Input\InputArgument;
|
|
use Symfony\Component\Console\Input\InputInterface;
|
|
use Symfony\Component\Console\Output\OutputInterface;
|
|
use TYPO3\CMS\Core\Core\Bootstrap;
|
|
use Wrm\Events\Domain\DestinationData\LegacyImportFactory;
|
|
use Wrm\Events\Service\DestinationDataImportService;
|
|
|
|
class DestinationDataImportCommand extends Command
|
|
{
|
|
/**
|
|
* @var DestinationDataImportService
|
|
*/
|
|
private $destinationDataImportService;
|
|
|
|
/**
|
|
* @var LegacyImportFactory
|
|
*/
|
|
private $importFactory;
|
|
|
|
public function __construct(
|
|
DestinationDataImportService $destinationDataImportService,
|
|
LegacyImportFactory $importFactory
|
|
) {
|
|
parent::__construct();
|
|
$this->destinationDataImportService = $destinationDataImportService;
|
|
$this->importFactory = $importFactory;
|
|
}
|
|
|
|
public function configure(): void
|
|
{
|
|
$this->setDescription('Import Destination Data Events');
|
|
$this->setHelp('Destination Data Events are imported');
|
|
|
|
$this->addArgument(
|
|
'storage-pid',
|
|
InputArgument::REQUIRED,
|
|
'What is the storage pid?'
|
|
);
|
|
$this->addArgument(
|
|
'rest-experience',
|
|
InputArgument::REQUIRED,
|
|
'What is the rest experience?'
|
|
);
|
|
$this->addArgument(
|
|
'files-folder',
|
|
InputArgument::REQUIRED,
|
|
'Where to save the image files?'
|
|
);
|
|
$this->addArgument(
|
|
'region-uid',
|
|
InputArgument::OPTIONAL,
|
|
'What is the region uid?'
|
|
);
|
|
$this->addArgument(
|
|
'query',
|
|
InputArgument::OPTIONAL,
|
|
'What is the additional query "q" parameter?'
|
|
);
|
|
}
|
|
|
|
protected function execute(InputInterface $input, OutputInterface $output)
|
|
{
|
|
Bootstrap::initializeBackendAuthentication();
|
|
|
|
$regionUid = $input->getArgument('region-uid');
|
|
if (is_numeric($regionUid)) {
|
|
$regionUid = (int) $regionUid;
|
|
} else {
|
|
$regionUid = null;
|
|
}
|
|
|
|
$query = $input->getArgument('query');
|
|
if (is_string($query) === false) {
|
|
$query = '';
|
|
}
|
|
|
|
$import = $this->importFactory->createFromArray([
|
|
'storage_pid' => $input->getArgument('storage-pid'),
|
|
|
|
'files_folder' => $input->getArgument('files-folder'),
|
|
|
|
'region_uid' => $regionUid,
|
|
|
|
'rest_experience' => $input->getArgument('rest-experience'),
|
|
'rest_search_query' => $query,
|
|
]);
|
|
|
|
return $this->destinationDataImportService->import(
|
|
$import
|
|
);
|
|
}
|
|
}
|