firefly-iii/app/Api/V1/Controllers/Models/Transaction/StoreController.php

139 lines
5.1 KiB
PHP
Raw Normal View History

2021-02-16 02:52:39 -06:00
<?php
/*
* StoreController.php
* Copyright (c) 2021 james@firefly-iii.org
*
* This file is part of Firefly III (https://github.com/firefly-iii).
*
* 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.
*
* This program 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 Affero General Public License for more details.
*
* 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/>.
*/
2021-03-28 04:39:26 -05:00
declare(strict_types=1);
2021-02-16 02:52:39 -06:00
2021-03-28 04:39:26 -05:00
namespace FireflyIII\Api\V1\Controllers\Models\Transaction;
2021-02-16 02:52:39 -06:00
use FireflyIII\Api\V1\Controllers\Controller;
2021-03-06 13:52:42 -06:00
use FireflyIII\Api\V1\Requests\Models\Transaction\StoreRequest;
2021-02-16 02:52:39 -06:00
use FireflyIII\Events\StoredTransactionGroup;
use FireflyIII\Exceptions\DuplicateTransactionException;
use FireflyIII\Exceptions\FireflyException;
use FireflyIII\Helpers\Collector\GroupCollectorInterface;
use FireflyIII\Repositories\TransactionGroup\TransactionGroupRepositoryInterface;
use FireflyIII\Rules\IsDuplicateTransaction;
use FireflyIII\Support\Http\Api\TransactionFilter;
use FireflyIII\Transformers\TransactionGroupTransformer;
use FireflyIII\User;
use Illuminate\Http\JsonResponse;
use Illuminate\Validation\ValidationException;
use League\Fractal\Resource\Item;
2021-02-16 23:54:00 -06:00
use Log;
2021-03-01 08:27:27 -06:00
use Validator;
2021-02-16 02:52:39 -06:00
/**
* Class StoreController
*/
class StoreController extends Controller
{
use TransactionFilter;
private TransactionGroupRepositoryInterface $groupRepository;
/**
* TransactionController constructor.
*
* @codeCoverageIgnore
*/
public function __construct()
{
parent::__construct();
$this->middleware(
function ($request, $next) {
/** @var User $admin */
$admin = auth()->user();
$this->groupRepository = app(TransactionGroupRepositoryInterface::class);
$this->groupRepository->setUser($admin);
return $next($request);
}
);
}
/**
2021-09-19 03:20:28 -05:00
* This endpoint is documented at:
* https://api-docs.firefly-iii.org/#/transactions/storeTransaction
*
2021-02-16 02:52:39 -06:00
* Store a new transaction.
*
2021-03-06 13:52:42 -06:00
* @param StoreRequest $request
2021-02-16 02:52:39 -06:00
*
* @return JsonResponse
* @throws FireflyException|ValidationException
*/
2021-03-06 13:52:42 -06:00
public function store(StoreRequest $request): JsonResponse
2021-02-16 02:52:39 -06:00
{
2021-02-16 23:54:00 -06:00
Log::debug('Now in API StoreController::store()');
2021-02-16 02:52:39 -06:00
$data = $request->getAll();
$data['user'] = auth()->user()->id;
Log::channel('audit')
->info('Store new transaction over API.', $data);
try {
$transactionGroup = $this->groupRepository->store($data);
} catch (DuplicateTransactionException $e) {
2022-10-30 08:44:49 -05:00
app('log')->warning('Caught a duplicate transaction. Return error message.');
2021-02-16 02:52:39 -06:00
$validator = Validator::make(
2022-10-30 08:23:00 -05:00
['transactions' => [['description' => $e->getMessage()]]],
['transactions.0.description' => new IsDuplicateTransaction()]
2021-02-16 02:52:39 -06:00
);
throw new ValidationException($validator, 0, $e);
2021-02-16 02:52:39 -06:00
} catch (FireflyException $e) {
2022-10-30 08:44:49 -05:00
app('log')->warning('Caught an exception. Return error message.');
2021-02-16 02:52:39 -06:00
Log::error($e->getMessage());
$message = sprintf('Internal exception: %s', $e->getMessage());
2022-10-30 08:23:00 -05:00
$validator = Validator::make(['transactions' => [['description' => $message]]], ['transactions.0.description' => new IsDuplicateTransaction()]);
throw new ValidationException($validator, 0, $e);
2021-02-16 02:52:39 -06:00
}
app('preferences')->mark();
$applyRules = $data['apply_rules'] ?? true;
2021-05-02 07:52:11 -05:00
$fireWebhooks = $data['fire_webhooks'] ?? true;
event(new StoredTransactionGroup($transactionGroup, $applyRules, $fireWebhooks));
2021-02-16 02:52:39 -06:00
$manager = $this->getManager();
/** @var User $admin */
$admin = auth()->user();
// use new group collector:
/** @var GroupCollectorInterface $collector */
$collector = app(GroupCollectorInterface::class);
$collector
->setUser($admin)
// filter on transaction group.
->setTransactionGroup($transactionGroup)
// all info needed for the API:
->withAPIInformation();
$selectedGroup = $collector->getGroups()->first();
if (null === $selectedGroup) {
2022-05-02 11:55:09 -05:00
throw new FireflyException('200032: Cannot find transaction. Possibly, a rule deleted this transaction after its creation.');
2021-02-16 02:52:39 -06:00
}
/** @var TransactionGroupTransformer $transformer */
$transformer = app(TransactionGroupTransformer::class);
$transformer->setParameters($this->parameters);
$resource = new Item($selectedGroup, $transformer, 'transactions');
return response()->json($manager->createData($resource)->toArray())->header('Content-Type', self::CONTENT_TYPE);
}
2021-03-28 04:39:26 -05:00
}