. */ declare(strict_types=1); namespace FireflyIII\Api\V1\Controllers\Models\Transaction; use FireflyIII\Api\V1\Controllers\Controller; use FireflyIII\Events\DestroyedTransactionGroup; use FireflyIII\Models\TransactionGroup; use FireflyIII\Models\TransactionJournal; use FireflyIII\Repositories\Journal\JournalRepositoryInterface; use FireflyIII\User; use Illuminate\Http\JsonResponse; /** * Class DestroyController */ class DestroyController extends Controller { private JournalRepositoryInterface $repository; /** * TransactionController constructor. * * @codeCoverageIgnore */ public function __construct() { parent::__construct(); $this->middleware( function ($request, $next) { /** @var User $admin */ $admin = auth()->user(); $this->repository = app(JournalRepositoryInterface::class); $this->repository->setUser($admin); return $next($request); } ); } /** * This endpoint is documented at: * https://api-docs.firefly-iii.org/#/transactions/deleteTransaction * * Remove the specified resource from storage. * * @param TransactionGroup $transactionGroup * * @return JsonResponse * @codeCoverageIgnore */ public function destroy(TransactionGroup $transactionGroup): JsonResponse { $this->repository->destroyGroup($transactionGroup); // trigger just after destruction event(new DestroyedTransactionGroup($transactionGroup)); app('preferences')->mark(); return response()->json([], 204); } /** * This endpoint is documented at: * https://api-docs.firefly-iii.org/#/transactions/deleteTransactionJournal * * Remove the specified resource from storage. * * @param TransactionJournal $transactionJournal * * @codeCoverageIgnore * @return JsonResponse */ public function destroyJournal(TransactionJournal $transactionJournal): JsonResponse { $this->repository->destroyJournal($transactionJournal); return response()->json([], 204); } }