mirror of
				https://github.com/firefly-iii/firefly-iii.git
				synced 2025-10-25 13:10:35 +00:00 
			
		
		
		
	Compare commits
	
		
			24 Commits
		
	
	
		
			develop-20
			...
			develop-20
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 86a51b5caa | ||
|  | c3e039a757 | ||
|  | 7762f555c5 | ||
|  | e412e23c87 | ||
|  | 2cb14f6b72 | ||
|  | d8f512ca3a | ||
|  | c074fec0a7 | ||
|  | 7c04c4c2bc | ||
|  | df82252c95 | ||
|  | c747f4afd8 | ||
|  | bcd7db0256 | ||
|  | 469acce76d | ||
|  | 568f71ce63 | ||
|  | f6fbcf54aa | ||
|  | c194a1ae20 | ||
|  | 7df3728394 | ||
|  | acad0b5b55 | ||
|  | 605ab38660 | ||
|  | 75b21b20d8 | ||
|  | e82459cd29 | ||
|  | 6dcf80967e | ||
|  | 3d9edaeaac | ||
|  | 4a5a31bf69 | ||
|  | 5f73e37657 | 
| @@ -53,6 +53,9 @@ return $config->setRules( | ||||
|         'statement_indentation'         => true, | ||||
|         'void_return'                   => true, | ||||
| 
 | ||||
|         // about importing statements
 | ||||
|         'global_namespace_import' => ['import_classes' => true, 'import_constants' => true, 'import_functions' => true], | ||||
| 
 | ||||
|         // disabled rules
 | ||||
|         'native_function_invocation'    => false, // annoying
 | ||||
|         'php_unit_data_provider_name'   => false, // bloody annoying long test names
 | ||||
|   | ||||
							
								
								
									
										42
									
								
								.ci/php-cs-fixer/composer.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										42
									
								
								.ci/php-cs-fixer/composer.lock
									
									
									
										generated
									
									
									
								
							| @@ -1349,16 +1349,16 @@ | ||||
|         }, | ||||
|         { | ||||
|             "name": "symfony/deprecation-contracts", | ||||
|             "version": "v3.5.1", | ||||
|             "version": "v3.6.0", | ||||
|             "source": { | ||||
|                 "type": "git", | ||||
|                 "url": "https://github.com/symfony/deprecation-contracts.git", | ||||
|                 "reference": "74c71c939a79f7d5bf3c1ce9f5ea37ba0114c6f6" | ||||
|                 "reference": "63afe740e99a13ba87ec199bb07bbdee937a5b62" | ||||
|             }, | ||||
|             "dist": { | ||||
|                 "type": "zip", | ||||
|                 "url": "https://api.github.com/repos/symfony/deprecation-contracts/zipball/74c71c939a79f7d5bf3c1ce9f5ea37ba0114c6f6", | ||||
|                 "reference": "74c71c939a79f7d5bf3c1ce9f5ea37ba0114c6f6", | ||||
|                 "url": "https://api.github.com/repos/symfony/deprecation-contracts/zipball/63afe740e99a13ba87ec199bb07bbdee937a5b62", | ||||
|                 "reference": "63afe740e99a13ba87ec199bb07bbdee937a5b62", | ||||
|                 "shasum": "" | ||||
|             }, | ||||
|             "require": { | ||||
| @@ -1371,7 +1371,7 @@ | ||||
|                     "name": "symfony/contracts" | ||||
|                 }, | ||||
|                 "branch-alias": { | ||||
|                     "dev-main": "3.5-dev" | ||||
|                     "dev-main": "3.6-dev" | ||||
|                 } | ||||
|             }, | ||||
|             "autoload": { | ||||
| @@ -1396,7 +1396,7 @@ | ||||
|             "description": "A generic function and convention to trigger deprecation notices", | ||||
|             "homepage": "https://symfony.com", | ||||
|             "support": { | ||||
|                 "source": "https://github.com/symfony/deprecation-contracts/tree/v3.5.1" | ||||
|                 "source": "https://github.com/symfony/deprecation-contracts/tree/v3.6.0" | ||||
|             }, | ||||
|             "funding": [ | ||||
|                 { | ||||
| @@ -1412,7 +1412,7 @@ | ||||
|                     "type": "tidelift" | ||||
|                 } | ||||
|             ], | ||||
|             "time": "2024-09-25T14:20:29+00:00" | ||||
|             "time": "2024-09-25T14:21:43+00:00" | ||||
|         }, | ||||
|         { | ||||
|             "name": "symfony/event-dispatcher", | ||||
| @@ -1496,16 +1496,16 @@ | ||||
|         }, | ||||
|         { | ||||
|             "name": "symfony/event-dispatcher-contracts", | ||||
|             "version": "v3.5.1", | ||||
|             "version": "v3.6.0", | ||||
|             "source": { | ||||
|                 "type": "git", | ||||
|                 "url": "https://github.com/symfony/event-dispatcher-contracts.git", | ||||
|                 "reference": "7642f5e970b672283b7823222ae8ef8bbc160b9f" | ||||
|                 "reference": "59eb412e93815df44f05f342958efa9f46b1e586" | ||||
|             }, | ||||
|             "dist": { | ||||
|                 "type": "zip", | ||||
|                 "url": "https://api.github.com/repos/symfony/event-dispatcher-contracts/zipball/7642f5e970b672283b7823222ae8ef8bbc160b9f", | ||||
|                 "reference": "7642f5e970b672283b7823222ae8ef8bbc160b9f", | ||||
|                 "url": "https://api.github.com/repos/symfony/event-dispatcher-contracts/zipball/59eb412e93815df44f05f342958efa9f46b1e586", | ||||
|                 "reference": "59eb412e93815df44f05f342958efa9f46b1e586", | ||||
|                 "shasum": "" | ||||
|             }, | ||||
|             "require": { | ||||
| @@ -1519,7 +1519,7 @@ | ||||
|                     "name": "symfony/contracts" | ||||
|                 }, | ||||
|                 "branch-alias": { | ||||
|                     "dev-main": "3.5-dev" | ||||
|                     "dev-main": "3.6-dev" | ||||
|                 } | ||||
|             }, | ||||
|             "autoload": { | ||||
| @@ -1552,7 +1552,7 @@ | ||||
|                 "standards" | ||||
|             ], | ||||
|             "support": { | ||||
|                 "source": "https://github.com/symfony/event-dispatcher-contracts/tree/v3.5.1" | ||||
|                 "source": "https://github.com/symfony/event-dispatcher-contracts/tree/v3.6.0" | ||||
|             }, | ||||
|             "funding": [ | ||||
|                 { | ||||
| @@ -1568,7 +1568,7 @@ | ||||
|                     "type": "tidelift" | ||||
|                 } | ||||
|             ], | ||||
|             "time": "2024-09-25T14:20:29+00:00" | ||||
|             "time": "2024-09-25T14:21:43+00:00" | ||||
|         }, | ||||
|         { | ||||
|             "name": "symfony/filesystem", | ||||
| @@ -2305,16 +2305,16 @@ | ||||
|         }, | ||||
|         { | ||||
|             "name": "symfony/service-contracts", | ||||
|             "version": "v3.5.1", | ||||
|             "version": "v3.6.0", | ||||
|             "source": { | ||||
|                 "type": "git", | ||||
|                 "url": "https://github.com/symfony/service-contracts.git", | ||||
|                 "reference": "e53260aabf78fb3d63f8d79d69ece59f80d5eda0" | ||||
|                 "reference": "f021b05a130d35510bd6b25fe9053c2a8a15d5d4" | ||||
|             }, | ||||
|             "dist": { | ||||
|                 "type": "zip", | ||||
|                 "url": "https://api.github.com/repos/symfony/service-contracts/zipball/e53260aabf78fb3d63f8d79d69ece59f80d5eda0", | ||||
|                 "reference": "e53260aabf78fb3d63f8d79d69ece59f80d5eda0", | ||||
|                 "url": "https://api.github.com/repos/symfony/service-contracts/zipball/f021b05a130d35510bd6b25fe9053c2a8a15d5d4", | ||||
|                 "reference": "f021b05a130d35510bd6b25fe9053c2a8a15d5d4", | ||||
|                 "shasum": "" | ||||
|             }, | ||||
|             "require": { | ||||
| @@ -2332,7 +2332,7 @@ | ||||
|                     "name": "symfony/contracts" | ||||
|                 }, | ||||
|                 "branch-alias": { | ||||
|                     "dev-main": "3.5-dev" | ||||
|                     "dev-main": "3.6-dev" | ||||
|                 } | ||||
|             }, | ||||
|             "autoload": { | ||||
| @@ -2368,7 +2368,7 @@ | ||||
|                 "standards" | ||||
|             ], | ||||
|             "support": { | ||||
|                 "source": "https://github.com/symfony/service-contracts/tree/v3.5.1" | ||||
|                 "source": "https://github.com/symfony/service-contracts/tree/v3.6.0" | ||||
|             }, | ||||
|             "funding": [ | ||||
|                 { | ||||
| @@ -2384,7 +2384,7 @@ | ||||
|                     "type": "tidelift" | ||||
|                 } | ||||
|             ], | ||||
|             "time": "2024-09-25T14:20:29+00:00" | ||||
|             "time": "2025-04-25T09:37:31+00:00" | ||||
|         }, | ||||
|         { | ||||
|             "name": "symfony/stopwatch", | ||||
|   | ||||
| @@ -28,43 +28,40 @@ use Rector\EarlyReturn\Rector\If_\ChangeOrIfContinueToMultiContinueRector; | ||||
| 
 | ||||
| return RectorConfig::configure() | ||||
|     ->withSkip([ | ||||
|                    ChangeOrIfContinueToMultiContinueRector::class, | ||||
|                ]) | ||||
|                    ->withPaths([ | ||||
| //                                   __DIR__ . '/../app',
 | ||||
| __DIR__ . '/../app/Api', | ||||
| __DIR__ . '/../app/Http', | ||||
| //                                   __DIR__ . '/../bootstrap',
 | ||||
| //                                   __DIR__ . '/../config',
 | ||||
| //                                   __DIR__ . '/../public',
 | ||||
| //                                   __DIR__ . '/../resources',
 | ||||
| //                                   __DIR__ . '/../routes',
 | ||||
| // __DIR__ . '/../tests',
 | ||||
|                                ]) | ||||
|                                                    // uncomment to reach your current PHP version
 | ||||
|                    ->withPhpSets() | ||||
|                    ->withPreparedSets( | ||||
|                        codingStyle        : false, // leave false
 | ||||
|                        privatization: false, // leave false.
 | ||||
|                        naming             : false, // leave false
 | ||||
|                        instanceOf         : true, | ||||
|                        earlyReturn        : true, | ||||
|                        strictBooleans     : true, | ||||
|                        carbon             : true, | ||||
|                        rectorPreset       : true, | ||||
|                        phpunitCodeQuality : true, | ||||
|                        doctrineCodeQuality: true, | ||||
|                        symfonyCodeQuality : true, | ||||
|                        symfonyConfigs     : true | ||||
|         ChangeOrIfContinueToMultiContinueRector::class, | ||||
|     ]) | ||||
|     ->withPaths([ | ||||
|         __DIR__ . '/../app', | ||||
|         __DIR__ . '/../bootstrap', | ||||
|         __DIR__ . '/../config', | ||||
|         __DIR__ . '/../public', | ||||
|         __DIR__ . '/../resources/lang/en_US', | ||||
|         __DIR__ . '/../routes', | ||||
|         __DIR__ . '/../tests', | ||||
|     ]) | ||||
|     // uncomment to reach your current PHP version
 | ||||
|     ->withPhpSets() | ||||
|     ->withPreparedSets( | ||||
|         codingStyle: false, // leave false
 | ||||
|         privatization: false, // leave false.
 | ||||
|         naming: false, // leave false
 | ||||
|         instanceOf: true, | ||||
|         earlyReturn: true, | ||||
|         strictBooleans: true, | ||||
|         carbon: true, | ||||
|         rectorPreset: true, | ||||
|         phpunitCodeQuality: true, | ||||
|         doctrineCodeQuality: true, | ||||
|         symfonyCodeQuality: true, | ||||
|         symfonyConfigs: true | ||||
| 
 | ||||
|                    ) | ||||
|                    ->withComposerBased( | ||||
|                        twig: true, | ||||
|                        doctrine: true, | ||||
|                        phpunit: true, | ||||
|                        symfony: true) | ||||
|                    ->withTypeCoverageLevel(0) | ||||
|                    ->withDeadCodeLevel(0) | ||||
|                    ->withCodeQualityLevel(0) | ||||
| 
 | ||||
|                    ->withImportNames(removeUnusedImports: true);// import statements instead of full classes.
 | ||||
|     ) | ||||
|     ->withComposerBased( | ||||
|         twig: true, | ||||
|         doctrine: true, | ||||
|         phpunit: true, | ||||
|         symfony: true) | ||||
|     ->withTypeCoverageLevel(0) | ||||
|     ->withDeadCodeLevel(0) | ||||
|     ->withCodeQualityLevel(0) | ||||
|     ->withImportNames(removeUnusedImports: true);// import statements instead of full classes.
 | ||||
|   | ||||
							
								
								
									
										1
									
								
								.github/workflows/sonarcloud.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.github/workflows/sonarcloud.yml
									
									
									
									
										vendored
									
									
								
							| @@ -5,7 +5,6 @@ on: | ||||
|   push: | ||||
|     branches: | ||||
|       - main | ||||
|       - develop | ||||
| env: | ||||
|   DB_CONNECTION: sqlite | ||||
|   APP_KEY: TestTestTestTestTestTestTestTest | ||||
|   | ||||
| @@ -24,6 +24,7 @@ declare(strict_types=1); | ||||
| 
 | ||||
| namespace FireflyIII\Api\V1\Controllers\Models\RuleGroup; | ||||
| 
 | ||||
