. */ declare(strict_types=1); namespace FireflyIII\Import\JobConfiguration; use FireflyIII\Exceptions\FireflyException; use FireflyIII\Models\ImportJob; use FireflyIII\Repositories\ImportJob\ImportJobRepositoryInterface; use FireflyIII\Support\Import\JobConfiguration\Spectre\AuthenticatedHandler; use FireflyIII\Support\Import\JobConfiguration\Spectre\ChooseAccountsHandler; use FireflyIII\Support\Import\JobConfiguration\Spectre\ChooseLoginHandler; use FireflyIII\Support\Import\JobConfiguration\Spectre\DoAuthenticateHandler; use FireflyIII\Support\Import\JobConfiguration\Spectre\NewSpectreJobHandler; use FireflyIII\Support\Import\JobConfiguration\Spectre\SpectreJobConfigurationInterface; use Illuminate\Support\MessageBag; use Log; /** * Class SpectreJobConfiguration */ class SpectreJobConfiguration implements JobConfigurationInterface { /** @var SpectreJobConfigurationInterface The job handler. */ private $handler; /** @var ImportJob The import job */ private $importJob; /** @var ImportJobRepositoryInterface Import job repository */ private $repository; /** * Returns true when the initial configuration for this job is complete. * * @return bool */ public function configurationComplete(): bool { return $this->handler->configurationComplete(); } /** * Store any data from the $data array into the job. Anything in the message bag will be flashed * as an error to the user, regardless of its content. * * @param array $data * * @return MessageBag */ public function configureJob(array $data): MessageBag { return $this->handler->configureJob($data); } /** * Return the data required for the next step in the job configuration. * * @return array */ public function getNextData(): array { return $this->handler->getNextData(); } /** * Returns the view of the next step in the job configuration. * * @return string */ public function getNextView(): string { return $this->handler->getNextView(); } /** * Set the import job. * * @param ImportJob $importJob * * @throws FireflyException */ public function setImportJob(ImportJob $importJob): void { $this->importJob = $importJob; $this->repository = app(ImportJobRepositoryInterface::class); $this->repository->setUser($importJob->user); $this->handler = $this->getHandler(); } /** * Get correct handler. * * @return SpectreJobConfigurationInterface * @throws FireflyException * * @SuppressWarnings(PHPMD.CyclomaticComplexity) */ private function getHandler(): SpectreJobConfigurationInterface { Log::debug(sprintf('Now in SpectreJobConfiguration::getHandler() with stage "%s"', $this->importJob->stage)); $handler = null; switch ($this->importJob->stage) { case 'new': /** @var NewSpectreJobHandler $handler */ $handler = app(NewSpectreJobHandler::class); $handler->setImportJob($this->importJob); break; case 'do-authenticate': /** @var DoAuthenticateHandler $handler */ $handler = app(DoAuthenticateHandler::class); $handler->setImportJob($this->importJob); break; case 'choose-login': /** @var ChooseLoginHandler $handler */ $handler = app(ChooseLoginHandler::class); $handler->setImportJob($this->importJob); break; case 'authenticated': /** @var AuthenticatedHandler $handler */ $handler = app(AuthenticatedHandler::class); $handler->setImportJob($this->importJob); break; case 'choose-accounts': /** @var ChooseAccountsHandler $handler */ $handler = app(ChooseAccountsHandler::class); $handler->setImportJob($this->importJob); break; default: // @codeCoverageIgnoreStart throw new FireflyException(sprintf('Firefly III cannot create a configuration handler for stage "%s"', $this->importJob->stage)); // @codeCoverageIgnoreEnd } return $handler; } }