| 
									
										
										
										
											2016-05-22 21:11:30 +02:00
										 |  |  | <?php | 
					
						
							| 
									
										
										
										
											2016-08-06 06:21:25 +02:00
										 |  |  | /** | 
					
						
							|  |  |  |  * ImportController.php | 
					
						
							|  |  |  |  * Copyright (C) 2016 thegrumpydictator@gmail.com | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2016-10-05 06:52:15 +02:00
										 |  |  |  * This software may be modified and distributed under the terms of the | 
					
						
							|  |  |  |  * Creative Commons Attribution-ShareAlike 4.0 International License. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * See the LICENSE file for details. | 
					
						
							| 
									
										
										
										
											2016-08-06 06:21:25 +02:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2016-09-17 07:57:32 +02:00
										 |  |  | declare(strict_types = 1); | 
					
						
							| 
									
										
										
										
											2016-05-22 21:11:30 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | namespace FireflyIII\Http\Controllers; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-10 21:00:00 +02:00
										 |  |  | use Crypt; | 
					
						
							| 
									
										
										
										
											2016-06-24 14:24:34 +02:00
										 |  |  | use FireflyIII\Exceptions\FireflyException; | 
					
						
							| 
									
										
										
										
											2016-06-10 21:00:00 +02:00
										 |  |  | use FireflyIII\Http\Requests\ImportUploadRequest; | 
					
						
							| 
									
										
										
										
											2016-12-25 12:55:22 +01:00
										 |  |  | use FireflyIII\Import\ImportProcedureInterface; | 
					
						
							| 
									
										
										
										
											2016-08-06 06:21:25 +02:00
										 |  |  | use FireflyIII\Import\Setup\SetupInterface; | 
					
						
							| 
									
										
										
										
											2016-06-10 21:00:00 +02:00
										 |  |  | use FireflyIII\Models\ImportJob; | 
					
						
							|  |  |  | use FireflyIII\Repositories\ImportJob\ImportJobRepositoryInterface; | 
					
						
							| 
									
										
										
										
											2016-08-14 11:31:09 +02:00
										 |  |  | use FireflyIII\Repositories\Tag\TagRepositoryInterface; | 
					
						
							| 
									
										
										
										
											2016-06-24 14:24:34 +02:00
										 |  |  | use Illuminate\Http\Request; | 
					
						
							| 
									
										
										
										
											2016-07-02 17:33:57 +02:00
										 |  |  | use Log; | 
					
						
							| 
									
										
										
										
											2016-08-13 21:51:01 +02:00
										 |  |  | use Response; | 
					
						
							| 
									
										
										
										
											2016-06-10 21:00:00 +02:00
										 |  |  | use SplFileObject; | 
					
						
							|  |  |  | use Storage; | 
					
						
							| 
									
										
										
										
											2016-07-02 17:33:57 +02:00
										 |  |  | use Symfony\Component\HttpFoundation\File\UploadedFile; | 
					
						
							| 
									
										
										
										
											2016-05-22 21:11:30 +02:00
										 |  |  | use View; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * Class ImportController | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @package FireflyIII\Http\Controllers | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | class ImportController extends Controller | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function __construct() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         parent::__construct(); | 
					
						
							| 
									
										
										
										
											2016-10-29 07:44:46 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         $this->middleware( | 
					
						
							|  |  |  |             function ($request, $next) { | 
					
						
							|  |  |  |                 View::share('mainTitleIcon', 'fa-archive'); | 
					
						
							|  |  |  |                 View::share('title', trans('firefly.import_data_full')); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 return $next($request); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         ); | 
					
						
							| 
									
										
										
										
											2016-05-22 21:11:30 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-02 23:08:47 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * This is the last step before the import starts. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param ImportJob $job | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-08-12 15:10:03 +02:00
										 |  |  |      * @return \Illuminate\Http\RedirectResponse|\Illuminate\Routing\Redirector|View | 
					
						
							| 
									
										
										
										
											2016-07-02 23:08:47 +02:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function complete(ImportJob $job) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         Log::debug('Now in complete()', ['job' => $job->key]); | 
					
						
							|  |  |  |         if (!$this->jobInCorrectStep($job, 'complete')) { | 
					
						
							|  |  |  |             return $this->redirectToCorrectStep($job); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-08-13 23:28:01 +02:00
										 |  |  |         $subTitle     = trans('firefly.import_complete'); | 
					
						
							| 
									
										
										
										
											2016-07-02 23:08:47 +02:00
										 |  |  |         $subTitleIcon = 'fa-star'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return view('import.complete', compact('job', 'subTitle', 'subTitleIcon')); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-10 21:00:00 +02:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2016-06-24 14:24:34 +02:00
										 |  |  |      * This is step 3. | 
					
						
							|  |  |  |      * This is the first step in configuring the job. It can only be executed | 
					
						
							|  |  |  |      * when the job is set to "import_status_never_started". | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-06-10 21:00:00 +02:00
										 |  |  |      * @param ImportJob $job | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return View | 
					
						
							| 
									
										
										
										
											2016-06-24 14:24:34 +02:00
										 |  |  |      * @throws FireflyException | 
					
						
							| 
									
										
										
										
											2016-06-10 21:00:00 +02:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function configure(ImportJob $job) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-07-02 23:08:47 +02:00
										 |  |  |         Log::debug('Now at start of configure()'); | 
					
						
							| 
									
										
										
										
											2016-06-24 14:24:34 +02:00
										 |  |  |         if (!$this->jobInCorrectStep($job, 'configure')) { | 
					
						
							| 
									
										
										
										
											2016-07-02 23:08:47 +02:00
										 |  |  |             Log::debug('Job is not in correct state for configure()', ['status' => $job->status]); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-24 14:24:34 +02:00
										 |  |  |             return $this->redirectToCorrectStep($job); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // actual code
 | 
					
						
							|  |  |  |         $importer = $this->makeImporter($job); | 
					
						
							| 
									
										
										
										
											2016-06-10 21:00:00 +02:00
										 |  |  |         $importer->configure(); | 
					
						
							| 
									
										
										
										
											2016-07-02 17:33:57 +02:00
										 |  |  |         $data         = $importer->getConfigurationData(); | 
					
						
							|  |  |  |         $subTitle     = trans('firefly.configure_import'); | 
					
						
							|  |  |  |         $subTitleIcon = 'fa-wrench'; | 
					
						
							| 
									
										
										
										
											2016-06-10 21:00:00 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-02 17:33:57 +02:00
										 |  |  |         return view('import.' . $job->file_type . '.configure', compact('data', 'job', 'subTitle', 'subTitleIcon')); | 
					
						
							| 
									
										
										
										
											2016-06-10 21:00:00 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-02 23:08:47 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Generate a JSON file of the job's config and send it to the user. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param ImportJob $job | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return mixed | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function download(ImportJob $job) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         Log::debug('Now in download()', ['job' => $job->key]); | 
					
						
							|  |  |  |         $config                            = $job->configuration; | 
					
						
							|  |  |  |         $config['column-roles-complete']   = false; | 
					
						
							|  |  |  |         $config['column-mapping-complete'] = false; | 
					
						
							| 
									
										
										
										
											2016-10-09 20:18:46 +02:00
										 |  |  |         $config['delimiter']               = $config['delimiter'] === "\t" ? 'tab' : $config['delimiter']; | 
					
						
							| 
									
										
										
										
											2016-07-02 23:08:47 +02:00
										 |  |  |         $result                            = json_encode($config, JSON_PRETTY_PRINT); | 
					
						
							|  |  |  |         $name                              = sprintf('"%s"', addcslashes('import-configuration-' . date('Y-m-d') . '.json', '"\\')); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return response($result, 200) | 
					
						
							|  |  |  |             ->header('Content-disposition', 'attachment; filename=' . $name) | 
					
						
							|  |  |  |             ->header('Content-Type', 'application/json') | 
					
						
							|  |  |  |             ->header('Content-Description', 'File Transfer') | 
					
						
							|  |  |  |             ->header('Connection', 'Keep-Alive') | 
					
						
							|  |  |  |             ->header('Expires', '0') | 
					
						
							|  |  |  |             ->header('Cache-Control', 'must-revalidate, post-check=0, pre-check=0') | 
					
						
							|  |  |  |             ->header('Pragma', 'public') | 
					
						
							|  |  |  |             ->header('Content-Length', strlen($result)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-10 21:00:00 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-13 23:28:01 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param ImportJob $job | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return View | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function finished(ImportJob $job) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-08-14 08:10:42 +02:00
										 |  |  |         if (!$this->jobInCorrectStep($job, 'finished')) { | 
					
						
							|  |  |  |             Log::debug('Job is not in correct state for finished()', ['status' => $job->status]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             return $this->redirectToCorrectStep($job); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-18 09:27:27 +01:00
										 |  |  |         // if there is a tag (there might not be), we can link to it:
 | 
					
						
							|  |  |  |         $tagId = $job->extended_status['importTag'] ?? 0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-13 23:28:01 +02:00
										 |  |  |         $subTitle     = trans('firefly.import_finished'); | 
					
						
							|  |  |  |         $subTitleIcon = 'fa-star'; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-18 09:27:27 +01:00
										 |  |  |         return view('import.finished', compact('job', 'subTitle', 'subTitleIcon', 'tagId')); | 
					
						
							| 
									
										
										
										
											2016-08-13 23:28:01 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-22 21:11:30 +02:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2016-06-24 14:24:34 +02:00
										 |  |  |      * This is step 1. Upload a file. | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-07-23 21:37:06 +02:00
										 |  |  |      * @return View | 
					
						
							| 
									
										
										
										
											2016-05-22 21:11:30 +02:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function index() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-07-02 23:08:47 +02:00
										 |  |  |         Log::debug('Now at index'); | 
					
						
							| 
									
										
										
										
											2016-05-22 21:11:30 +02:00
										 |  |  |         $subTitle          = trans('firefly.import_data_index'); | 
					
						
							|  |  |  |         $subTitleIcon      = 'fa-home'; | 
					
						
							|  |  |  |         $importFileTypes   = []; | 
					
						
							|  |  |  |         $defaultImportType = config('firefly.default_import_format'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         foreach (array_keys(config('firefly.import_formats')) as $type) { | 
					
						
							|  |  |  |             $importFileTypes[$type] = trans('firefly.import_file_type_' . $type); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return view('import.index', compact('subTitle', 'subTitleIcon', 'importFileTypes', 'defaultImportType')); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-06-10 21:00:00 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-13 21:51:01 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @param ImportJob $job | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return \Illuminate\Http\JsonResponse | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function json(ImportJob $job) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-08-14 09:10:08 +02:00
										 |  |  |         $result     = [ | 
					
						
							| 
									
										
										
										
											2016-08-13 21:51:01 +02:00
										 |  |  |             'showPercentage' => false, | 
					
						
							|  |  |  |             'started'        => false, | 
					
						
							| 
									
										
										
										
											2016-08-14 10:11:49 +02:00
										 |  |  |             'finished'       => false, | 
					
						
							| 
									
										
										
										
											2016-08-13 21:51:01 +02:00
										 |  |  |             'running'        => false, | 
					
						
							| 
									
										
										
										
											2016-08-13 23:28:01 +02:00
										 |  |  |             'errors'         => $job->extended_status['errors'], | 
					
						
							| 
									
										
										
										
											2016-08-13 21:51:01 +02:00
										 |  |  |             'percentage'     => 0, | 
					
						
							|  |  |  |             'steps'          => $job->extended_status['total_steps'], | 
					
						
							|  |  |  |             'stepsDone'      => $job->extended_status['steps_done'], | 
					
						
							|  |  |  |             'statusText'     => trans('firefly.import_status_' . $job->status), | 
					
						
							| 
									
										
										
										
											2016-08-14 11:31:09 +02:00
										 |  |  |             'finishedText'   => '', | 
					
						
							| 
									
										
										
										
											2016-08-13 21:51:01 +02:00
										 |  |  |         ]; | 
					
						
							| 
									
										
										
										
											2016-08-14 09:10:08 +02:00
										 |  |  |         $percentage = 0; | 
					
						
							|  |  |  |         if ($job->extended_status['total_steps'] !== 0) { | 
					
						
							|  |  |  |             $percentage = round(($job->extended_status['steps_done'] / $job->extended_status['total_steps']) * 100, 0); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-08-14 10:11:49 +02:00
										 |  |  |         if ($job->status === 'import_complete') { | 
					
						
							| 
									
										
										
										
											2016-08-14 11:31:09 +02:00
										 |  |  |             $tagId = $job->extended_status['importTag']; | 
					
						
							|  |  |  |             /** @var TagRepositoryInterface $repository */ | 
					
						
							|  |  |  |             $repository             = app(TagRepositoryInterface::class); | 
					
						
							|  |  |  |             $tag                    = $repository->find($tagId); | 
					
						
							|  |  |  |             $result['finished']     = true; | 
					
						
							|  |  |  |             $result['finishedText'] = trans('firefly.import_finished_link', ['link' => route('tags.show', [$tag->id]), 'tag' => $tag->tag]); | 
					
						
							| 
									
										
										
										
											2016-08-14 10:11:49 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-08-14 09:10:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-13 21:51:01 +02:00
										 |  |  |         if ($job->status === 'import_running') { | 
					
						
							|  |  |  |             $result['started']        = true; | 
					
						
							|  |  |  |             $result['running']        = true; | 
					
						
							|  |  |  |             $result['showPercentage'] = true; | 
					
						
							| 
									
										
										
										
											2016-08-14 09:10:08 +02:00
										 |  |  |             $result['percentage']     = $percentage; | 
					
						
							| 
									
										
										
										
											2016-08-13 21:51:01 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return Response::json($result); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-10 21:00:00 +02:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2016-06-24 14:24:34 +02:00
										 |  |  |      * Step 4. Save the configuration. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param Request   $request | 
					
						
							|  |  |  |      * @param ImportJob $job | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return \Illuminate\Http\RedirectResponse|\Illuminate\Routing\Redirector | 
					
						
							|  |  |  |      * @throws FireflyException | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-06-27 15:15:46 +02:00
										 |  |  |     public function postConfigure(Request $request, ImportJob $job) | 
					
						
							| 
									
										
										
										
											2016-06-24 14:24:34 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-07-02 23:08:47 +02:00
										 |  |  |         Log::debug('Now in postConfigure()', ['job' => $job->key]); | 
					
						
							| 
									
										
										
										
											2016-06-24 14:24:34 +02:00
										 |  |  |         if (!$this->jobInCorrectStep($job, 'process')) { | 
					
						
							|  |  |  |             return $this->redirectToCorrectStep($job); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-07-02 23:08:47 +02:00
										 |  |  |         Log::debug('Continue postConfigure()', ['job' => $job->key]); | 
					
						
							| 
									
										
										
										
											2016-06-24 14:24:34 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         // actual code
 | 
					
						
							|  |  |  |         $importer = $this->makeImporter($job); | 
					
						
							|  |  |  |         $data     = $request->all(); | 
					
						
							| 
									
										
										
										
											2016-06-27 15:15:46 +02:00
										 |  |  |         $files    = $request->files; | 
					
						
							|  |  |  |         $importer->saveImportConfiguration($data, $files); | 
					
						
							| 
									
										
										
										
											2016-06-24 14:24:34 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         // update job:
 | 
					
						
							|  |  |  |         $job->status = 'import_configuration_saved'; | 
					
						
							|  |  |  |         $job->save(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // return redirect to settings.
 | 
					
						
							|  |  |  |         // this could loop until the user is done.
 | 
					
						
							| 
									
										
										
										
											2016-08-12 15:27:44 +02:00
										 |  |  |         return redirect(route('import.settings', [$job->key])); | 
					
						
							| 
									
										
										
										
											2016-06-24 14:24:34 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-02 17:33:57 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * This step 6. Depending on the importer, this will process the | 
					
						
							|  |  |  |      * settings given and store them. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param Request   $request | 
					
						
							|  |  |  |      * @param ImportJob $job | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return \Illuminate\Http\RedirectResponse|\Illuminate\Routing\Redirector | 
					
						
							|  |  |  |      * @throws FireflyException | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function postSettings(Request $request, ImportJob $job) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-07-02 23:08:47 +02:00
										 |  |  |         Log::debug('Now in postSettings()', ['job' => $job->key]); | 
					
						
							| 
									
										
										
										
											2016-07-02 17:33:57 +02:00
										 |  |  |         if (!$this->jobInCorrectStep($job, 'store-settings')) { | 
					
						
							|  |  |  |             return $this->redirectToCorrectStep($job); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         $importer = $this->makeImporter($job); | 
					
						
							|  |  |  |         $importer->storeSettings($request); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // return redirect to settings (for more settings perhaps)
 | 
					
						
							|  |  |  |         return redirect(route('import.settings', [$job->key])); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-24 14:24:34 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Step 5. Depending on the importer, this will show the user settings to | 
					
						
							|  |  |  |      * fill in. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param ImportJob $job | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-08-26 09:30:52 +02:00
										 |  |  |      * @return View | 
					
						
							| 
									
										
										
										
											2016-06-24 14:24:34 +02:00
										 |  |  |      * @throws FireflyException | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function settings(ImportJob $job) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-07-02 23:08:47 +02:00
										 |  |  |         Log::debug('Now in settings()', ['job' => $job->key]); | 
					
						
							| 
									
										
										
										
											2016-06-24 14:24:34 +02:00
										 |  |  |         if (!$this->jobInCorrectStep($job, 'settings')) { | 
					
						
							| 
									
										
										
										
											2016-07-02 23:08:47 +02:00
										 |  |  |             Log::debug('Job should not be in settings()'); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-24 14:24:34 +02:00
										 |  |  |             return $this->redirectToCorrectStep($job); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-07-02 23:08:47 +02:00
										 |  |  |         Log::debug('Continue in settings()'); | 
					
						
							| 
									
										
										
										
											2016-07-02 17:33:57 +02:00
										 |  |  |         $importer     = $this->makeImporter($job); | 
					
						
							| 
									
										
										
										
											2016-08-12 10:07:53 +02:00
										 |  |  |         $subTitle     = trans('firefly.settings_for_import'); | 
					
						
							| 
									
										
										
										
											2016-07-02 17:33:57 +02:00
										 |  |  |         $subTitleIcon = 'fa-wrench'; | 
					
						
							| 
									
										
										
										
											2016-06-24 14:24:34 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-27 15:15:46 +02:00
										 |  |  |         // now show settings screen to user.
 | 
					
						
							|  |  |  |         if ($importer->requireUserSettings()) { | 
					
						
							| 
									
										
										
										
											2016-07-02 23:08:47 +02:00
										 |  |  |             Log::debug('Job requires user config.'); | 
					
						
							| 
									
										
										
										
											2016-06-27 15:15:46 +02:00
										 |  |  |             $data = $importer->getDataForSettings(); | 
					
						
							|  |  |  |             $view = $importer->getViewForSettings(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-02 17:33:57 +02:00
										 |  |  |             return view($view, compact('data', 'job', 'subTitle', 'subTitleIcon')); | 
					
						
							| 
									
										
										
										
											2016-06-27 15:15:46 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-07-02 23:08:47 +02:00
										 |  |  |         Log::debug('Job does NOT require user config.'); | 
					
						
							| 
									
										
										
										
											2016-06-24 14:24:34 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-02 23:08:47 +02:00
										 |  |  |         $job->status = 'settings_complete'; | 
					
						
							|  |  |  |         $job->save(); | 
					
						
							| 
									
										
										
										
											2016-06-24 14:24:34 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-02 23:08:47 +02:00
										 |  |  |         // if no more settings, save job and continue to process thing.
 | 
					
						
							|  |  |  |         return redirect(route('import.complete', [$job->key])); | 
					
						
							| 
									
										
										
										
											2016-06-24 14:24:34 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         // ask the importer for the requested action.
 | 
					
						
							|  |  |  |         // for example pick columns or map data.
 | 
					
						
							|  |  |  |         // depends of course on the data in the job.
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-13 21:51:01 +02:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2016-12-25 12:55:22 +01:00
										 |  |  |      * @param ImportProcedureInterface $importProcedure | 
					
						
							|  |  |  |      * @param ImportJob                $job | 
					
						
							| 
									
										
										
										
											2016-08-13 21:51:01 +02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-12-25 12:55:22 +01:00
										 |  |  |     public function start(ImportProcedureInterface $importProcedure, ImportJob $job) | 
					
						
							| 
									
										
										
										
											2016-08-13 21:51:01 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-08-28 07:05:42 +02:00
										 |  |  |         set_time_limit(0); | 
					
						
							| 
									
										
										
										
											2016-09-17 07:57:32 +02:00
										 |  |  |         if ($job->status == 'settings_complete') { | 
					
						
							| 
									
										
										
										
											2016-12-17 19:19:49 +01:00
										 |  |  |             $importProcedure->runImport($job); | 
					
						
							| 
									
										
										
										
											2016-08-13 21:51:01 +02:00
										 |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * This is the last step before the import starts. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param ImportJob $job | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return \Illuminate\Http\RedirectResponse|\Illuminate\Routing\Redirector|View | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function status(ImportJob $job) | 
					
						
							| 
									
										
										
										
											2016-12-25 12:55:22 +01:00
										 |  |  |     { //
 | 
					
						
							| 
									
										
										
										
											2016-08-13 21:51:01 +02:00
										 |  |  |         Log::debug('Now in status()', ['job' => $job->key]); | 
					
						
							|  |  |  |         if (!$this->jobInCorrectStep($job, 'status')) { | 
					
						
							|  |  |  |             return $this->redirectToCorrectStep($job); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-08-13 23:28:01 +02:00
										 |  |  |         $subTitle     = trans('firefly.import_status'); | 
					
						
							| 
									
										
										
										
											2016-08-13 21:51:01 +02:00
										 |  |  |         $subTitleIcon = 'fa-star'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return view('import.status', compact('job', 'subTitle', 'subTitleIcon')); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-24 14:24:34 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * This is step 2. It creates an Import Job. Stores the import. | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-06-10 21:00:00 +02:00
										 |  |  |      * @param ImportUploadRequest          $request | 
					
						
							|  |  |  |      * @param ImportJobRepositoryInterface $repository | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return \Illuminate\Http\RedirectResponse|\Illuminate\Routing\Redirector | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function upload(ImportUploadRequest $request, ImportJobRepositoryInterface $repository) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-07-02 23:08:47 +02:00
										 |  |  |         Log::debug('Now in upload()'); | 
					
						
							| 
									
										
										
										
											2016-06-10 21:00:00 +02:00
										 |  |  |         // create import job:
 | 
					
						
							| 
									
										
										
										
											2016-07-02 17:33:57 +02:00
										 |  |  |         $type = $request->get('import_file_type'); | 
					
						
							|  |  |  |         $job  = $repository->create($type); | 
					
						
							|  |  |  |         Log::debug('Created new job', ['key' => $job->key, 'id' => $job->id]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         /** @var UploadedFile $upload */ | 
					
						
							| 
									
										
										
										
											2016-06-10 21:00:00 +02:00
										 |  |  |         $upload           = $request->files->get('import_file'); | 
					
						
							|  |  |  |         $newName          = $job->key . '.upload'; | 
					
						
							|  |  |  |         $uploaded         = new SplFileObject($upload->getRealPath()); | 
					
						
							|  |  |  |         $content          = $uploaded->fread($uploaded->getSize()); | 
					
						
							|  |  |  |         $contentEncrypted = Crypt::encrypt($content); | 
					
						
							|  |  |  |         $disk             = Storage::disk('upload'); | 
					
						
							|  |  |  |         $disk->put($newName, $contentEncrypted); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-02 17:33:57 +02:00
										 |  |  |         Log::debug('Uploaded file', ['name' => $upload->getClientOriginalName(), 'size' => $upload->getSize(), 'mime' => $upload->getClientMimeType()]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // store configuration file's content into the job's configuration
 | 
					
						
							|  |  |  |         // thing.
 | 
					
						
							|  |  |  |         // otherwise, leave it empty.
 | 
					
						
							|  |  |  |         if ($request->files->has('configuration_file')) { | 
					
						
							|  |  |  |             /** @var UploadedFile $configFile */ | 
					
						
							|  |  |  |             $configFile = $request->files->get('configuration_file'); | 
					
						
							|  |  |  |             Log::debug( | 
					
						
							|  |  |  |                 'Uploaded configuration file', | 
					
						
							|  |  |  |                 ['name' => $configFile->getClientOriginalName(), 'size' => $configFile->getSize(), 'mime' => $configFile->getClientMimeType()] | 
					
						
							|  |  |  |             ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             $configFileObject = new SplFileObject($configFile->getRealPath()); | 
					
						
							|  |  |  |             $configRaw        = $configFileObject->fread($configFileObject->getSize()); | 
					
						
							|  |  |  |             $configuration    = json_decode($configRaw, true); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             if (!is_null($configuration) && is_array($configuration)) { | 
					
						
							|  |  |  |                 Log::debug('Found configuration', $configuration); | 
					
						
							|  |  |  |                 $job->configuration = $configuration; | 
					
						
							|  |  |  |                 $job->save(); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-10 21:00:00 +02:00
										 |  |  |         return redirect(route('import.configure', [$job->key])); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-06-24 14:24:34 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param ImportJob $job | 
					
						
							|  |  |  |      * @param string    $method | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return bool | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     private function jobInCorrectStep(ImportJob $job, string $method): bool | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-07-02 23:08:47 +02:00
										 |  |  |         Log::debug('Now in jobInCorrectStep()', ['job' => $job->key, 'method' => $method]); | 
					
						
							| 
									
										
										
										
											2016-06-24 14:24:34 +02:00
										 |  |  |         switch ($method) { | 
					
						
							|  |  |  |             case 'configure': | 
					
						
							|  |  |  |             case 'process': | 
					
						
							|  |  |  |                 return $job->status === 'import_status_never_started'; | 
					
						
							|  |  |  |             case 'settings': | 
					
						
							| 
									
										
										
										
											2016-07-02 17:33:57 +02:00
										 |  |  |             case 'store-settings': | 
					
						
							| 
									
										
										
										
											2016-06-24 14:24:34 +02:00
										 |  |  |                 return $job->status === 'import_configuration_saved'; | 
					
						
							| 
									
										
										
										
											2016-08-14 08:10:42 +02:00
										 |  |  |             case 'finished': | 
					
						
							| 
									
										
										
										
											2016-08-14 11:31:09 +02:00
										 |  |  |                 return $job->status === 'import_complete'; | 
					
						
							| 
									
										
										
										
											2016-07-02 23:08:47 +02:00
										 |  |  |             case 'complete': | 
					
						
							|  |  |  |                 return $job->status === 'settings_complete'; | 
					
						
							| 
									
										
										
										
											2016-08-13 21:51:01 +02:00
										 |  |  |             case 'status': | 
					
						
							|  |  |  |                 return ($job->status === 'settings_complete') || ($job->status === 'import_running'); | 
					
						
							| 
									
										
										
										
											2016-06-24 14:24:34 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return false; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param ImportJob $job | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-08-06 06:21:25 +02:00
										 |  |  |      * @return SetupInterface | 
					
						
							| 
									
										
										
										
											2016-09-25 08:20:17 +02:00
										 |  |  |      * @throws FireflyException | 
					
						
							| 
									
										
										
										
											2016-06-24 14:24:34 +02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-08-06 06:21:25 +02:00
										 |  |  |     private function makeImporter(ImportJob $job): SetupInterface | 
					
						
							| 
									
										
										
										
											2016-06-24 14:24:34 +02:00
										 |  |  |     { | 
					
						
							|  |  |  |         // create proper importer (depends on job)
 | 
					
						
							| 
									
										
										
										
											2016-09-25 08:20:17 +02:00
										 |  |  |         $type = strtolower($job->file_type); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // validate type:
 | 
					
						
							| 
									
										
										
										
											2016-09-25 08:46:42 +02:00
										 |  |  |         $validTypes = array_keys(config('firefly.import_formats')); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-17 09:50:40 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-25 08:20:17 +02:00
										 |  |  |         if (in_array($type, $validTypes)) { | 
					
						
							|  |  |  |             /** @var SetupInterface $importer */ | 
					
						
							|  |  |  |             $importer = app('FireflyIII\Import\Setup\\' . ucfirst($type) . 'Setup'); | 
					
						
							|  |  |  |             $importer->setJob($job); | 
					
						
							| 
									
										
										
										
											2016-06-24 14:24:34 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-25 08:20:17 +02:00
										 |  |  |             return $importer; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         throw new FireflyException(sprintf('"%s" is not a valid file type', $type)); | 
					
						
							| 
									
										
										
										
											2016-06-24 14:24:34 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param ImportJob $job | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return \Illuminate\Http\RedirectResponse|\Illuminate\Routing\Redirector | 
					
						
							|  |  |  |      * @throws FireflyException | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     private function redirectToCorrectStep(ImportJob $job) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-07-02 23:08:47 +02:00
										 |  |  |         Log::debug('Now in redirectToCorrectStep()', ['job' => $job->key]); | 
					
						
							| 
									
										
										
										
											2016-06-24 14:24:34 +02:00
										 |  |  |         switch ($job->status) { | 
					
						
							|  |  |  |             case 'import_status_never_started': | 
					
						
							| 
									
										
										
										
											2016-07-02 23:08:47 +02:00
										 |  |  |                 Log::debug('Will redirect to configure()'); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-24 14:24:34 +02:00
										 |  |  |                 return redirect(route('import.configure', [$job->key])); | 
					
						
							|  |  |  |             case 'import_configuration_saved': | 
					
						
							| 
									
										
										
										
											2016-07-02 23:08:47 +02:00
										 |  |  |                 Log::debug('Will redirect to settings()'); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-24 14:24:34 +02:00
										 |  |  |                 return redirect(route('import.settings', [$job->key])); | 
					
						
							| 
									
										
										
										
											2016-07-02 23:08:47 +02:00
										 |  |  |             case 'settings_complete': | 
					
						
							|  |  |  |                 Log::debug('Will redirect to complete()'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 return redirect(route('import.complete', [$job->key])); | 
					
						
							| 
									
										
										
										
											2016-09-17 07:57:32 +02:00
										 |  |  |             case 'import_complete': | 
					
						
							| 
									
										
										
										
											2016-08-14 11:31:09 +02:00
										 |  |  |                 Log::debug('Will redirect to finished()'); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-13 23:28:01 +02:00
										 |  |  |                 return redirect(route('import.finished', [$job->key])); | 
					
						
							| 
									
										
										
										
											2016-06-24 14:24:34 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         throw new FireflyException('Cannot redirect for job state ' . $job->status); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-05-22 21:11:30 +02:00
										 |  |  | } |