| use Exception; | ||||
| use FireflyIII\Api\V1\Controllers\Controller; | ||||
| use FireflyIII\Api\V1\Requests\Models\RuleGroup\TestRequest; | ||||
| use FireflyIII\Api\V1\Requests\Models\RuleGroup\TriggerRequest; | ||||
| @@ -128,7 +129,7 @@ class TriggerController extends Controller | ||||
|      * | ||||
|      * Execute the given rule group on a set of existing transactions. | ||||
|      * | ||||
|      * @throws \Exception | ||||
|      * @throws Exception | ||||
|      */ | ||||
|     public function triggerGroup(TriggerRequest $request, RuleGroup $group): JsonResponse | ||||
|     { | ||||
|   | ||||
| @@ -24,6 +24,7 @@ declare(strict_types=1); | ||||
| 
 | ||||
| namespace FireflyIII\Api\V1\Controllers\Summary; | ||||
| 
 | ||||
| use Exception; | ||||
| use Carbon\Carbon; | ||||
| use FireflyIII\Api\V1\Controllers\Controller; | ||||
| use FireflyIII\Api\V1\Requests\Data\DateRequest; | ||||
| @@ -91,7 +92,7 @@ class BasicController extends Controller | ||||
|      * This endpoint is documented at: | ||||
|      * https://api-docs.firefly-iii.org/?urls.primaryName=2.0.0%20(v1)#/summary/getBasicSummary
 | ||||
|      * | ||||
|      * @throws \Exception | ||||
|      * @throws Exception | ||||
|      */ | ||||
|     public function basic(DateRequest $request): JsonResponse | ||||
|     { | ||||
| @@ -467,7 +468,7 @@ class BasicController extends Controller | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * @throws \Exception | ||||
|      * @throws Exception | ||||
|      */ | ||||
|     private function getLeftToSpendInfo(Carbon $start, Carbon $end): array | ||||
|     { | ||||
|   | ||||
| @@ -23,6 +23,7 @@ declare(strict_types=1); | ||||
| 
 | ||||
| namespace FireflyIII\Api\V1\Middleware; | ||||
| 
 | ||||
| use Closure; | ||||
| use FireflyIII\User; | ||||
| use Illuminate\Http\Request; | ||||
| 
 | ||||
| @@ -36,7 +37,7 @@ class ApiDemoUser | ||||
|      * | ||||
|      * @return mixed | ||||
|      */ | ||||
|     public function handle(Request $request, \Closure $next) | ||||
|     public function handle(Request $request, Closure $next) | ||||
|     { | ||||
|         /** @var null|User $user */ | ||||
|         $user = $request->user(); | ||||
|   | ||||
| @@ -24,6 +24,7 @@ declare(strict_types=1); | ||||
| 
 | ||||
| namespace FireflyIII\Api\V1\Requests\Data\Bulk; | ||||
| 
 | ||||
| use JsonException; | ||||
| use FireflyIII\Enums\ClauseType; | ||||
| use FireflyIII\Rules\IsValidBulkClause; | ||||
| use FireflyIII\Support\Request\ChecksLogin; | ||||
| @@ -52,7 +53,7 @@ class TransactionRequest extends FormRequest | ||||
|             $data = [ | ||||
|                 'query' => json_decode($this->get('query'), true, 8, JSON_THROW_ON_ERROR), | ||||
|             ]; | ||||
|         } catch (\JsonException $e) { | ||||
|         } catch (JsonException $e) { | ||||
|             // dont really care. the validation should catch invalid json.
 | ||||
|             app('log')->error($e->getMessage()); | ||||
|         } | ||||
|   | ||||
| @@ -24,6 +24,8 @@ declare(strict_types=1); | ||||
| 
 | ||||
| namespace FireflyIII\Api\V1\Requests\Models\Bill; | ||||
| 
 | ||||
| use ValueError; | ||||
| use TypeError; | ||||
| use FireflyIII\Rules\IsBoolean; | ||||
| use FireflyIII\Rules\IsValidPositiveAmount; | ||||
| use FireflyIII\Support\Request\ChecksLogin; | ||||
| @@ -109,7 +111,7 @@ class StoreRequest extends FormRequest | ||||
| 
 | ||||
|                 try { | ||||
|                     $result = bccomp($min, $max); | ||||
|                 } catch (\ValueError $e) { | ||||
|                 } catch (ValueError $e) { | ||||
|                     Log::error($e->getMessage()); | ||||
|                     $validator->errors()->add('amount_min', (string) trans('validation.generic_invalid')); | ||||
|                     $validator->errors()->add('amount_max', (string) trans('validation.generic_invalid')); | ||||
| @@ -124,7 +126,7 @@ class StoreRequest extends FormRequest | ||||
| 
 | ||||
|         try { | ||||
|             $failed = $validator->fails(); | ||||
|         } catch (\TypeError $e) { | ||||
|         } catch (TypeError $e) { | ||||
|             Log::error($e->getMessage()); | ||||
|             $failed = false; | ||||
|         } | ||||
|   | ||||
| @@ -24,6 +24,7 @@ declare(strict_types=1); | ||||
| 
 | ||||
| namespace FireflyIII\Api\V2\Controllers\Summary; | ||||
| 
 | ||||
| use Exception; | ||||
| use Carbon\Carbon; | ||||
| use FireflyIII\Api\V2\Controllers\Controller; | ||||
| use FireflyIII\Api\V2\Request\Generic\DateRequest; | ||||
| @@ -92,7 +93,7 @@ class BasicController extends Controller | ||||
|      * This endpoint is documented at: | ||||
|      * https://api-docs.firefly-iii.org/?urls.primaryName=2.0.0%20(v2)#/summary/getBasicSummary
 | ||||
|      * | ||||
|      * @throws \Exception | ||||
|      * @throws Exception | ||||
|      * | ||||
|      * @SuppressWarnings("PHPMD.UnusedFormalParameter") | ||||
|      */ | ||||
|   | ||||
| @@ -24,6 +24,7 @@ declare(strict_types=1); | ||||
| 
 | ||||
| namespace FireflyIII\Api\V2\Request\Model\Transaction; | ||||
| 
 | ||||
| use Override; | ||||
| use FireflyIII\Api\V1\Requests\Models\AvailableBudget\Request; | ||||
| use FireflyIII\Exceptions\FireflyException; | ||||
| use FireflyIII\Models\TransactionGroup; | ||||
| @@ -64,7 +65,7 @@ class UpdateRequest extends Request | ||||
|      * | ||||
|      * @throws FireflyException | ||||
|      */ | ||||
|     #[\Override]
 | ||||
|     #[Override]
 | ||||
|     public function getAll(): array | ||||
|     { | ||||
|         app('log')->debug(sprintf('Now in %s', __METHOD__)); | ||||
| @@ -248,7 +249,7 @@ class UpdateRequest extends Request | ||||
|     /** | ||||
|      * The rules that the incoming request must be matched against. | ||||
|      */ | ||||
|     #[\Override]
 | ||||
|     #[Override]
 | ||||
|     public function rules(): array | ||||
|     { | ||||
|         app('log')->debug(sprintf('Now in %s', __METHOD__)); | ||||
| @@ -332,7 +333,7 @@ class UpdateRequest extends Request | ||||
|     /** | ||||
|      * Configure the validator instance. | ||||
|      */ | ||||
|     #[\Override]
 | ||||
|     #[Override]
 | ||||
|     public function withValidator(Validator $validator): void | ||||
|     { | ||||
|         app('log')->debug('Now in withValidator'); | ||||
|   | ||||
| @@ -24,6 +24,7 @@ declare(strict_types=1); | ||||
| 
 | ||||
| namespace FireflyIII\Api\V2\Response\Sum; | ||||
| 
 | ||||
| use Closure; | ||||
| use FireflyIII\Exceptions\FireflyException; | ||||
| use FireflyIII\Models\TransactionCurrency; | ||||
| use Illuminate\Database\Eloquent\Model; | ||||
| @@ -39,7 +40,7 @@ class AutoSum | ||||
|     /** | ||||
|      * @throws FireflyException | ||||
|      */ | ||||
|     public function autoSum(Collection $objects, \Closure $getCurrency, \Closure $getSum): array | ||||
|     public function autoSum(Collection $objects, Closure $getCurrency, Closure $getSum): array | ||||
|     { | ||||
|         $return = []; | ||||
| 
 | ||||
|   | ||||
| @@ -42,6 +42,7 @@ use FireflyIII\Support\Facades\Amount; | ||||
| use Illuminate\Console\Command; | ||||
| use Illuminate\Support\Facades\DB; | ||||
| use Illuminate\Support\Facades\Log; | ||||
| use ValueError; | ||||
| 
 | ||||
| class CorrectsAmounts extends Command | ||||
| { | ||||
| @@ -234,7 +235,7 @@ class CorrectsAmounts extends Command | ||||
|     { | ||||
|         try { | ||||
|             $check = bccomp((string) $item->trigger_value, '0'); | ||||
|         } catch (\ValueError) { | ||||
|         } catch (ValueError) { | ||||
|             $this->friendlyError(sprintf('Rule #%d contained invalid %s-trigger "%s". The trigger has been removed, and the rule is disabled.', $item->rule_id, $item->trigger_type, $item->trigger_value)); | ||||
|             $item->rule->active = false; | ||||
|             $item->rule->save(); | ||||
|   | ||||
| @@ -76,7 +76,7 @@ class CorrectsOpeningBalanceCurrencies extends Command | ||||
|     { | ||||
|         // get the asset account for this opening balance:
 | ||||
|         $account = $this->getAccount($journal); | ||||
|         if (null === $account) { | ||||
|         if (!$account instanceof Account) { | ||||
|             $message = sprintf('Transaction journal #%d has no valid account. Can\'t fix this line.', $journal->id); | ||||
|             app('log')->warning($message); | ||||
|             $this->friendlyError($message); | ||||
|   | ||||
| @@ -34,6 +34,8 @@ use FireflyIII\Support\Models\AccountBalanceCalculator; | ||||
| use Illuminate\Console\Command; | ||||
| use Illuminate\Support\Facades\DB; | ||||
| use Illuminate\Support\Facades\Log; | ||||
| use ValueError; | ||||
| use stdClass; | ||||
| 
 | ||||
| class CorrectsUnevenAmount extends Command | ||||
| { | ||||
| @@ -135,7 +137,7 @@ class CorrectsUnevenAmount extends Command | ||||
|             ->get(['transaction_journal_id', DB::raw('SUM(amount) AS the_sum')]) | ||||
|         ; | ||||
| 
 | ||||
|         /** @var \stdClass $entry */ | ||||
|         /** @var stdClass $entry */ | ||||
|         foreach ($journals as $entry) { | ||||
|             $sum = (string) $entry->the_sum; | ||||
|             if (!is_numeric($sum) | ||||
| @@ -157,7 +159,7 @@ class CorrectsUnevenAmount extends Command | ||||
| 
 | ||||
|             try { | ||||
|                 $res = bccomp($sum, '0'); | ||||
|             } catch (\ValueError $e) { | ||||
|             } catch (ValueError $e) { | ||||
|                 $this->friendlyError(sprintf('Could not bccomp("%s", "0").', $sum)); | ||||
|                 Log::error($e->getMessage()); | ||||
|                 Log::error($e->getTraceAsString()); | ||||
| @@ -385,7 +387,7 @@ class CorrectsUnevenAmount extends Command | ||||
| 
 | ||||
|                 continue; | ||||
|             } | ||||
|             if (0 === bccomp($source->amount, $source->foreign_amount) && 0 === bccomp($source->foreign_amount, $source->amount)) { | ||||
|             if (0 === bccomp((string) $source->amount, (string) $source->foreign_amount) && 0 === bccomp((string) $source->foreign_amount, (string) $source->amount)) { | ||||
|                 Log::debug('Already fixed, continue.'); | ||||
| 
 | ||||
|                 continue; | ||||
|   | ||||
| @@ -28,6 +28,7 @@ use FireflyIII\Console\Commands\ShowsFriendlyMessages; | ||||
| use FireflyIII\Repositories\User\UserRepositoryInterface; | ||||
| use FireflyIII\User; | ||||
| use Illuminate\Console\Command; | ||||
| use Exception; | ||||
| 
 | ||||
| class CreatesAccessTokens extends Command | ||||
| { | ||||
| @@ -40,7 +41,7 @@ class CreatesAccessTokens extends Command | ||||
|     /** | ||||
|      * Execute the console command. | ||||
|      * | ||||
|      * @throws \Exception | ||||
|      * @throws Exception | ||||
|      */ | ||||
|     public function handle(): int | ||||
|     { | ||||
|   | ||||
| @@ -27,6 +27,7 @@ namespace FireflyIII\Console\Commands\Correction; | ||||
| use FireflyIII\Console\Commands\ShowsFriendlyMessages; | ||||
| use FireflyIII\Models\TransactionGroup; | ||||
| use Illuminate\Console\Command; | ||||
| use Exception; | ||||
| 
 | ||||
| class RemovesEmptyGroups extends Command | ||||
| { | ||||
| @@ -38,7 +39,7 @@ class RemovesEmptyGroups extends Command | ||||
|     /** | ||||
|      * Execute the console command. | ||||
|      * | ||||
|      * @throws \Exception | ||||
|      * @throws Exception | ||||
|      */ | ||||
|     public function handle(): int | ||||
|     { | ||||
|   | ||||
| @@ -28,6 +28,8 @@ use FireflyIII\Console\Commands\ShowsFriendlyMessages; | ||||
| use FireflyIII\Models\Transaction; | ||||
| use FireflyIII\Models\TransactionJournal; | ||||
| use Illuminate\Console\Command; | ||||
| use Exception; | ||||
| use stdClass; | ||||
| 
 | ||||
| /** | ||||
|  * Deletes transactions where the journal has been deleted. | ||||
| @@ -43,7 +45,7 @@ class RemovesOrphanedTransactions extends Command | ||||
|     /** | ||||
|      * Execute the console command. | ||||
|      * | ||||
|      * @throws \Exception | ||||
|      * @throws Exception | ||||
|      */ | ||||
|     public function handle(): int | ||||
|     { | ||||
| @@ -85,7 +87,7 @@ class RemovesOrphanedTransactions extends Command | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * @throws \Exception | ||||
|      * @throws Exception | ||||
|      */ | ||||
|     private function deleteOrphanedTransactions(): void | ||||
|     { | ||||
| @@ -102,7 +104,7 @@ class RemovesOrphanedTransactions extends Command | ||||
|             ) | ||||
|         ; | ||||
| 
 | ||||
|         /** @var \stdClass $entry */ | ||||
|         /** @var stdClass $entry */ | ||||
|         foreach ($set as $entry) { | ||||
|             $transaction = Transaction::find((int) $entry->transaction_id); | ||||
|             if (null !== $transaction) { | ||||
|   | ||||
| @@ -24,6 +24,7 @@ declare(strict_types=1); | ||||
| 
 | ||||
| namespace FireflyIII\Console\Commands\Export; | ||||
| 
 | ||||
| use FireflyIII\Models\TransactionJournal; | ||||
| use Carbon\Carbon; | ||||
| use FireflyIII\Console\Commands\ShowsFriendlyMessages; | ||||
| use FireflyIII\Console\Commands\VerifiesAccessToken; | ||||
| @@ -35,6 +36,10 @@ use FireflyIII\Repositories\Journal\JournalRepositoryInterface; | ||||
| use FireflyIII\Support\Export\ExportDataGenerator; | ||||
| use Illuminate\Console\Command; | ||||
| use Illuminate\Support\Collection; | ||||
| use Exception; | ||||
| use InvalidArgumentException; | ||||
| 
 | ||||
| use function Safe\file_put_contents; | ||||
| 
 | ||||
| class ExportsData extends Command | ||||
| { | ||||
| @@ -139,7 +144,7 @@ class ExportsData extends Command | ||||
| 
 | ||||
|     /** | ||||
|      * @throws FireflyException | ||||
|      * @throws \Exception | ||||
|      * @throws Exception | ||||
|      */ | ||||
|     private function parseOptions(): array | ||||
|     { | ||||
| @@ -169,7 +174,7 @@ class ExportsData extends Command | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * @throws \Exception | ||||
|      * @throws Exception | ||||
|      */ | ||||
|     private function getDateParameter(string $field): Carbon | ||||
|     { | ||||
| @@ -183,7 +188,7 @@ class ExportsData extends Command | ||||
|         if (is_string($this->option($field))) { | ||||
|             try { | ||||
|                 $date = Carbon::createFromFormat('!Y-m-d', $this->option($field)); | ||||
|             } catch (\InvalidArgumentException $e) { | ||||
|             } catch (InvalidArgumentException $e) { | ||||
|                 app('log')->error($e->getMessage()); | ||||
|                 $this->friendlyError(sprintf('%s date "%s" must be formatted YYYY-MM-DD. Field will be ignored.', $field, $this->option('start'))); | ||||
|                 $error = true; | ||||
| @@ -201,7 +206,7 @@ class ExportsData extends Command | ||||
| 
 | ||||
|         if (true === $error && 'start' === $field) { | ||||
|             $journal = $this->journalRepository->firstNull(); | ||||
|             $date    = null === $journal ? today(config('app.timezone'))->subYear() : $journal->date; | ||||
|             $date    = $journal instanceof TransactionJournal ? $journal->date : today(config('app.timezone'))->subYear(); | ||||
|             $date->startOfDay(); | ||||
| 
 | ||||
|             return $date; | ||||
| @@ -273,7 +278,7 @@ class ExportsData extends Command | ||||
|      */ | ||||
|     private function exportData(array $options, array $data): void | ||||
|     { | ||||
|         $date = date('Y_m_d'); | ||||
|         $date = Carbon::now()->format('Y_m_d'); | ||||
|         foreach ($data as $key => $content) { | ||||
|             $file = sprintf('%s%s_%s.csv', $options['directory'], $date, $key); | ||||
|             if (false === $options['force'] && file_exists($file)) { | ||||
| @@ -283,7 +288,7 @@ class ExportsData extends Command | ||||
|                 $this->friendlyWarning(sprintf('File "%s" exists already but will be replaced.', $file)); | ||||
|             } | ||||
|             // continue to write to file.
 | ||||
|             \Safe\file_put_contents($file, $content); | ||||
|             file_put_contents($file, $content); | ||||
|             $this->friendlyPositive(sprintf('Wrote %s-export to file "%s".', $key, $file)); | ||||
|         } | ||||
|     } | ||||
|   | ||||
| @@ -30,6 +30,7 @@ use FireflyIII\Models\Budget; | ||||
| use FireflyIII\Models\Category; | ||||
| use FireflyIII\Models\Tag; | ||||
| use Illuminate\Console\Command; | ||||
| use stdClass; | ||||
| 
 | ||||
| class ReportsEmptyObjects extends Command | ||||
| { | ||||
| @@ -66,7 +67,7 @@ class ReportsEmptyObjects extends Command | ||||
|             ->get(['budgets.id', 'budgets.name', 'budgets.user_id', 'users.email']) | ||||
|         ; | ||||
| 
 | ||||
|         /** @var \stdClass $entry */ | ||||
|         /** @var stdClass $entry */ | ||||
|         foreach ($set as $entry) { | ||||
|             $line = sprintf( | ||||
|                 'User #%d (%s) has budget #%d ("%s") which has no transaction journals.', | ||||
| @@ -92,7 +93,7 @@ class ReportsEmptyObjects extends Command | ||||
|             ->get(['categories.id', 'categories.name', 'categories.user_id', 'users.email']) | ||||
|         ; | ||||
| 
 | ||||
|         /** @var \stdClass $entry */ | ||||
|         /** @var stdClass $entry */ | ||||
|         foreach ($set as $entry) { | ||||
|             $line = sprintf( | ||||
|                 'User #%d (%s) has category #%d ("%s") which has no transaction journals.', | ||||
| @@ -115,7 +116,7 @@ class ReportsEmptyObjects extends Command | ||||
|             ->get(['tags.id', 'tags.tag', 'tags.user_id', 'users.email']) | ||||
|         ; | ||||
| 
 | ||||
|         /** @var \stdClass $entry */ | ||||
|         /** @var stdClass $entry */ | ||||
|         foreach ($set as $entry) { | ||||
|             $line = sprintf( | ||||
|                 'User #%d (%s) has tag #%d ("%s") which has no transaction journals.', | ||||
| @@ -142,7 +143,7 @@ class ReportsEmptyObjects extends Command | ||||
|             ) | ||||
|         ; | ||||
| 
 | ||||
|         /** @var \stdClass $entry */ | ||||
|         /** @var stdClass $entry */ | ||||
|         foreach ($set as $entry) { | ||||
|             $line = 'User #%d (%s) has account #%d ("%s") which has no transactions.'; | ||||
|             $line = sprintf($line, $entry->user_id, $entry->email, $entry->id, $entry->name); | ||||
|   | ||||
| @@ -27,6 +27,7 @@ namespace FireflyIII\Console\Commands\System; | ||||
| use FireflyIII\Console\Commands\ShowsFriendlyMessages; | ||||
| use Illuminate\Console\Command; | ||||
| use PDO; | ||||
| use PDOException; | ||||
| 
 | ||||
| class CreatesDatabase extends Command | ||||
| { | ||||
| @@ -53,15 +54,15 @@ class CreatesDatabase extends Command | ||||
|         $this->friendlyLine(sprintf('DSN is %s', $dsn)); | ||||
| 
 | ||||
|         $options = [ | ||||
|             \PDO::ATTR_ERRMODE            => \PDO::ERRMODE_EXCEPTION, | ||||
|             \PDO::ATTR_DEFAULT_FETCH_MODE => \PDO::FETCH_ASSOC, | ||||
|             \PDO::ATTR_EMULATE_PREPARES   => false, | ||||
|             PDO::ATTR_ERRMODE            => PDO::ERRMODE_EXCEPTION, | ||||
|             PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC, | ||||
|             PDO::ATTR_EMULATE_PREPARES   => false, | ||||
|         ]; | ||||
| 
 | ||||
|         // when it fails, display error
 | ||||
|         try { | ||||
|             $pdo = new \PDO($dsn, (string) env('DB_USERNAME'), (string) env('DB_PASSWORD'), $options); | ||||
|         } catch (\PDOException $e) { | ||||
|             $pdo = new PDO($dsn, (string) env('DB_USERNAME'), (string) env('DB_PASSWORD'), $options); | ||||
|         } catch (PDOException $e) { | ||||
|             $this->friendlyError(sprintf('Error when connecting to DB: %s', $e->getMessage())); | ||||
| 
 | ||||
|             return 1; | ||||
|   | ||||
| @@ -43,6 +43,9 @@ use Illuminate\Database\Eloquent\Model; | ||||
| use Illuminate\Support\Collection; | ||||
| use Illuminate\Support\Facades\DB; | ||||
| 
 | ||||
| use function Safe\mb_regex_encoding; | ||||
| use function Safe\json_encode; | ||||
| 
 | ||||
| /** | ||||
|  * This command was inspired by https://github.com/elliot-gh. It will check all amount fields | ||||
|  * and their values and correct them to the correct number of decimal places. This fixes issues where | ||||
| @@ -130,7 +133,7 @@ class ForcesDecimalSize extends Command | ||||
|         // if sqlite, add function?
 | ||||
|         if ('sqlite' === (string) config('database.default')) { | ||||
|             DB::connection()->getPdo()->sqliteCreateFunction('REGEXP', static function ($pattern, $value) { | ||||
|                 \Safe\mb_regex_encoding('UTF-8'); | ||||
|                 mb_regex_encoding('UTF-8'); | ||||
|                 $pattern = trim($pattern, '"'); | ||||
| 
 | ||||
|                 return (false !== mb_ereg($pattern, (string) $value)) ? 1 : 0; | ||||
| @@ -234,7 +237,7 @@ class ForcesDecimalSize extends Command | ||||
|         /** @var Builder $query */ | ||||
|         $query             = Account::leftJoin('account_meta', 'accounts.id', '=', 'account_meta.account_id') | ||||
|             ->where('account_meta.name', 'currency_id') | ||||
|             ->where('account_meta.data', \Safe\json_encode((string) $currency->id)) | ||||
|             ->where('account_meta.data', json_encode((string) $currency->id)) | ||||
|         ; | ||||
|         $query->where(static function (Builder $q) use ($fields, $currency, $operator, $cast, $regularExpression): void { | ||||
|             foreach ($fields as $field) { | ||||
| @@ -338,7 +341,7 @@ class ForcesDecimalSize extends Command | ||||
|             ->leftJoin('accounts', 'piggy_banks.account_id', '=', 'accounts.id') | ||||
|             ->leftJoin('account_meta', 'accounts.id', '=', 'account_meta.account_id') | ||||
|             ->where('account_meta.name', 'currency_id') | ||||
|             ->where('account_meta.data', \Safe\json_encode((string) $currency->id)) | ||||
|             ->where('account_meta.data', json_encode((string) $currency->id)) | ||||
|             ->where(static function (Builder $q) use ($fields, $currency, $cast, $operator, $regularExpression): void { | ||||
|                 foreach ($fields as $field) { | ||||
|                     $q->orWhere( | ||||
| @@ -394,7 +397,7 @@ class ForcesDecimalSize extends Command | ||||
|             ->leftJoin('accounts', 'piggy_banks.account_id', '=', 'accounts.id') | ||||
|             ->leftJoin('account_meta', 'accounts.id', '=', 'account_meta.account_id') | ||||
|             ->where('account_meta.name', 'currency_id') | ||||
|             ->where('account_meta.data', \Safe\json_encode((string) $currency->id)) | ||||
|             ->where('account_meta.data', json_encode((string) $currency->id)) | ||||
|             ->where(static function (Builder $q) use ($fields, $currency, $operator, $cast, $regularExpression): void { | ||||
|                 foreach ($fields as $field) { | ||||
|                     $q->orWhere( | ||||
| @@ -448,7 +451,7 @@ class ForcesDecimalSize extends Command | ||||
|         $query             = PiggyBank::leftJoin('accounts', 'piggy_banks.account_id', '=', 'accounts.id') | ||||
|             ->leftJoin('account_meta', 'accounts.id', '=', 'account_meta.account_id') | ||||
|             ->where('account_meta.name', 'currency_id') | ||||
|             ->where('account_meta.data', \Safe\json_encode((string) $currency->id)) | ||||
|             ->where('account_meta.data', json_encode((string) $currency->id)) | ||||
|             ->where(static function (Builder $q) use ($fields, $currency, $operator, $cast, $regularExpression): void { | ||||
|                 foreach ($fields as $field) { | ||||
|                     $q->orWhere( | ||||
|   | ||||
| @@ -24,6 +24,7 @@ declare(strict_types=1); | ||||
| 
 | ||||
| namespace FireflyIII\Console\Commands\System; | ||||
| 
 | ||||
| use Carbon\Carbon; | ||||
| use FireflyIII\Support\System\GeneratesInstallationId; | ||||
| use Illuminate\Console\Command; | ||||
| 
 | ||||
| @@ -111,8 +112,8 @@ class OutputsInstructions extends Command | ||||
|      */ | ||||
|     private function showLogo(): void | ||||
|     { | ||||
|         $today  = date('m-d'); | ||||
|         $month  = date('m'); | ||||
|         $today  = Carbon::now()->format('m-d'); | ||||
|         $month  = Carbon::now()->format('m'); | ||||
|         // variation in colors and effects just because I can!
 | ||||
|         // default is Ukraine flag:
 | ||||
|         $colors = ['blue', 'blue', 'blue', 'yellow', 'yellow', 'yellow', 'default', 'default']; | ||||
|   | ||||
| @@ -31,6 +31,11 @@ use Illuminate\Contracts\Encryption\DecryptException; | ||||
| use Illuminate\Support\Facades\Crypt; | ||||
| use Illuminate\Support\Facades\Storage; | ||||
| 
 | ||||
| use function Safe\tempnam; | ||||
| use function Safe\file_put_contents; | ||||
| use function Safe\md5_file; | ||||
| use function Safe\mime_content_type; | ||||
| 
 | ||||
| class ScansAttachments extends Command | ||||
| { | ||||
|     use ShowsFriendlyMessages; | ||||
| @@ -63,15 +68,15 @@ class ScansAttachments extends Command | ||||
|                 app('log')->error(sprintf('Could not decrypt data of attachment #%d: %s', $attachment->id, $e->getMessage())); | ||||
|                 $decryptedContent = $encryptedContent; | ||||
|             } | ||||
|             $tempFileName     = \Safe\tempnam(sys_get_temp_dir(), 'FireflyIII'); | ||||
|             $tempFileName     = tempnam(sys_get_temp_dir(), 'FireflyIII'); | ||||
|             if (false === $tempFileName) { | ||||
|                 app('log')->error(sprintf('Could not create temporary file for attachment #%d', $attachment->id)); | ||||
| 
 | ||||
|                 exit(1); | ||||
|             } | ||||
|             \Safe\file_put_contents($tempFileName, $decryptedContent); | ||||
|             $attachment->md5  = (string) \Safe\md5_file($tempFileName); | ||||
|             $attachment->mime = (string) \Safe\mime_content_type($tempFileName); | ||||
|             file_put_contents($tempFileName, $decryptedContent); | ||||
|             $attachment->md5  = (string) md5_file($tempFileName); | ||||
|             $attachment->mime = (string) mime_content_type($tempFileName); | ||||
|             $attachment->save(); | ||||
|             $this->friendlyInfo(sprintf('Fixed attachment #%d', $attachment->id)); | ||||
|         } | ||||
|   | ||||
| @@ -30,6 +30,8 @@ use Illuminate\Database\QueryException; | ||||
| use Illuminate\Support\Facades\Storage; | ||||
| use League\Flysystem\FilesystemException; | ||||
| 
 | ||||
| use function Safe\json_decode; | ||||
| 
 | ||||
| class VerifySecurityAlerts extends Command | ||||
| { | ||||
|     use ShowsFriendlyMessages; | ||||
| @@ -57,7 +59,7 @@ class VerifySecurityAlerts extends Command | ||||
|             return 0; | ||||
|         } | ||||
|         $content = $disk->get('alerts.json'); | ||||
|         $json    = \Safe\json_decode($content, true, 10); | ||||
|         $json    = json_decode((string) $content, true, 10); | ||||
| 
 | ||||
|         /** @var array $array */ | ||||
|         foreach ($json as $array) { | ||||
|   | ||||
| @@ -248,7 +248,7 @@ class ApplyRules extends Command | ||||
| 
 | ||||
|         foreach ($ruleList as $ruleId) { | ||||
|             $rule = $this->ruleRepository->find((int) $ruleId); | ||||
|             if (null !== $rule && true === $rule->active) { | ||||
|             if ($rule instanceof Rule && true === $rule->active) { | ||||
|                 $this->ruleSelection[] = $rule->id; | ||||
|             } | ||||
|         } | ||||
|   | ||||
| @@ -34,6 +34,7 @@ use FireflyIII\Support\Cronjobs\RecurringCronjob; | ||||
| use FireflyIII\Support\Cronjobs\UpdateCheckCronjob; | ||||
| use Illuminate\Console\Command; | ||||
| use Illuminate\Support\Facades\Log; | ||||
| use InvalidArgumentException; | ||||
| 
 | ||||
| class Cron extends Command | ||||
| { | ||||
| @@ -62,7 +63,7 @@ class Cron extends Command | ||||
| 
 | ||||
|         try { | ||||
|             $date = new Carbon($this->option('date')); | ||||
|         } catch (\InvalidArgumentException $e) { | ||||
|         } catch (InvalidArgumentException $e) { | ||||
|             $this->friendlyError(sprintf('"%s" is not a valid date', $this->option('date'))); | ||||
|         } | ||||
|         $force = (bool) $this->option('force'); // @phpstan-ignore-line
 | ||||
| @@ -133,7 +134,7 @@ class Cron extends Command | ||||
|         $exchangeRates = new ExchangeRatesCronjob(); | ||||
|         $exchangeRates->setForce($force); | ||||
|         // set date in cron job:
 | ||||
|         if (null !== $date) { | ||||
|         if ($date instanceof Carbon) { | ||||
|             $exchangeRates->setDate($date); | ||||
|         } | ||||
| 
 | ||||
| @@ -176,7 +177,7 @@ class Cron extends Command | ||||
|         $recurring->setForce($force); | ||||
| 
 | ||||
|         // set date in cron job:
 | ||||
|         if (null !== $date) { | ||||
|         if ($date instanceof Carbon) { | ||||
|             $recurring->setDate($date); | ||||
|         } | ||||
| 
 | ||||
| @@ -197,7 +198,7 @@ class Cron extends Command | ||||
|         $autoBudget = new AutoBudgetCronjob(); | ||||
|         $autoBudget->setForce($force); | ||||
|         // set date in cron job:
 | ||||
|         if (null !== $date) { | ||||
|         if ($date instanceof Carbon) { | ||||
|             $autoBudget->setDate($date); | ||||
|         } | ||||
| 
 | ||||
| @@ -222,7 +223,7 @@ class Cron extends Command | ||||
|         $autoBudget = new BillWarningCronjob(); | ||||
|         $autoBudget->setForce($force); | ||||
|         // set date in cron job:
 | ||||
|         if (null !== $date) { | ||||
|         if ($date instanceof Carbon) { | ||||
|             $autoBudget->setDate($date); | ||||
|         } | ||||
| 
 | ||||
|   | ||||
| @@ -120,7 +120,7 @@ class AddsTransactionIdentifiers extends Command | ||||
|         /** @var Transaction $transaction */ | ||||
|         foreach ($transactions as $transaction) { | ||||
|             $opposing = $this->findOpposing($transaction, $exclude); | ||||
|             if (null !== $opposing) { | ||||
|             if ($opposing instanceof Transaction) { | ||||
|                 // give both a new identifier:
 | ||||
|                 $transaction->identifier = $identifier; | ||||
|                 $opposing->identifier    = $identifier; | ||||
|   | ||||
| @@ -31,6 +31,10 @@ use Illuminate\Console\Command; | ||||
| use Illuminate\Contracts\Encryption\DecryptException; | ||||
| use Illuminate\Support\Facades\Crypt; | ||||
| use Illuminate\Support\Facades\DB; | ||||
| use JsonException; | ||||
| use stdClass; | ||||
| 
 | ||||
| use function Safe\json_decode; | ||||
| 
 | ||||
| class RemovesDatabaseDecryption extends Command | ||||
| { | ||||
| @@ -105,13 +109,13 @@ class RemovesDatabaseDecryption extends Command | ||||
|     { | ||||
|         $rows = DB::table($table)->get(['id', $field]); | ||||
| 
 | ||||
|         /** @var \stdClass $row */ | ||||
|         /** @var stdClass $row */ | ||||
|         foreach ($rows as $row) { | ||||
|             $this->decryptRow($table, $field, $row); | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     private function decryptRow(string $table, string $field, \stdClass $row): void | ||||
|     private function decryptRow(string $table, string $field, stdClass $row): void | ||||
|     { | ||||
|         $original = $row->{$field}; | ||||
|         if (null === $original) { | ||||
| @@ -167,8 +171,8 @@ class RemovesDatabaseDecryption extends Command | ||||
|     { | ||||
|         // try to json_decrypt the value.
 | ||||
|         try { | ||||
|             $newValue = \Safe\json_decode($value, true, 512, JSON_THROW_ON_ERROR) ?? $value; | ||||
|         } catch (\JsonException $e) { | ||||
|             $newValue = json_decode($value, true, 512, JSON_THROW_ON_ERROR) ?? $value; | ||||
|         } catch (JsonException $e) { | ||||
|             $message = sprintf('Could not JSON decode preference row #%d: %s. This does not have to be a problem.', $id, $e->getMessage()); | ||||
|             $this->friendlyError($message); | ||||
|             app('log')->warning($message); | ||||
|   | ||||
| @@ -24,6 +24,7 @@ declare(strict_types=1); | ||||
| 
 | ||||
| namespace FireflyIII\Console\Commands\Upgrade; | ||||
| 
 | ||||
| use FireflyIII\Models\TransactionJournal; | ||||
| use FireflyIII\Console\Commands\ShowsFriendlyMessages; | ||||
| use FireflyIII\Enums\AccountTypeEnum; | ||||
| use FireflyIII\Exceptions\FireflyException; | ||||
| @@ -141,7 +142,7 @@ class UpgradesAccountCurrencies extends Command | ||||
|             return; | ||||
|         } | ||||
|         // do not match and opening balance id is not null.
 | ||||
|         if ($accountCurrency !== $obCurrency && null !== $openingBalance) { | ||||
|         if ($accountCurrency !== $obCurrency && $openingBalance instanceof TransactionJournal) { | ||||
|             // update opening balance:
 | ||||
|             $openingBalance->transaction_currency_id = $accountCurrency; | ||||
|             $openingBalance->save(); | ||||
|   | ||||
| @@ -123,7 +123,7 @@ class UpgradesBillsToRules extends Command | ||||
|         $groupTitle = (string) trans('firefly.rulegroup_for_bills_title', [], $language); | ||||
|         $ruleGroup  = $this->ruleGroupRepository->findByTitle($groupTitle); | ||||
| 
 | ||||
|         if (null === $ruleGroup) { | ||||
|         if (!$ruleGroup instanceof RuleGroup) { | ||||
|             $ruleGroup = $this->ruleGroupRepository->store( | ||||
|                 [ | ||||
|                     'title'       => (string) trans('firefly.rulegroup_for_bills_title', [], $language), | ||||
|   | ||||
| @@ -27,8 +27,10 @@ namespace FireflyIII\Console\Commands\Upgrade; | ||||
| use Illuminate\Support\Facades\Log; | ||||
| use Safe\Exceptions\InfoException; | ||||
| 
 | ||||
| use function Safe\set_time_limit; | ||||
| 
 | ||||
| try { | ||||
|     \Safe\set_time_limit(0); | ||||
|     set_time_limit(0); | ||||
| } catch (InfoException) { | ||||
|     Log::warning('set_time_limit returned false. This could be an issue, unless you also run XDebug.'); | ||||
| } | ||||
|   | ||||
| @@ -122,7 +122,7 @@ class UpgradesLiabilities extends Command | ||||
|     { | ||||
|         $source      = $this->getSourceTransaction($openingBalance); | ||||
|         $destination = $this->getDestinationTransaction($openingBalance); | ||||
|         if (null === $source || null === $destination) { | ||||
|         if (!$source instanceof Transaction || !$destination instanceof Transaction) { | ||||
|             return; | ||||
|         } | ||||
|         // source MUST be the liability.
 | ||||
|   | ||||
| @@ -30,6 +30,8 @@ use FireflyIII\Models\RecurrenceMeta; | ||||
| use FireflyIII\Models\RecurrenceTransactionMeta; | ||||
| use Illuminate\Console\Command; | ||||
| 
 | ||||
| use function Safe\json_encode; | ||||
| 
 | ||||
| class UpgradesRecurrenceMetaData extends Command | ||||
| { | ||||
|     use ShowsFriendlyMessages; | ||||
| @@ -100,7 +102,7 @@ class UpgradesRecurrenceMetaData extends Command | ||||
| 
 | ||||
|         if ('tags' === $meta->name) { | ||||
|             $array = explode(',', $meta->value); | ||||
|             $value = \Safe\json_encode($array, JSON_THROW_ON_ERROR); | ||||
|             $value = json_encode($array, JSON_THROW_ON_ERROR); | ||||
|         } | ||||
| 
 | ||||
|         RecurrenceTransactionMeta::create( | ||||
|   | ||||
| @@ -24,6 +24,7 @@ declare(strict_types=1); | ||||
| 
 | ||||
| namespace FireflyIII\Console\Commands\Upgrade; | ||||
| 
 | ||||
| use Carbon\Carbon; | ||||
| use FireflyIII\Console\Commands\ShowsFriendlyMessages; | ||||
| use FireflyIII\Factory\TransactionGroupFactory; | ||||
| use FireflyIII\Models\Budget; | ||||
| @@ -36,6 +37,7 @@ use FireflyIII\Services\Internal\Destroy\JournalDestroyService; | ||||
| use Illuminate\Console\Command; | ||||
| use Illuminate\Support\Collection; | ||||
| use Illuminate\Support\Facades\DB; | ||||
| use Exception; | ||||
| 
 | ||||
| class UpgradesToGroups extends Command | ||||
| { | ||||
| @@ -103,7 +105,7 @@ class UpgradesToGroups extends Command | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * @throws \Exception | ||||
|      * @throws Exception | ||||
|      */ | ||||
|     private function makeGroupsFromSplitJournals(): void | ||||
|     { | ||||
| @@ -119,7 +121,7 @@ class UpgradesToGroups extends Command | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * @throws \Exception | ||||
|      * @throws Exception | ||||
|      */ | ||||
|     private function makeMultiGroup(TransactionJournal $journal): void | ||||
|     { | ||||
| @@ -191,7 +193,7 @@ class UpgradesToGroups extends Command | ||||
|         app('log')->debug(sprintf('Now going to add transaction #%d to the array.', $transaction->id)); | ||||
|         $opposingTr     = $this->findOpposingTransaction($journal, $transaction); | ||||
| 
 | ||||
|         if (null === $opposingTr) { | ||||
|         if (!$opposingTr instanceof Transaction) { | ||||
|             $this->friendlyError( | ||||
|                 sprintf( | ||||
|                     'Journal #%d has no opposing transaction for transaction #%d. Cannot upgrade this entry.', | ||||
| @@ -366,8 +368,8 @@ class UpgradesToGroups extends Command | ||||
|     { | ||||
|         $groupId = DB::table('transaction_groups')->insertGetId( | ||||
|             [ | ||||
|                 'created_at' => date('Y-m-d H:i:s'), | ||||
|                 'updated_at' => date('Y-m-d H:i:s'), | ||||
|                 'created_at' => Carbon::now()->format('Y-m-d H:i:s'), | ||||
|                 'updated_at' => Carbon::now()->format('Y-m-d H:i:s'), | ||||
|                 'title'      => null, | ||||
|                 'user_id'    => $array['user_id'], | ||||
|             ] | ||||
|   | ||||
| @@ -202,7 +202,7 @@ class UpgradesTransferCurrencies extends Command | ||||
|     { | ||||
|         $this->sourceTransaction = $this->getSourceTransaction($journal); | ||||
|         $this->sourceAccount     = $this->sourceTransaction?->account; | ||||
|         $this->sourceCurrency    = null === $this->sourceAccount ? null : $this->getCurrency($this->sourceAccount); | ||||
|         $this->sourceCurrency    = $this->sourceAccount instanceof Account ? $this->getCurrency($this->sourceAccount) : null; | ||||
|     } | ||||
| 
 | ||||
|     private function getSourceTransaction(TransactionJournal $transfer): ?Transaction | ||||
| @@ -221,7 +221,7 @@ class UpgradesTransferCurrencies extends Command | ||||
|             return $this->accountCurrencies[$accountId]; | ||||
|         } | ||||
|         $currency                            = $this->accountRepos->getAccountCurrency($account); | ||||
|         if (null === $currency) { | ||||
|         if (!$currency instanceof TransactionCurrency) { | ||||
|             $this->accountCurrencies[$accountId] = 0; | ||||
| 
 | ||||
|             return null; | ||||
| @@ -238,7 +238,7 @@ class UpgradesTransferCurrencies extends Command | ||||
|     { | ||||
|         $this->destinationTransaction = $this->getDestinationTransaction($journal); | ||||
|         $this->destinationAccount     = $this->destinationTransaction?->account; | ||||
|         $this->destinationCurrency    = null === $this->destinationAccount ? null : $this->getCurrency($this->destinationAccount); | ||||
|         $this->destinationCurrency    = $this->destinationAccount instanceof Account ? $this->getCurrency($this->destinationAccount) : null; | ||||
|     } | ||||
| 
 | ||||
|     private function getDestinationTransaction(TransactionJournal $transfer): ?Transaction | ||||
| @@ -252,15 +252,15 @@ class UpgradesTransferCurrencies extends Command | ||||
|      */ | ||||
|     private function isEmptyTransactions(): bool | ||||
|     { | ||||
|         return null === $this->sourceTransaction || null === $this->destinationTransaction | ||||
|                || null === $this->sourceAccount | ||||
|                || null === $this->destinationAccount; | ||||
|         return !$this->sourceTransaction instanceof Transaction || !$this->destinationTransaction instanceof Transaction | ||||
|                || !$this->sourceAccount instanceof Account | ||||
|                || !$this->destinationAccount instanceof Account; | ||||
|     } | ||||
| 
 | ||||
|     private function isNoCurrencyPresent(): bool | ||||
|     { | ||||
|         // source account must have a currency preference.
 | ||||
|         if (null === $this->sourceCurrency) { | ||||
|         if (!$this->sourceCurrency instanceof TransactionCurrency) { | ||||
|             $message = sprintf('Account #%d ("%s") must have currency preference but has none.', $this->sourceAccount->id, $this->sourceAccount->name); | ||||
|             app('log')->error($message); | ||||
|             $this->friendlyError($message); | ||||
| @@ -269,7 +269,7 @@ class UpgradesTransferCurrencies extends Command | ||||
|         } | ||||
| 
 | ||||
|         // destination account must have a currency preference.
 | ||||
|         if (null === $this->destinationCurrency) { | ||||
|         if (!$this->destinationCurrency instanceof TransactionCurrency) { | ||||
|             $message = sprintf( | ||||
|                 'Account #%d ("%s") must have currency preference but has none.', | ||||
|                 $this->destinationAccount->id, | ||||
| @@ -290,7 +290,7 @@ class UpgradesTransferCurrencies extends Command | ||||
|      */ | ||||
|     private function fixSourceNoCurrency(): void | ||||
|     { | ||||
|         if (null === $this->sourceTransaction->transaction_currency_id && null !== $this->sourceCurrency) { | ||||
|         if (null === $this->sourceTransaction->transaction_currency_id && $this->sourceCurrency instanceof TransactionCurrency) { | ||||
|             $this->sourceTransaction | ||||
|                 ->transaction_currency_id | ||||
|                      = $this->sourceCurrency->id | ||||
| @@ -312,7 +312,7 @@ class UpgradesTransferCurrencies extends Command | ||||
|      */ | ||||
|     private function fixSourceUnmatchedCurrency(): void | ||||
|     { | ||||
|         if (null !== $this->sourceCurrency | ||||
|         if ($this->sourceCurrency instanceof TransactionCurrency | ||||
|             && null === $this->sourceTransaction->foreign_amount | ||||
|             && (int) $this->sourceTransaction->transaction_currency_id !== $this->sourceCurrency->id | ||||
|         ) { | ||||
| @@ -336,7 +336,7 @@ class UpgradesTransferCurrencies extends Command | ||||
|      */ | ||||
|     private function fixDestNoCurrency(): void | ||||
|     { | ||||
|         if (null === $this->destinationTransaction->transaction_currency_id && null !== $this->destinationCurrency) { | ||||
|         if (null === $this->destinationTransaction->transaction_currency_id && $this->destinationCurrency instanceof TransactionCurrency) { | ||||
|             $this->destinationTransaction | ||||
|                 ->transaction_currency_id | ||||
|                      = $this->destinationCurrency->id | ||||
| @@ -358,7 +358,7 @@ class UpgradesTransferCurrencies extends Command | ||||
|      */ | ||||
|     private function fixDestinationUnmatchedCurrency(): void | ||||
|     { | ||||
|         if (null !== $this->destinationCurrency | ||||
|         if ($this->destinationCurrency instanceof TransactionCurrency | ||||
|             && null === $this->destinationTransaction->foreign_amount | ||||
|             && (int) $this->destinationTransaction->transaction_currency_id !== $this->destinationCurrency->id | ||||
|         ) { | ||||
|   | ||||
| @@ -120,7 +120,7 @@ class UpgradesVariousCurrencyInformation extends Command | ||||
| 
 | ||||
|         $leadTransaction = $this->getLeadTransaction($journal); | ||||
| 
 | ||||
|         if (null === $leadTransaction) { | ||||
|         if (!$leadTransaction instanceof Transaction) { | ||||
|             $this->friendlyError(sprintf('Could not reliably determine which transaction is in the lead for transaction journal #%d.', $journal->id)); | ||||
| 
 | ||||
|             return; | ||||
| @@ -129,7 +129,7 @@ class UpgradesVariousCurrencyInformation extends Command | ||||
|         $account         = $leadTransaction->account; | ||||
|         $currency        = $this->getCurrency($account); | ||||
|         $isMultiCurrency = $this->isMultiCurrency($account); | ||||
|         if (null === $currency) { | ||||
|         if (!$currency instanceof TransactionCurrency) { | ||||
|             $this->friendlyError( | ||||
|                 sprintf( | ||||
|                     'Account #%d ("%s") has no currency preference, so transaction journal #%d can\'t be corrected', | ||||
| @@ -227,7 +227,7 @@ class UpgradesVariousCurrencyInformation extends Command | ||||
|             return $this->accountCurrencies[$accountId]; | ||||
|         } | ||||
|         $currency                            = $this->accountRepos->getAccountCurrency($account); | ||||
|         if (null === $currency) { | ||||
|         if (!$currency instanceof TransactionCurrency) { | ||||
|             $this->accountCurrencies[$accountId] = 0; | ||||
| 
 | ||||
|             return null; | ||||
|   | ||||
| @@ -26,6 +26,7 @@ namespace FireflyIII\Console; | ||||
| 
 | ||||
| use Illuminate\Console\Scheduling\Schedule; | ||||
| use Illuminate\Foundation\Console\Kernel as ConsoleKernel; | ||||
| use Override; | ||||
| 
 | ||||
| /** | ||||
|  * File to make sure commands work. | ||||
| @@ -35,7 +36,7 @@ class Kernel extends ConsoleKernel | ||||
|     /** | ||||
|      * Register the commands for the application. | ||||
|      */ | ||||
|     #[\Override]
 | ||||
|     #[Override]
 | ||||
|     protected function commands(): void | ||||
|     { | ||||
|         $this->load(__DIR__.'/Commands'); | ||||
| @@ -46,7 +47,7 @@ class Kernel extends ConsoleKernel | ||||
|     /** | ||||
|      * Define the application's command schedule. | ||||
|      */ | ||||
|     #[\Override]
 | ||||
|     #[Override]
 | ||||
|     protected function schedule(Schedule $schedule): void | ||||
|     { | ||||
|         $schedule->call( | ||||
|   | ||||
| @@ -24,7 +24,9 @@ declare(strict_types=1); | ||||
| 
 | ||||
| namespace FireflyIII\Exceptions; | ||||
| 
 | ||||
| class BadHttpHeaderException extends \Exception | ||||
| use Exception; | ||||
| 
 | ||||
| class BadHttpHeaderException extends Exception | ||||
| { | ||||
|     public int $statusCode = 406; | ||||
| } | ||||
|   | ||||
| @@ -24,7 +24,9 @@ declare(strict_types=1); | ||||
| 
 | ||||
| namespace FireflyIII\Exceptions; | ||||
| 
 | ||||
| use Exception; | ||||
| 
 | ||||
| /** | ||||
|  * Class DuplicateTransactionException | ||||
|  */ | ||||
| class DuplicateTransactionException extends \Exception {} | ||||
| class DuplicateTransactionException extends Exception {} | ||||
|   | ||||
| @@ -24,7 +24,9 @@ declare(strict_types=1); | ||||
| 
 | ||||
| namespace FireflyIII\Exceptions; | ||||
| 
 | ||||
| use Exception; | ||||
| 
 | ||||
| /** | ||||
|  * Class FireflyException. | ||||
|  */ | ||||
| class FireflyException extends \Exception {} | ||||
| class FireflyException extends Exception {} | ||||
|   | ||||
| @@ -34,6 +34,8 @@ use FireflyIII\User; | ||||
| use Illuminate\Foundation\Exceptions\Handler as ExceptionHandler; | ||||
| use Illuminate\Http\Request; | ||||
| use Symfony\Component\HttpFoundation\Response; | ||||
| use Override; | ||||
| use Throwable; | ||||
| 
 | ||||
| /** | ||||
|  * Class GracefulNotFoundHandler | ||||
| @@ -45,12 +47,12 @@ class GracefulNotFoundHandler extends ExceptionHandler | ||||
|      * | ||||
|      * @param Request $request | ||||
|      * | ||||
|      * @throws \Throwable | ||||
|      * @throws Throwable | ||||
|      * | ||||
|      * @SuppressWarnings("PHPMD.CyclomaticComplexity") | ||||
|      */ | ||||
|     #[\Override]
 | ||||
|     public function render($request, \Throwable $e): Response | ||||
|     #[Override]
 | ||||
|     public function render($request, Throwable $e): Response | ||||
|     { | ||||
|         $route = $request->route(); | ||||
|         if (null === $route) { | ||||
| @@ -149,9 +151,9 @@ class GracefulNotFoundHandler extends ExceptionHandler | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * @throws \Throwable | ||||
|      * @throws Throwable | ||||
|      */ | ||||
|     private function handleAccount(Request $request, \Throwable $exception): Response | ||||
|     private function handleAccount(Request $request, Throwable $exception): Response | ||||
|     { | ||||
|         app('log')->debug('404 page is probably a deleted account. Redirect to overview of account types.'); | ||||
| 
 | ||||
| @@ -184,9 +186,9 @@ class GracefulNotFoundHandler extends ExceptionHandler | ||||
|     /** | ||||
|      * @return Response | ||||
|      * | ||||
|      * @throws \Throwable | ||||
|      * @throws Throwable | ||||
|      */ | ||||
|     private function handleGroup(Request $request, \Throwable $exception) | ||||
|     private function handleGroup(Request $request, Throwable $exception) | ||||
|     { | ||||
|         app('log')->debug('404 page is probably a deleted group. Redirect to overview of group types.'); | ||||
| 
 | ||||
| @@ -224,9 +226,9 @@ class GracefulNotFoundHandler extends ExceptionHandler | ||||
|     /** | ||||
|      * @return Response | ||||
|      * | ||||
|      * @throws \Throwable | ||||
|      * @throws Throwable | ||||
|      */ | ||||
|     private function handleAttachment(Request $request, \Throwable $exception) | ||||
|     private function handleAttachment(Request $request, Throwable $exception) | ||||
|     { | ||||
|         app('log')->debug('404 page is probably a deleted attachment. Redirect to parent object.'); | ||||
| 
 | ||||
|   | ||||
| @@ -24,6 +24,7 @@ declare(strict_types=1); | ||||
| 
 | ||||
| namespace FireflyIII\Exceptions; | ||||
| 
 | ||||
| use Carbon\Carbon; | ||||
| use Brick\Math\Exception\NumberFormatException; | ||||
| use FireflyIII\Jobs\MailError; | ||||
| use Illuminate\Auth\Access\AuthorizationException; | ||||
| @@ -44,6 +45,12 @@ use Symfony\Component\HttpKernel\Exception\BadRequestHttpException; | ||||
| use Symfony\Component\HttpKernel\Exception\HttpException; | ||||
| use Symfony\Component\HttpKernel\Exception\MethodNotAllowedHttpException; | ||||
| use Symfony\Component\HttpKernel\Exception\NotFoundHttpException; | ||||
| use ErrorException; | ||||
| use Override; | ||||
| use Throwable; | ||||
| 
 | ||||
| use function Safe\json_encode; | ||||
| use function Safe\parse_url; | ||||
| 
 | ||||
| // temp
 | ||||
| /** | ||||
| @@ -52,7 +59,7 @@ use Symfony\Component\HttpKernel\Exception\NotFoundHttpException; | ||||
| class Handler extends ExceptionHandler | ||||
| { | ||||
|     /** | ||||
|      * @var array<int, class-string<\Throwable>> | ||||
|      * @var array<int, class-string<Throwable>> | ||||
|      */ | ||||
|     protected $dontReport | ||||
|         = [ | ||||
| @@ -70,7 +77,7 @@ class Handler extends ExceptionHandler | ||||
|     /** | ||||
|      * Register the exception handling callbacks for the application. | ||||
|      */ | ||||
|     #[\Override]
 | ||||
|     #[Override]
 | ||||
|     public function register(): void {} | ||||
| 
 | ||||
|     /** | ||||
| @@ -79,13 +86,13 @@ class Handler extends ExceptionHandler | ||||
|      * | ||||
|      * @param Request $request | ||||
|      * | ||||
|      * @throws \Throwable | ||||
|      * @throws Throwable | ||||
|      * | ||||
|      * @SuppressWarnings("PHPMD.NPathComplexity") | ||||
|      * @SuppressWarnings("PHPMD.CyclomaticComplexity") | ||||
|      */ | ||||
|     #[\Override]
 | ||||
|     public function render($request, \Throwable $e): Response | ||||
|     #[Override]
 | ||||
|     public function render($request, Throwable $e): Response | ||||
|     { | ||||
|         $expectsJson = $request->expectsJson(); | ||||
| 
 | ||||
| @@ -188,7 +195,7 @@ class Handler extends ExceptionHandler | ||||
|             return response()->view('errors.DatabaseException', ['exception' => $e, 'debug' => $isDebug], 500); | ||||
|         } | ||||
| 
 | ||||
|         if ($e instanceof FireflyException || $e instanceof \ErrorException || $e instanceof OAuthServerException) { | ||||
|         if ($e instanceof FireflyException || $e instanceof ErrorException || $e instanceof OAuthServerException) { | ||||
|             app('log')->debug('Return Firefly III error view.'); | ||||
|             $isDebug = config('app.debug'); | ||||
| 
 | ||||
| @@ -203,10 +210,10 @@ class Handler extends ExceptionHandler | ||||
|     /** | ||||
|      * Report or log an exception. | ||||
|      * | ||||
|      * @throws \Throwable | ||||
|      * @throws Throwable | ||||
|      */ | ||||
|     #[\Override]
 | ||||
|     public function report(\Throwable $e): void | ||||
|     #[Override]
 | ||||
|     public function report(Throwable $e): void | ||||
|     { | ||||
|         $doMailError = (bool) config('firefly.send_error_message'); | ||||
|         if ($this->shouldntReportLocal($e) || !$doMailError) { | ||||
| @@ -228,7 +235,7 @@ class Handler extends ExceptionHandler | ||||
|         $data        = [ | ||||
|             'class'        => $e::class, | ||||
|             'errorMessage' => $e->getMessage(), | ||||
|             'time'         => date('r'), | ||||
|             'time'         => Carbon::now()->format('r'), | ||||
|             'stackTrace'   => $e->getTraceAsString(), | ||||
|             'file'         => $e->getFile(), | ||||
|             'line'         => $e->getLine(), | ||||
| @@ -239,7 +246,7 @@ class Handler extends ExceptionHandler | ||||
|             'json'         => request()->acceptsJson(), | ||||
|             'method'       => request()->method(), | ||||
|             'headers'      => $headers, | ||||
|             'post'         => 'POST' === request()->method() ? \Safe\json_encode(request()->all()) : '', | ||||
|             'post'         => 'POST' === request()->method() ? json_encode(request()->all()) : '', | ||||
|         ]; | ||||
| 
 | ||||
|         // create job that will mail.
 | ||||
| @@ -250,7 +257,7 @@ class Handler extends ExceptionHandler | ||||
|         parent::report($e); | ||||
|     } | ||||
| 
 | ||||
|     private function shouldntReportLocal(\Throwable $e): bool | ||||
|     private function shouldntReportLocal(Throwable $e): bool | ||||
|     { | ||||
|         return null !== Arr::first( | ||||
|             $this->dontReport, | ||||
| @@ -263,7 +270,7 @@ class Handler extends ExceptionHandler | ||||
|      * | ||||
|      * @param Request $request | ||||
|      */ | ||||
|     #[\Override]
 | ||||
|     #[Override]
 | ||||
|     protected function invalid($request, LaravelValidationException $exception): \Illuminate\Http\Response|JsonResponse|RedirectResponse | ||||
|     { | ||||
|         // protect against open redirect when submitting invalid forms.
 | ||||
| @@ -286,8 +293,8 @@ class Handler extends ExceptionHandler | ||||
|         } | ||||
|         $safe         = route('index'); | ||||
|         $previous     = $exception->redirectTo; | ||||
|         $previousHost = \Safe\parse_url($previous, PHP_URL_HOST); | ||||
|         $safeHost     = \Safe\parse_url($safe, PHP_URL_HOST); | ||||
|         $previousHost = parse_url($previous, PHP_URL_HOST); | ||||
|         $safeHost     = parse_url($safe, PHP_URL_HOST); | ||||
| 
 | ||||
|         return null !== $previousHost && $previousHost === $safeHost ? $previous : $safe; | ||||
|     } | ||||
|   | ||||
| @@ -25,11 +25,13 @@ declare(strict_types=1); | ||||
| namespace FireflyIII\Exceptions; | ||||
| 
 | ||||
| use FireflyIII\Support\Calendar\Periodicity; | ||||
| use Exception; | ||||
| use Throwable; | ||||
| 
 | ||||
| /** | ||||
|  * Class IntervalException | ||||
|  */ | ||||
| final class IntervalException extends \Exception | ||||
| final class IntervalException extends Exception | ||||
| { | ||||
|     public array       $availableIntervals; | ||||
|     public Periodicity $periodicity; | ||||
| @@ -37,7 +39,7 @@ final class IntervalException extends \Exception | ||||
|     /** @var mixed */ | ||||
|     protected $message = 'The periodicity %s is unknown. Choose one of available periodicity: %s'; | ||||
| 
 | ||||
|     public function __construct(string $message = '', int $code = 0, ?\Throwable $previous = null) | ||||
|     public function __construct(string $message = '', int $code = 0, ?Throwable $previous = null) | ||||
|     { | ||||
|         parent::__construct($message, $code, $previous); | ||||
|         $this->availableIntervals = []; | ||||
| @@ -48,7 +50,7 @@ final class IntervalException extends \Exception | ||||
|         Periodicity $periodicity, | ||||
|         array       $intervals, | ||||
|         int         $code = 0, | ||||
|         ?\Throwable $previous = null | ||||
|         ?Throwable $previous = null | ||||
|     ): self { | ||||
|         $message                       = sprintf( | ||||
|             'The periodicity %s is unknown. Choose one of available periodicity: %s', | ||||
|   | ||||
| @@ -24,7 +24,9 @@ declare(strict_types=1); | ||||
| 
 | ||||
| namespace FireflyIII\Exceptions; | ||||
| 
 | ||||
| use Exception; | ||||
| 
 | ||||
| /** | ||||
|  * Class NotImplementedException. | ||||
|  */ | ||||
| class NotImplementedException extends \Exception {} | ||||
| class NotImplementedException extends Exception {} | ||||
|   | ||||
| @@ -24,7 +24,9 @@ declare(strict_types=1); | ||||
| 
 | ||||
| namespace FireflyIII\Exceptions; | ||||
| 
 | ||||
| use Exception; | ||||
| 
 | ||||
| /** | ||||
|  * Class ValidationExceptions. | ||||
|  */ | ||||
| class ValidationException extends \Exception {} | ||||
| class ValidationException extends Exception {} | ||||
|   | ||||
| @@ -75,7 +75,7 @@ class AccountFactory | ||||
|         app('log')->debug(sprintf('findOrCreate("%s", "%s")', $accountName, $accountType)); | ||||
| 
 | ||||
|         $type   = $this->accountRepository->getAccountTypeByType($accountType); | ||||
|         if (null === $type) { | ||||
|         if (!$type instanceof AccountType) { | ||||
|             throw new FireflyException(sprintf('Cannot find account type "%s"', $accountType)); | ||||
|         } | ||||
|         $return = $this->user->accounts->where('account_type_id', $type->id)->where('name', $accountName)->first(); | ||||
| @@ -111,7 +111,7 @@ class AccountFactory | ||||
|         // account may exist already:
 | ||||
|         $return       = $this->find($data['name'], $type->type); | ||||
| 
 | ||||
|         if (null !== $return) { | ||||
|         if ($return instanceof Account) { | ||||
|             return $return; | ||||
|         } | ||||
| 
 | ||||
|   | ||||
| @@ -24,6 +24,7 @@ declare(strict_types=1); | ||||
| 
 | ||||
| namespace FireflyIII\Factory; | ||||
| 
 | ||||
| use FireflyIII\Models\ObjectGroup; | ||||
| use FireflyIII\Exceptions\FireflyException; | ||||
| use FireflyIII\Models\Bill; | ||||
| use FireflyIII\Repositories\ObjectGroup\CreatesObjectGroups; | ||||
| @@ -93,7 +94,7 @@ class BillFactory | ||||
|         $objectGroupTitle = $data['object_group_title'] ?? ''; | ||||
|         if ('' !== $objectGroupTitle) { | ||||
|             $objectGroup = $this->findOrCreateObjectGroup($objectGroupTitle); | ||||
|             if (null !== $objectGroup) { | ||||
|             if ($objectGroup instanceof ObjectGroup) { | ||||
|                 $bill->objectGroups()->sync([$objectGroup->id]); | ||||
|                 $bill->save(); | ||||
|             } | ||||
| @@ -102,7 +103,7 @@ class BillFactory | ||||
|         $objectGroupId    = (int) ($data['object_group_id'] ?? 0); | ||||
|         if (0 !== $objectGroupId) { | ||||
|             $objectGroup = $this->findObjectGroupById($objectGroupId); | ||||
|             if (null !== $objectGroup) { | ||||
|             if ($objectGroup instanceof ObjectGroup) { | ||||
|                 $bill->objectGroups()->sync([$objectGroup->id]); | ||||
|                 $bill->save(); | ||||
|             } | ||||
| @@ -124,7 +125,7 @@ class BillFactory | ||||
| 
 | ||||
|         // then find by name:
 | ||||
|         if (null === $bill && '' !== $billName) { | ||||
|             $bill = $this->findByName($billName); | ||||
|             return $this->findByName($billName); | ||||
|         } | ||||
| 
 | ||||
|         return $bill; | ||||
|   | ||||
| @@ -53,7 +53,7 @@ class BudgetFactory | ||||
| 
 | ||||
|         if ('' !== $budgetName) { | ||||
|             $budget = $this->findByName($budgetName); | ||||
|             if (null !== $budget) { | ||||
|             if ($budget instanceof Budget) { | ||||
|                 return $budget; | ||||
|             } | ||||
|         } | ||||
|   | ||||
| @@ -59,7 +59,7 @@ class CategoryFactory | ||||
| 
 | ||||
|         if ('' !== $categoryName) { | ||||
|             $category = $this->findByName($categoryName); | ||||
|             if (null !== $category) { | ||||
|             if ($category instanceof Category) { | ||||
|                 return $category; | ||||
|             } | ||||
| 
 | ||||
|   | ||||
| @@ -37,7 +37,7 @@ class PiggyBankEventFactory | ||||
|     public function create(TransactionJournal $journal, ?PiggyBank $piggyBank): void | ||||
|     { | ||||
|         app('log')->debug(sprintf('Now in PiggyBankEventCreate for a %s', $journal->transactionType->type)); | ||||
|         if (null === $piggyBank) { | ||||
|         if (!$piggyBank instanceof PiggyBank) { | ||||
|             app('log')->debug('Piggy bank is null'); | ||||
| 
 | ||||
|             return; | ||||
|   | ||||
| @@ -23,6 +23,8 @@ declare(strict_types=1); | ||||
| 
 | ||||
| namespace FireflyIII\Factory; | ||||
| 
 | ||||
| use FireflyIII\Models\ObjectGroup; | ||||
| use FireflyIII\Models\Account; | ||||
| use FireflyIII\Events\Model\PiggyBank\ChangedAmount; | ||||
| use FireflyIII\Exceptions\FireflyException; | ||||
| use FireflyIII\Models\PiggyBank; | ||||
| @@ -35,6 +37,8 @@ use FireflyIII\User; | ||||
| use Illuminate\Database\QueryException; | ||||
| use Illuminate\Support\Facades\Log; | ||||
| 
 | ||||
| use function Safe\json_encode; | ||||
| 
 | ||||
| /** | ||||
|  * Class PiggyBankFactory | ||||
|  */ | ||||
| @@ -99,7 +103,7 @@ class PiggyBankFactory | ||||
|         $objectGroupTitle                         = $data['object_group_title'] ?? ''; | ||||
|         if ('' !== $objectGroupTitle) { | ||||
|             $objectGroup = $this->findOrCreateObjectGroup($objectGroupTitle); | ||||
|             if (null !== $objectGroup) { | ||||
|             if ($objectGroup instanceof ObjectGroup) { | ||||
|                 $piggyBank->objectGroups()->sync([$objectGroup->id]); | ||||
|             } | ||||
|         } | ||||
| @@ -107,7 +111,7 @@ class PiggyBankFactory | ||||
|         $objectGroupId                            = (int) ($data['object_group_id'] ?? 0); | ||||
|         if (0 !== $objectGroupId) { | ||||
|             $objectGroup = $this->findObjectGroupById($objectGroupId); | ||||
|             if (null !== $objectGroup) { | ||||
|             if ($objectGroup instanceof ObjectGroup) { | ||||
|                 $piggyBank->objectGroups()->sync([$objectGroup->id]); | ||||
|             } | ||||
|         } | ||||
| @@ -241,7 +245,7 @@ class PiggyBankFactory | ||||
|         /** @var array $info */ | ||||
|         foreach ($accounts as $info) { | ||||
|             $account = $this->accountRepository->find((int) ($info['account_id'] ?? 0)); | ||||
|             if (null === $account) { | ||||
|             if (!$account instanceof Account) { | ||||
|                 Log::debug(sprintf('Account #%d not found, skipping.', (int) ($info['account_id'] ?? 0))); | ||||
| 
 | ||||
|                 continue; | ||||
| @@ -284,7 +288,7 @@ class PiggyBankFactory | ||||
|                 Log::debug(sprintf('Will link account #%d with info: ', $account->id), $toBeLinked[$account->id]); | ||||
|             } | ||||
|         } | ||||
|         Log::debug(sprintf('Link information: %s', \Safe\json_encode($toBeLinked))); | ||||
|         Log::debug(sprintf('Link information: %s', json_encode($toBeLinked))); | ||||
|         if (0 !== count($toBeLinked)) { | ||||
|             $piggyBank->accounts()->sync($toBeLinked); | ||||
|         } | ||||
|   | ||||
| @@ -59,7 +59,7 @@ class TagFactory | ||||
|                 'zoom_level'  => null, | ||||
|             ] | ||||
|         ); | ||||
|         if (null === $newTag) { | ||||
|         if (!$newTag instanceof Tag) { | ||||
|             app('log')->error(sprintf('TagFactory::findOrCreate("%s") but tag is unexpectedly NULL!', $tag)); | ||||
| 
 | ||||
|             return null; | ||||
|   | ||||
| @@ -118,7 +118,7 @@ class TransactionFactory | ||||
|         ); | ||||
| 
 | ||||
|         // do foreign currency thing: add foreign currency info to $one and $two if necessary.
 | ||||
|         if (null !== $this->foreignCurrency | ||||
|         if ($this->foreignCurrency instanceof TransactionCurrency | ||||
|             && null !== $foreignAmount | ||||
|             && $this->foreignCurrency->id !== $this->currency->id) { | ||||
|             $result->foreign_currency_id = $this->foreignCurrency->id; | ||||
|   | ||||
| @@ -24,6 +24,8 @@ declare(strict_types=1); | ||||
| 
 | ||||
| namespace FireflyIII\Factory; | ||||
| 
 | ||||
| use FireflyIII\Models\Bill; | ||||
| use FireflyIII\Models\PiggyBank; | ||||
| use Carbon\Carbon; | ||||
| use FireflyIII\Enums\AccountTypeEnum; | ||||
| use FireflyIII\Enums\TransactionTypeEnum; | ||||
| @@ -51,6 +53,10 @@ use FireflyIII\User; | ||||
| use FireflyIII\Validation\AccountValidator; | ||||
| use Illuminate\Support\Collection; | ||||
| use Illuminate\Support\Facades\Log; | ||||
| use Exception; | ||||
| use JsonException; | ||||
| 
 | ||||
| use function Safe\json_encode; | ||||
| 
 | ||||
| /** | ||||
|  * Class TransactionJournalFactory | ||||
| @@ -76,7 +82,7 @@ class TransactionJournalFactory | ||||
|     /** | ||||
|      * Constructor. | ||||
|      * | ||||
|      * @throws \Exception | ||||
|      * @throws Exception | ||||
|      */ | ||||
|     public function __construct() | ||||
|     { | ||||
| @@ -120,10 +126,10 @@ class TransactionJournalFactory | ||||
|             foreach ($transactions as $index => $row) { | ||||
|                 Log::debug(sprintf('Now creating journal %d/%d', $index + 1, count($transactions))); | ||||
|                 $journal = $this->createJournal(new NullArrayObject($row)); | ||||
|                 if (null !== $journal) { | ||||
|                 if ($journal instanceof TransactionJournal) { | ||||
|                     $collection->push($journal); | ||||
|                 } | ||||
|                 if (null === $journal) { | ||||
|                 if (!$journal instanceof TransactionJournal) { | ||||
|                     Log::error('The createJournal() method returned NULL. This may indicate an error.'); | ||||
|                 } | ||||
|             } | ||||
| @@ -173,7 +179,7 @@ class TransactionJournalFactory | ||||
| 
 | ||||
|         $foreignCurrency       = $this->currencyRepository->findCurrencyNull($row['foreign_currency_id'], $row['foreign_currency_code']); | ||||
|         $bill                  = $this->billRepository->findBill((int) $row['bill_id'], $row['bill_name']); | ||||
|         $billId                = TransactionTypeEnum::WITHDRAWAL->value === $type->type && null !== $bill ? $bill->id : null; | ||||
|         $billId                = TransactionTypeEnum::WITHDRAWAL->value === $type->type && $bill instanceof Bill ? $bill->id : null; | ||||
|         $description           = (string) $row['description']; | ||||
| 
 | ||||
|         // Manipulate basic fields
 | ||||
| @@ -284,7 +290,7 @@ class TransactionJournalFactory | ||||
|         // see the currency they expect to see.
 | ||||
|         $amount                = (string) $row['amount']; | ||||
|         $foreignAmount         = (string) $row['foreign_amount']; | ||||
|         if (null !== $foreignCurrency && $foreignCurrency->id !== $currency->id | ||||
|         if ($foreignCurrency instanceof TransactionCurrency && $foreignCurrency->id !== $currency->id | ||||
|             && (TransactionTypeEnum::TRANSFER->value === $type->type || $this->isBetweenAssetAndLiability($sourceAccount, $destinationAccount)) | ||||
|         ) { | ||||
|             $transactionFactory->setCurrency($foreignCurrency); | ||||
| @@ -323,8 +329,8 @@ class TransactionJournalFactory | ||||
|         unset($dataRow['import_hash_v2'], $dataRow['original_source']); | ||||
| 
 | ||||
|         try { | ||||
|             $json = \Safe\json_encode($dataRow, JSON_THROW_ON_ERROR); | ||||
|         } catch (\JsonException $e) { | ||||
|             $json = json_encode($dataRow, JSON_THROW_ON_ERROR); | ||||
|         } catch (JsonException $e) { | ||||
|             Log::error(sprintf('Could not encode dataRow: %s', $e->getMessage())); | ||||
|             $json = microtime(); | ||||
|         } | ||||
| @@ -352,7 +358,7 @@ class TransactionJournalFactory | ||||
|             ->leftJoin('transaction_journals', 'transaction_journals.id', '=', 'journal_meta.transaction_journal_id') | ||||
|             ->whereNotNull('transaction_journals.id') | ||||
|             ->where('transaction_journals.user_id', $this->user->id) | ||||
|             ->where('data', \Safe\json_encode($hash, JSON_THROW_ON_ERROR)) | ||||
|             ->where('data', json_encode($hash, JSON_THROW_ON_ERROR)) | ||||
|             ->with(['transactionJournal', 'transactionJournal.transactionGroup']) | ||||
|             ->first(['journal_meta.*']) | ||||
|         ; | ||||
| @@ -425,12 +431,12 @@ class TransactionJournalFactory | ||||
|     private function reconciliationSanityCheck(?Account $sourceAccount, ?Account $destinationAccount): array | ||||
|     { | ||||
|         Log::debug(sprintf('Now in %s', __METHOD__)); | ||||
|         if (null !== $sourceAccount && null !== $destinationAccount) { | ||||
|         if ($sourceAccount instanceof Account && $destinationAccount instanceof Account) { | ||||
|             Log::debug('Both accounts exist, simply return them.'); | ||||
| 
 | ||||
|             return [$sourceAccount, $destinationAccount]; | ||||
|         } | ||||
|         if (null === $destinationAccount) { | ||||
|         if (!$destinationAccount instanceof Account) { | ||||
|             Log::debug('Destination account is NULL, source account is not.'); | ||||
|             $account = $this->accountRepository->getReconciliation($sourceAccount); | ||||
|             Log::debug(sprintf('Will return account #%d ("%s") of type "%s"', $account->id, $account->name, $account->accountType->type)); | ||||
| @@ -438,7 +444,7 @@ class TransactionJournalFactory | ||||
|             return [$sourceAccount, $account]; | ||||
|         } | ||||
| 
 | ||||
|         if (null === $sourceAccount) { // @phpstan-ignore-line
 | ||||
|         if (!$sourceAccount instanceof Account) { // @phpstan-ignore-line
 | ||||
|             Log::debug('Source account is NULL, destination account is not.'); | ||||
|             $account = $this->accountRepository->getReconciliation($destinationAccount); | ||||
|             Log::debug(sprintf('Will return account #%d ("%s") of type "%s"', $account->id, $account->name, $account->accountType->type)); | ||||
| @@ -480,7 +486,7 @@ class TransactionJournalFactory | ||||
| 
 | ||||
|         /** @var null|TransactionCurrency $preference */ | ||||
|         $preference = $this->accountRepository->getAccountCurrency($account); | ||||
|         if (null === $preference && null === $currency) { | ||||
|         if (null === $preference && !$currency instanceof TransactionCurrency) { | ||||
|             // return user's default:
 | ||||
|             return app('amount')->getNativeCurrencyByUserGroup($this->user->userGroup); | ||||
|         } | ||||
| @@ -496,10 +502,10 @@ class TransactionJournalFactory | ||||
|     private function compareCurrencies(?TransactionCurrency $currency, ?TransactionCurrency $foreignCurrency): ?TransactionCurrency | ||||
|     { | ||||
|         Log::debug(sprintf('Now in compareCurrencies("%s", "%s")', $currency?->code, $foreignCurrency?->code)); | ||||
|         if (null === $currency) { | ||||
|         if (!$currency instanceof TransactionCurrency) { | ||||
|             return null; | ||||
|         } | ||||
|         if (null !== $foreignCurrency && $foreignCurrency->id === $currency->id) { | ||||
|         if ($foreignCurrency instanceof TransactionCurrency && $foreignCurrency->id === $currency->id) { | ||||
|             return null; | ||||
|         } | ||||
| 
 | ||||
| @@ -556,7 +562,7 @@ class TransactionJournalFactory | ||||
| 
 | ||||
|         $piggyBank = $this->piggyRepository->findPiggyBank((int) $data['piggy_bank_id'], $data['piggy_bank_name']); | ||||
| 
 | ||||
|         if (null !== $piggyBank) { | ||||
|         if ($piggyBank instanceof PiggyBank) { | ||||
|             $this->piggyEventFactory->create($journal, $piggyBank); | ||||
|             Log::debug('Create piggy event.'); | ||||
| 
 | ||||
|   | ||||
| @@ -27,6 +27,7 @@ use Carbon\Carbon; | ||||
| use FireflyIII\Exceptions\FireflyException; | ||||
| use FireflyIII\Generator\Report\ReportGeneratorInterface; | ||||
| use Illuminate\Support\Collection; | ||||
| use Throwable; | ||||
| 
 | ||||
| /** | ||||
|  * Class MonthReportGenerator. | ||||
| @@ -56,7 +57,7 @@ class MonthReportGenerator implements ReportGeneratorInterface | ||||
|                 ->with('doubles', $this->expense) | ||||
|                 ->render() | ||||
|             ; | ||||
|         } catch (\Throwable $e) { | ||||
|         } catch (Throwable $e) { | ||||
|             app('log')->error(sprintf('Cannot render reports.double.report: %s', $e->getMessage())); | ||||
|             app('log')->error($e->getTraceAsString()); | ||||
|             $result = sprintf('Could not render report view: %s', $e->getMessage()); | ||||
|   | ||||
| @@ -23,6 +23,8 @@ declare(strict_types=1); | ||||
| 
 | ||||
| namespace FireflyIII\Generator\Report\Account; | ||||
| 
 | ||||
| use Override; | ||||
| 
 | ||||
| /** | ||||
|  * Class MultiYearReportGenerator. | ||||
|  */ | ||||
| @@ -31,7 +33,7 @@ class MultiYearReportGenerator extends MonthReportGenerator | ||||
|     /** | ||||
|      * Returns the preferred period. | ||||
|      */ | ||||
|     #[\Override]
 | ||||
|     #[Override]
 | ||||
|     protected function preferredPeriod(): string | ||||
|     { | ||||
|         return 'year'; | ||||
|   | ||||
| @@ -23,6 +23,8 @@ declare(strict_types=1); | ||||
| 
 | ||||
| namespace FireflyIII\Generator\Report\Account; | ||||
| 
 | ||||
| use Override; | ||||
| 
 | ||||
| /** | ||||
|  * Class YearReportGenerator. | ||||
|  */ | ||||
| @@ -31,7 +33,7 @@ class YearReportGenerator extends MonthReportGenerator | ||||
|     /** | ||||
|      * Returns the preferred period. | ||||
|      */ | ||||
|     #[\Override]
 | ||||
|     #[Override]
 | ||||
|     protected function preferredPeriod(): string | ||||
|     { | ||||
|         return 'month'; | ||||
|   | ||||
| @@ -34,6 +34,7 @@ use FireflyIII\Repositories\Journal\JournalRepositoryInterface; | ||||
| use FireflyIII\Support\Facades\Steam; | ||||
| use Illuminate\Support\Collection; | ||||
| use Illuminate\Support\Facades\Log; | ||||
| use Throwable; | ||||
| 
 | ||||
| /** | ||||
|  * Class MonthReportGenerator. | ||||
| @@ -103,7 +104,7 @@ class MonthReportGenerator implements ReportGeneratorInterface | ||||
|                 ->with('start', $this->start)->with('end', $this->end)->with('accounts', $this->accounts) | ||||
|                 ->render() | ||||
|             ; | ||||
|         } catch (\Throwable $e) { | ||||
|         } catch (Throwable $e) { | ||||
|             app('log')->error(sprintf('Cannot render reports.audit.report: %s', $e->getMessage())); | ||||
|             app('log')->error($e->getTraceAsString()); | ||||
|             $result = sprintf('Could not render report view: %s', $e->getMessage()); | ||||
|   | ||||
| @@ -29,6 +29,7 @@ use FireflyIII\Exceptions\FireflyException; | ||||
| use FireflyIII\Generator\Report\ReportGeneratorInterface; | ||||
| use FireflyIII\Helpers\Collector\GroupCollectorInterface; | ||||
| use Illuminate\Support\Collection; | ||||
| use Throwable; | ||||
| 
 | ||||
| /** | ||||
|  * Class MonthReportGenerator. | ||||
| @@ -70,7 +71,7 @@ class MonthReportGenerator implements ReportGeneratorInterface | ||||
|                 ->with('accounts', $this->accounts) | ||||
|                 ->render() | ||||
|             ; | ||||
|         } catch (\Throwable $e) { | ||||
|         } catch (Throwable $e) { | ||||
|             app('log')->error(sprintf('Cannot render reports.account.report: %s', $e->getMessage())); | ||||
|             app('log')->error($e->getTraceAsString()); | ||||
|             $result = sprintf('Could not render report view: %s', $e->getMessage()); | ||||
|   | ||||
| @@ -29,6 +29,7 @@ use FireflyIII\Exceptions\FireflyException; | ||||
| use FireflyIII\Generator\Report\ReportGeneratorInterface; | ||||
| use FireflyIII\Helpers\Collector\GroupCollectorInterface; | ||||
| use Illuminate\Support\Collection; | ||||
| use Throwable; | ||||
| 
 | ||||
| /** | ||||
|  * Class MonthReportGenerator. | ||||
| @@ -71,7 +72,7 @@ class MonthReportGenerator implements ReportGeneratorInterface | ||||
|                 ->with('accounts', $this->accounts) | ||||
|                 ->render() | ||||
|             ; | ||||
|         } catch (\Throwable $e) { | ||||
|         } catch (Throwable $e) { | ||||
|             app('log')->error(sprintf('Cannot render reports.category.month: %s', $e->getMessage())); | ||||
|             app('log')->error($e->getTraceAsString()); | ||||
|             $result = sprintf('Could not render report view: %s', $e->getMessage()); | ||||
|   | ||||
| @@ -27,6 +27,7 @@ use Carbon\Carbon; | ||||
| use FireflyIII\Exceptions\FireflyException; | ||||
| use FireflyIII\Generator\Report\ReportGeneratorInterface; | ||||
| use Illuminate\Support\Collection; | ||||
| use Throwable; | ||||
| 
 | ||||
| /** | ||||
|  * Class MonthReportGenerator. | ||||
| @@ -54,7 +55,7 @@ class MonthReportGenerator implements ReportGeneratorInterface | ||||
| 
 | ||||
|         try { | ||||
|             return view('reports.default.month', compact('accountIds', 'reportType'))->with('start', $this->start)->with('end', $this->end)->render(); | ||||
|         } catch (\Throwable $e) { | ||||
|         } catch (Throwable $e) { | ||||
|             app('log')->error(sprintf('Cannot render reports.default.month: %s', $e->getMessage())); | ||||
|             app('log')->error($e->getTraceAsString()); | ||||
|             $result = 'Could not render report view.'; | ||||
|   | ||||
| @@ -27,6 +27,7 @@ use Carbon\Carbon; | ||||
| use FireflyIII\Exceptions\FireflyException; | ||||
| use FireflyIII\Generator\Report\ReportGeneratorInterface; | ||||
| use Illuminate\Support\Collection; | ||||
| use Throwable; | ||||
| 
 | ||||
| /** | ||||
|  * Class MonthReportGenerator. | ||||
| @@ -58,7 +59,7 @@ class MultiYearReportGenerator implements ReportGeneratorInterface | ||||
|                 'reports.default.multi-year', | ||||
|                 compact('accountIds', 'reportType') | ||||
|             )->with('start', $this->start)->with('end', $this->end)->render(); | ||||
|         } catch (\Throwable $e) { | ||||
|         } catch (Throwable $e) { | ||||
|             app('log')->error(sprintf('Cannot render reports.default.multi-year: %s', $e->getMessage())); | ||||
|             app('log')->error($e->getTraceAsString()); | ||||
|             $result = sprintf('Could not render report view: %s', $e->getMessage()); | ||||
|   | ||||
| @@ -27,6 +27,7 @@ use Carbon\Carbon; | ||||
| use FireflyIII\Exceptions\FireflyException; | ||||
| use FireflyIII\Generator\Report\ReportGeneratorInterface; | ||||
| use Illuminate\Support\Collection; | ||||
| use Throwable; | ||||
| 
 | ||||
| /** | ||||
|  * Class MonthReportGenerator. | ||||
| @@ -58,7 +59,7 @@ class YearReportGenerator implements ReportGeneratorInterface | ||||
|                 'reports.default.year', | ||||
|                 compact('accountIds', 'reportType') | ||||
|             )->with('start', $this->start)->with('end', $this->end)->render(); | ||||
|         } catch (\Throwable $e) { | ||||
|         } catch (Throwable $e) { | ||||
|             app('log')->error(sprintf('Cannot render reports.account.report: %s', $e->getMessage())); | ||||
|             app('log')->error($e->getTraceAsString()); | ||||
|             $result = 'Could not render report view.'; | ||||
|   | ||||
| @@ -28,6 +28,7 @@ use Carbon\Carbon; | ||||
| use FireflyIII\Exceptions\FireflyException; | ||||
| use FireflyIII\Generator\Report\ReportGeneratorInterface; | ||||
| use Illuminate\Support\Collection; | ||||
| use Throwable; | ||||
| 
 | ||||
| /** | ||||
|  * Class MonthReportGenerator. | ||||
| @@ -65,7 +66,7 @@ class MonthReportGenerator implements ReportGeneratorInterface | ||||
|                 'reports.tag.month', | ||||
|                 compact('accountIds', 'reportType', 'tagIds') | ||||
|             )->with('start', $this->start)->with('end', $this->end)->with('tags', $this->tags)->with('accounts', $this->accounts)->render(); | ||||
|         } catch (\Throwable $e) { | ||||
|         } catch (Throwable $e) { | ||||
|             app('log')->error(sprintf('Cannot render reports.tag.month: %s', $e->getMessage())); | ||||
|             app('log')->error($e->getTraceAsString()); | ||||
|             $result = sprintf('Could not render report view: %s', $e->getMessage()); | ||||
|   | ||||
| @@ -28,6 +28,7 @@ use FireflyIII\Notifications\User\NewAccessToken; | ||||
| use FireflyIII\Repositories\User\UserRepositoryInterface; | ||||
| use Illuminate\Support\Facades\Notification; | ||||
| use Laravel\Passport\Events\AccessTokenCreated; | ||||
| use Exception; | ||||
| 
 | ||||
| /** | ||||
|  * Class APIEventHandler | ||||
| @@ -48,7 +49,7 @@ class APIEventHandler | ||||
|         if (null !== $user) { | ||||
|             try { | ||||
|                 Notification::send($user, new NewAccessToken()); | ||||
|             } catch (\Exception $e) { | ||||
|             } catch (Exception $e) { | ||||
|                 $message = $e->getMessage(); | ||||
|                 if (str_contains($message, 'Bcc')) { | ||||
|                     app('log')->warning('[Bcc] Could not send notification. Please validate your email settings, use the .env.example file as a guide.'); | ||||
|   | ||||
| @@ -37,6 +37,7 @@ use FireflyIII\Notifications\Test\OwnerTestNotificationPushover; | ||||
| use FireflyIII\Notifications\Test\OwnerTestNotificationSlack; | ||||
| use Illuminate\Support\Facades\Log; | ||||
| use Illuminate\Support\Facades\Notification; | ||||
| use Exception; | ||||
| 
 | ||||
| /** | ||||
|  * Class AdminEventHandler. | ||||
| @@ -52,7 +53,7 @@ class AdminEventHandler | ||||
| 
 | ||||
|         try { | ||||
|             Notification::send(new OwnerNotifiable(), new UserInvitation($event->invitee)); | ||||
|         } catch (\Exception $e) { | ||||
|         } catch (Exception $e) { | ||||
|             $message = $e->getMessage(); | ||||
|             if (str_contains($message, 'Bcc')) { | ||||
|                 app('log')->warning('[Bcc] Could not send notification. Please validate your email settings, use the .env.example file as a guide.'); | ||||
| @@ -74,7 +75,7 @@ class AdminEventHandler | ||||
|         try { | ||||
|             $owner = new OwnerNotifiable(); | ||||
|             Notification::send($owner, new UnknownUserLoginAttempt($event->address)); | ||||
|         } catch (\Exception $e) { | ||||
|         } catch (Exception $e) { | ||||
|             $message = $e->getMessage(); | ||||
|             if (str_contains($message, 'Bcc')) { | ||||
|                 app('log')->warning('[Bcc] Could not send notification. Please validate your email settings, use the .env.example file as a guide.'); | ||||
| @@ -104,7 +105,7 @@ class AdminEventHandler | ||||
|         try { | ||||
|             $owner = new OwnerNotifiable(); | ||||
|             Notification::send($owner, new VersionCheckResult($event->message)); | ||||
|         } catch (\Exception $e) { | ||||
|         } catch (Exception $e) { | ||||
|             $message = $e->getMessage(); | ||||
|             if (str_contains($message, 'Bcc')) { | ||||
|                 app('log')->warning('[Bcc] Could not send notification. Please validate your email settings, use the .env.example file as a guide.'); | ||||
| @@ -158,7 +159,7 @@ class AdminEventHandler | ||||
| 
 | ||||
|         try { | ||||
|             Notification::send($event->owner, new $class()); | ||||
|         } catch (\Exception $e) { | ||||
|         } catch (Exception $e) { | ||||
|             $message = $e->getMessage(); | ||||
|             if (str_contains($message, 'Bcc')) { | ||||
|                 app('log')->warning('[Bcc] Could not send notification. Please validate your email settings, use the .env.example file as a guide.'); | ||||
|   | ||||
| @@ -31,6 +31,7 @@ use FireflyIII\Notifications\User\TransactionCreation; | ||||
| use FireflyIII\Repositories\User\UserRepositoryInterface; | ||||
| use FireflyIII\Transformers\TransactionGroupTransformer; | ||||
| use Illuminate\Support\Facades\Notification; | ||||
| use Exception; | ||||
| 
 | ||||
| /** | ||||
|  * Class AutomationHandler | ||||
| @@ -78,7 +79,7 @@ class AutomationHandler | ||||
| 
 | ||||
|         try { | ||||
|             Notification::send($user, new TransactionCreation($groups)); | ||||
|         } catch (\Exception $e) { | ||||
|         } catch (Exception $e) { | ||||
|             $message = $e->getMessage(); | ||||
|             if (str_contains($message, 'Bcc')) { | ||||
|                 app('log')->warning('[Bcc] Could not send notification. Please validate your email settings, use the .env.example file as a guide.'); | ||||
|   | ||||
| @@ -27,6 +27,7 @@ namespace FireflyIII\Handlers\Events; | ||||
| use FireflyIII\Events\WarnUserAboutBill; | ||||
| use FireflyIII\Notifications\User\BillReminder; | ||||
| use Illuminate\Support\Facades\Notification; | ||||
| use Exception; | ||||
| 
 | ||||
| /** | ||||
|  * Class BillEventHandler | ||||
| @@ -47,7 +48,7 @@ class BillEventHandler | ||||
| 
 | ||||
|             try { | ||||
|                 Notification::send($bill->user, new BillReminder($bill, $event->field, $event->diff)); | ||||
|             } catch (\Exception $e) { | ||||
|             } catch (Exception $e) { | ||||
|                 $message = $e->getMessage(); | ||||
|                 if (str_contains($message, 'Bcc')) { | ||||
|                     app('log')->warning('[Bcc] Could not send notification. Please validate your email settings, use the .env.example file as a guide.'); | ||||
|   | ||||
| @@ -204,7 +204,7 @@ class BudgetLimitHandler | ||||
|             if (!$limitPeriod->equals($abPeriod) && !$abPeriod->contains($limitPeriod) && $abPeriod->overlapsWith($limitPeriod)) { | ||||
|                 Log::debug('This budget limit is something else entirely!'); | ||||
|                 $overlap = $abPeriod->overlap($limitPeriod); | ||||
|                 if (null !== $overlap) { | ||||
|                 if ($overlap instanceof Period) { | ||||
|                     $length    = $overlap->length(); | ||||
|                     $daily     = bcmul($this->getDailyAmount($budgetLimit), (string) $length); | ||||
|                     $newAmount = bcadd($newAmount, $daily); | ||||
|   | ||||
| @@ -24,6 +24,7 @@ declare(strict_types=1); | ||||
| 
 | ||||
| namespace FireflyIII\Handlers\Events\Model; | ||||
| 
 | ||||
| use FireflyIII\Models\TransactionGroup; | ||||
| use FireflyIII\Events\Model\PiggyBank\ChangedAmount; | ||||
| use FireflyIII\Models\PiggyBankEvent; | ||||
| 
 | ||||
| @@ -36,7 +37,7 @@ class PiggyBankEventHandler | ||||
|     { | ||||
|         // find journal if group is present.
 | ||||
|         $journal = $event->transactionJournal; | ||||
|         if (null !== $event->transactionGroup) { | ||||
|         if ($event->transactionGroup instanceof TransactionGroup) { | ||||
|             $journal = $event->transactionGroup->transactionJournals()->first(); | ||||
|         } | ||||
|         $date    = $journal->date ?? today(config('app.timezone')); | ||||
|   | ||||
| @@ -108,13 +108,12 @@ class PreferencesEventHandler | ||||
|         /** @var Budget $budget */ | ||||
|         foreach ($set as $budget) { | ||||
|             foreach ($budget->autoBudgets as $autoBudget) { | ||||
|                 if (null !== $autoBudget->native_amount) { | ||||
|                     if (null !== $autoBudget->native_amount) { | ||||
|                         Log::debug(sprintf('Resetting native_amount for budget #%d and auto budget #%d.', $budget->id, $autoBudget->id)); | ||||
|                         $autoBudget->native_amount = null; | ||||
|                         $autoBudget->saveQuietly(); | ||||
|                     } | ||||
|                 if (null === $autoBudget->native_amount) { | ||||
|                     continue; | ||||
|                 } | ||||
|                 Log::debug(sprintf('Resetting native_amount for budget #%d and auto budget #%d.', $budget->id, $autoBudget->id)); | ||||
|                 $autoBudget->native_amount = null; | ||||
|                 $autoBudget->saveQuietly(); | ||||
|             } | ||||
|             foreach ($budget->budgetlimits as $limit) { | ||||
|                 if (null !== $limit->native_amount) { | ||||
|   | ||||
| @@ -39,6 +39,7 @@ use FireflyIII\Notifications\Security\MFAManyFailedAttemptsNotification; | ||||
| use FireflyIII\Notifications\Security\MFAUsedBackupCodeNotification; | ||||
| use FireflyIII\Notifications\Security\NewBackupCodesNotification; | ||||
| use Illuminate\Support\Facades\Notification; | ||||
| use Exception; | ||||
| 
 | ||||
| class MFAHandler | ||||
| { | ||||
| @@ -51,7 +52,7 @@ class MFAHandler | ||||
| 
 | ||||
|         try { | ||||
|             Notification::send($user, new MFABackupFewLeftNotification($user, $count)); | ||||
|         } catch (\Exception $e) { | ||||
|         } catch (Exception $e) { | ||||
|             $message = $e->getMessage(); | ||||
|             if (str_contains($message, 'Bcc')) { | ||||
|                 app('log')->warning('[Bcc] Could not send notification. Please validate your email settings, use the .env.example file as a guide.'); | ||||
| @@ -76,7 +77,7 @@ class MFAHandler | ||||
| 
 | ||||
|         try { | ||||
|             Notification::send($user, new MFABackupNoLeftNotification($user)); | ||||
|         } catch (\Exception $e) { | ||||
|         } catch (Exception $e) { | ||||
|             $message = $e->getMessage(); | ||||
|             if (str_contains($message, 'Bcc')) { | ||||
|                 app('log')->warning('[Bcc] Could not send notification. Please validate your email settings, use the .env.example file as a guide.'); | ||||
| @@ -101,7 +102,7 @@ class MFAHandler | ||||
| 
 | ||||
|         try { | ||||
|             Notification::send($user, new DisabledMFANotification($user)); | ||||
|         } catch (\Exception $e) { | ||||
|         } catch (Exception $e) { | ||||
|             $message = $e->getMessage(); | ||||
|             if (str_contains($message, 'Bcc')) { | ||||
|                 app('log')->warning('[Bcc] Could not send notification. Please validate your email settings, use the .env.example file as a guide.'); | ||||
| @@ -126,7 +127,7 @@ class MFAHandler | ||||
| 
 | ||||
|         try { | ||||
|             Notification::send($user, new EnabledMFANotification($user)); | ||||
|         } catch (\Exception $e) { | ||||
|         } catch (Exception $e) { | ||||
|             $message = $e->getMessage(); | ||||
|             if (str_contains($message, 'Bcc')) { | ||||
|                 app('log')->warning('[Bcc] Could not send notification. Please validate your email settings, use the .env.example file as a guide.'); | ||||
| @@ -152,7 +153,7 @@ class MFAHandler | ||||
| 
 | ||||
|         try { | ||||
|             Notification::send($user, new MFAManyFailedAttemptsNotification($user, $count)); | ||||
|         } catch (\Exception $e) { | ||||
|         } catch (Exception $e) { | ||||
|             $message = $e->getMessage(); | ||||
|             if (str_contains($message, 'Bcc')) { | ||||
|                 app('log')->warning('[Bcc] Could not send notification. Please validate your email settings, use the .env.example file as a guide.'); | ||||
| @@ -177,7 +178,7 @@ class MFAHandler | ||||
| 
 | ||||
|         try { | ||||
|             Notification::send($user, new NewBackupCodesNotification($user)); | ||||
|         } catch (\Exception $e) { | ||||
|         } catch (Exception $e) { | ||||
|             $message = $e->getMessage(); | ||||
|             if (str_contains($message, 'Bcc')) { | ||||
|                 app('log')->warning('[Bcc] Could not send notification. Please validate your email settings, use the .env.example file as a guide.'); | ||||
| @@ -202,7 +203,7 @@ class MFAHandler | ||||
| 
 | ||||
|         try { | ||||
|             Notification::send($user, new MFAUsedBackupCodeNotification($user)); | ||||
|         } catch (\Exception $e) { | ||||
|         } catch (Exception $e) { | ||||
|             $message = $e->getMessage(); | ||||
|             if (str_contains($message, 'Bcc')) { | ||||
|                 app('log')->warning('[Bcc] Could not send notification. Please validate your email settings, use the .env.example file as a guide.'); | ||||
|   | ||||
| @@ -56,6 +56,7 @@ use Illuminate\Auth\Events\Login; | ||||
| use Illuminate\Support\Facades\Log; | ||||
| use Illuminate\Support\Facades\Mail; | ||||
| use Illuminate\Support\Facades\Notification; | ||||
| use Exception; | ||||
| 
 | ||||
| /** | ||||
|  * Class UserEventHandler. | ||||
| @@ -203,7 +204,7 @@ class UserEventHandler | ||||
|             if (false === $entry['notified']) { | ||||
|                 try { | ||||
|                     Notification::send($user, new UserLogin()); | ||||
|                 } catch (\Exception $e) { | ||||
|                 } catch (Exception $e) { | ||||
|                     $message = $e->getMessage(); | ||||
|                     if (str_contains($message, 'Bcc')) { | ||||
|                         app('log')->warning('[Bcc] Could not send notification. Please validate your email settings, use the .env.example file as a guide.'); | ||||
| @@ -233,7 +234,7 @@ class UserEventHandler | ||||
| 
 | ||||
|             try { | ||||
|                 Notification::send($owner, new AdminRegistrationNotification($event->user)); | ||||
|             } catch (\Exception $e) { | ||||
|             } catch (Exception $e) { | ||||
|                 $message = $e->getMessage(); | ||||
|                 if (str_contains($message, 'Bcc')) { | ||||
|                     app('log')->warning('[Bcc] Could not send notification. Please validate your email settings, use the .env.example file as a guide.'); | ||||
| @@ -267,7 +268,7 @@ class UserEventHandler | ||||
| 
 | ||||
|         try { | ||||
|             Mail::to($newEmail)->send(new ConfirmEmailChangeMail($newEmail, $oldEmail, $url)); | ||||
|         } catch (\Exception $e) { | ||||
|         } catch (Exception $e) { | ||||
|             app('log')->error($e->getMessage()); | ||||
|             app('log')->error($e->getTraceAsString()); | ||||
| 
 | ||||
| @@ -292,7 +293,7 @@ class UserEventHandler | ||||
| 
 | ||||
|         try { | ||||
|             Mail::to($oldEmail)->send(new UndoEmailChangeMail($newEmail, $oldEmail, $url)); | ||||
|         } catch (\Exception $e) { | ||||
|         } catch (Exception $e) { | ||||
|             app('log')->error($e->getMessage()); | ||||
|             app('log')->error($e->getTraceAsString()); | ||||
| 
 | ||||
| @@ -304,7 +305,7 @@ class UserEventHandler | ||||
|     { | ||||
|         try { | ||||
|             Notification::send($event->user, new UserFailedLoginAttempt($event->user)); | ||||
|         } catch (\Exception $e) { | ||||
|         } catch (Exception $e) { | ||||
|             $message = $e->getMessage(); | ||||
|             if (str_contains($message, 'Bcc')) { | ||||
|                 app('log')->warning('[Bcc] Could not send notification. Please validate your email settings, use the .env.example file as a guide.'); | ||||
| @@ -328,7 +329,7 @@ class UserEventHandler | ||||
|     { | ||||
|         try { | ||||
|             Notification::send($event->user, new UserNewPassword(route('password.reset', [$event->token]))); | ||||
|         } catch (\Exception $e) { | ||||
|         } catch (Exception $e) { | ||||
|             $message = $e->getMessage(); | ||||
|             if (str_contains($message, 'Bcc')) { | ||||
|                 app('log')->warning('[Bcc] Could not send notification. Please validate your email settings, use the .env.example file as a guide.'); | ||||
| @@ -356,7 +357,7 @@ class UserEventHandler | ||||
| 
 | ||||
|         try { | ||||
|             Mail::to($invitee)->send(new InvitationMail($invitee, $admin, $url)); | ||||
|         } catch (\Exception $e) { | ||||
|         } catch (Exception $e) { | ||||
|             app('log')->error($e->getMessage()); | ||||
|             app('log')->error($e->getTraceAsString()); | ||||
| 
 | ||||
| @@ -374,7 +375,7 @@ class UserEventHandler | ||||
|         if ($sendMail) { | ||||
|             try { | ||||
|                 Notification::send($event->user, new UserRegistrationNotification()); | ||||
|             } catch (\Exception $e) { | ||||
|             } catch (Exception $e) { | ||||
|                 $message = $e->getMessage(); | ||||
|                 if (str_contains($message, 'Bcc')) { | ||||
|                     app('log')->warning('[Bcc] Could not send notification. Please validate your email settings, use the .env.example file as a guide.'); | ||||
| @@ -429,7 +430,7 @@ class UserEventHandler | ||||
| 
 | ||||
|         try { | ||||
|             Notification::send($event->user, new $class()); | ||||
|         } catch (\Exception $e) { | ||||
|         } catch (Exception $e) { | ||||
|             $message = $e->getMessage(); | ||||
|             if (str_contains($message, 'Bcc')) { | ||||
|                 app('log')->warning('[Bcc] Could not send notification. Please validate your email settings, use the .env.example file as a guide.'); | ||||
| @@ -483,7 +484,7 @@ class UserEventHandler | ||||
|             } | ||||
|             // clean up old entries (6 months)
 | ||||
|             $carbon = Carbon::createFromFormat('Y-m-d H:i:s', $preference[$index]['time']); | ||||
|             if (null !== $carbon && $carbon->diffInMonths(today(), true) > 6) { | ||||
|             if ($carbon instanceof Carbon && $carbon->diffInMonths(today(), true) > 6) { | ||||
|                 app('log')->debug(sprintf('Entry for %s is very old, remove it.', $row['ip'])); | ||||
|                 unset($preference[$index]); | ||||
|             } | ||||
|   | ||||
| @@ -23,6 +23,7 @@ declare(strict_types=1); | ||||
| 
 | ||||
| namespace FireflyIII\Handlers\Events; | ||||
| 
 | ||||
| use Carbon\Carbon; | ||||
| use FireflyIII\Events\RequestedVersionCheckStatus; | ||||
| use FireflyIII\Exceptions\FireflyException; | ||||
| use FireflyIII\Helpers\Update\UpdateTrait; | ||||
| @@ -68,12 +69,12 @@ class VersionCheckEventHandler | ||||
|         } | ||||
| 
 | ||||
|         /** @var Configuration $lastCheckTime */ | ||||
|         $lastCheckTime = app('fireflyconfig')->get('last_update_check', time()); | ||||
|         $now           = time(); | ||||
|         $lastCheckTime = app('fireflyconfig')->get('last_update_check', Carbon::now()->getTimestamp()); | ||||
|         $now           = Carbon::now()->getTimestamp(); | ||||
|         $diff          = $now - $lastCheckTime->data; | ||||
|         Log::debug(sprintf('Last check time is %d, current time is %d, difference is %d', $lastCheckTime->data, $now, $diff)); | ||||
|         if ($diff < 604800) { | ||||
|             Log::debug(sprintf('Checked for updates less than a week ago (on %s).', date('Y-m-d H:i:s', $lastCheckTime->data))); | ||||
|             Log::debug(sprintf('Checked for updates less than a week ago (on %s).', Carbon::createFromTimestamp($lastCheckTime->data)->format('Y-m-d H:i:s'))); | ||||
| 
 | ||||
|             return; | ||||
|         } | ||||
| @@ -82,7 +83,7 @@ class VersionCheckEventHandler | ||||
|         $release       = $this->getLatestRelease(); | ||||
| 
 | ||||
|         session()->flash($release['level'], $release['message']); | ||||
|         app('fireflyconfig')->set('last_update_check', time()); | ||||
|         app('fireflyconfig')->set('last_update_check', Carbon::now()->getTimestamp()); | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
| @@ -100,12 +101,12 @@ class VersionCheckEventHandler | ||||
|         } | ||||
| 
 | ||||
|         /** @var Configuration $lastCheckTime */ | ||||
|         $lastCheckTime = app('fireflyconfig')->get('last_update_warning', time()); | ||||
|         $now           = time(); | ||||
|         $lastCheckTime = app('fireflyconfig')->get('last_update_warning', Carbon::now()->getTimestamp()); | ||||
|         $now           = Carbon::now()->getTimestamp(); | ||||
|         $diff          = $now - $lastCheckTime->data; | ||||
|         Log::debug(sprintf('Last warning time is %d, current time is %d, difference is %d', $lastCheckTime->data, $now, $diff)); | ||||
|         if ($diff < 604800 * 4) { | ||||
|             Log::debug(sprintf('Warned about updates less than four weeks ago (on %s).', date('Y-m-d H:i:s', $lastCheckTime->data))); | ||||
|             Log::debug(sprintf('Warned about updates less than four weeks ago (on %s).', Carbon::createFromTimestamp($lastCheckTime->data)->format('Y-m-d H:i:s'))); | ||||
| 
 | ||||
|             return; | ||||
|         } | ||||
| @@ -113,6 +114,6 @@ class VersionCheckEventHandler | ||||
|         Log::debug('Have warned about a new version in four weeks!'); | ||||
| 
 | ||||
|         session()->flash('info', (string) trans('firefly.disabled_but_check')); | ||||
|         app('fireflyconfig')->set('last_update_warning', time()); | ||||
|         app('fireflyconfig')->set('last_update_warning', Carbon::now()->getTimestamp()); | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -37,6 +37,14 @@ use Illuminate\Support\Facades\Storage; | ||||
| use Illuminate\Support\MessageBag; | ||||
| use Symfony\Component\HttpFoundation\File\UploadedFile; | ||||
| 
 | ||||
| use function Safe\tmpfile; | ||||
| use function Safe\fwrite; | ||||
| use function Safe\finfo_open; | ||||
| use function Safe\fclose; | ||||
| use function Safe\md5_file; | ||||
| 
 | ||||
| use const DIRECTORY_SEPARATOR; | ||||
| 
 | ||||
| /** | ||||
|  * Class AttachmentHelper. | ||||
|  */ | ||||
| @@ -85,7 +93,7 @@ class AttachmentHelper implements AttachmentHelperInterface | ||||
|      */ | ||||
|     public function getAttachmentLocation(Attachment $attachment): string | ||||
|     { | ||||
|         return sprintf('%sat-%d.data', \DIRECTORY_SEPARATOR, $attachment->id); | ||||
|         return sprintf('%sat-%d.data', DIRECTORY_SEPARATOR, $attachment->id); | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
| @@ -118,7 +126,7 @@ class AttachmentHelper implements AttachmentHelperInterface | ||||
|     public function saveAttachmentFromApi(Attachment $attachment, string $content): bool | ||||
|     { | ||||
|         Log::debug(sprintf('Now in %s', __METHOD__)); | ||||
|         $resource             = \Safe\tmpfile(); | ||||
|         $resource             = tmpfile(); | ||||
|         if (false === $resource) { | ||||
|             Log::error('Cannot create temp-file for file upload.'); | ||||
| 
 | ||||
| @@ -133,17 +141,17 @@ class AttachmentHelper implements AttachmentHelperInterface | ||||
| 
 | ||||
|         $path                 = stream_get_meta_data($resource)['uri']; | ||||
|         Log::debug(sprintf('Path is %s', $path)); | ||||
|         $result               = \Safe\fwrite($resource, $content); | ||||
|         $result               = fwrite($resource, $content); | ||||
|         if (false === $result) { | ||||
|             Log::error('Could not write temp file.'); | ||||
| 
 | ||||
|             return false; | ||||
|         } | ||||
|         Log::debug(sprintf('Wrote %d bytes to temp file.', $result)); | ||||
|         $finfo                = \Safe\finfo_open(FILEINFO_MIME_TYPE); | ||||
|         $finfo                = finfo_open(FILEINFO_MIME_TYPE); | ||||
|         if (false === $finfo) { | ||||
|             Log::error('Could not open finfo.'); | ||||
|             \Safe\fclose($resource); | ||||
|             fclose($resource); | ||||
| 
 | ||||
|             return false; | ||||
|         } | ||||
| @@ -151,7 +159,7 @@ class AttachmentHelper implements AttachmentHelperInterface | ||||
|         $allowedMime          = config('firefly.allowedMimes'); | ||||
|         if (!in_array($mime, $allowedMime, true)) { | ||||
|             Log::error(sprintf('Mime type %s is not allowed for API file upload.', $mime)); | ||||
|             \Safe\fclose($resource); | ||||
|             fclose($resource); | ||||
| 
 | ||||
|             return false; | ||||
|         } | ||||
| @@ -163,7 +171,7 @@ class AttachmentHelper implements AttachmentHelperInterface | ||||
|         $this->uploadDisk->put($file, $content); | ||||
| 
 | ||||
|         // update attachment.
 | ||||
|         $attachment->md5      = (string) \Safe\md5_file($path); | ||||
|         $attachment->md5      = (string) md5_file($path); | ||||
|         $attachment->mime     = $mime; | ||||
|         $attachment->size     = strlen($content); | ||||
|         $attachment->uploaded = true; | ||||
| @@ -225,7 +233,7 @@ class AttachmentHelper implements AttachmentHelperInterface | ||||
|             $attachment           = new Attachment(); // create Attachment object.
 | ||||
|             $attachment->user()->associate($user); | ||||
|             $attachment->attachable()->associate($model); | ||||
|             $attachment->md5      = (string) \Safe\md5_file($file->getRealPath()); | ||||
|             $attachment->md5      = (string) md5_file($file->getRealPath()); | ||||
|             $attachment->filename = $file->getClientOriginalName(); | ||||
|             $attachment->mime     = $file->getMimeType(); | ||||
|             $attachment->size     = $file->getSize(); | ||||
| @@ -280,7 +288,7 @@ class AttachmentHelper implements AttachmentHelperInterface | ||||
|         } | ||||
| 
 | ||||
|         if (true === $result && $this->hasFile($file, $model)) { | ||||
|             $result = false; | ||||
|             return false; | ||||
|         } | ||||
| 
 | ||||
|         return $result; | ||||
| @@ -333,7 +341,7 @@ class AttachmentHelper implements AttachmentHelperInterface | ||||
|      */ | ||||
|     protected function hasFile(UploadedFile $file, Model $model): bool | ||||
|     { | ||||
|         $md5    = \Safe\md5_file($file->getRealPath()); | ||||
|         $md5    = md5_file($file->getRealPath()); | ||||
|         $name   = $file->getClientOriginalName(); | ||||
|         $class  = $model::class; | ||||
|         $count  = 0; | ||||
|   | ||||
| @@ -30,13 +30,14 @@ use FireflyIII\Support\Facades\Steam; | ||||
| use Illuminate\Database\Eloquent\Builder as EloquentBuilder; | ||||
| use Illuminate\Support\Collection; | ||||
| use Illuminate\Support\Facades\Log; | ||||
| use Override; | ||||
| 
 | ||||
| /** | ||||
|  * Trait AccountCollection | ||||
|  */ | ||||
| trait AccountCollection | ||||
| { | ||||
|     #[\Override]
 | ||||
|     #[Override]
 | ||||
|     public function accountBalanceIs(string $direction, string $operator, string $value): GroupCollectorInterface | ||||
|     { | ||||
|         Log::warning(sprintf('GroupCollector will be SLOW: accountBalanceIs: "%s" "%s" "%s"', $direction, $operator, $value)); | ||||
|   | ||||
| @@ -36,6 +36,8 @@ use Illuminate\Database\Query\JoinClause; | ||||
| use Illuminate\Support\Collection; | ||||
| use Illuminate\Support\Facades\Log; | ||||
| 
 | ||||
| use function Safe\json_encode; | ||||
| 
 | ||||
| /** | ||||
|  * Trait MetaCollection | ||||
|  */ | ||||
| @@ -167,7 +169,7 @@ trait MetaCollection | ||||
|     { | ||||
|         $this->joinMetaDataTables(); | ||||
|         $this->query->where('journal_meta.name', '=', 'external_id'); | ||||
|         $this->query->where('journal_meta.data', '!=', sprintf('%s', \Safe\json_encode($externalId))); | ||||
|         $this->query->where('journal_meta.data', '!=', sprintf('%s', json_encode($externalId))); | ||||
|         $this->query->whereNull('journal_meta.deleted_at'); | ||||
| 
 | ||||
|         return $this; | ||||
| @@ -190,14 +192,14 @@ trait MetaCollection | ||||
|     { | ||||
|         $this->joinMetaDataTables(); | ||||
|         $this->query->where('journal_meta.name', '=', 'external_url'); | ||||
|         $this->query->where('journal_meta.data', '!=', \Safe\json_encode($url)); | ||||
|         $this->query->where('journal_meta.data', '!=', json_encode($url)); | ||||
| 
 | ||||
|         return $this; | ||||
|     } | ||||
| 
 | ||||
|     public function excludeInternalReference(string $internalReference): GroupCollectorInterface | ||||
|     { | ||||
|         $internalReference = (string) \Safe\json_encode($internalReference); | ||||
|         $internalReference = (string) json_encode($internalReference); | ||||
|         $internalReference = str_replace('\\', '\\\\', trim($internalReference, '"')); | ||||
| 
 | ||||
|         $this->joinMetaDataTables(); | ||||
| @@ -211,14 +213,14 @@ trait MetaCollection | ||||
|     { | ||||
|         $this->joinMetaDataTables(); | ||||
|         $this->query->where('journal_meta.name', '=', 'recurrence_id'); | ||||
|         $this->query->where('journal_meta.data', '!=', sprintf('%s', \Safe\json_encode($recurringId))); | ||||
|         $this->query->where('journal_meta.data', '!=', sprintf('%s', json_encode($recurringId))); | ||||
| 
 | ||||
|         return $this; | ||||
|     } | ||||
| 
 | ||||
|     public function externalIdContains(string $externalId): GroupCollectorInterface | ||||
|     { | ||||
|         $externalId = (string) \Safe\json_encode($externalId); | ||||
|         $externalId = (string) json_encode($externalId); | ||||
|         $externalId = str_replace('\\', '\\\\', trim($externalId, '"')); | ||||
| 
 | ||||
|         $this->joinMetaDataTables(); | ||||
| @@ -230,7 +232,7 @@ trait MetaCollection | ||||
| 
 | ||||
|     public function externalIdDoesNotContain(string $externalId): GroupCollectorInterface | ||||
|     { | ||||
|         $externalId = (string) \Safe\json_encode($externalId); | ||||
|         $externalId = (string) json_encode($externalId); | ||||
|         $externalId = str_replace('\\', '\\\\', trim($externalId, '"')); | ||||
| 
 | ||||
|         $this->joinMetaDataTables(); | ||||
| @@ -242,7 +244,7 @@ trait MetaCollection | ||||
| 
 | ||||
|     public function externalIdDoesNotEnd(string $externalId): GroupCollectorInterface | ||||
|     { | ||||
|         $externalId = (string) \Safe\json_encode($externalId); | ||||
|         $externalId = (string) json_encode($externalId); | ||||
|         $externalId = str_replace('\\', '\\\\', trim($externalId, '"')); | ||||
| 
 | ||||
|         $this->joinMetaDataTables(); | ||||
| @@ -254,7 +256,7 @@ trait MetaCollection | ||||
| 
 | ||||
|     public function externalIdDoesNotStart(string $externalId): GroupCollectorInterface | ||||
|     { | ||||
|         $externalId = (string) \Safe\json_encode($externalId); | ||||
|         $externalId = (string) json_encode($externalId); | ||||
|         $externalId = str_replace('\\', '\\\\', trim($externalId, '"')); | ||||
| 
 | ||||
|         $this->joinMetaDataTables(); | ||||
| @@ -266,7 +268,7 @@ trait MetaCollection | ||||
| 
 | ||||
|     public function externalIdEnds(string $externalId): GroupCollectorInterface | ||||
|     { | ||||
|         $externalId = (string) \Safe\json_encode($externalId); | ||||
|         $externalId = (string) json_encode($externalId); | ||||
|         $externalId = str_replace('\\', '\\\\', trim($externalId, '"')); | ||||
| 
 | ||||
|         $this->joinMetaDataTables(); | ||||
| @@ -278,7 +280,7 @@ trait MetaCollection | ||||
| 
 | ||||
|     public function externalIdStarts(string $externalId): GroupCollectorInterface | ||||
|     { | ||||
|         $externalId = (string) \Safe\json_encode($externalId); | ||||
|         $externalId = (string) json_encode($externalId); | ||||
|         $externalId = str_replace('\\', '\\\\', trim($externalId, '"')); | ||||
| 
 | ||||
|         $this->joinMetaDataTables(); | ||||
| @@ -291,7 +293,7 @@ trait MetaCollection | ||||
|     public function externalUrlContains(string $url): GroupCollectorInterface | ||||
|     { | ||||
|         $this->joinMetaDataTables(); | ||||
|         $url = (string) \Safe\json_encode($url); | ||||
|         $url = (string) json_encode($url); | ||||
|         $url = str_replace('\\', '\\\\', trim($url, '"')); | ||||
|         $this->query->where('journal_meta.name', '=', 'external_url'); | ||||
|         $this->query->whereLike('journal_meta.data', sprintf('%%%s%%', $url)); | ||||
| @@ -302,7 +304,7 @@ trait MetaCollection | ||||
|     public function externalUrlDoesNotContain(string $url): GroupCollectorInterface | ||||
|     { | ||||
|         $this->joinMetaDataTables(); | ||||
|         $url = (string) \Safe\json_encode($url); | ||||
|         $url = (string) json_encode($url); | ||||
|         $url = str_replace('\\', '\\\\', trim($url, '"')); | ||||
|         $this->query->where('journal_meta.name', '=', 'external_url'); | ||||
|         $this->query->whereNotLike('journal_meta.data', sprintf('%%%s%%', $url)); | ||||
| @@ -313,7 +315,7 @@ trait MetaCollection | ||||
|     public function externalUrlDoesNotEnd(string $url): GroupCollectorInterface | ||||
|     { | ||||
|         $this->joinMetaDataTables(); | ||||
|         $url = (string) \Safe\json_encode($url); | ||||
|         $url = (string) json_encode($url); | ||||
|         $url = str_replace('\\', '\\\\', ltrim($url, '"')); | ||||
|         $this->query->where('journal_meta.name', '=', 'external_url'); | ||||
|         $this->query->whereNotLike('journal_meta.data', sprintf('%%%s', $url)); | ||||
| @@ -324,7 +326,7 @@ trait MetaCollection | ||||
|     public function externalUrlDoesNotStart(string $url): GroupCollectorInterface | ||||
|     { | ||||
|         $this->joinMetaDataTables(); | ||||
|         $url = (string) \Safe\json_encode($url); | ||||
|         $url = (string) json_encode($url); | ||||
|         $url = str_replace('\\', '\\\\', rtrim($url, '"')); | ||||
|         // var_dump($url);
 | ||||
| 
 | ||||
| @@ -337,7 +339,7 @@ trait MetaCollection | ||||
|     public function externalUrlEnds(string $url): GroupCollectorInterface | ||||
|     { | ||||
|         $this->joinMetaDataTables(); | ||||
|         $url = (string) \Safe\json_encode($url); | ||||
|         $url = (string) json_encode($url); | ||||
|         $url = str_replace('\\', '\\\\', ltrim($url, '"')); | ||||
|         $this->query->where('journal_meta.name', '=', 'external_url'); | ||||
|         $this->query->whereLike('journal_meta.data', sprintf('%%%s', $url)); | ||||
| @@ -348,7 +350,7 @@ trait MetaCollection | ||||
|     public function externalUrlStarts(string $url): GroupCollectorInterface | ||||
|     { | ||||
|         $this->joinMetaDataTables(); | ||||
|         $url = (string) \Safe\json_encode($url); | ||||
|         $url = (string) json_encode($url); | ||||
|         $url = str_replace('\\', '\\\\', rtrim($url, '"')); | ||||
|         // var_dump($url);
 | ||||
| 
 | ||||
| @@ -399,7 +401,7 @@ trait MetaCollection | ||||
| 
 | ||||
|     public function internalReferenceContains(string $internalReference): GroupCollectorInterface | ||||
|     { | ||||
|         $internalReference = (string) \Safe\json_encode($internalReference); | ||||
|         $internalReference = (string) json_encode($internalReference); | ||||
|         $internalReference = str_replace('\\', '\\\\', trim($internalReference, '"')); | ||||
|         // var_dump($internalReference);
 | ||||
|         // exit;
 | ||||
| @@ -414,7 +416,7 @@ trait MetaCollection | ||||
| 
 | ||||
|     public function internalReferenceDoesNotContain(string $internalReference): GroupCollectorInterface | ||||
|     { | ||||
|         $internalReference = (string) \Safe\json_encode($internalReference); | ||||
|         $internalReference = (string) json_encode($internalReference); | ||||
|         $internalReference = str_replace('\\', '\\\\', trim($internalReference, '"')); | ||||
| 
 | ||||
|         $this->joinMetaDataTables(); | ||||
| @@ -427,7 +429,7 @@ trait MetaCollection | ||||
| 
 | ||||
|     public function internalReferenceDoesNotEnd(string $internalReference): GroupCollectorInterface | ||||
|     { | ||||
|         $internalReference = (string) \Safe\json_encode($internalReference); | ||||
|         $internalReference = (string) json_encode($internalReference); | ||||
|         $internalReference = str_replace('\\', '\\\\', trim($internalReference, '"')); | ||||
| 
 | ||||
|         $this->joinMetaDataTables(); | ||||
| @@ -440,7 +442,7 @@ trait MetaCollection | ||||
| 
 | ||||
|     public function internalReferenceDoesNotStart(string $internalReference): GroupCollectorInterface | ||||
|     { | ||||
|         $internalReference = (string) \Safe\json_encode($internalReference); | ||||
|         $internalReference = (string) json_encode($internalReference); | ||||
|         $internalReference = str_replace('\\', '\\\\', trim($internalReference, '"')); | ||||
| 
 | ||||
|         $this->joinMetaDataTables(); | ||||
| @@ -453,7 +455,7 @@ trait MetaCollection | ||||
| 
 | ||||
|     public function internalReferenceEnds(string $internalReference): GroupCollectorInterface | ||||
|     { | ||||
|         $internalReference = (string) \Safe\json_encode($internalReference); | ||||
|         $internalReference = (string) json_encode($internalReference); | ||||
|         $internalReference = str_replace('\\', '\\\\', trim($internalReference, '"')); | ||||
| 
 | ||||
|         $this->joinMetaDataTables(); | ||||
| @@ -466,7 +468,7 @@ trait MetaCollection | ||||
| 
 | ||||
|     public function internalReferenceStarts(string $internalReference): GroupCollectorInterface | ||||
|     { | ||||
|         $internalReference = (string) \Safe\json_encode($internalReference); | ||||
|         $internalReference = (string) json_encode($internalReference); | ||||
|         $internalReference = str_replace('\\', '\\\\', trim($internalReference, '"')); | ||||
| 
 | ||||
|         $this->joinMetaDataTables(); | ||||
| @@ -704,7 +706,7 @@ trait MetaCollection | ||||
|     { | ||||
|         $this->joinMetaDataTables(); | ||||
|         $this->query->where('journal_meta.name', '=', 'external_id'); | ||||
|         $this->query->where('journal_meta.data', '=', sprintf('%s', \Safe\json_encode($externalId))); | ||||
|         $this->query->where('journal_meta.data', '=', sprintf('%s', json_encode($externalId))); | ||||
|         $this->query->whereNull('journal_meta.deleted_at'); | ||||
| 
 | ||||
|         return $this; | ||||
| @@ -714,7 +716,7 @@ trait MetaCollection | ||||
|     { | ||||
|         $this->joinMetaDataTables(); | ||||
|         $this->query->where('journal_meta.name', '=', 'external_url'); | ||||
|         $this->query->where('journal_meta.data', '=', \Safe\json_encode($url)); | ||||
|         $this->query->where('journal_meta.data', '=', json_encode($url)); | ||||
|         $this->query->whereNull('journal_meta.deleted_at'); | ||||
| 
 | ||||
|         return $this; | ||||
| @@ -722,12 +724,12 @@ trait MetaCollection | ||||
| 
 | ||||
|     public function setInternalReference(string $internalReference): GroupCollectorInterface | ||||
|     { | ||||
|         $internalReference = (string) \Safe\json_encode($internalReference); | ||||
|         $internalReference = (string) json_encode($internalReference); | ||||
|         $internalReference = str_replace('\\', '\\\\', trim($internalReference, '"')); | ||||
| 
 | ||||
|         $this->joinMetaDataTables(); | ||||
|         $this->query->where('journal_meta.name', '=', 'internal_reference'); | ||||
|         $this->query->where('journal_meta.data', '=', sprintf('%s', \Safe\json_encode($internalReference))); | ||||
|         $this->query->where('journal_meta.data', '=', sprintf('%s', json_encode($internalReference))); | ||||
|         $this->query->whereNull('journal_meta.deleted_at'); | ||||
| 
 | ||||
|         return $this; | ||||
| @@ -737,7 +739,7 @@ trait MetaCollection | ||||
|     { | ||||
|         $this->joinMetaDataTables(); | ||||
|         $this->query->where('journal_meta.name', '=', 'recurrence_id'); | ||||
|         $this->query->where('journal_meta.data', '=', sprintf('%s', \Safe\json_encode($recurringId))); | ||||
|         $this->query->where('journal_meta.data', '=', sprintf('%s', json_encode($recurringId))); | ||||
|         $this->query->whereNull('journal_meta.deleted_at'); | ||||
| 
 | ||||
|         return $this; | ||||
| @@ -747,7 +749,7 @@ trait MetaCollection | ||||
|     { | ||||
|         $this->joinMetaDataTables(); | ||||
|         $this->query->where('journal_meta.name', '=', 'sepa_ct_id'); | ||||
|         $this->query->where('journal_meta.data', '=', sprintf('%s', \Safe\json_encode($sepaCT))); | ||||
|         $this->query->where('journal_meta.data', '=', sprintf('%s', json_encode($sepaCT))); | ||||
|         $this->query->whereNull('journal_meta.deleted_at'); | ||||
| 
 | ||||
|         return $this; | ||||
|   | ||||
| @@ -73,7 +73,11 @@ trait TimeCollection | ||||
|         $filter              = static function (array $object) use ($field, $start, $end): bool { | ||||
|             foreach ($object['transactions'] as $transaction) { | ||||
|                 if (array_key_exists($field, $transaction) && $transaction[$field] instanceof Carbon) { | ||||
|                     return $transaction[$field]->lt($start) || $transaction[$field]->gt($end); | ||||
|                     if ($transaction[$field]->lt($start)) { | ||||
|                         return true; | ||||
|                     } | ||||
| 
 | ||||
|                     return $transaction[$field]->gt($end); | ||||
|                 } | ||||
|             } | ||||
| 
 | ||||
| @@ -589,17 +593,17 @@ trait TimeCollection | ||||
|      */ | ||||
|     public function setRange(?Carbon $start, ?Carbon $end): GroupCollectorInterface | ||||
|     { | ||||
|         if (null !== $start && null !== $end && $end < $start) { | ||||
|         if ($start instanceof Carbon && $end instanceof Carbon && $end < $start) { | ||||
|             [$start, $end] = [$end, $start]; | ||||
|         } | ||||
|         // always got to end of day / start of day for ranges.
 | ||||
|         $startStr = $start?->format('Y-m-d 00:00:00'); | ||||
|         $endStr   = $end?->format('Y-m-d 23:59:59'); | ||||
| 
 | ||||
|         if (null !== $start) { | ||||
|         if ($start instanceof Carbon) { | ||||
|             $this->query->where('transaction_journals.date', '>=', $startStr); | ||||
|         } | ||||
|         if (null !== $end) { | ||||
|         if ($end instanceof Carbon) { | ||||
|             $this->query->where('transaction_journals.date', '<=', $endStr); | ||||
|         } | ||||
| 
 | ||||
|   | ||||
| @@ -45,6 +45,10 @@ use Illuminate\Database\Query\JoinClause; | ||||
| use Illuminate\Pagination\LengthAwarePaginator; | ||||
| use Illuminate\Support\Collection; | ||||
| use Illuminate\Support\Facades\Log; | ||||
| use Closure; | ||||
| use Override; | ||||
| 
 | ||||
| use function Safe\json_decode; | ||||
| 
 | ||||
| /** | ||||
|  * Class GroupCollector | ||||
| @@ -582,7 +586,7 @@ class GroupCollector implements GroupCollectorInterface | ||||
|             $result['date']->setTimezone(config('app.timezone')); | ||||
|             $result['created_at']->setTimezone(config('app.timezone')); | ||||
|             $result['updated_at']->setTimezone(config('app.timezone')); | ||||
|         } catch (\Exception $e) { // intentional generic exception
 | ||||
|         } catch (Exception $e) { // intentional generic exception
 | ||||
|             app('log')->error($e->getMessage()); | ||||
| 
 | ||||
|             throw new FireflyException($e->getMessage(), 0, $e); | ||||
| @@ -593,7 +597,7 @@ class GroupCollector implements GroupCollectorInterface | ||||
|         if (array_key_exists('meta_name', $result) && in_array($result['meta_name'], $dates, true)) { | ||||
|             $name = $result['meta_name']; | ||||
|             if (array_key_exists('meta_data', $result) && '' !== (string) $result['meta_data']) { | ||||
|                 $result[$name] = Carbon::createFromFormat('!Y-m-d', substr((string) \Safe\json_decode($result['meta_data']), 0, 10)); | ||||
|                 $result[$name] = Carbon::createFromFormat('!Y-m-d', substr((string) json_decode((string) $result['meta_data']), 0, 10)); | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
| @@ -778,7 +782,7 @@ class GroupCollector implements GroupCollectorInterface | ||||
|         app('log')->debug(sprintf('GroupCollector: postFilterCollection has %d filter(s) and %d transaction(s).', count($this->postFilters), count($currentCollection))); | ||||
| 
 | ||||
|         /** | ||||
|          * @var \Closure $function | ||||
|          * @var Closure $function | ||||
|          */ | ||||
|         foreach ($this->postFilters as $function) { | ||||
|             app('log')->debug('Applying filter...'); | ||||
| @@ -812,7 +816,7 @@ class GroupCollector implements GroupCollectorInterface | ||||
|         return $currentCollection; | ||||
|     } | ||||
| 
 | ||||
|     #[\Override]
 | ||||
|     #[Override]
 | ||||
|     public function sortCollection(Collection $collection): Collection | ||||
|     { | ||||
|         /** | ||||
| @@ -1004,7 +1008,7 @@ class GroupCollector implements GroupCollectorInterface | ||||
|         return $this; | ||||
|     } | ||||
| 
 | ||||
|     #[\Override]
 | ||||
|     #[Override]
 | ||||
|     public function setSorting(array $instructions): GroupCollectorInterface | ||||
|     { | ||||
|         $this->sorting = $instructions; | ||||
| @@ -1044,7 +1048,7 @@ class GroupCollector implements GroupCollectorInterface | ||||
|      */ | ||||
|     public function setUser(User $user): GroupCollectorInterface | ||||
|     { | ||||
|         if (null === $this->user) { | ||||
|         if (!$this->user instanceof User) { | ||||
|             $this->user = $user; | ||||
|             $this->startQuery(); | ||||
|         } | ||||
| @@ -1104,7 +1108,7 @@ class GroupCollector implements GroupCollectorInterface | ||||
|      */ | ||||
|     public function setUserGroup(UserGroup $userGroup): GroupCollectorInterface | ||||
|     { | ||||
|         if (null === $this->userGroup) { | ||||
|         if (!$this->userGroup instanceof UserGroup) { | ||||
|             $this->userGroup = $userGroup; | ||||
|             $this->startQueryForGroup(); | ||||
|         } | ||||
|   | ||||
| @@ -149,10 +149,10 @@ class PopupReport implements PopupReportInterface | ||||
|             ->setRange($attributes['startDate'], $attributes['endDate'])->withAccountInformation() | ||||
|         ; | ||||
| 
 | ||||
|         if (null !== $category) { | ||||
|         if ($category instanceof Category) { | ||||
|             $collector->setCategory($category); | ||||
|         } | ||||
|         if (null === $category) { | ||||
|         if (!$category instanceof Category) { | ||||
|             $collector->withoutCategory(); | ||||
|         } | ||||
| 
 | ||||
|   | ||||
| @@ -24,8 +24,12 @@ declare(strict_types=1); | ||||
| 
 | ||||
| namespace FireflyIII\Helpers\Webhook; | ||||
| 
 | ||||
| use Carbon\Carbon; | ||||
| use FireflyIII\Exceptions\FireflyException; | ||||
| use FireflyIII\Models\WebhookMessage; | ||||
| use JsonException; | ||||
| 
 | ||||
| use function Safe\json_encode; | ||||
| 
 | ||||
| /** | ||||
|  * Class Sha3SignatureGenerator | ||||
| @@ -46,8 +50,8 @@ class Sha3SignatureGenerator implements SignatureGeneratorInterface | ||||
|         $json      = ''; | ||||
| 
 | ||||
|         try { | ||||
|             $json = \Safe\json_encode($message->message, JSON_THROW_ON_ERROR); | ||||
|         } catch (\JsonException $e) { | ||||
|             $json = json_encode($message->message, JSON_THROW_ON_ERROR); | ||||
|         } catch (JsonException $e) { | ||||
|             app('log')->error('Could not generate hash.'); | ||||
|             app('log')->error(sprintf('JSON value: %s', $json)); | ||||
|             app('log')->error($e->getMessage()); | ||||
| @@ -62,7 +66,7 @@ class Sha3SignatureGenerator implements SignatureGeneratorInterface | ||||
|         // The character .
 | ||||
|         // The character .
 | ||||
|         // The actual JSON payload (i.e., the request body)
 | ||||
|         $timestamp = time(); | ||||
|         $timestamp = Carbon::now()->getTimestamp(); | ||||
|         $payload   = sprintf('%s.%s', $timestamp, $json); | ||||
|         $signature = hash_hmac('sha3-256', $payload, (string) $message->webhook->secret, false); | ||||
| 
 | ||||
|   | ||||
| @@ -53,6 +53,9 @@ use Symfony\Component\HttpKernel\Exception\NotFoundHttpException; | ||||
| use function Safe\file_get_contents; | ||||
| use function Safe\ini_get; | ||||
| 
 | ||||
| use const PHP_INT_SIZE; | ||||
| use const PHP_SAPI; | ||||
| 
 | ||||
| /** | ||||
|  * Class DebugController | ||||
|  */ | ||||
| @@ -111,7 +114,7 @@ class DebugController extends Controller | ||||
| 
 | ||||
|         try { | ||||
|             Artisan::call('twig:clean'); | ||||
|         } catch (\Exception $e) {  // intentional generic exception
 | ||||
|         } catch (Exception $e) {  // intentional generic exception
 | ||||
|             throw new FireflyException($e->getMessage(), 0, $e); | ||||
|         } | ||||
| 
 | ||||
| @@ -177,8 +180,8 @@ class DebugController extends Controller | ||||
|             'php_version'     => PHP_VERSION, | ||||
|             'php_os'          => PHP_OS, | ||||
|             'uname'           => php_uname('m'), | ||||
|             'interface'       => \PHP_SAPI, | ||||
|             'bits'            => \PHP_INT_SIZE * 8, | ||||
|             'interface'       => PHP_SAPI, | ||||
|             'bits'            => PHP_INT_SIZE * 8, | ||||
|             'bcscale'         => bcscale(), | ||||
|             'display_errors'  => ini_get('display_errors'), | ||||
|             'error_reporting' => $this->errorReporting((int) ini_get('error_reporting')), | ||||
| @@ -203,7 +206,7 @@ class DebugController extends Controller | ||||
|                 $return['build'] = trim((string) file_get_contents('/var/www/counter-main.txt')); | ||||
|                 app('log')->debug(sprintf('build is now "%s"', $return['build'])); | ||||
|             } | ||||
|         } catch (\Exception $e) { | ||||
|         } catch (Exception $e) { | ||||
|             app('log')->debug('Could not check build counter, but thats ok.'); | ||||
|             app('log')->warning($e->getMessage()); | ||||
|         } | ||||
| @@ -212,7 +215,7 @@ class DebugController extends Controller | ||||
|             if (file_exists('/var/www/build-date-main.txt')) { | ||||
|                 $return['build_date'] = trim((string) file_get_contents('/var/www/build-date-main.txt')); | ||||
|             } | ||||
|         } catch (\Exception $e) { | ||||
|         } catch (Exception $e) { | ||||
|             app('log')->debug('Could not check build date, but thats ok.'); | ||||
|             app('log')->warning($e->getMessage()); | ||||
|         } | ||||
|   | ||||
| @@ -23,6 +23,7 @@ declare(strict_types=1); | ||||
| 
 | ||||
| namespace FireflyIII\Http\Controllers; | ||||
| 
 | ||||
| use Exception; | ||||
| use Carbon\Carbon; | ||||
| use Carbon\Exceptions\InvalidFormatException; | ||||
| use FireflyIII\Enums\AccountTypeEnum; | ||||
| @@ -57,7 +58,7 @@ class HomeController extends Controller | ||||
|     /** | ||||
|      * Change index date range. | ||||
|      * | ||||
|      * @throws \Exception | ||||
|      * @throws Exception | ||||
|      */ | ||||
|     public function dateRange(Request $request): JsonResponse | ||||
|     { | ||||
|   | ||||
| @@ -23,6 +23,7 @@ declare(strict_types=1); | ||||
| 
 | ||||
| namespace FireflyIII\Http\Controllers\Json; | ||||
| 
 | ||||
| use Throwable; | ||||
| use FireflyIII\Exceptions\FireflyException; | ||||
| use FireflyIII\Http\Controllers\Controller; | ||||
| use FireflyIII\Models\PiggyBank; | ||||
| @@ -89,7 +90,7 @@ class FrontpageController extends Controller | ||||
|         if (0 !== count($info)) { | ||||
|             try { | ||||
|                 $html = view('json.piggy-banks', compact('info', 'convertToNative', 'native'))->render(); | ||||
|             } catch (\Throwable $e) { | ||||
|             } catch (Throwable $e) { | ||||
|                 app('log')->error(sprintf('Cannot render json.piggy-banks: %s', $e->getMessage())); | ||||
|                 app('log')->error($e->getTraceAsString()); | ||||
|                 $html = 'Could not render view.'; | ||||
|   | ||||
| @@ -24,6 +24,7 @@ declare(strict_types=1); | ||||
| 
 | ||||
| namespace FireflyIII\Http\Controllers\Json; | ||||
| 
 | ||||
| use Throwable; | ||||
| use Carbon\Carbon; | ||||
| use FireflyIII\Enums\TransactionTypeEnum; | ||||
| use FireflyIII\Exceptions\FireflyException; | ||||
| @@ -130,7 +131,7 @@ class ReconcileController extends Controller | ||||
| 
 | ||||
|         try { | ||||
|             $view = view('accounts.reconcile.overview', compact('account', 'start', 'diffCompare', 'difference', 'end', 'clearedAmount', 'startBalance', 'endBalance', 'amount', 'route', 'countCleared', 'reconSum', 'selectedIds'))->render(); | ||||
|         } catch (\Throwable $e) { | ||||
|         } catch (Throwable $e) { | ||||
|             app('log')->debug(sprintf('View error: %s', $e->getMessage())); | ||||
|             app('log')->error($e->getTraceAsString()); | ||||
|             $view = sprintf('Could not render accounts.reconcile.overview: %s', $e->getMessage()); | ||||
| @@ -228,7 +229,7 @@ class ReconcileController extends Controller | ||||
|                 'accounts.reconcile.transactions', | ||||
|                 compact('account', 'journals', 'currency', 'start', 'end', 'selectionStart', 'selectionEnd') | ||||
|             )->render(); | ||||
|         } catch (\Throwable $e) { | ||||
|         } catch (Throwable $e) { | ||||
|             app('log')->debug(sprintf('Could not render: %s', $e->getMessage())); | ||||
|             app('log')->error($e->getTraceAsString()); | ||||
|             $html = sprintf('Could not render accounts.reconcile.transactions: %s', $e->getMessage()); | ||||
|   | ||||
| @@ -24,6 +24,7 @@ declare(strict_types=1); | ||||
| 
 | ||||
| namespace FireflyIII\Http\Controllers\Json; | ||||
| 
 | ||||
| use Throwable; | ||||
| use FireflyIII\Exceptions\FireflyException; | ||||
| use FireflyIII\Http\Controllers\Controller; | ||||
| use Illuminate\Http\JsonResponse; | ||||
| @@ -50,7 +51,7 @@ class RuleController extends Controller | ||||
| 
 | ||||
|         try { | ||||
|             $view = view('rules.partials.action', compact('actions', 'count'))->render(); | ||||
|         } catch (\Throwable $e) { | ||||
|         } catch (Throwable $e) { | ||||
|             app('log')->error(sprintf('Cannot render rules.partials.action: %s', $e->getMessage())); | ||||
|             app('log')->error($e->getTraceAsString()); | ||||
|             $view = 'Could not render view.'; | ||||
| @@ -80,7 +81,7 @@ class RuleController extends Controller | ||||
| 
 | ||||
|         try { | ||||
|             $view = view('rules.partials.trigger', compact('triggers', 'count'))->render(); | ||||
|         } catch (\Throwable $e) { | ||||
|         } catch (Throwable $e) { | ||||
|             app('log')->error(sprintf('Cannot render rules.partials.trigger: %s', $e->getMessage())); | ||||
|             app('log')->error($e->getTraceAsString()); | ||||
|             $view = 'Could not render view.'; | ||||
|   | ||||
| @@ -23,6 +23,7 @@ declare(strict_types=1); | ||||
| 
 | ||||
| namespace FireflyIII\Http\Controllers; | ||||
| 
 | ||||
| use JsonException; | ||||
| use Carbon\Carbon; | ||||
| use FireflyIII\Enums\AccountTypeEnum; | ||||
| use FireflyIII\Events\Preferences\UserGroupChangedDefaultCurrency; | ||||
| @@ -155,7 +156,7 @@ class PreferencesController extends Controller | ||||
| 
 | ||||
|         try { | ||||
|             $locales = json_decode((string) file_get_contents(resource_path(sprintf('locales/%s/locales.json', $language))), true, 512, JSON_THROW_ON_ERROR); | ||||
|         } catch (\JsonException $e) { | ||||
|         } catch (JsonException $e) { | ||||
|             app('log')->error($e->getMessage()); | ||||
|             $locales = []; | ||||
|         } | ||||
|   | ||||
| @@ -23,6 +23,7 @@ declare(strict_types=1); | ||||
| 
 | ||||
| namespace FireflyIII\Http\Controllers; | ||||
| 
 | ||||
| use Exception; | ||||
| use Illuminate\Support\Facades\Auth; | ||||
| use Illuminate\Support\Facades\Hash; | ||||
| use FireflyIII\Events\UserChangedEmail; | ||||
| @@ -362,7 +363,7 @@ class ProfileController extends Controller | ||||
|      * | ||||
|      * @return Redirector|RedirectResponse | ||||
|      * | ||||
|      * @throws \Exception | ||||
|      * @throws Exception | ||||
|      */ | ||||
|     public function regenerate(Request $request) | ||||
|     { | ||||
|   | ||||
| @@ -23,6 +23,7 @@ declare(strict_types=1); | ||||
| 
 | ||||
| namespace FireflyIII\Http\Controllers\Report; | ||||
| 
 | ||||
| use Throwable; | ||||
| use Carbon\Carbon; | ||||
| use FireflyIII\Exceptions\FireflyException; | ||||
| use FireflyIII\Http\Controllers\Controller; | ||||
| @@ -58,7 +59,7 @@ class AccountController extends Controller | ||||
| 
 | ||||
|         try { | ||||
|             $result = view('reports.partials.accounts', compact('accountReport'))->render(); | ||||
|         } catch (\Throwable $e) { | ||||
|         } catch (Throwable $e) { | ||||
|             app('log')->error(sprintf('Could not render reports.partials.accounts: %s', $e->getMessage())); | ||||
|             app('log')->error($e->getTraceAsString()); | ||||
|             $result = 'Could not render view.'; | ||||
|   | ||||
| @@ -23,6 +23,7 @@ declare(strict_types=1); | ||||
| 
 | ||||
| namespace FireflyIII\Http\Controllers\Report; | ||||
| 
 | ||||
| use Throwable; | ||||
| use Carbon\Carbon; | ||||
| use FireflyIII\Enums\TransactionTypeEnum; | ||||
| use FireflyIII\Exceptions\FireflyException; | ||||
| @@ -140,7 +141,7 @@ class BalanceController extends Controller | ||||
| 
 | ||||
|         try { | ||||
|             $result = view('reports.partials.balance', compact('report'))->render(); | ||||
|         } catch (\Throwable $e) { | ||||
|         } catch (Throwable $e) { | ||||
|             app('log')->error(sprintf('Could not render reports.partials.balance: %s', $e->getMessage())); | ||||
|             app('log')->error($e->getTraceAsString()); | ||||
|             $result = 'Could not render view.'; | ||||
|   | ||||
| @@ -24,6 +24,7 @@ declare(strict_types=1); | ||||
| 
 | ||||
| namespace FireflyIII\Http\Controllers\Report; | ||||
| 
 | ||||
| use Throwable; | ||||
| use Carbon\Carbon; | ||||
| use FireflyIII\Exceptions\FireflyException; | ||||
| use FireflyIII\Helpers\Report\ReportHelperInterface; | ||||
| @@ -58,7 +59,7 @@ class BillController extends Controller | ||||
| 
 | ||||
|         try { | ||||
|             $result = view('reports.partials.bills', compact('report'))->render(); | ||||
|         } catch (\Throwable $e) { | ||||
|         } catch (Throwable $e) { | ||||
|             app('log')->error(sprintf('Could not render reports.partials.budgets: %s', $e->getMessage())); | ||||
|             app('log')->error($e->getTraceAsString()); | ||||
|             $result = 'Could not render view.'; | ||||
|   | ||||
| @@ -23,6 +23,7 @@ declare(strict_types=1); | ||||
| 
 | ||||
| namespace FireflyIII\Http\Controllers\Report; | ||||
| 
 | ||||
| use Throwable; | ||||
| use Carbon\Carbon; | ||||
| use FireflyIII\Exceptions\FireflyException; | ||||
| use FireflyIII\Http\Controllers\Controller; | ||||
| @@ -176,7 +177,7 @@ class BudgetController extends Controller | ||||
| 
 | ||||
|         try { | ||||
|             $result = view('reports.budget.partials.avg-expenses', compact('result'))->render(); | ||||
|         } catch (\Throwable $e) { | ||||
|         } catch (Throwable $e) { | ||||
|             app('log')->error(sprintf('Could not render reports.partials.budget-period: %s', $e->getMessage())); | ||||
|             $result = sprintf('Could not render view: %s', $e->getMessage()); | ||||
|             app('log')->error($e->getTraceAsString()); | ||||
| @@ -326,7 +327,7 @@ class BudgetController extends Controller | ||||
| 
 | ||||
|         try { | ||||
|             $result = view('reports.partials.budget-period', compact('report', 'periods'))->render(); | ||||
|         } catch (\Throwable $e) { | ||||
|         } catch (Throwable $e) { | ||||
|             app('log')->error(sprintf('Could not render reports.partials.budget-period: %s', $e->getMessage())); | ||||
|             app('log')->error($e->getTraceAsString()); | ||||
|             $result = 'Could not render view.'; | ||||
| @@ -377,7 +378,7 @@ class BudgetController extends Controller | ||||
| 
 | ||||
|         try { | ||||
|             $result = view('reports.budget.partials.top-expenses', compact('result'))->render(); | ||||
|         } catch (\Throwable $e) { | ||||
|         } catch (Throwable $e) { | ||||
|             app('log')->error(sprintf('Could not render reports.partials.budget-period: %s', $e->getMessage())); | ||||
|             $result = sprintf('Could not render view: %s', $e->getMessage()); | ||||
| 
 | ||||
|   | ||||
| @@ -23,6 +23,7 @@ declare(strict_types=1); | ||||
| 
 | ||||
| namespace FireflyIII\Http\Controllers\Report; | ||||
| 
 | ||||
| use Throwable; | ||||
| use Carbon\Carbon; | ||||
| use FireflyIII\Exceptions\FireflyException; | ||||
| use FireflyIII\Http\Controllers\Controller; | ||||
| @@ -295,7 +296,7 @@ class CategoryController extends Controller | ||||
| 
 | ||||
|         try { | ||||
|             $result = view('reports.category.partials.avg-expenses', compact('result'))->render(); | ||||
|         } catch (\Throwable $e) { | ||||
|         } catch (Throwable $e) { | ||||
|             app('log')->error(sprintf('Could not render reports.partials.budget-period: %s', $e->getMessage())); | ||||
|             $result = sprintf('Could not render view: %s', $e->getMessage()); | ||||
| 
 | ||||
| @@ -345,7 +346,7 @@ class CategoryController extends Controller | ||||
| 
 | ||||
|         try { | ||||
|             $result = view('reports.category.partials.avg-income', compact('result'))->render(); | ||||
|         } catch (\Throwable $e) { | ||||
|         } catch (Throwable $e) { | ||||
|             app('log')->error(sprintf('Could not render reports.partials.budget-period: %s', $e->getMessage())); | ||||
|             $result = sprintf('Could not render view: %s', $e->getMessage()); | ||||
| 
 | ||||
| @@ -527,7 +528,7 @@ class CategoryController extends Controller | ||||
| 
 | ||||
|         try { | ||||
|             $result = view('reports.partials.category-period', compact('report', 'periods'))->render(); | ||||
|         } catch (\Throwable $e) { | ||||
|         } catch (Throwable $e) { | ||||
|             app('log')->error(sprintf('Could not render category::expenses: %s', $e->getMessage())); | ||||
|             $result = sprintf('An error prevented Firefly III from rendering: %s. Apologies.', $e->getMessage()); | ||||
| 
 | ||||
| @@ -599,7 +600,7 @@ class CategoryController extends Controller | ||||
| 
 | ||||
|         try { | ||||
|             $result = view('reports.partials.category-period', compact('report', 'periods'))->render(); | ||||
|         } catch (\Throwable $e) { | ||||
|         } catch (Throwable $e) { | ||||
|             app('log')->error(sprintf('Could not render category::expenses: %s', $e->getMessage())); | ||||
|             $result = sprintf('An error prevented Firefly III from rendering: %s. Apologies.', $e->getMessage()); | ||||
| 
 | ||||
| @@ -639,7 +640,7 @@ class CategoryController extends Controller | ||||
|         try { | ||||
|             $result = view('reports.partials.categories', compact('report'))->render(); | ||||
|             $cache->store($result); | ||||
|         } catch (\Throwable $e) { | ||||
|         } catch (Throwable $e) { | ||||
|             app('log')->error(sprintf('Could not render category::expenses: %s', $e->getMessage())); | ||||
|             $result = sprintf('An error prevented Firefly III from rendering: %s. Apologies.', $e->getMessage()); | ||||
| 
 | ||||
| @@ -687,7 +688,7 @@ class CategoryController extends Controller | ||||
| 
 | ||||
|         try { | ||||
|             $result = view('reports.category.partials.top-expenses', compact('result'))->render(); | ||||
|         } catch (\Throwable $e) { | ||||
|         } catch (Throwable $e) { | ||||
|             app('log')->debug(sprintf('Could not render reports.partials.budget-period: %s', $e->getMessage())); | ||||
|             $result = sprintf('Could not render view: %s', $e->getMessage()); | ||||
| 
 | ||||
| @@ -735,7 +736,7 @@ class CategoryController extends Controller | ||||
| 
 | ||||
|         try { | ||||
|             $result = view('reports.category.partials.top-income', compact('result'))->render(); | ||||
|         } catch (\Throwable $e) { | ||||
|         } catch (Throwable $e) { | ||||
|             app('log')->debug(sprintf('Could not render reports.partials.budget-period: %s', $e->getMessage())); | ||||
|             $result = sprintf('Could not render view: %s', $e->getMessage()); | ||||
| 
 | ||||
|   | ||||
| @@ -23,6 +23,7 @@ declare(strict_types=1); | ||||
| 
 | ||||
| namespace FireflyIII\Http\Controllers\Report; | ||||
| 
 | ||||
| use Throwable; | ||||
| use Carbon\Carbon; | ||||
| use FireflyIII\Exceptions\FireflyException; | ||||
| use FireflyIII\Http\Controllers\Controller; | ||||
| @@ -102,7 +103,7 @@ class DoubleController extends Controller | ||||
| 
 | ||||
|         try { | ||||
|             $result = view('reports.double.partials.avg-expenses', compact('result'))->render(); | ||||
|         } catch (\Throwable $e) { | ||||
|         } catch (Throwable $e) { | ||||
|             app('log')->error(sprintf('Could not render reports.partials.budget-period: %s', $e->getMessage())); | ||||
|             $result = sprintf('Could not render view: %s', $e->getMessage()); | ||||
| 
 | ||||
| @@ -152,7 +153,7 @@ class DoubleController extends Controller | ||||
| 
 | ||||
|         try { | ||||
|             $result = view('reports.double.partials.avg-income', compact('result'))->render(); | ||||
|         } catch (\Throwable $e) { | ||||
|         } catch (Throwable $e) { | ||||
|             app('log')->error(sprintf('Could not render reports.partials.budget-period: %s', $e->getMessage())); | ||||
|             $result = sprintf('Could not render view: %s', $e->getMessage()); | ||||
| 
 | ||||
| @@ -429,7 +430,7 @@ class DoubleController extends Controller | ||||
| 
 | ||||
|         try { | ||||
|             $result = view('reports.double.partials.top-expenses', compact('result'))->render(); | ||||
|         } catch (\Throwable $e) { | ||||
|         } catch (Throwable $e) { | ||||
|             app('log')->error(sprintf('Could not render reports.partials.budget-period: %s', $e->getMessage())); | ||||
|             $result = sprintf('Could not render view: %s', $e->getMessage()); | ||||
| 
 | ||||
| @@ -477,7 +478,7 @@ class DoubleController extends Controller | ||||
| 
 | ||||
|         try { | ||||
|             $result = view('reports.double.partials.top-income', compact('result'))->render(); | ||||
|         } catch (\Throwable $e) { | ||||
|         } catch (Throwable $e) { | ||||
|             app('log')->error(sprintf('Could not render reports.partials.budget-period: %s', $e->getMessage())); | ||||
|             $result = sprintf('Could not render view: %s', $e->getMessage()); | ||||
| 
 | ||||
|   | ||||
| @@ -23,6 +23,7 @@ declare(strict_types=1); | ||||
| 
 | ||||
| namespace FireflyIII\Http\Controllers\Report; | ||||
| 
 | ||||
| use Throwable; | ||||
| use Carbon\Carbon; | ||||
| use FireflyIII\Exceptions\FireflyException; | ||||
| use FireflyIII\Http\Controllers\Controller; | ||||
| @@ -78,7 +79,7 @@ class OperationsController extends Controller | ||||
| 
 | ||||
|         try { | ||||
|             $result = view('reports.partials.income-expenses', compact('report', 'type'))->render(); | ||||
|         } catch (\Throwable $e) { | ||||
|         } catch (Throwable $e) { | ||||
|             app('log')->error(sprintf('Could not render reports.partials.income-expense: %s', $e->getMessage())); | ||||
|             app('log')->error($e->getTraceAsString()); | ||||
|             $result = 'Could not render view.'; | ||||
| @@ -112,7 +113,7 @@ class OperationsController extends Controller | ||||
| 
 | ||||
|         try { | ||||
|             $result = view('reports.partials.income-expenses', compact('report', 'type'))->render(); | ||||
|         } catch (\Throwable $e) { | ||||
|         } catch (Throwable $e) { | ||||
|             app('log')->error(sprintf('Could not render reports.partials.income-expenses: %s', $e->getMessage())); | ||||
|             app('log')->error($e->getTraceAsString()); | ||||
|             $result = 'Could not render view.'; | ||||
| @@ -167,7 +168,7 @@ class OperationsController extends Controller | ||||
| 
 | ||||
|         try { | ||||
|             $result = view('reports.partials.operations', compact('sums'))->render(); | ||||
|         } catch (\Throwable $e) { | ||||
|         } catch (Throwable $e) { | ||||
|             app('log')->error(sprintf('Could not render reports.partials.operations: %s', $e->getMessage())); | ||||
|             app('log')->error($e->getTraceAsString()); | ||||
|             $result = 'Could not render view.'; | ||||
|   | ||||
| @@ -24,6 +24,7 @@ declare(strict_types=1); | ||||
| 
 | ||||
| namespace FireflyIII\Http\Controllers\Report; | ||||
| 
 | ||||
| use Throwable; | ||||
| use Carbon\Carbon; | ||||
| use FireflyIII\Exceptions\FireflyException; | ||||
| use FireflyIII\Http\Controllers\Controller; | ||||
| @@ -292,7 +293,7 @@ class TagController extends Controller | ||||
| 
 | ||||
|         try { | ||||
|             $result = view('reports.tag.partials.avg-expenses', compact('result'))->render(); | ||||
|         } catch (\Throwable $e) { | ||||
|         } catch (Throwable $e) { | ||||
|             app('log')->debug(sprintf('Could not render reports.partials.budget-period: %s', $e->getMessage())); | ||||
|             $result = sprintf('Could not render view: %s', $e->getMessage()); | ||||
| 
 | ||||
| @@ -342,7 +343,7 @@ class TagController extends Controller | ||||
| 
 | ||||
|         try { | ||||
|             $result = view('reports.tag.partials.avg-income', compact('result'))->render(); | ||||
|         } catch (\Throwable $e) { | ||||
|         } catch (Throwable $e) { | ||||
|             app('log')->debug(sprintf('Could not render reports.partials.budget-period: %s', $e->getMessage())); | ||||
|             $result = sprintf('Could not render view: %s', $e->getMessage()); | ||||
| 
 | ||||
| @@ -490,7 +491,7 @@ class TagController extends Controller | ||||
| 
 | ||||
|         try { | ||||
|             $result = view('reports.tag.partials.top-expenses', compact('result'))->render(); | ||||
|         } catch (\Throwable $e) { | ||||
|         } catch (Throwable $e) { | ||||
|             app('log')->debug(sprintf('Could not render reports.partials.budget-period: %s', $e->getMessage())); | ||||
|             $result = sprintf('Could not render view: %s', $e->getMessage()); | ||||
| 
 | ||||
| @@ -538,7 +539,7 @@ class TagController extends Controller | ||||
| 
 | ||||
|         try { | ||||
|             $result = view('reports.tag.partials.top-income', compact('result'))->render(); | ||||
|         } catch (\Throwable $e) { | ||||
|         } catch (Throwable $e) { | ||||
|             app('log')->debug(sprintf('Could not render reports.partials.budget-period: %s', $e->getMessage())); | ||||
|             $result = sprintf('Could not render view: %s', $e->getMessage()); | ||||
| 
 | ||||
|   | ||||
| @@ -24,6 +24,7 @@ declare(strict_types=1); | ||||
| 
 | ||||
| namespace FireflyIII\Http\Controllers\Rule; | ||||
| 
 | ||||
| use Throwable; | ||||
| use FireflyIII\Exceptions\FireflyException; | ||||
| use FireflyIII\Http\Controllers\Controller; | ||||
| use FireflyIII\Http\Requests\RuleFormRequest; | ||||
| @@ -177,7 +178,7 @@ class EditController extends Controller | ||||
|                         'triggers'   => $triggers, | ||||
|                     ] | ||||
|                 )->render(); | ||||
|             } catch (\Throwable $e) { | ||||
|             } catch (Throwable $e) { | ||||
|                 $message = sprintf('Throwable was thrown in getPreviousTriggers(): %s', $e->getMessage()); | ||||
|                 app('log')->debug($message); | ||||
|                 app('log')->error($e->getTraceAsString()); | ||||
|   | ||||
| @@ -24,6 +24,7 @@ declare(strict_types=1); | ||||
| 
 | ||||
| namespace FireflyIII\Http\Controllers\Rule; | ||||
| 
 | ||||
| use Throwable; | ||||
| use Carbon\Carbon; | ||||
| use FireflyIII\Exceptions\FireflyException; | ||||
| use FireflyIII\Http\Controllers\Controller; | ||||
| @@ -174,7 +175,7 @@ class SelectController extends Controller | ||||
| 
 | ||||
|         try { | ||||
|             $view = view('list.journals-array-tiny', ['groups' => $collection])->render(); | ||||
|         } catch (\Throwable $exception) { | ||||
|         } catch (Throwable $exception) { | ||||
|             app('log')->error(sprintf('Could not render view in testTriggers(): %s', $exception->getMessage())); | ||||
|             app('log')->error($exception->getTraceAsString()); | ||||
|             $view = sprintf('Could not render list.journals-tiny: %s', $exception->getMessage()); | ||||
| @@ -216,7 +217,7 @@ class SelectController extends Controller | ||||
| 
 | ||||
|         try { | ||||
|             $view = view('list.journals-array-tiny', ['groups' => $collection])->render(); | ||||
|         } catch (\Throwable $exception) { | ||||
|         } catch (Throwable $exception) { | ||||
|             $message = sprintf('Could not render view in testTriggersByRule(): %s', $exception->getMessage()); | ||||
|             app('log')->error($message); | ||||
|             app('log')->error($exception->getTraceAsString()); | ||||
|   | ||||
| @@ -24,6 +24,7 @@ declare(strict_types=1); | ||||
| 
 | ||||
| namespace FireflyIII\Http\Controllers\RuleGroup; | ||||
| 
 | ||||
| use Exception; | ||||
| use Carbon\Carbon; | ||||
| use FireflyIII\Http\Controllers\Controller; | ||||
| use FireflyIII\Http\Requests\SelectTransactionsRequest; | ||||
| @@ -64,7 +65,7 @@ class ExecutionController extends Controller | ||||
|     /** | ||||
|      * Execute the given rulegroup on a set of existing transactions. | ||||
|      * | ||||
|      * @throws \Exception | ||||
|      * @throws Exception | ||||
|      */ | ||||
|     public function execute(SelectTransactionsRequest $request, RuleGroup $ruleGroup): RedirectResponse | ||||
|     { | ||||
|   | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user