| 
									
										
										
										
											2018-12-08 08:22:53 +01:00
										 |  |  | <?php | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * ImportController.php | 
					
						
							|  |  |  |  * Copyright (c) 2018 thegrumpydictator@gmail.com | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This file is part of Firefly III. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Firefly III is free software: you can redistribute it and/or modify | 
					
						
							|  |  |  |  * it under the terms of the GNU General Public License as published by | 
					
						
							|  |  |  |  * the Free Software Foundation, either version 3 of the License, or | 
					
						
							|  |  |  |  * (at your option) any later version. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Firefly III is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  |  * GNU General Public License for more details. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * You should have received a copy of the GNU General Public License | 
					
						
							|  |  |  |  * along with Firefly III. If not, see <http://www.gnu.org/licenses/>. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | declare(strict_types=1); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace FireflyIII\Api\V1\Controllers; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-25 15:14:09 +01:00
										 |  |  | use FireflyIII\Helpers\Collector\GroupCollectorInterface; | 
					
						
							| 
									
										
										
										
											2018-12-08 08:22:53 +01:00
										 |  |  | use FireflyIII\Models\ImportJob; | 
					
						
							|  |  |  | use FireflyIII\Repositories\ImportJob\ImportJobRepositoryInterface; | 
					
						
							| 
									
										
										
										
											2018-12-08 21:26:20 +01:00
										 |  |  | use FireflyIII\Support\Http\Api\TransactionFilter; | 
					
						
							| 
									
										
										
										
											2018-12-08 08:22:53 +01:00
										 |  |  | use FireflyIII\Transformers\ImportJobTransformer; | 
					
						
							| 
									
										
										
										
											2019-03-25 15:14:09 +01:00
										 |  |  | use FireflyIII\Transformers\TransactionGroupTransformer; | 
					
						
							| 
									
										
										
										
											2018-12-08 08:22:53 +01:00
										 |  |  | use FireflyIII\User; | 
					
						
							|  |  |  | use Illuminate\Http\JsonResponse; | 
					
						
							|  |  |  | use Illuminate\Http\Request; | 
					
						
							|  |  |  | use Illuminate\Pagination\LengthAwarePaginator; | 
					
						
							|  |  |  | use Illuminate\Support\Collection; | 
					
						
							|  |  |  | use League\Fractal\Manager; | 
					
						
							|  |  |  | use League\Fractal\Pagination\IlluminatePaginatorAdapter; | 
					
						
							|  |  |  | use League\Fractal\Resource\Collection as FractalCollection; | 
					
						
							|  |  |  | use League\Fractal\Resource\Item; | 
					
						
							|  |  |  | use League\Fractal\Serializer\JsonApiSerializer; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * Class ImportController | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | class ImportController extends Controller | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2018-12-08 21:26:20 +01:00
										 |  |  |     use TransactionFilter; | 
					
						
							| 
									
										
										
										
											2018-12-08 08:22:53 +01:00
										 |  |  |     /** @var ImportJobRepositoryInterface Import job repository. */ | 
					
						
							|  |  |  |     private $repository; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2019-04-12 04:53:18 +02:00
										 |  |  |      * ImportController constructor. | 
					
						
							|  |  |  |      * @codeCoverageIgnore | 
					
						
							| 
									
										
										
										
											2018-12-08 08:22:53 +01:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function __construct() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         parent::__construct(); | 
					
						
							|  |  |  |         $this->middleware( | 
					
						
							|  |  |  |             function ($request, $next) { | 
					
						
							|  |  |  |                 /** @var User $user */ | 
					
						
							|  |  |  |                 $user             = auth()->user(); | 
					
						
							|  |  |  |                 $this->repository = app(ImportJobRepositoryInterface::class); | 
					
						
							|  |  |  |                 $this->repository->setUser($user); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 return $next($request); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @param Request $request | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return JsonResponse | 
					
						
							| 
									
										
										
										
											2019-05-30 12:39:06 +02:00
										 |  |  |      * @codeCoverageIgnore | 
					
						
							| 
									
										
										
										
											2018-12-08 08:22:53 +01:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function listAll(Request $request): JsonResponse | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         // create some objects:
 | 
					
						
							|  |  |  |         $manager  = new Manager; | 
					
						
							|  |  |  |         $baseUrl  = $request->getSchemeAndHttpHost() . '/api/v1'; | 
					
						
							|  |  |  |         $pageSize = (int)app('preferences')->getForUser(auth()->user(), 'listPageSize', 50)->data; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // get list of accounts. Count it and split it.
 | 
					
						
							|  |  |  |         $collection = $this->repository->get(); | 
					
						
							|  |  |  |         $count      = $collection->count(); | 
					
						
							|  |  |  |         $importJobs = $collection->slice(($this->parameters->get('page') - 1) * $pageSize, $pageSize); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // make paginator:
 | 
					
						
							|  |  |  |         $paginator = new LengthAwarePaginator($importJobs, $count, $pageSize, $this->parameters->get('page')); | 
					
						
							|  |  |  |         $paginator->setPath(route('api.v1.import.list') . $this->buildParams()); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // present to user.
 | 
					
						
							|  |  |  |         $manager->setSerializer(new JsonApiSerializer($baseUrl)); | 
					
						
							| 
									
										
										
										
											2018-12-15 22:03:05 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         /** @var ImportJobTransformer $transformer */ | 
					
						
							|  |  |  |         $transformer = app(ImportJobTransformer::class); | 
					
						
							|  |  |  |         $transformer->setParameters($this->parameters); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $resource = new FractalCollection($importJobs, $transformer, 'import_jobs'); | 
					
						
							| 
									
										
										
										
											2018-12-08 08:22:53 +01:00
										 |  |  |         $resource->setPaginator(new IlluminatePaginatorAdapter($paginator)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return response()->json($manager->createData($resource)->toArray())->header('Content-Type', 'application/vnd.api+json'); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2019-05-30 12:39:06 +02:00
										 |  |  |      * @param Request $request | 
					
						
							| 
									
										
										
										
											2018-12-08 08:22:53 +01:00
										 |  |  |      * @param ImportJob $importJob | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return JsonResponse | 
					
						
							| 
									
										
										
										
											2019-05-30 12:39:06 +02:00
										 |  |  |      * @codeCoverageIgnore | 
					
						
							| 
									
										
										
										
											2018-12-08 08:22:53 +01:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function show(Request $request, ImportJob $importJob): JsonResponse | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $manager = new Manager; | 
					
						
							|  |  |  |         $baseUrl = $request->getSchemeAndHttpHost() . '/api/v1'; | 
					
						
							|  |  |  |         $manager->setSerializer(new JsonApiSerializer($baseUrl)); | 
					
						
							| 
									
										
										
										
											2018-12-15 22:03:05 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         /** @var ImportJobTransformer $transformer */ | 
					
						
							|  |  |  |         $transformer = app(ImportJobTransformer::class); | 
					
						
							|  |  |  |         $transformer->setParameters($this->parameters); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $resource = new Item($importJob, $transformer, 'import_jobs'); | 
					
						
							| 
									
										
										
										
											2018-12-08 08:22:53 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         return response()->json($manager->createData($resource)->toArray())->header('Content-Type', 'application/vnd.api+json'); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * Show all transactions | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2019-05-30 12:39:06 +02:00
										 |  |  |      * @param Request $request | 
					
						
							| 
									
										
										
										
											2018-12-08 08:22:53 +01:00
										 |  |  |      * @param ImportJob $importJob | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return JsonResponse | 
					
						
							| 
									
										
										
										
											2019-05-30 12:39:06 +02:00
										 |  |  |      * @codeCoverageIgnore | 
					
						
							| 
									
										
										
										
											2018-12-08 08:22:53 +01:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function transactions(Request $request, ImportJob $importJob): JsonResponse | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $pageSize = (int)app('preferences')->getForUser(auth()->user(), 'listPageSize', 50)->data; | 
					
						
							|  |  |  |         $type     = $request->get('type') ?? 'default'; | 
					
						
							|  |  |  |         $this->parameters->set('type', $type); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-12-08 21:26:20 +01:00
										 |  |  |         $types   = $this->mapTransactionTypes($this->parameters->get('type')); | 
					
						
							| 
									
										
										
										
											2018-12-08 08:22:53 +01:00
										 |  |  |         $manager = new Manager(); | 
					
						
							|  |  |  |         $baseUrl = $request->getSchemeAndHttpHost() . '/api/v1'; | 
					
						
							|  |  |  |         $manager->setSerializer(new JsonApiSerializer($baseUrl)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $tag          = $importJob->tag; | 
					
						
							|  |  |  |         $transactions = new Collection(); | 
					
						
							|  |  |  |         $paginator    = new LengthAwarePaginator($transactions, 0, $pageSize); | 
					
						
							|  |  |  |         $paginator->setPath(route('api.v1.import.transactions', [$importJob->key]) . $this->buildParams()); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (null !== $tag) { | 
					
						
							|  |  |  |             /** @var User $admin */ | 
					
						
							|  |  |  |             $admin = auth()->user(); | 
					
						
							| 
									
										
										
										
											2019-03-25 15:14:09 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |             // use new group collector:
 | 
					
						
							|  |  |  |             /** @var GroupCollectorInterface $collector */ | 
					
						
							|  |  |  |             $collector = app(GroupCollectorInterface::class); | 
					
						
							|  |  |  |             $collector | 
					
						
							|  |  |  |                 ->setUser($admin) | 
					
						
							|  |  |  |                 // filter on tag.
 | 
					
						
							|  |  |  |                 ->setTag($tag) | 
					
						
							|  |  |  |                 // all info needed for the API:
 | 
					
						
							|  |  |  |                 ->withAPIInformation() | 
					
						
							|  |  |  |                 // set page size:
 | 
					
						
							|  |  |  |                 ->setLimit($pageSize) | 
					
						
							|  |  |  |                 // set page to retrieve
 | 
					
						
							|  |  |  |                 ->setPage($this->parameters->get('page')) | 
					
						
							|  |  |  |                 // set types of transactions to return.
 | 
					
						
							|  |  |  |                 ->setTypes($types); | 
					
						
							| 
									
										
										
										
											2018-12-08 08:22:53 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |             if (null !== $this->parameters->get('start') && null !== $this->parameters->get('end')) { | 
					
						
							|  |  |  |                 $collector->setRange($this->parameters->get('start'), $this->parameters->get('end')); | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2019-03-25 15:14:09 +01:00
										 |  |  |             $paginator = $collector->getPaginatedGroups(); | 
					
						
							| 
									
										
										
										
											2018-12-08 08:22:53 +01:00
										 |  |  |             $paginator->setPath(route('api.v1.transactions.index') . $this->buildParams()); | 
					
						
							|  |  |  |             $transactions = $paginator->getCollection(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-03-25 15:14:09 +01:00
										 |  |  |         /** @var TransactionGroupTransformer $transformer */ | 
					
						
							|  |  |  |         $transformer = app(TransactionGroupTransformer::class); | 
					
						
							| 
									
										
										
										
											2018-12-15 22:03:05 +01:00
										 |  |  |         $transformer->setParameters($this->parameters); | 
					
						
							| 
									
										
										
										
											2018-12-08 08:22:53 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-12-21 16:38:10 +01:00
										 |  |  |         $resource = new FractalCollection($transactions, $transformer, 'transactions'); | 
					
						
							| 
									
										
										
										
											2018-12-08 08:22:53 +01:00
										 |  |  |         $resource->setPaginator(new IlluminatePaginatorAdapter($paginator)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return response()->json($manager->createData($resource)->toArray())->header('Content-Type', 'application/vnd.api+json'); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-12-31 07:48:23 +01:00
										 |  |  | } |