firefly-iii/app/Services/Internal/Destroy/BudgetDestroyService.php

65 lines
1.9 KiB
PHP
Raw Normal View History

2019-01-11 09:57:40 -06:00
<?php
/**
* BudgetDestroyService.php
2020-02-16 06:56:35 -06:00
* Copyright (c) 2019 james@firefly-iii.org
2019-01-11 09:57:40 -06:00
*
* This file is part of Firefly III (https://github.com/firefly-iii).
2019-01-11 09:57:40 -06: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.
2019-01-11 09:57:40 -06:00
*
* This program is distributed in the hope that it will be useful,
2019-01-11 09:57:40 -06: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.
2019-01-11 09:57:40 -06: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/>.
2019-01-11 09:57:40 -06:00
*/
declare(strict_types=1);
namespace FireflyIII\Services\Internal\Destroy;
use DB;
use Exception;
use FireflyIII\Models\Budget;
use Log;
/**
* Class BudgetDestroyService
2021-03-15 04:31:11 -05:00
*
2019-07-31 09:53:09 -05:00
* @codeCoverageIgnore
2019-01-11 09:57:40 -06:00
*/
class BudgetDestroyService
{
/**
* @param Budget $budget
*/
public function destroy(Budget $budget): void
{
2019-01-11 09:57:40 -06:00
try {
$budget->delete();
} catch (Exception $e) { // @codeCoverageIgnore
Log::error(sprintf('Could not delete budget: %s', $e->getMessage())); // @codeCoverageIgnore
}
// also delete auto budget:
foreach ($budget->autoBudgets()->get() as $autoBudget) {
$autoBudget->delete();
}
2019-01-11 09:57:40 -06:00
// also delete all relations between categories and transaction journals:
DB::table('budget_transaction_journal')->where('budget_id', (int)$budget->id)->delete();
// also delete all relations between categories and transactions:
DB::table('budget_transaction')->where('budget_id', (int)$budget->id)->delete();
2020-02-10 22:34:36 -06:00
// also delete all budget limits
$budget->budgetlimits()->delete();
2019-01-11 09:57:40 -06:00
}
}