| 
									
										
										
										
											2018-04-29 21:20:06 +02:00
										 |  |  | <?php | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * JobStatusController.php | 
					
						
							| 
									
										
										
										
											2020-01-31 07:32:04 +01:00
										 |  |  |  * Copyright (c) 2019 james@firefly-iii.org | 
					
						
							| 
									
										
										
										
											2018-04-29 21:20:06 +02:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02:00
										 |  |  |  * This file is part of Firefly III (https://github.com/firefly-iii). | 
					
						
							| 
									
										
										
										
											2018-04-29 21:20:06 +02:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02:00
										 |  |  |  * This program is free software: you can redistribute it and/or modify | 
					
						
							|  |  |  |  * it under the terms of the GNU Affero General Public License as | 
					
						
							|  |  |  |  * published by the Free Software Foundation, either version 3 of the | 
					
						
							|  |  |  |  * License, or (at your option) any later version. | 
					
						
							| 
									
										
										
										
											2018-04-29 21:20:06 +02:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02:00
										 |  |  |  * This program is distributed in the hope that it will be useful, | 
					
						
							| 
									
										
										
										
											2018-04-29 21:20:06 +02:00
										 |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02:00
										 |  |  |  * GNU Affero General Public License for more details. | 
					
						
							| 
									
										
										
										
											2018-04-29 21:20:06 +02:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02:00
										 |  |  |  * You should have received a copy of the GNU Affero General Public License | 
					
						
							|  |  |  |  * along with this program.  If not, see <https://www.gnu.org/licenses/>. | 
					
						
							| 
									
										
										
										
											2018-04-29 21:20:06 +02:00
										 |  |  |  */ | 
					
						
							|  |  |  | declare(strict_types=1); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace FireflyIII\Http\Controllers\Import; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-05-03 17:23:16 +02:00
										 |  |  | use Exception; | 
					
						
							| 
									
										
										
										
											2018-04-29 21:20:06 +02:00
										 |  |  | use FireflyIII\Exceptions\FireflyException; | 
					
						
							|  |  |  | use FireflyIII\Http\Controllers\Controller; | 
					
						
							|  |  |  | use FireflyIII\Import\Routine\RoutineInterface; | 
					
						
							|  |  |  | use FireflyIII\Models\ImportJob; | 
					
						
							| 
									
										
										
										
											2018-04-30 06:37:29 +02:00
										 |  |  | use FireflyIII\Repositories\ImportJob\ImportJobRepositoryInterface; | 
					
						
							| 
									
										
										
										
											2018-08-10 17:05:37 +02:00
										 |  |  | use FireflyIII\Support\Http\Controllers\CreateStuff; | 
					
						
							| 
									
										
										
										
											2018-04-29 21:20:06 +02:00
										 |  |  | use Illuminate\Http\JsonResponse; | 
					
						
							|  |  |  | use Log; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * Class JobStatusController | 
					
						
							| 
									
										
										
										
											2020-03-17 15:01:00 +01:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2020-03-15 15:31:51 +01:00
										 |  |  |  * @deprecated | 
					
						
							|  |  |  |  * @codeCoverageIgnore | 
					
						
							| 
									
										
										
										
											2018-04-29 21:20:06 +02:00
										 |  |  |  */ | 
					
						
							|  |  |  | class JobStatusController extends Controller | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2018-08-10 17:05:37 +02:00
										 |  |  |     use CreateStuff; | 
					
						
							| 
									
										
										
										
											2018-07-21 08:06:24 +02:00
										 |  |  |     /** @var ImportJobRepositoryInterface The import job repository */ | 
					
						
							| 
									
										
										
										
											2018-04-30 06:37:29 +02:00
										 |  |  |     private $repository; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-29 21:20:06 +02:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2018-07-21 08:06:24 +02:00
										 |  |  |      * JobStatusController constructor. | 
					
						
							| 
									
										
										
										
											2018-04-29 21:20:06 +02:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function __construct() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         parent::__construct(); | 
					
						
							| 
									
										
										
										
											2018-09-17 16:50:46 +02:00
										 |  |  |         // set time limit to zero to prevent timeouts.
 | 
					
						
							|  |  |  |         set_time_limit(0); | 
					
						
							| 
									
										
										
										
											2018-04-29 21:20:06 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         $this->middleware( | 
					
						
							|  |  |  |             function ($request, $next) { | 
					
						
							|  |  |  |                 app('view')->share('mainTitleIcon', 'fa-archive'); | 
					
						
							| 
									
										
										
										
											2020-03-17 15:01:00 +01:00
										 |  |  |                 app('view')->share('title', (string) trans('firefly.import_index_title')); | 
					
						
							| 
									
										
										
										
											2018-04-30 06:37:29 +02:00
										 |  |  |                 $this->repository = app(ImportJobRepositoryInterface::class); | 
					
						
							| 
									
										
										
										
											2018-04-29 21:20:06 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 return $next($request); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2018-07-21 08:06:24 +02:00
										 |  |  |      * Index for job status. | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2018-04-29 21:20:06 +02:00
										 |  |  |      * @param ImportJob $importJob | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return \Illuminate\Contracts\View\Factory|\Illuminate\View\View | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function index(ImportJob $importJob) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2018-05-04 06:59:14 +02:00
										 |  |  |         $subTitleIcon = 'fa-gear'; | 
					
						
							| 
									
										
										
										
											2020-03-17 15:01:00 +01:00
										 |  |  |         $subTitle     = (string) trans('import.job_status_breadcrumb', ['key' => $importJob->key]); | 
					
						
							| 
									
										
										
										
											2018-05-04 06:59:14 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         return view('import.status', compact('importJob', 'subTitle', 'subTitleIcon')); | 
					
						
							| 
									
										
										
										
											2018-04-29 21:20:06 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2018-07-21 08:06:24 +02:00
										 |  |  |      * JSON overview of job status. | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2018-05-03 17:23:16 +02:00
										 |  |  |      * @param ImportJob $importJob | 
					
						
							| 
									
										
										
										
											2018-04-29 21:20:06 +02:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return JsonResponse | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2018-05-01 20:47:38 +02:00
										 |  |  |     public function json(ImportJob $importJob): JsonResponse | 
					
						
							| 
									
										
										
										
											2018-04-29 21:20:06 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2018-10-25 20:03:48 +02:00
										 |  |  |         $count = $this->repository->countTransactions($importJob); | 
					
						
							| 
									
										
										
										
											2018-05-04 20:21:27 +02:00
										 |  |  |         $json  = [ | 
					
						
							| 
									
										
										
										
											2018-05-30 18:36:21 +02:00
										 |  |  |             'status'               => $importJob->status, | 
					
						
							|  |  |  |             'errors'               => $importJob->errors, | 
					
						
							|  |  |  |             'count'                => $count, | 
					
						
							|  |  |  |             'tag_id'               => $importJob->tag_id, | 
					
						
							|  |  |  |             'tag_name'             => null === $importJob->tag_id ? null : $importJob->tag->tag, | 
					
						
							| 
									
										
										
										
											2020-03-17 15:01:00 +01:00
										 |  |  |             'report_txt'           => (string) trans('import.unknown_import_result'), | 
					
						
							| 
									
										
										
										
											2018-05-30 18:36:21 +02:00
										 |  |  |             'download_config'      => false, | 
					
						
							|  |  |  |             'download_config_text' => '', | 
					
						
							| 
									
										
										
										
											2018-04-29 21:20:06 +02:00
										 |  |  |         ]; | 
					
						
							| 
									
										
										
										
											2018-05-30 18:36:21 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-08 07:59:58 +02:00
										 |  |  |         if ('file' === $importJob->provider) { | 
					
						
							| 
									
										
										
										
											2018-05-30 18:36:21 +02:00
										 |  |  |             $json['download_config'] = true; | 
					
						
							|  |  |  |             $json['download_config_text'] | 
					
						
							| 
									
										
										
										
											2018-07-26 06:10:17 +02:00
										 |  |  |                                      = trans('import.should_download_config', ['route' => route('import.job.download', [$importJob->key])]) . ' ' | 
					
						
							|  |  |  |                                        . trans('import.share_config_file'); | 
					
						
							| 
									
										
										
										
											2018-05-30 18:36:21 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-05-04 06:59:14 +02:00
										 |  |  |         // if count is zero:
 | 
					
						
							| 
									
										
										
										
											2018-05-04 20:21:27 +02:00
										 |  |  |         if (null !== $importJob->tag_id) { | 
					
						
							| 
									
										
										
										
											2019-07-27 13:54:06 +02:00
										 |  |  |             $count = $this->repository->countByTag($importJob); | 
					
						
							| 
									
										
										
										
											2018-05-04 20:21:27 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2018-07-08 07:59:58 +02:00
										 |  |  |         if (0 === $count) { | 
					
						
							| 
									
										
										
										
											2020-03-17 15:01:00 +01:00
										 |  |  |             $json['report_txt'] = (string) trans('import.result_no_transactions'); | 
					
						
							| 
									
										
										
										
											2018-05-04 06:59:14 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2018-07-08 07:59:58 +02:00
										 |  |  |         if (1 === $count && null !== $importJob->tag_id) { | 
					
						
							| 
									
										
										
										
											2018-05-31 22:33:42 +02:00
										 |  |  |             $json['report_txt'] = trans( | 
					
						
							| 
									
										
										
										
											2020-03-17 15:01:00 +01:00
										 |  |  |                 'import.result_one_transaction', | 
					
						
							|  |  |  |                 ['route' => route('tags.show', [$importJob->tag_id, 'all']), 'tag' => $importJob->tag->tag] | 
					
						
							| 
									
										
										
										
											2018-05-31 22:33:42 +02:00
										 |  |  |             ); | 
					
						
							| 
									
										
										
										
											2018-05-04 06:59:14 +02:00
										 |  |  |         } | 
					
						
							|  |  |  |         if ($count > 1 && null !== $importJob->tag_id) { | 
					
						
							| 
									
										
										
										
											2018-05-04 20:21:27 +02:00
										 |  |  |             $json['report_txt'] = trans( | 
					
						
							| 
									
										
										
										
											2018-05-31 22:33:42 +02:00
										 |  |  |                 'import.result_many_transactions', | 
					
						
							|  |  |  |                 ['count' => $count, 'route' => route('tags.show', [$importJob->tag_id, 'all']), 'tag' => $importJob->tag->tag] | 
					
						
							| 
									
										
										
										
											2018-05-04 20:21:27 +02:00
										 |  |  |             ); | 
					
						
							| 
									
										
										
										
											2018-05-03 18:17:59 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2018-04-29 21:20:06 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         return response()->json($json); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2018-07-21 08:06:24 +02:00
										 |  |  |      * Calls to start the job. | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2018-05-04 20:21:27 +02:00
										 |  |  |      * @param ImportJob $importJob | 
					
						
							| 
									
										
										
										
											2018-04-29 21:20:06 +02:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return JsonResponse | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2018-05-01 20:47:38 +02:00
										 |  |  |     public function start(ImportJob $importJob): JsonResponse | 
					
						
							| 
									
										
										
										
											2018-04-29 21:20:06 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2018-10-31 16:25:21 +01:00
										 |  |  |         Log::info('Now in JobStatusController::start'); | 
					
						
							| 
									
										
										
										
											2018-05-01 20:47:38 +02:00
										 |  |  |         // catch impossible status:
 | 
					
						
							| 
									
										
										
										
											2018-07-02 20:17:50 +02:00
										 |  |  |         $allowed = ['ready_to_run', 'need_job_config']; | 
					
						
							| 
									
										
										
										
											2018-05-06 20:42:30 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-21 19:10:02 +02:00
										 |  |  |         if (null !== $importJob && !in_array($importJob->status, $allowed, true)) { | 
					
						
							| 
									
										
										
										
											2018-07-29 21:02:03 +02:00
										 |  |  |             Log::error(sprintf('Job is not ready. Status should be in array, but is %s', $importJob->status), $allowed); | 
					
						
							| 
									
										
										
										
											2018-05-06 20:42:30 +02:00
										 |  |  |             $this->repository->setStatus($importJob, 'error'); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-05-30 18:36:21 +02:00
										 |  |  |             return response()->json( | 
					
						
							|  |  |  |                 ['status' => 'NOK', 'message' => sprintf('JobStatusController::start expects status "ready_to_run" instead of "%s".', $importJob->status)] | 
					
						
							|  |  |  |             ); | 
					
						
							| 
									
										
										
										
											2018-05-01 20:47:38 +02:00
										 |  |  |         } | 
					
						
							|  |  |  |         $importProvider = $importJob->provider; | 
					
						
							| 
									
										
										
										
											2018-04-29 21:20:06 +02:00
										 |  |  |         $key            = sprintf('import.routine.%s', $importProvider); | 
					
						
							|  |  |  |         $className      = config($key); | 
					
						
							|  |  |  |         if (null === $className || !class_exists($className)) { | 
					
						
							| 
									
										
										
										
											2018-05-04 20:21:27 +02:00
										 |  |  |             // @codeCoverageIgnoreStart
 | 
					
						
							| 
									
										
										
										
											2018-10-31 16:25:21 +01:00
										 |  |  |             $message = sprintf('Cannot find import routine class for job of type "%s".', $importProvider); | 
					
						
							|  |  |  |             Log::error($message); | 
					
						
							| 
									
										
										
										
											2019-02-13 17:38:41 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-05-04 20:21:27 +02:00
										 |  |  |             return response()->json( | 
					
						
							| 
									
										
										
										
											2018-10-31 16:25:21 +01:00
										 |  |  |                 ['status' => 'NOK', 'message' => $message] | 
					
						
							| 
									
										
										
										
											2018-05-04 20:21:27 +02:00
										 |  |  |             ); | 
					
						
							|  |  |  |             // @codeCoverageIgnoreEnd
 | 
					
						
							| 
									
										
										
										
											2018-05-03 17:23:16 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-29 21:20:06 +02:00
										 |  |  |         /** @var RoutineInterface $routine */ | 
					
						
							|  |  |  |         $routine = app($className); | 
					
						
							| 
									
										
										
										
											2018-05-12 15:50:01 +02:00
										 |  |  |         $routine->setImportJob($importJob); | 
					
						
							| 
									
										
										
										
											2018-07-29 21:02:03 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         Log::debug(sprintf('Created class of type %s', $className)); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-29 21:20:06 +02:00
										 |  |  |         try { | 
					
						
							| 
									
										
										
										
											2018-07-29 21:02:03 +02:00
										 |  |  |             Log::debug(sprintf('Try to call %s:run()', $className)); | 
					
						
							| 
									
										
										
										
											2018-04-29 21:20:06 +02:00
										 |  |  |             $routine->run(); | 
					
						
							| 
									
										
										
										
											2018-05-04 20:21:27 +02:00
										 |  |  |         } catch (FireflyException|Exception $e) { | 
					
						
							| 
									
										
										
										
											2018-04-29 21:20:06 +02:00
										 |  |  |             $message = 'The import routine crashed: ' . $e->getMessage(); | 
					
						
							|  |  |  |             Log::error($message); | 
					
						
							|  |  |  |             Log::error($e->getTraceAsString()); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-30 06:37:29 +02:00
										 |  |  |             // set job errored out:
 | 
					
						
							| 
									
										
										
										
											2018-05-01 20:47:38 +02:00
										 |  |  |             $this->repository->setStatus($importJob, 'error'); | 
					
						
							| 
									
										
										
										
											2018-04-30 06:37:29 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-29 21:20:06 +02:00
										 |  |  |             return response()->json(['status' => 'NOK', 'message' => $message]); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // expect nothing from routine, just return OK to user.
 | 
					
						
							| 
									
										
										
										
											2018-10-31 16:25:21 +01:00
										 |  |  |         Log::info('Now finished with JobStatusController::start'); | 
					
						
							| 
									
										
										
										
											2019-02-13 17:38:41 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-05-01 20:47:38 +02:00
										 |  |  |         return response()->json(['status' => 'OK', 'message' => 'stage_finished']); | 
					
						
							| 
									
										
										
										
											2018-05-03 17:23:16 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2018-05-04 20:21:27 +02:00
										 |  |  |      * Store does three things: | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * - Store the transactions. | 
					
						
							|  |  |  |      * - Add them to a tag. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param ImportJob $importJob | 
					
						
							| 
									
										
										
										
											2018-05-03 17:23:16 +02:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @return JsonResponse | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function store(ImportJob $importJob): JsonResponse | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2018-10-31 16:25:21 +01:00
										 |  |  |         Log::info('Now in JobStatusController::store'); | 
					
						
							| 
									
										
										
										
											2018-05-03 17:23:16 +02:00
										 |  |  |         // catch impossible status:
 | 
					
						
							| 
									
										
										
										
											2018-05-12 19:09:34 +02:00
										 |  |  |         $allowed = ['provider_finished', 'storing_data']; | 
					
						
							| 
									
										
										
										
											2019-06-21 19:10:02 +02:00
										 |  |  |         if (null !== $importJob && !in_array($importJob->status, $allowed, true)) { | 
					
						
							| 
									
										
										
										
											2018-07-29 21:02:03 +02:00
										 |  |  |             Log::error(sprintf('Job is not ready. Status should be in array, but is %s', $importJob->status), $allowed); | 
					
						
							| 
									
										
										
										
											2018-05-03 17:23:16 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-05-13 09:58:21 +02:00
										 |  |  |             return response()->json( | 
					
						
							|  |  |  |                 ['status' => 'NOK', 'message' => sprintf('JobStatusController::start expects status "provider_finished" instead of "%s".', $importJob->status)] | 
					
						
							|  |  |  |             ); | 
					
						
							| 
									
										
										
										
											2018-05-03 17:23:16 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // set job to be storing data:
 | 
					
						
							|  |  |  |         $this->repository->setStatus($importJob, 'storing_data'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         try { | 
					
						
							| 
									
										
										
										
											2018-05-04 20:21:27 +02:00
										 |  |  |             $this->storeTransactions($importJob); | 
					
						
							| 
									
										
										
										
											2018-05-03 17:23:16 +02:00
										 |  |  |         } catch (FireflyException $e) { | 
					
						
							|  |  |  |             $message = 'The import storage routine crashed: ' . $e->getMessage(); | 
					
						
							|  |  |  |             Log::error($message); | 
					
						
							|  |  |  |             Log::error($e->getTraceAsString()); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             // set job errored out:
 | 
					
						
							|  |  |  |             $this->repository->setStatus($importJob, 'error'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             return response()->json(['status' => 'NOK', 'message' => $message]); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2018-05-04 20:21:27 +02:00
										 |  |  |         // set storage to be finished:
 | 
					
						
							|  |  |  |         $this->repository->setStatus($importJob, 'storage_finished'); | 
					
						
							| 
									
										
										
										
											2018-05-03 17:23:16 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-31 16:25:21 +01:00
										 |  |  |         Log::info('Now finished with JobStatusController::start'); | 
					
						
							| 
									
										
										
										
											2019-02-13 17:38:41 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-05-03 17:23:16 +02:00
										 |  |  |         // expect nothing from routine, just return OK to user.
 | 
					
						
							|  |  |  |         return response()->json(['status' => 'OK', 'message' => 'storage_finished']); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2018-04-29 21:20:06 +02:00
										 |  |  | } |