| 
									
										
										
										
											2015-07-03 10:45:00 +02:00
										 |  |  | <?php | 
					
						
							| 
									
										
										
										
											2016-02-05 12:08:25 +01:00
										 |  |  | declare(strict_types = 1); | 
					
						
							| 
									
										
										
										
											2015-07-03 10:45:00 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | namespace FireflyIII\Http\Controllers; | 
					
						
							| 
									
										
										
										
											2015-07-03 11:52:51 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-04 07:53:37 +02:00
										 |  |  | use Config; | 
					
						
							| 
									
										
										
										
											2015-07-09 16:37:42 +02:00
										 |  |  | use ExpandedForm; | 
					
						
							| 
									
										
										
										
											2015-07-04 07:53:37 +02:00
										 |  |  | use FireflyIII\Exceptions\FireflyException; | 
					
						
							| 
									
										
										
										
											2015-07-05 06:18:02 +02:00
										 |  |  | use FireflyIII\Helpers\Csv\Data; | 
					
						
							|  |  |  | use FireflyIII\Helpers\Csv\Importer; | 
					
						
							|  |  |  | use FireflyIII\Helpers\Csv\WizardInterface; | 
					
						
							| 
									
										
										
										
											2015-12-30 08:00:52 +01:00
										 |  |  | use FireflyIII\Repositories\Account\AccountRepositoryInterface as ARI; | 
					
						
							| 
									
										
										
										
											2015-07-03 11:52:51 +02:00
										 |  |  | use Illuminate\Http\Request; | 
					
						
							|  |  |  | use Input; | 
					
						
							| 
									
										
										
										
											2015-07-05 08:45:05 +02:00
										 |  |  | use Log; | 
					
						
							| 
									
										
										
										
											2015-07-05 14:37:36 +02:00
										 |  |  | use Preferences; | 
					
						
							| 
									
										
										
										
											2016-01-23 08:48:36 +01:00
										 |  |  | use Request as RequestFacade; | 
					
						
							| 
									
										
										
										
											2015-07-03 11:52:51 +02:00
										 |  |  | use Session; | 
					
						
							| 
									
										
										
										
											2015-07-03 10:45:00 +02:00
										 |  |  | use View; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * Class CsvController | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @package FireflyIII\Http\Controllers | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | class CsvController extends Controller | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-05 06:18:02 +02:00
										 |  |  |     /** @var  Data */ | 
					
						
							|  |  |  |     protected $data; | 
					
						
							|  |  |  |     /** @var  WizardInterface */ | 
					
						
							|  |  |  |     protected $wizard; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-03 10:45:00 +02:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2016-02-04 07:27:03 +01:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2015-07-03 10:45:00 +02:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function __construct() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         parent::__construct(); | 
					
						
							| 
									
										
										
										
											2015-07-03 11:52:51 +02:00
										 |  |  |         View::share('title', trans('firefly.csv')); | 
					
						
							| 
									
										
										
										
											2015-07-03 10:45:00 +02:00
										 |  |  |         View::share('mainTitleIcon', 'fa-file-text-o'); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-05 08:47:16 +02:00
										 |  |  |         if (Config::get('firefly.csv_import_enabled') === false) { | 
					
						
							|  |  |  |             throw new FireflyException('CSV Import is not enabled.'); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-07 19:09:45 +02:00
										 |  |  |         $this->wizard = app('FireflyIII\Helpers\Csv\WizardInterface'); | 
					
						
							|  |  |  |         $this->data   = app('FireflyIII\Helpers\Csv\Data'); | 
					
						
							| 
									
										
										
										
											2015-07-05 06:18:02 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-03 10:45:00 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-03 11:52:51 +02:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2015-07-04 07:53:37 +02:00
										 |  |  |      * Define column roles and mapping. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * STEP THREE | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2015-07-06 10:39:44 +02:00
										 |  |  |      * @return \Illuminate\Http\RedirectResponse|\Illuminate\View\View | 
					
						
							| 
									
										
										
										
											2015-07-04 07:53:37 +02:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function columnRoles() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2015-07-05 06:18:02 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-23 08:48:36 +01:00
										 |  |  |         $fields = ['csv-file', 'csv-date-format', 'csv-has-headers', 'csv-import-account', 'csv-specifix', 'csv-delimiter']; | 
					
						
							| 
									
										
										
										
											2015-07-05 06:18:02 +02:00
										 |  |  |         if (!$this->wizard->sessionHasValues($fields)) { | 
					
						
							| 
									
										
										
										
											2016-01-23 08:48:36 +01:00
										 |  |  |             Log::error('Could not recover upload.'); | 
					
						
							| 
									
										
										
										
											2015-07-05 06:18:02 +02:00
										 |  |  |             Session::flash('warning', 'Could not recover upload.'); | 
					
						
							| 
									
										
										
										
											2015-07-04 07:53:37 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-06 16:08:36 +02:00
										 |  |  |             return redirect(route('csv.index')); | 
					
						
							| 
									
										
										
										
											2015-07-04 07:53:37 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-06 08:33:39 +02:00
										 |  |  |         $subTitle       = trans('firefly.csv_define_column_roles'); | 
					
						
							| 
									
										
										
										
											2015-07-05 06:18:02 +02:00
										 |  |  |         $firstRow       = $this->data->getReader()->fetchOne(); | 
					
						
							|  |  |  |         $count          = count($firstRow); | 
					
						
							|  |  |  |         $headers        = []; | 
					
						
							| 
									
										
										
										
											2015-07-05 14:37:36 +02:00
										 |  |  |         $example        = $this->data->getReader()->fetchOne(1); | 
					
						
							| 
									
										
										
										
											2015-07-05 06:18:02 +02:00
										 |  |  |         $availableRoles = []; | 
					
						
							|  |  |  |         $roles          = $this->data->getRoles(); | 
					
						
							|  |  |  |         $map            = $this->data->getMap(); | 
					
						
							| 
									
										
										
										
											2015-07-04 07:53:37 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         for ($i = 1; $i <= $count; $i++) { | 
					
						
							| 
									
										
										
										
											2015-07-05 08:45:05 +02:00
										 |  |  |             $headers[] = trans('firefly.csv_column') . ' #' . $i; | 
					
						
							| 
									
										
										
										
											2015-07-04 07:53:37 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2015-07-06 22:23:34 +02:00
										 |  |  |         if ($this->data->hasHeaders()) { | 
					
						
							| 
									
										
										
										
											2015-07-04 07:53:37 +02:00
										 |  |  |             $headers = $firstRow; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-01-15 17:53:54 +01:00
										 |  |  |         $keys = array_keys(Config::get('csv.roles')); | 
					
						
							|  |  |  |         foreach ($keys as $name) { | 
					
						
							| 
									
										
										
										
											2016-01-20 21:24:48 +01:00
										 |  |  |             $availableRoles[$name] = trans('firefly.csv_column_' . $name); | 
					
						
							| 
									
										
										
										
											2015-07-04 07:53:37 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-02-11 07:03:12 +01:00
										 |  |  |         asort($availableRoles); | 
					
						
							| 
									
										
										
										
											2015-07-05 06:18:02 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         return view('csv.column-roles', compact('availableRoles', 'map', 'roles', 'headers', 'example', 'subTitle')); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-07-04 07:53:37 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-05 06:18:02 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Optional download of mapping. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * STEP FOUR THREE-A | 
					
						
							| 
									
										
										
										
											2015-07-06 16:08:36 +02:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return \Illuminate\Http\RedirectResponse|string | 
					
						
							| 
									
										
										
										
											2015-07-05 06:18:02 +02:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function downloadConfig() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-01-22 20:43:44 +01:00
										 |  |  |         $fields = ['csv-date-format', 'csv-has-headers', 'csv-delimiter']; | 
					
						
							| 
									
										
										
										
											2015-07-05 06:18:02 +02:00
										 |  |  |         if (!$this->wizard->sessionHasValues($fields)) { | 
					
						
							|  |  |  |             Session::flash('warning', 'Could not recover upload.'); | 
					
						
							| 
									
										
										
										
											2015-07-04 07:53:37 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-06 16:08:36 +02:00
										 |  |  |             return redirect(route('csv.index')); | 
					
						
							| 
									
										
										
										
											2015-07-05 06:18:02 +02:00
										 |  |  |         } | 
					
						
							|  |  |  |         $data = [ | 
					
						
							| 
									
										
										
										
											2016-02-04 07:27:03 +01:00
										 |  |  |             'date-format' => session('csv-date-format'), | 
					
						
							|  |  |  |             'has-headers' => session('csv-has-headers'), | 
					
						
							| 
									
										
										
										
											2015-07-05 06:18:02 +02:00
										 |  |  |         ]; | 
					
						
							|  |  |  |         if (Session::has('csv-map')) { | 
					
						
							| 
									
										
										
										
											2016-02-04 07:27:03 +01:00
										 |  |  |             $data['map'] = session('csv-map'); | 
					
						
							| 
									
										
										
										
											2015-07-05 06:18:02 +02:00
										 |  |  |         } | 
					
						
							|  |  |  |         if (Session::has('csv-roles')) { | 
					
						
							| 
									
										
										
										
											2016-02-04 07:27:03 +01:00
										 |  |  |             $data['roles'] = session('csv-roles'); | 
					
						
							| 
									
										
										
										
											2015-07-05 06:18:02 +02:00
										 |  |  |         } | 
					
						
							|  |  |  |         if (Session::has('csv-mapped')) { | 
					
						
							| 
									
										
										
										
											2016-02-04 07:27:03 +01:00
										 |  |  |             $data['mapped'] = session('csv-mapped'); | 
					
						
							| 
									
										
										
										
											2015-07-05 06:18:02 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-09 19:05:59 +02:00
										 |  |  |         if (Session::has('csv-specifix')) { | 
					
						
							| 
									
										
										
										
											2016-02-04 07:27:03 +01:00
										 |  |  |             $data['specifix'] = session('csv-specifix'); | 
					
						
							| 
									
										
										
										
											2015-07-09 19:05:59 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-05 06:18:02 +02:00
										 |  |  |         $result = json_encode($data, JSON_PRETTY_PRINT); | 
					
						
							| 
									
										
										
										
											2016-01-23 08:48:36 +01:00
										 |  |  |         $name   = sprintf('"%s"', addcslashes('csv-configuration-' . date('Y-m-d') . '.json', '"\\')); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         RequestFacade::header('Content-disposition: attachment; filename=' . $name); | 
					
						
							|  |  |  |         RequestFacade::header('Content-Type: application/json'); | 
					
						
							|  |  |  |         RequestFacade::header('Content-Description: File Transfer'); | 
					
						
							|  |  |  |         RequestFacade::header('Connection: Keep-Alive'); | 
					
						
							|  |  |  |         RequestFacade::header('Expires: 0'); | 
					
						
							|  |  |  |         RequestFacade::header('Cache-Control: must-revalidate, post-check=0, pre-check=0'); | 
					
						
							|  |  |  |         RequestFacade::header('Pragma: public'); | 
					
						
							|  |  |  |         RequestFacade::header('Content-Length: ' . strlen($result)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $result; | 
					
						
							| 
									
										
										
										
											2015-07-05 06:18:02 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2015-07-06 16:08:36 +02:00
										 |  |  |      * @return \Illuminate\View\View | 
					
						
							| 
									
										
										
										
											2015-07-05 06:18:02 +02:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function downloadConfigPage() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-01-23 08:48:36 +01:00
										 |  |  |         $fields = ['csv-date-format', 'csv-has-headers', 'csv-delimiter']; | 
					
						
							|  |  |  |         if (!$this->wizard->sessionHasValues($fields)) { | 
					
						
							|  |  |  |             Session::flash('warning', 'Could not recover upload.'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             return redirect(route('csv.index')); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-06 08:33:39 +02:00
										 |  |  |         $subTitle = trans('firefly.csv_download_config_title'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return view('csv.download-config', compact('subTitle')); | 
					
						
							| 
									
										
										
										
											2015-07-04 07:53:37 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * This method shows the initial upload form. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * STEP ONE | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-01-01 21:49:27 +01:00
										 |  |  |      * @param ARI $repository | 
					
						
							| 
									
										
										
										
											2015-12-28 07:55:09 +01:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2015-07-06 16:08:36 +02:00
										 |  |  |      * @return \Illuminate\View\View | 
					
						
							| 
									
										
										
										
											2015-07-03 11:52:51 +02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2015-12-30 08:00:52 +01:00
										 |  |  |     public function index(ARI $repository) | 
					
						
							| 
									
										
										
										
											2015-07-03 10:45:00 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2015-07-03 11:52:51 +02:00
										 |  |  |         $subTitle = trans('firefly.csv_import'); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-04 07:53:37 +02:00
										 |  |  |         Session::forget('csv-date-format'); | 
					
						
							|  |  |  |         Session::forget('csv-has-headers'); | 
					
						
							|  |  |  |         Session::forget('csv-file'); | 
					
						
							| 
									
										
										
										
											2015-07-09 16:37:42 +02:00
										 |  |  |         Session::forget('csv-import-account'); | 
					
						
							| 
									
										
										
										
											2015-07-05 06:18:02 +02:00
										 |  |  |         Session::forget('csv-map'); | 
					
						
							|  |  |  |         Session::forget('csv-roles'); | 
					
						
							|  |  |  |         Session::forget('csv-mapped'); | 
					
						
							| 
									
										
										
										
											2015-07-05 18:18:44 +02:00
										 |  |  |         Session::forget('csv-specifix'); | 
					
						
							| 
									
										
										
										
											2016-01-20 21:24:48 +01:00
										 |  |  |         Session::forget('csv-delimiter'); | 
					
						
							| 
									
										
										
										
											2015-07-04 07:53:37 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-06 20:21:55 +02:00
										 |  |  |         // get list of supported specifix
 | 
					
						
							|  |  |  |         $specifix = []; | 
					
						
							|  |  |  |         foreach (Config::get('csv.specifix') as $entry) { | 
					
						
							|  |  |  |             $specifix[$entry] = trans('firefly.csv_specifix_' . $entry); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2015-07-04 07:53:37 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-15 16:26:19 +01:00
										 |  |  |         // get a list of delimiters:
 | 
					
						
							|  |  |  |         $delimiters = [ | 
					
						
							|  |  |  |             ','   => trans('form.csv_comma'), | 
					
						
							|  |  |  |             ';'   => trans('form.csv_semicolon'), | 
					
						
							| 
									
										
										
										
											2016-01-15 17:53:54 +01:00
										 |  |  |             'tab' => trans('form.csv_tab'), | 
					
						
							| 
									
										
										
										
											2016-01-15 16:26:19 +01:00
										 |  |  |         ]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-09 16:37:42 +02:00
										 |  |  |         // get a list of asset accounts:
 | 
					
						
							|  |  |  |         $accounts = ExpandedForm::makeSelectList($repository->getAccounts(['Asset account', 'Default account'])); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-03 11:52:51 +02:00
										 |  |  |         // can actually upload?
 | 
					
						
							| 
									
										
										
										
											2015-07-03 12:22:20 +02:00
										 |  |  |         $uploadPossible = is_writable(storage_path('upload')); | 
					
						
							| 
									
										
										
										
											2015-07-03 11:52:51 +02:00
										 |  |  |         $path           = storage_path('upload'); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-15 16:26:24 +01:00
										 |  |  |         return view('csv.index', compact('subTitle', 'uploadPossible', 'path', 'specifix', 'accounts', 'delimiters')); | 
					
						
							| 
									
										
										
										
											2015-07-03 11:52:51 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2015-07-04 07:53:37 +02:00
										 |  |  |      * Parse the file. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * STEP FOUR | 
					
						
							| 
									
										
										
										
											2015-07-03 11:52:51 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2015-07-04 07:53:37 +02:00
										 |  |  |      * @return \Illuminate\Http\RedirectResponse | 
					
						
							| 
									
										
										
										
											2015-07-03 11:52:51 +02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2015-07-04 07:53:37 +02:00
										 |  |  |     public function initialParse() | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2016-01-22 20:43:44 +01:00
										 |  |  |         $fields = ['csv-file', 'csv-date-format', 'csv-has-headers', 'csv-delimiter']; | 
					
						
							| 
									
										
										
										
											2015-07-05 06:18:02 +02:00
										 |  |  |         if (!$this->wizard->sessionHasValues($fields)) { | 
					
						
							|  |  |  |             Session::flash('warning', 'Could not recover upload.'); | 
					
						
							| 
									
										
										
										
											2015-07-04 07:53:37 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-06 16:08:36 +02:00
										 |  |  |             return redirect(route('csv.index')); | 
					
						
							| 
									
										
										
										
											2015-07-04 07:53:37 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-05 06:18:02 +02:00
										 |  |  |         // process given roles and mapping:
 | 
					
						
							|  |  |  |         $roles = $this->wizard->processSelectedRoles(Input::get('role')); | 
					
						
							|  |  |  |         $maps  = $this->wizard->processSelectedMapping($roles, Input::get('map')); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         Session::put('csv-map', $maps); | 
					
						
							|  |  |  |         Session::put('csv-roles', $roles); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-06 22:23:34 +02:00
										 |  |  |         // Go back when no roles defined:
 | 
					
						
							| 
									
										
										
										
											2015-07-04 07:53:37 +02:00
										 |  |  |         if (count($roles) === 0) { | 
					
						
							|  |  |  |             Session::flash('warning', 'Please select some roles.'); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-06 16:08:36 +02:00
										 |  |  |             return redirect(route('csv.column-roles')); | 
					
						
							| 
									
										
										
										
											2015-07-04 07:53:37 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         /* | 
					
						
							| 
									
										
										
										
											2015-07-05 06:18:02 +02:00
										 |  |  |          * Continue with map specification when necessary. | 
					
						
							| 
									
										
										
										
											2015-07-04 07:53:37 +02:00
										 |  |  |          */ | 
					
						
							| 
									
										
										
										
											2015-07-05 06:18:02 +02:00
										 |  |  |         if (count($maps) > 0) { | 
					
						
							| 
									
										
										
										
											2015-07-06 16:08:36 +02:00
										 |  |  |             return redirect(route('csv.map')); | 
					
						
							| 
									
										
										
										
											2015-07-04 07:53:37 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-05 06:18:02 +02:00
										 |  |  |         /* | 
					
						
							|  |  |  |          * Or simply start processing. | 
					
						
							|  |  |  |          */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-05 08:45:05 +02:00
										 |  |  |         // proceed to download config
 | 
					
						
							| 
									
										
										
										
											2015-07-06 16:08:36 +02:00
										 |  |  |         return redirect(route('csv.download-config-page')); | 
					
						
							| 
									
										
										
										
											2015-07-04 07:53:37 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * Map first if necessary, | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * STEP FIVE. | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2015-07-06 16:08:36 +02:00
										 |  |  |      * @return \Illuminate\Http\RedirectResponse|\Illuminate\View\View | 
					
						
							| 
									
										
										
										
											2015-07-04 07:53:37 +02:00
										 |  |  |      * @throws FireflyException | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function map() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-06 22:12:35 +02:00
										 |  |  |         // Make sure all fields we need are accounted for.
 | 
					
						
							| 
									
										
										
										
											2016-01-22 20:43:44 +01:00
										 |  |  |         $fields = ['csv-file', 'csv-date-format', 'csv-has-headers', 'csv-map', 'csv-roles', 'csv-delimiter']; | 
					
						
							| 
									
										
										
										
											2015-07-05 06:18:02 +02:00
										 |  |  |         if (!$this->wizard->sessionHasValues($fields)) { | 
					
						
							|  |  |  |             Session::flash('warning', 'Could not recover upload.'); | 
					
						
							| 
									
										
										
										
											2015-07-04 07:53:37 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-06 16:08:36 +02:00
										 |  |  |             return redirect(route('csv.index')); | 
					
						
							| 
									
										
										
										
											2015-07-04 07:53:37 +02:00
										 |  |  |         } | 
					
						
							|  |  |  |         /* | 
					
						
							|  |  |  |          * The "options" array contains all options the user has | 
					
						
							|  |  |  |          * per column, where the key represents the column. | 
					
						
							|  |  |  |          * | 
					
						
							|  |  |  |          * For each key there is an array which in turn represents | 
					
						
							|  |  |  |          * all the options available: grouped by ID. | 
					
						
							| 
									
										
										
										
											2015-07-05 06:18:02 +02:00
										 |  |  |          * | 
					
						
							|  |  |  |          * options[column index] = [ | 
					
						
							| 
									
										
										
										
											2015-07-06 22:12:35 +02:00
										 |  |  |          *       field id => field identifier. | 
					
						
							| 
									
										
										
										
											2015-07-05 06:18:02 +02:00
										 |  |  |          * ] | 
					
						
							| 
									
										
										
										
											2015-07-04 07:53:37 +02:00
										 |  |  |          */ | 
					
						
							| 
									
										
										
										
											2016-02-06 05:01:34 +01:00
										 |  |  |         $options = $this->wizard->showOptions($this->data->getMap()); | 
					
						
							| 
									
										
										
										
											2015-07-04 07:53:37 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-06 22:12:35 +02:00
										 |  |  |         // After these values are prepped, read the actual CSV file
 | 
					
						
							| 
									
										
										
										
											2015-07-05 06:18:02 +02:00
										 |  |  |         $reader     = $this->data->getReader(); | 
					
						
							|  |  |  |         $map        = $this->data->getMap(); | 
					
						
							| 
									
										
										
										
											2015-07-06 22:23:34 +02:00
										 |  |  |         $hasHeaders = $this->data->hasHeaders(); | 
					
						
							| 
									
										
										
										
											2015-07-05 06:18:02 +02:00
										 |  |  |         $values     = $this->wizard->getMappableValues($reader, $map, $hasHeaders); | 
					
						
							|  |  |  |         $map        = $this->data->getMap(); | 
					
						
							|  |  |  |         $mapped     = $this->data->getMapped(); | 
					
						
							| 
									
										
										
										
											2015-07-06 08:33:39 +02:00
										 |  |  |         $subTitle   = trans('firefly.csv_map_values'); | 
					
						
							| 
									
										
										
										
											2015-07-05 06:18:02 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-06 08:33:39 +02:00
										 |  |  |         return view('csv.map', compact('map', 'options', 'values', 'mapped', 'subTitle')); | 
					
						
							| 
									
										
										
										
											2015-07-04 07:53:37 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2015-07-06 16:08:36 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2015-07-04 07:53:37 +02:00
										 |  |  |      * Finally actually process the CSV file. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * STEP SEVEN | 
					
						
							| 
									
										
										
										
											2015-07-06 16:08:36 +02:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return \Illuminate\Http\RedirectResponse|\Illuminate\View\View | 
					
						
							| 
									
										
										
										
											2015-07-04 07:53:37 +02:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function process() | 
					
						
							| 
									
										
										
										
											2015-07-03 11:52:51 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2015-07-04 07:53:37 +02:00
										 |  |  |         /* | 
					
						
							|  |  |  |          * Make sure all fields we need are accounted for. | 
					
						
							|  |  |  |          */ | 
					
						
							| 
									
										
										
										
											2016-01-22 20:43:44 +01:00
										 |  |  |         $fields = ['csv-file', 'csv-date-format', 'csv-has-headers', 'csv-map', 'csv-roles', 'csv-mapped', 'csv-delimiter']; | 
					
						
							| 
									
										
										
										
											2015-07-05 06:18:02 +02:00
										 |  |  |         if (!$this->wizard->sessionHasValues($fields)) { | 
					
						
							|  |  |  |             Session::flash('warning', 'Could not recover upload.'); | 
					
						
							| 
									
										
										
										
											2015-07-04 07:53:37 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-06 16:08:36 +02:00
										 |  |  |             return redirect(route('csv.index')); | 
					
						
							| 
									
										
										
										
											2015-07-04 07:53:37 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-05 08:45:05 +02:00
										 |  |  |         Log::debug('Created importer'); | 
					
						
							| 
									
										
										
										
											2015-07-05 06:18:02 +02:00
										 |  |  |         $importer = new Importer; | 
					
						
							|  |  |  |         $importer->setData($this->data); | 
					
						
							| 
									
										
										
										
											2016-02-06 05:01:34 +01:00
										 |  |  |         $importer->run(); | 
					
						
							| 
									
										
										
										
											2015-07-05 08:45:05 +02:00
										 |  |  |         Log::debug('Done importing!'); | 
					
						
							| 
									
										
										
										
											2015-07-05 06:18:02 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-05 14:37:36 +02:00
										 |  |  |         $rows     = $importer->getRows(); | 
					
						
							|  |  |  |         $errors   = $importer->getErrors(); | 
					
						
							|  |  |  |         $imported = $importer->getImported(); | 
					
						
							| 
									
										
										
										
											2015-07-09 18:38:15 +02:00
										 |  |  |         $journals = $importer->getJournals(); | 
					
						
							| 
									
										
										
										
											2015-07-05 14:37:36 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         Preferences::mark(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-06 08:33:39 +02:00
										 |  |  |         $subTitle = trans('firefly.csv_process_title'); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-09 18:38:15 +02:00
										 |  |  |         return view('csv.process', compact('rows', 'errors', 'imported', 'subTitle', 'journals')); | 
					
						
							| 
									
										
										
										
											2015-07-05 06:18:02 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-04 07:53:37 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Store the mapping the user has made. This is | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * STEP SIX | 
					
						
							| 
									
										
										
										
											2015-07-06 16:08:36 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-01-15 20:48:06 +01:00
										 |  |  |      * @SuppressWarnings(PHPMD.CyclomaticComplexity) it's 6, but it's allright. | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2015-07-06 16:08:36 +02:00
										 |  |  |      * @return \Illuminate\Http\RedirectResponse | 
					
						
							| 
									
										
										
										
											2015-07-04 07:53:37 +02:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function saveMapping() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         /* | 
					
						
							|  |  |  |          * Make sure all fields we need are accounted for. | 
					
						
							|  |  |  |          */ | 
					
						
							| 
									
										
										
										
											2016-01-22 20:43:44 +01:00
										 |  |  |         $fields = ['csv-file', 'csv-date-format', 'csv-has-headers', 'csv-map', 'csv-roles', 'csv-delimiter']; | 
					
						
							| 
									
										
										
										
											2015-07-05 06:18:02 +02:00
										 |  |  |         if (!$this->wizard->sessionHasValues($fields)) { | 
					
						
							|  |  |  |             Session::flash('warning', 'Could not recover upload.'); | 
					
						
							| 
									
										
										
										
											2015-07-04 07:53:37 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-06 16:08:36 +02:00
										 |  |  |             return redirect(route('csv.index')); | 
					
						
							| 
									
										
										
										
											2015-07-04 07:53:37 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2015-07-05 06:18:02 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-04 07:53:37 +02:00
										 |  |  |         // save mapping to session.
 | 
					
						
							|  |  |  |         $mapped = []; | 
					
						
							|  |  |  |         if (!is_array(Input::get('mapping'))) { | 
					
						
							|  |  |  |             Session::flash('warning', 'Invalid mapping.'); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-06 16:08:36 +02:00
										 |  |  |             return redirect(route('csv.map')); | 
					
						
							| 
									
										
										
										
											2015-07-04 07:53:37 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         foreach (Input::get('mapping') as $index => $data) { | 
					
						
							|  |  |  |             $mapped[$index] = []; | 
					
						
							|  |  |  |             foreach ($data as $value => $mapping) { | 
					
						
							| 
									
										
										
										
											2015-07-06 08:33:39 +02:00
										 |  |  |                 if (intval($mapping) !== 0) { | 
					
						
							|  |  |  |                     $mapped[$index][$value] = $mapping; | 
					
						
							|  |  |  |                 } | 
					
						
							| 
									
										
										
										
											2015-07-04 07:53:37 +02:00
										 |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         Session::put('csv-mapped', $mapped); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // proceed to process.
 | 
					
						
							| 
									
										
										
										
											2015-07-06 16:08:36 +02:00
										 |  |  |         return redirect(route('csv.download-config-page')); | 
					
						
							| 
									
										
										
										
											2015-07-04 07:53:37 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * This method processes the file, puts it away somewhere safe | 
					
						
							|  |  |  |      * and sends you onwards. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * STEP TWO | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2016-01-15 19:37:09 +01:00
										 |  |  |      * @SuppressWarnings(PHPMD.ExcessiveMethodLength) // need the length.
 | 
					
						
							|  |  |  |      * @SuppressWarnings(PHPMD.CyclomaticComplexity) // its exactly 5, its ok
 | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2015-07-04 07:53:37 +02:00
										 |  |  |      * @param Request $request | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return \Illuminate\Http\RedirectResponse | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function upload(Request $request) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2015-07-03 11:52:51 +02:00
										 |  |  |         if (!$request->hasFile('csv')) { | 
					
						
							|  |  |  |             Session::flash('warning', 'No file uploaded.'); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-06 16:08:36 +02:00
										 |  |  |             return redirect(route('csv.index')); | 
					
						
							| 
									
										
										
										
											2015-07-03 11:52:51 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-09 16:37:42 +02:00
										 |  |  |         $fullPath                   = $this->wizard->storeCsvFile($request->file('csv')->getRealPath()); | 
					
						
							|  |  |  |         $settings                   = []; | 
					
						
							|  |  |  |         $settings['date-format']    = Input::get('date_format'); | 
					
						
							|  |  |  |         $settings['has-headers']    = intval(Input::get('has_headers')) === 1; | 
					
						
							| 
									
										
										
										
											2016-01-22 21:08:04 +01:00
										 |  |  |         $settings['specifix']       = is_array(Input::get('specifix')) ? Input::get('specifix') : []; | 
					
						
							| 
									
										
										
										
											2015-07-09 16:37:42 +02:00
										 |  |  |         $settings['import-account'] = intval(Input::get('csv_import_account')); | 
					
						
							| 
									
										
										
										
											2016-01-15 15:24:07 +01:00
										 |  |  |         $settings['delimiter']      = Input::get('csv_delimiter', ','); | 
					
						
							| 
									
										
										
										
											2016-01-15 16:26:49 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-15 15:24:07 +01:00
										 |  |  |         // A tab character cannot be used itself as option value in HTML
 | 
					
						
							|  |  |  |         // See http://stackoverflow.com/questions/6064135/valid-characters-in-option-value
 | 
					
						
							| 
									
										
										
										
											2016-01-15 16:26:49 +01:00
										 |  |  |         if ($settings['delimiter'] == 'tab') { | 
					
						
							|  |  |  |             $settings['delimiter'] = "\t"; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $settings['map']    = []; | 
					
						
							|  |  |  |         $settings['mapped'] = []; | 
					
						
							|  |  |  |         $settings['roles']  = []; | 
					
						
							| 
									
										
										
										
											2015-07-09 16:37:42 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         if ($request->hasFile('csv_config')) { // Process config file if present.
 | 
					
						
							| 
									
										
										
										
											2015-07-05 06:18:02 +02:00
										 |  |  |             $data = file_get_contents($request->file('csv_config')->getRealPath()); | 
					
						
							|  |  |  |             $json = json_decode($data, true); | 
					
						
							| 
									
										
										
										
											2015-07-06 16:08:36 +02:00
										 |  |  |             if (is_array($json)) { | 
					
						
							|  |  |  |                 $settings = array_merge($settings, $json); | 
					
						
							| 
									
										
										
										
											2015-07-05 06:18:02 +02:00
										 |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2015-07-04 07:53:37 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-05 06:18:02 +02:00
										 |  |  |         $this->data->setCsvFileLocation($fullPath); | 
					
						
							| 
									
										
										
										
											2015-07-06 16:08:36 +02:00
										 |  |  |         $this->data->setDateFormat($settings['date-format']); | 
					
						
							|  |  |  |         $this->data->setHasHeaders($settings['has-headers']); | 
					
						
							|  |  |  |         $this->data->setMap($settings['map']); | 
					
						
							|  |  |  |         $this->data->setMapped($settings['mapped']); | 
					
						
							|  |  |  |         $this->data->setRoles($settings['roles']); | 
					
						
							| 
									
										
										
										
											2015-07-06 20:21:55 +02:00
										 |  |  |         $this->data->setSpecifix($settings['specifix']); | 
					
						
							| 
									
										
										
										
											2015-07-09 16:37:42 +02:00
										 |  |  |         $this->data->setImportAccount($settings['import-account']); | 
					
						
							| 
									
										
										
										
											2016-01-15 15:24:07 +01:00
										 |  |  |         $this->data->setDelimiter($settings['delimiter']); | 
					
						
							| 
									
										
										
										
											2016-01-15 16:26:49 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-06 16:08:36 +02:00
										 |  |  |         return redirect(route('csv.column-roles')); | 
					
						
							| 
									
										
										
										
											2015-07-03 11:52:51 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-07-03 10:45:00 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-07-09 21:26:40 +02:00
										 |  |  | } |