firefly-iii/app/Api/V1/Controllers/BudgetLimitController.php

259 lines
9.0 KiB
PHP
Raw Normal View History

2018-06-24 06:20:29 -05:00
<?php
/**
* BudgetLimitController.php
* Copyright (c) 2019 james@firefly-iii.org
2018-06-24 06:20:29 -05:00
*
* This file is part of Firefly III (https://github.com/firefly-iii).
2018-06-24 06:20:29 -05: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-06-24 06:20:29 -05:00
*
* This program is distributed in the hope that it will be useful,
2018-06-24 06:20:29 -05:00
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
2018-06-24 06:20:29 -05: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-06-24 06:20:29 -05:00
*/
declare(strict_types=1);
namespace FireflyIII\Api\V1\Controllers;
2018-07-25 23:10:17 -05:00
2020-11-08 06:31:54 -06:00
use FireflyIII\Api\V1\Requests\BudgetLimitStoreRequest;
use FireflyIII\Api\V1\Requests\BudgetLimitUpdateRequest;
2018-06-24 06:20:29 -05:00
use FireflyIII\Exceptions\FireflyException;
2019-03-25 09:14:09 -05:00
use FireflyIII\Helpers\Collector\GroupCollectorInterface;
2018-06-24 06:20:29 -05:00
use FireflyIII\Models\BudgetLimit;
2019-08-30 00:49:08 -05:00
use FireflyIII\Repositories\Budget\BudgetLimitRepositoryInterface;
2018-06-24 06:20:29 -05:00
use FireflyIII\Repositories\Budget\BudgetRepositoryInterface;
2018-12-09 01:45:53 -06:00
use FireflyIII\Support\Http\Api\TransactionFilter;
2018-06-24 06:20:29 -05:00
use FireflyIII\Transformers\BudgetLimitTransformer;
2019-03-25 09:14:09 -05:00
use FireflyIII\Transformers\TransactionGroupTransformer;
2018-06-24 06:20:29 -05:00
use FireflyIII\User;
use Illuminate\Http\JsonResponse;
use Illuminate\Http\Request;
use Illuminate\Pagination\LengthAwarePaginator;
use Illuminate\Support\Collection;
use League\Fractal\Pagination\IlluminatePaginatorAdapter;
use League\Fractal\Resource\Collection as FractalCollection;
use League\Fractal\Resource\Item;
2018-07-25 23:10:17 -05:00
2018-06-24 06:20:29 -05:00
/**
* Class BudgetLimitController.
2018-06-24 06:20:29 -05:00
*/
class BudgetLimitController extends Controller
{
2018-12-09 01:45:53 -06:00
use TransactionFilter;
2020-07-31 02:42:00 -05:00
2020-11-15 07:02:29 -06:00
private BudgetLimitRepositoryInterface $blRepository;
private BudgetRepositoryInterface $repository;
2019-08-30 00:49:08 -05:00
2020-07-31 02:24:08 -05:00
2018-06-24 06:20:29 -05:00
/**
* BudgetLimitController constructor.
*
* @codeCoverageIgnore
2018-06-24 06:20:29 -05:00
*/
public function __construct()
{
parent::__construct();
$this->middleware(
function ($request, $next) {
/** @var User $user */
2019-09-04 10:39:39 -05:00
$user = auth()->user();
$this->repository = app(BudgetRepositoryInterface::class);
2019-08-30 00:49:08 -05:00
$this->blRepository = app(BudgetLimitRepositoryInterface::class);
2018-06-24 06:20:29 -05:00
$this->repository->setUser($user);
2019-08-30 00:49:08 -05:00
$this->blRepository->setUser($user);
2018-06-24 06:20:29 -05:00
return $next($request);
}
);
}
/**
* Remove the specified resource from storage.
*
* @param BudgetLimit $budgetLimit
*
* @return JsonResponse
* @codeCoverageIgnore
2018-06-24 06:20:29 -05:00
*/
public function delete(BudgetLimit $budgetLimit): JsonResponse
{
2019-08-30 00:49:08 -05:00
$this->blRepository->destroyBudgetLimit($budgetLimit);
2018-06-24 06:20:29 -05:00
return response()->json([], 204);
}
/**
* Display a listing of the resource.
*
* @param Request $request
*
* @return JsonResponse
* @codeCoverageIgnore
2018-06-24 06:20:29 -05:00
*/
public function index(Request $request): JsonResponse
{
2019-09-04 10:39:39 -05:00
$manager = $this->getManager();
2020-11-15 07:02:29 -06:00
$budgetId = (int)($request->get('budget_id') ?? 0);
2018-07-05 11:02:02 -05:00
$budget = $this->repository->findNull($budgetId);
2020-11-15 07:02:29 -06:00
$pageSize = (int)app('preferences')->getForUser(auth()->user(), 'listPageSize', 50)->data;
2018-07-21 01:06:24 -05:00
$this->parameters->set('budget_id', $budgetId);
2018-06-24 06:20:29 -05:00
$collection = new Collection;
if (null === $budget) {
2019-08-30 00:54:09 -05:00
$collection = $this->blRepository->getAllBudgetLimits($this->parameters->get('start'), $this->parameters->get('end'));
2018-06-24 06:20:29 -05:00
}
if (null !== $budget) {
2019-08-30 01:09:13 -05:00
$collection = $this->blRepository->getBudgetLimits($budget, $this->parameters->get('start'), $this->parameters->get('end'));
2018-06-24 06:20:29 -05:00
}
$count = $collection->count();
$budgetLimits = $collection->slice(($this->parameters->get('page') - 1) * $pageSize, $pageSize);
2018-07-05 11:42:51 -05:00
$paginator = new LengthAwarePaginator($budgetLimits, $count, $pageSize, $this->parameters->get('page'));
2018-06-24 06:20:29 -05:00
$paginator->setPath(route('api.v1.budget_limits.index') . $this->buildParams());
2018-12-15 15:03:05 -06:00
/** @var BudgetLimitTransformer $transformer */
$transformer = app(BudgetLimitTransformer::class);
$transformer->setParameters($this->parameters);
$resource = new FractalCollection($budgetLimits, $transformer, 'budget_limits');
2018-06-24 06:20:29 -05:00
$resource->setPaginator(new IlluminatePaginatorAdapter($paginator));
2020-10-03 09:51:44 -05:00
return response()->json($manager->createData($resource)->toArray())->header('Content-Type', self::CONTENT_TYPE);
2018-06-24 06:20:29 -05:00
}
/**
* Display the specified resource.
*
* @param BudgetLimit $budgetLimit
*
* @return JsonResponse
* @codeCoverageIgnore
2018-06-24 06:20:29 -05:00
*/
2019-09-04 10:39:39 -05:00
public function show(BudgetLimit $budgetLimit): JsonResponse
2018-06-24 06:20:29 -05:00
{
2019-09-04 10:39:39 -05:00
$manager = $this->getManager();
2018-12-15 15:03:05 -06:00
/** @var BudgetLimitTransformer $transformer */
$transformer = app(BudgetLimitTransformer::class);
$transformer->setParameters($this->parameters);
$resource = new Item($budgetLimit, $transformer, 'budget_limits');
2018-06-24 06:20:29 -05:00
2020-10-03 09:51:44 -05:00
return response()->json($manager->createData($resource)->toArray())->header('Content-Type', self::CONTENT_TYPE);
2018-06-24 06:20:29 -05:00
}
/**
* Store a newly created resource in storage.
*
2020-11-08 06:31:54 -06:00
* @param BudgetLimitStoreRequest $request
2018-06-24 06:20:29 -05:00
*
2020-08-02 04:53:04 -05:00
* @return JsonResponse
2018-06-24 06:20:29 -05:00
* @throws FireflyException
*
2018-06-24 06:20:29 -05:00
*/
2020-11-08 06:31:54 -06:00
public function store(BudgetLimitStoreRequest $request): JsonResponse
2018-06-24 06:20:29 -05:00
{
2020-08-02 04:53:04 -05:00
$data = $request->getAll();
$data['start_date'] = $data['start'];
$data['end_date'] = $data['end'];
$budgetLimit = $this->blRepository->store($data);
$manager = $this->getManager();
2018-06-24 06:20:29 -05:00
2018-12-15 15:03:05 -06:00
/** @var BudgetLimitTransformer $transformer */
$transformer = app(BudgetLimitTransformer::class);
$transformer->setParameters($this->parameters);
$resource = new Item($budgetLimit, $transformer, 'budget_limits');
2018-06-24 06:20:29 -05:00
2020-10-03 09:51:44 -05:00
return response()->json($manager->createData($resource)->toArray())->header('Content-Type', self::CONTENT_TYPE);
2018-06-24 06:20:29 -05:00
}
2018-12-09 01:45:53 -06:00
/**
* Show all transactions.
*
2019-09-04 10:39:39 -05:00
* @param Request $request
2018-12-09 01:45:53 -06:00
* @param BudgetLimit $budgetLimit
*
* @return JsonResponse
* @codeCoverageIgnore
2018-12-09 01:45:53 -06:00
*/
public function transactions(Request $request, BudgetLimit $budgetLimit): JsonResponse
{
2020-11-15 07:02:29 -06:00
$pageSize = (int)app('preferences')->getForUser(auth()->user(), 'listPageSize', 50)->data;
2018-12-09 01:45:53 -06:00
$type = $request->get('type') ?? 'default';
$this->parameters->set('type', $type);
$types = $this->mapTransactionTypes($this->parameters->get('type'));
2019-09-04 10:39:39 -05:00
$manager = $this->getManager();
2018-12-09 01:45:53 -06:00
/** @var User $admin */
$admin = auth()->user();
2019-03-25 09:14:09 -05:00
// use new group collector:
/** @var GroupCollectorInterface $collector */
$collector = app(GroupCollectorInterface::class);
$collector
->setUser($admin)
// filter on budget.
->setBudget($budgetLimit->budget)
// 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-09 01:45:53 -06:00
$collector->setRange($budgetLimit->start_date, $budgetLimit->end_date);
$collector->setTypes($types);
2019-03-25 09:14:09 -05:00
$paginator = $collector->getPaginatedGroups();
2018-12-09 01:45:53 -06:00
$paginator->setPath(route('api.v1.budget_limits.transactions', [$budgetLimit->id]) . $this->buildParams());
$transactions = $paginator->getCollection();
2018-12-15 15:03:05 -06:00
2019-03-25 09:14:09 -05:00
/** @var TransactionGroupTransformer $transformer */
$transformer = app(TransactionGroupTransformer::class);
2018-12-15 15:03:05 -06:00
$transformer->setParameters($this->parameters);
2018-12-21 09:38:10 -06:00
$resource = new FractalCollection($transactions, $transformer, 'transactions');
2018-12-09 01:45:53 -06:00
$resource->setPaginator(new IlluminatePaginatorAdapter($paginator));
2020-10-03 09:51:44 -05:00
return response()->json($manager->createData($resource)->toArray())->header('Content-Type', self::CONTENT_TYPE);
2018-12-09 01:45:53 -06:00
}
2018-06-24 06:20:29 -05:00
/**
* Update the specified resource in storage.
*
2020-11-08 06:31:54 -06:00
* @param BudgetLimitUpdateRequest $request
2020-11-15 07:02:29 -06:00
* @param BudgetLimit $budgetLimit
2018-06-24 06:20:29 -05:00
*
* @return JsonResponse
*/
2020-11-08 06:31:54 -06:00
public function update(BudgetLimitUpdateRequest $request, BudgetLimit $budgetLimit): JsonResponse
2018-06-24 06:20:29 -05:00
{
2020-10-18 01:01:10 -05:00
$data = $request->getAll();
$budgetLimit = $this->blRepository->update($budgetLimit, $data);
$manager = $this->getManager();
2018-06-24 06:20:29 -05:00
2018-12-15 15:03:05 -06:00
/** @var BudgetLimitTransformer $transformer */
$transformer = app(BudgetLimitTransformer::class);
$transformer->setParameters($this->parameters);
$resource = new Item($budgetLimit, $transformer, 'budget_limits');
2018-06-24 06:20:29 -05:00
2020-10-03 09:51:44 -05:00
return response()->json($manager->createData($resource)->toArray())->header('Content-Type', self::CONTENT_TYPE);
2018-06-24 06:20:29 -05:00
}
}