| 
									
										
										
										
											2017-12-31 11:38:21 +01:00
										 |  |  | <?php | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * DebugController.php | 
					
						
							| 
									
										
										
										
											2020-01-31 07:32:04 +01:00
										 |  |  |  * Copyright (c) 2019 james@firefly-iii.org | 
					
						
							| 
									
										
										
										
											2017-12-31 11:38:21 +01:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02:00
										 |  |  |  * This file is part of Firefly III (https://github.com/firefly-iii). | 
					
						
							| 
									
										
										
										
											2017-12-31 11:38:21 +01:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02:00
										 |  |  |  * This program is free software: you can redistribute it and/or modify | 
					
						
							|  |  |  |  * it under the terms of the GNU Affero General Public License as | 
					
						
							|  |  |  |  * published by the Free Software Foundation, either version 3 of the | 
					
						
							|  |  |  |  * License, or (at your option) any later version. | 
					
						
							| 
									
										
										
										
											2017-12-31 11:38:21 +01:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02:00
										 |  |  |  * This program is distributed in the hope that it will be useful, | 
					
						
							| 
									
										
										
										
											2017-12-31 11:38:21 +01:00
										 |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02:00
										 |  |  |  * GNU Affero General Public License for more details. | 
					
						
							| 
									
										
										
										
											2017-12-31 11:38:21 +01:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02:00
										 |  |  |  * You should have received a copy of the GNU Affero General Public License | 
					
						
							|  |  |  |  * along with this program.  If not, see <https://www.gnu.org/licenses/>. | 
					
						
							| 
									
										
										
										
											2017-12-31 11:38:21 +01:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | declare(strict_types=1); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace FireflyIII\Http\Controllers; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-09 05:57:00 +02:00
										 |  |  | use Carbon\Carbon; | 
					
						
							| 
									
										
										
										
											2017-12-31 11:38:21 +01:00
										 |  |  | use DB; | 
					
						
							| 
									
										
										
										
											2018-01-12 21:43:04 +01:00
										 |  |  | use Exception; | 
					
						
							| 
									
										
										
										
											2018-06-15 22:06:33 +02:00
										 |  |  | use FireflyIII\Exceptions\FireflyException; | 
					
						
							| 
									
										
										
										
											2018-01-07 12:53:20 +01:00
										 |  |  | use FireflyIII\Http\Middleware\IsDemoUser; | 
					
						
							| 
									
										
										
										
											2023-09-03 17:38:54 +02:00
										 |  |  | use FireflyIII\Models\AccountType; | 
					
						
							|  |  |  | use FireflyIII\Models\TransactionType; | 
					
						
							| 
									
										
										
										
											2018-08-09 17:50:30 +02:00
										 |  |  | use FireflyIII\Support\Http\Controllers\GetConfigurationData; | 
					
						
							| 
									
										
										
										
											2023-09-03 17:38:54 +02:00
										 |  |  | use FireflyIII\User; | 
					
						
							| 
									
										
										
										
											2021-03-28 11:46:23 +02:00
										 |  |  | use Illuminate\Contracts\View\Factory; | 
					
						
							| 
									
										
										
										
											2020-03-17 15:01:00 +01:00
										 |  |  | use Illuminate\Http\RedirectResponse; | 
					
						
							| 
									
										
										
										
											2017-12-31 11:38:21 +01:00
										 |  |  | use Illuminate\Http\Request; | 
					
						
							| 
									
										
										
										
											2020-03-17 15:01:00 +01:00
										 |  |  | use Illuminate\Routing\Redirector; | 
					
						
							| 
									
										
										
										
											2023-07-09 18:45:44 +02:00
										 |  |  | use Illuminate\Support\Facades\Artisan; | 
					
						
							| 
									
										
										
										
											2023-04-01 07:04:42 +02:00
										 |  |  | use Illuminate\Support\Facades\Log; | 
					
						
							| 
									
										
										
										
											2023-04-29 11:15:30 +02:00
										 |  |  | use Illuminate\View\View; | 
					
						
							| 
									
										
										
										
											2017-12-31 11:38:21 +01:00
										 |  |  | use Monolog\Handler\RotatingFileHandler; | 
					
						
							| 
									
										
										
										
											2023-09-03 17:38:54 +02:00
										 |  |  | use Psr\Container\ContainerExceptionInterface; | 
					
						
							|  |  |  | use Psr\Container\NotFoundExceptionInterface; | 
					
						
							| 
									
										
										
										
											2023-12-10 06:51:59 +01:00
										 |  |  | use const PHP_SAPI; | 
					
						
							| 
									
										
										
										
											2017-12-31 11:38:21 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * Class DebugController | 
					
						
							| 
									
										
										
										
											2018-07-17 22:21:03 +02:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2017-12-31 11:38:21 +01:00
										 |  |  |  */ | 
					
						
							|  |  |  | class DebugController extends Controller | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2018-08-09 17:50:30 +02:00
										 |  |  |     use GetConfigurationData; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-07 12:53:20 +01:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2019-07-21 17:15:06 +02:00
										 |  |  |      * DebugController constructor. | 
					
						
							| 
									
										
										
										
											2020-03-17 15:01:00 +01:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2023-02-12 07:15:06 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-07 12:53:20 +01:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function __construct() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         parent::__construct(); | 
					
						
							| 
									
										
										
										
											2020-02-06 22:01:59 +01:00
										 |  |  |         $this->middleware(IsDemoUser::class)->except(['displayError']); | 
					
						
							| 
									
										
										
										
											2018-01-07 12:53:20 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-15 22:06:33 +02:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2018-07-22 08:10:16 +02:00
										 |  |  |      * Show all possible errors. | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2018-06-15 22:06:33 +02:00
										 |  |  |      * @throws FireflyException | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2018-07-08 12:28:42 +02:00
										 |  |  |     public function displayError(): void | 
					
						
							| 
									
										
										
										
											2018-06-15 22:06:33 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2023-10-29 06:33:43 +01:00
										 |  |  |         app('log')->debug('This is a test message at the DEBUG level.'); | 
					
						
							| 
									
										
										
										
											2023-10-29 06:31:27 +01:00
										 |  |  |         app('log')->info('This is a test message at the INFO level.'); | 
					
						
							| 
									
										
										
										
											2018-06-15 22:06:33 +02:00
										 |  |  |         Log::notice('This is a test message at the NOTICE level.'); | 
					
						
							| 
									
										
										
										
											2022-10-30 14:44:49 +01:00
										 |  |  |         app('log')->warning('This is a test message at the WARNING level.'); | 
					
						
							| 
									
										
										
										
											2023-10-29 06:32:00 +01:00
										 |  |  |         app('log')->error('This is a test message at the ERROR level.'); | 
					
						
							| 
									
										
										
										
											2018-06-15 22:06:33 +02:00
										 |  |  |         Log::critical('This is a test message at the CRITICAL level.'); | 
					
						
							|  |  |  |         Log::alert('This is a test message at the ALERT level.'); | 
					
						
							|  |  |  |         Log::emergency('This is a test message at the EMERGENCY level.'); | 
					
						
							|  |  |  |         throw new FireflyException('A very simple test error.'); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2018-07-22 08:10:16 +02:00
										 |  |  |      * Clear log and session. | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2023-06-21 12:34:58 +02:00
										 |  |  |      * @param Request $request | 
					
						
							| 
									
										
										
										
											2018-06-15 22:06:33 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2020-03-17 15:01:00 +01:00
										 |  |  |      * @return RedirectResponse|Redirector | 
					
						
							| 
									
										
										
										
											2023-02-22 18:03:31 +01:00
										 |  |  |      * @throws FireflyException | 
					
						
							| 
									
										
										
										
											2018-06-15 22:06:33 +02:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function flush(Request $request) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2018-07-08 12:08:53 +02:00
										 |  |  |         app('preferences')->mark(); | 
					
						
							| 
									
										
										
										
											2022-12-29 19:41:57 +01:00
										 |  |  |         $request->session()->forget(['start', 'end', '_previous', 'viewRange', 'range', 'is_custom_range', 'temp-mfa-secret', 'temp-mfa-codes']); | 
					
						
							| 
									
										
										
										
											2023-10-29 06:33:43 +01:00
										 |  |  |         app('log')->debug('Call cache:clear...'); | 
					
						
							| 
									
										
										
										
											2023-07-09 18:45:44 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-15 22:06:33 +02:00
										 |  |  |         Artisan::call('cache:clear'); | 
					
						
							| 
									
										
										
										
											2023-10-29 06:33:43 +01:00
										 |  |  |         app('log')->debug('Call config:clear...'); | 
					
						
							| 
									
										
										
										
											2018-06-15 22:06:33 +02:00
										 |  |  |         Artisan::call('config:clear'); | 
					
						
							| 
									
										
										
										
											2023-10-29 06:33:43 +01:00
										 |  |  |         app('log')->debug('Call route:clear...'); | 
					
						
							| 
									
										
										
										
											2018-06-15 22:06:33 +02:00
										 |  |  |         Artisan::call('route:clear'); | 
					
						
							| 
									
										
										
										
											2023-10-29 06:33:43 +01:00
										 |  |  |         app('log')->debug('Call twig:clean...'); | 
					
						
							| 
									
										
										
										
											2018-06-15 22:06:33 +02:00
										 |  |  |         try { | 
					
						
							|  |  |  |             Artisan::call('twig:clean'); | 
					
						
							| 
									
										
										
										
											2022-12-30 20:25:04 +01:00
										 |  |  |         } catch (Exception $e) {  // intentional generic exception
 | 
					
						
							|  |  |  |             throw new FireflyException($e->getMessage(), 0, $e); | 
					
						
							| 
									
										
										
										
											2018-06-15 22:06:33 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2021-04-07 07:28:43 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-29 06:33:43 +01:00
										 |  |  |         app('log')->debug('Call view:clear...'); | 
					
						
							| 
									
										
										
										
											2018-06-15 22:06:33 +02:00
										 |  |  |         Artisan::call('view:clear'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return redirect(route('index')); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2017-12-31 11:38:21 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2018-07-22 08:10:16 +02:00
										 |  |  |      * Show debug info. | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2021-03-28 11:46:23 +02:00
										 |  |  |      * @return Factory|View | 
					
						
							| 
									
										
										
										
											2021-05-24 08:50:17 +02:00
										 |  |  |      * @throws FireflyException | 
					
						
							| 
									
										
										
										
											2017-12-31 11:38:21 +01:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2023-11-29 06:30:35 +01:00
										 |  |  |     public function index() | 
					
						
							| 
									
										
										
										
											2017-12-31 11:38:21 +01:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2023-09-03 17:38:54 +02:00
										 |  |  |         $table = $this->generateTable(); | 
					
						
							| 
									
										
										
										
											2023-09-03 18:00:07 +02:00
										 |  |  |         $table = str_replace(["\n", "\t", '  '], '', $table); | 
					
						
							| 
									
										
										
										
											2023-09-03 17:38:54 +02:00
										 |  |  |         $now   = now(config('app.timezone'))->format('Y-m-d H:i:s'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // get latest log file:
 | 
					
						
							|  |  |  |         $logger = Log::driver(); | 
					
						
							|  |  |  |         // PHPstan doesn't recognize the method because of its polymorphic nature.
 | 
					
						
							| 
									
										
										
										
											2023-12-10 06:51:59 +01:00
										 |  |  |         $handlers = $logger->getHandlers(); // @phpstan-ignore-line
 | 
					
						
							| 
									
										
										
										
											2023-09-03 17:38:54 +02:00
										 |  |  |         $logContent = ''; | 
					
						
							|  |  |  |         foreach ($handlers as $handler) { | 
					
						
							|  |  |  |             if ($handler instanceof RotatingFileHandler) { | 
					
						
							|  |  |  |                 $logFile = $handler->getUrl(); | 
					
						
							|  |  |  |                 if (null !== $logFile && file_exists($logFile)) { | 
					
						
							|  |  |  |                     $logContent = file_get_contents($logFile); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         if ('' !== $logContent) { | 
					
						
							|  |  |  |             // last few lines
 | 
					
						
							| 
									
										
										
										
											2023-11-26 12:10:42 +01:00
										 |  |  |             $logContent = 'Truncated from this point <----|' . substr((string)$logContent, -16384); | 
					
						
							| 
									
										
										
										
											2023-09-03 17:38:54 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return view('debug', compact('table', 'now', 'logContent')); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @return string | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     private function generateTable(): string | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         // system information:
 | 
					
						
							|  |  |  |         $system = $this->getSystemInformation(); | 
					
						
							|  |  |  |         $docker = $this->getBuildInfo(); | 
					
						
							|  |  |  |         $app    = $this->getAppInfo(); | 
					
						
							|  |  |  |         $user   = $this->getuserInfo(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return (string)view('partials.debug-table', compact('system', 'docker', 'app', 'user')); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @return array | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     private function getSystemInformation(): array | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2023-11-26 12:10:42 +01:00
										 |  |  |         $maxFileSize   = app('steam')->phpBytes((string)ini_get('upload_max_filesize')); | 
					
						
							|  |  |  |         $maxPostSize   = app('steam')->phpBytes((string)ini_get('post_max_size')); | 
					
						
							| 
									
										
										
										
											2023-09-03 17:38:54 +02:00
										 |  |  |         $drivers       = DB::availableDrivers(); | 
					
						
							|  |  |  |         $currentDriver = DB::getDriverName(); | 
					
						
							|  |  |  |         return [ | 
					
						
							|  |  |  |             'db_version'      => app('fireflyconfig')->get('db_version', 1)->data, | 
					
						
							|  |  |  |             'php_version'     => PHP_VERSION, | 
					
						
							|  |  |  |             'php_os'          => PHP_OS, | 
					
						
							| 
									
										
										
										
											2023-12-10 06:51:59 +01:00
										 |  |  |             'interface'       => PHP_SAPI, | 
					
						
							| 
									
										
										
										
											2023-09-03 17:38:54 +02:00
										 |  |  |             'bcscale'         => bcscale(), | 
					
						
							|  |  |  |             'display_errors'  => ini_get('display_errors'), | 
					
						
							|  |  |  |             'error_reporting' => $this->errorReporting((int)ini_get('error_reporting')), | 
					
						
							|  |  |  |             'upload_size'     => min($maxFileSize, $maxPostSize), | 
					
						
							|  |  |  |             'all_drivers'     => $drivers, | 
					
						
							|  |  |  |             'current_driver'  => $currentDriver, | 
					
						
							|  |  |  |         ]; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @return array | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     private function getBuildInfo(): array | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $return = [ | 
					
						
							|  |  |  |             'is_docker'       => env('IS_DOCKER', false), | 
					
						
							|  |  |  |             'build'           => '(unknown)', | 
					
						
							|  |  |  |             'build_date'      => '(unknown)', | 
					
						
							|  |  |  |             'base_build'      => '(unknown)', | 
					
						
							|  |  |  |             'base_build_date' => '(unknown)', | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         ]; | 
					
						
							| 
									
										
										
										
											2023-05-27 06:40:23 +02:00
										 |  |  |         try { | 
					
						
							|  |  |  |             if (file_exists('/var/www/counter-main.txt')) { | 
					
						
							| 
									
										
										
										
											2023-11-26 12:10:42 +01:00
										 |  |  |                 $return['build'] = trim((string)file_get_contents('/var/www/counter-main.txt')); | 
					
						
							| 
									
										
										
										
											2023-05-27 06:40:23 +02:00
										 |  |  |             } | 
					
						
							| 
									
										
										
										
											2023-10-29 12:10:03 +01:00
										 |  |  |         } catch (Exception $e) { // @phpstan-ignore-line
 | 
					
						
							| 
									
										
										
										
											2023-10-29 06:33:43 +01:00
										 |  |  |             app('log')->debug('Could not check build counter, but thats ok.'); | 
					
						
							| 
									
										
										
										
											2023-10-29 06:31:13 +01:00
										 |  |  |             app('log')->warning($e->getMessage()); | 
					
						
							| 
									
										
										
										
											2021-12-24 10:51:08 +01:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2023-05-27 06:40:23 +02:00
										 |  |  |         try { | 
					
						
							|  |  |  |             if (file_exists('/var/www/build-date-main.txt')) { | 
					
						
							| 
									
										
										
										
											2023-11-26 12:10:42 +01:00
										 |  |  |                 $return['build_date'] = trim((string)file_get_contents('/var/www/build-date-main.txt')); | 
					
						
							| 
									
										
										
										
											2023-05-27 06:40:23 +02:00
										 |  |  |             } | 
					
						
							| 
									
										
										
										
											2023-10-29 12:10:03 +01:00
										 |  |  |         } catch (Exception $e) { // @phpstan-ignore-line
 | 
					
						
							| 
									
										
										
										
											2023-10-29 06:33:43 +01:00
										 |  |  |             app('log')->debug('Could not check build date, but thats ok.'); | 
					
						
							| 
									
										
										
										
											2023-10-29 06:31:13 +01:00
										 |  |  |             app('log')->warning($e->getMessage()); | 
					
						
							| 
									
										
										
										
											2021-12-24 10:51:08 +01:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2023-05-27 06:40:23 +02:00
										 |  |  |         if ('' !== (string)env('BASE_IMAGE_BUILD')) { | 
					
						
							| 
									
										
										
										
											2023-09-03 17:38:54 +02:00
										 |  |  |             $return['base_build'] = env('BASE_IMAGE_BUILD'); | 
					
						
							| 
									
										
										
										
											2023-04-29 11:15:30 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2023-05-27 06:40:23 +02:00
										 |  |  |         if ('' !== (string)env('BASE_IMAGE_DATE')) { | 
					
						
							| 
									
										
										
										
											2023-09-03 17:38:54 +02:00
										 |  |  |             $return['base_build_date'] = env('BASE_IMAGE_DATE'); | 
					
						
							| 
									
										
										
										
											2023-04-29 11:15:30 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2023-09-03 17:38:54 +02:00
										 |  |  |         return $return; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2023-04-29 11:15:30 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-09-03 17:38:54 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @return array | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     private function getAppInfo(): array | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $userGuard = config('auth.defaults.guard'); | 
					
						
							| 
									
										
										
										
											2022-03-10 17:59:30 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-09 05:57:00 +02:00
										 |  |  |         $config         = app('fireflyconfig')->get('last_rt_job', 0); | 
					
						
							|  |  |  |         $lastTime       = (int)$config->data; | 
					
						
							|  |  |  |         $lastCronjob    = 'never'; | 
					
						
							|  |  |  |         $lastCronjobAgo = 'never'; | 
					
						
							|  |  |  |         if ($lastTime > 0) { | 
					
						
							|  |  |  |             $carbon         = Carbon::createFromTimestamp($lastTime); | 
					
						
							|  |  |  |             $lastCronjob    = $carbon->format('Y-m-d H:i:s'); | 
					
						
							| 
									
										
										
										
											2023-11-26 12:10:42 +01:00
										 |  |  |             $lastCronjobAgo = $carbon->locale('en')->diffForHumans(); // @phpstan-ignore-line
 | 
					
						
							| 
									
										
										
										
											2023-10-09 05:57:00 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-09-03 17:38:54 +02:00
										 |  |  |         return [ | 
					
						
							|  |  |  |             'debug'              => var_export(config('app.debug'), true), | 
					
						
							|  |  |  |             'audit_log_channel'  => envNonEmpty('AUDIT_LOG_CHANNEL', '(empty)'), | 
					
						
							|  |  |  |             'default_language'   => (string)config('firefly.default_language'), | 
					
						
							|  |  |  |             'default_locale'     => (string)config('firefly.default_locale'), | 
					
						
							|  |  |  |             'remote_header'      => $userGuard === 'remote_user_guard' ? config('auth.guard_header') : 'N/A', | 
					
						
							|  |  |  |             'remote_mail_header' => $userGuard === 'remote_user_guard' ? config('auth.guard_email') : 'N/A', | 
					
						
							| 
									
										
										
										
											2023-11-04 14:18:49 +01:00
										 |  |  |             'stateful_domains'   => implode(', ', config('sanctum.stateful')), | 
					
						
							| 
									
										
										
										
											2023-10-09 05:57:00 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |             // the dates for the cron job are based on the recurring cron job's times.
 | 
					
						
							|  |  |  |             // any of the cron jobs will do, they always run at the same time.
 | 
					
						
							|  |  |  |             // but this job is the oldest, so the biggest chance it ran once
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             'last_cronjob'     => $lastCronjob, | 
					
						
							|  |  |  |             'last_cronjob_ago' => $lastCronjobAgo, | 
					
						
							| 
									
										
										
										
											2023-09-03 17:38:54 +02:00
										 |  |  |         ]; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-05-26 06:28:42 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-09-03 17:38:54 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * @return array | 
					
						
							|  |  |  |      * @throws ContainerExceptionInterface | 
					
						
							|  |  |  |      * @throws NotFoundExceptionInterface | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     private function getuserInfo(): array | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $userFlags = $this->getUserFlags(); | 
					
						
							| 
									
										
										
										
											2020-09-21 15:39:03 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-09-03 17:38:54 +02:00
										 |  |  |         // user info
 | 
					
						
							|  |  |  |         $userAgent = request()->header('user-agent'); | 
					
						
							| 
									
										
										
										
											2017-12-31 11:38:21 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-10 07:15:21 +01:00
										 |  |  |         // set languages, see what happens:
 | 
					
						
							| 
									
										
										
										
											2023-11-04 11:31:14 +01:00
										 |  |  |         $original       = setlocale(LC_ALL, '0'); | 
					
						
							| 
									
										
										
										
											2018-03-10 07:15:21 +01:00
										 |  |  |         $localeAttempts = []; | 
					
						
							| 
									
										
										
										
											2020-04-22 09:28:20 +02:00
										 |  |  |         $parts          = app('steam')->getLocaleArray(app('steam')->getLocale()); | 
					
						
							| 
									
										
										
										
											2018-03-10 07:15:21 +01:00
										 |  |  |         foreach ($parts as $code) { | 
					
						
							| 
									
										
										
										
											2020-05-26 06:28:42 +02:00
										 |  |  |             $code = trim($code); | 
					
						
							| 
									
										
										
										
											2023-10-29 06:33:43 +01:00
										 |  |  |             app('log')->debug(sprintf('Trying to set %s', $code)); | 
					
						
							| 
									
										
										
										
											2023-09-03 17:38:54 +02:00
										 |  |  |             $result                = setlocale(LC_ALL, $code); | 
					
						
							|  |  |  |             $localeAttempts[$code] = $result === $code; | 
					
						
							| 
									
										
										
										
											2018-03-10 07:15:21 +01:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2023-12-10 06:51:59 +01:00
										 |  |  |         setlocale(LC_ALL, (string)$original); | 
					
						
							| 
									
										
										
										
											2018-03-10 07:15:21 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-09-03 17:38:54 +02:00
										 |  |  |         return [ | 
					
						
							|  |  |  |             'user_id'         => auth()->user()->id, | 
					
						
							|  |  |  |             'user_count'      => User::count(), | 
					
						
							|  |  |  |             'user_flags'      => $userFlags, | 
					
						
							|  |  |  |             'user_agent'      => $userAgent, | 
					
						
							|  |  |  |             'locale_attempts' => $localeAttempts, | 
					
						
							|  |  |  |             'locale'          => app('steam')->getLocale(), | 
					
						
							|  |  |  |             'language'        => app('steam')->getLanguage(), | 
					
						
							|  |  |  |             'view_range'      => app('preferences')->get('viewRange', '1M')->data, | 
					
						
							|  |  |  |         ]; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @return string | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     private function getUserFlags(): string | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $flags = []; | 
					
						
							|  |  |  |         /** @var User $user */ | 
					
						
							|  |  |  |         $user = auth()->user(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // has liabilities
 | 
					
						
							|  |  |  |         if ($user->accounts()->accountTypeIn([AccountType::DEBT, AccountType::LOAN, AccountType::MORTGAGE])->count() > 0) { | 
					
						
							| 
									
										
										
										
											2023-10-09 05:57:00 +02:00
										 |  |  |             $flags[] = '<span title="Has liabilities">:credit_card:</span>'; | 
					
						
							| 
									
										
										
										
											2017-12-31 11:38:21 +01:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2023-09-03 17:38:54 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         // has piggies
 | 
					
						
							|  |  |  |         if ($user->piggyBanks()->count() > 0) { | 
					
						
							| 
									
										
										
										
											2023-10-09 05:57:00 +02:00
										 |  |  |             $flags[] = '<span title="Has piggy banks">:pig:</span>'; | 
					
						
							| 
									
										
										
										
											2023-09-03 17:38:54 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // has stored reconciliations
 | 
					
						
							|  |  |  |         $type = TransactionType::whereType(TransactionType::RECONCILIATION)->first(); | 
					
						
							| 
									
										
										
										
											2023-11-05 09:40:45 +01:00
										 |  |  |         if ($user->transactionJournals()->where('transaction_type_id', $type->id)->count() > 0) { | 
					
						
							| 
									
										
										
										
											2023-10-09 05:57:00 +02:00
										 |  |  |             $flags[] = '<span title="Has reconciled">:ledger:</span>'; | 
					
						
							| 
									
										
										
										
											2018-11-02 21:17:07 +01:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2017-12-31 11:38:21 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-09-03 17:38:54 +02:00
										 |  |  |         // has used importer?
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // has rules
 | 
					
						
							|  |  |  |         if ($user->rules()->count() > 0) { | 
					
						
							| 
									
										
										
										
											2023-10-09 05:57:00 +02:00
										 |  |  |             $flags[] = '<span title="Has rules">:wrench:</span>'; | 
					
						
							| 
									
										
										
										
											2023-09-03 17:38:54 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // has recurring transactions
 | 
					
						
							|  |  |  |         if ($user->recurrences()->count() > 0) { | 
					
						
							| 
									
										
										
										
											2023-10-09 05:57:00 +02:00
										 |  |  |             $flags[] = '<span title="Has recurring transactions">:clock130:</span>'; | 
					
						
							| 
									
										
										
										
											2023-09-03 17:38:54 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // has groups
 | 
					
						
							|  |  |  |         if ($user->objectGroups()->count() > 0) { | 
					
						
							| 
									
										
										
										
											2023-10-09 05:57:00 +02:00
										 |  |  |             $flags[] = '<span title="Has object groups">:bookmark_tabs:</span>'; | 
					
						
							| 
									
										
										
										
											2023-09-03 17:38:54 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // uses bills
 | 
					
						
							|  |  |  |         if ($user->bills()->count() > 0) { | 
					
						
							| 
									
										
										
										
											2023-10-09 05:57:00 +02:00
										 |  |  |             $flags[] = '<span title="Has subscriptions">:email:</span>'; | 
					
						
							| 
									
										
										
										
											2023-09-03 17:38:54 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2023-11-04 14:18:49 +01:00
										 |  |  |         return implode(' ', $flags); | 
					
						
							| 
									
										
										
										
											2017-12-31 11:38:21 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-15 22:06:33 +02:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2018-07-22 08:10:16 +02:00
										 |  |  |      * Flash all types of messages. | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2023-06-21 12:34:58 +02:00
										 |  |  |      * @param Request $request | 
					
						
							| 
									
										
										
										
											2018-06-15 22:06:33 +02:00
										 |  |  |      * | 
					
						
							| 
									
										
										
										
											2020-03-17 15:01:00 +01:00
										 |  |  |      * @return RedirectResponse|Redirector | 
					
						
							| 
									
										
										
										
											2018-06-15 22:06:33 +02:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function testFlash(Request $request) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $request->session()->flash('success', 'This is a success message.'); | 
					
						
							|  |  |  |         $request->session()->flash('info', 'This is an info message.'); | 
					
						
							|  |  |  |         $request->session()->flash('warning', 'This is a warning.'); | 
					
						
							|  |  |  |         $request->session()->flash('error', 'This is an error!'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return redirect(route('home')); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2023-09-03 17:38:54 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-05 19:35:58 +01:00
										 |  |  | } |