| 
									
										
										
										
											2017-12-31 11:38:21 +01:00
										 |  |  | <?php | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * DebugController.php | 
					
						
							|  |  |  |  * Copyright (c) 2017 thegrumpydictator@gmail.com | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This file is part of Firefly III. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Firefly III is free software: you can redistribute it and/or modify | 
					
						
							|  |  |  |  * it under the terms of the GNU General Public License as published by | 
					
						
							|  |  |  |  * the Free Software Foundation, either version 3 of the License, or | 
					
						
							|  |  |  |  * (at your option) any later version. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Firefly III is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  |  * GNU General Public License for more details. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * You should have received a copy of the GNU General Public License | 
					
						
							|  |  |  |  * along with Firefly III. If not, see <http://www.gnu.org/licenses/>. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | declare(strict_types=1); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace FireflyIII\Http\Controllers; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-15 22:06:33 +02:00
										 |  |  | use Artisan; | 
					
						
							| 
									
										
										
										
											2017-12-31 11:38:21 +01:00
										 |  |  | use Carbon\Carbon; | 
					
						
							|  |  |  | 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; | 
					
						
							| 
									
										
										
										
											2018-08-09 17:50:30 +02:00
										 |  |  | use FireflyIII\Support\Http\Controllers\GetConfigurationData; | 
					
						
							| 
									
										
										
										
											2017-12-31 11:38:21 +01:00
										 |  |  | use Illuminate\Http\Request; | 
					
						
							| 
									
										
										
										
											2018-06-15 22:06:33 +02:00
										 |  |  | use Illuminate\Routing\Route; | 
					
						
							| 
									
										
										
										
											2017-12-31 11:38:21 +01:00
										 |  |  | use Log; | 
					
						
							|  |  |  | use Monolog\Handler\RotatingFileHandler; | 
					
						
							| 
									
										
										
										
											2018-06-15 22:06:33 +02:00
										 |  |  | use Route as RouteFacade; | 
					
						
							| 
									
										
										
										
											2017-12-31 11:38:21 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * Class DebugController | 
					
						
							| 
									
										
										
										
											2018-07-17 22:21:03 +02:00
										 |  |  |  * | 
					
						
							|  |  |  |  * @SuppressWarnings(PHPMD.CouplingBetweenObjects) | 
					
						
							| 
									
										
										
										
											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
										 |  |  |     /** | 
					
						
							|  |  |  |      * HomeController constructor. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function __construct() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         parent::__construct(); | 
					
						
							|  |  |  |         $this->middleware(IsDemoUser::class); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											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
										 |  |  |     { | 
					
						
							|  |  |  |         Log::debug('This is a test message at the DEBUG level.'); | 
					
						
							|  |  |  |         Log::info('This is a test message at the INFO level.'); | 
					
						
							|  |  |  |         Log::notice('This is a test message at the NOTICE level.'); | 
					
						
							|  |  |  |         Log::warning('This is a test message at the WARNING level.'); | 
					
						
							|  |  |  |         Log::error('This is a test message at the ERROR level.'); | 
					
						
							|  |  |  |         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. | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2018-06-15 22:06:33 +02:00
										 |  |  |      * @param Request $request | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return \Illuminate\Http\RedirectResponse|\Illuminate\Routing\Redirector | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public function flush(Request $request) | 
					
						
							|  |  |  |     { | 
					
						
							| 
									
										
										
										
											2018-07-08 12:08:53 +02:00
										 |  |  |         app('preferences')->mark(); | 
					
						
							| 
									
										
										
										
											2018-06-15 22:06:33 +02:00
										 |  |  |         $request->session()->forget(['start', 'end', '_previous', 'viewRange', 'range', 'is_custom_range']); | 
					
						
							|  |  |  |         Log::debug('Call cache:clear...'); | 
					
						
							|  |  |  |         Artisan::call('cache:clear'); | 
					
						
							|  |  |  |         Log::debug('Call config:clear...'); | 
					
						
							|  |  |  |         Artisan::call('config:clear'); | 
					
						
							|  |  |  |         Log::debug('Call route:clear...'); | 
					
						
							|  |  |  |         Artisan::call('route:clear'); | 
					
						
							|  |  |  |         Log::debug('Call twig:clean...'); | 
					
						
							|  |  |  |         try { | 
					
						
							|  |  |  |             Artisan::call('twig:clean'); | 
					
						
							|  |  |  |             // @codeCoverageIgnoreStart
 | 
					
						
							|  |  |  |         } catch (Exception $e) { | 
					
						
							|  |  |  |             // don't care
 | 
					
						
							| 
									
										
										
										
											2018-07-08 07:59:58 +02:00
										 |  |  |             Log::debug(sprintf('Called twig:clean: %s', $e->getMessage())); | 
					
						
							| 
									
										
										
										
											2018-06-15 22:06:33 +02:00
										 |  |  |         } | 
					
						
							|  |  |  |         // @codeCoverageIgnoreEnd
 | 
					
						
							|  |  |  |         Log::debug('Call view:clear...'); | 
					
						
							|  |  |  |         Artisan::call('view:clear'); | 
					
						
							|  |  |  |         Log::debug('Done! Redirecting...'); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return redirect(route('index')); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2017-12-31 11:38:21 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2018-07-22 08:10:16 +02:00
										 |  |  |      * Show debug info. | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2017-12-31 11:38:21 +01:00
										 |  |  |      * @param Request $request | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return \Illuminate\Contracts\View\Factory|\Illuminate\View\View | 
					
						
							| 
									
										
										
										
											2018-07-17 22:21:03 +02:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @SuppressWarnings(PHPMD.CyclomaticComplexity) | 
					
						
							|  |  |  |      * @SuppressWarnings(PHPMD.ExcessiveMethodLength) | 
					
						
							| 
									
										
										
										
											2017-12-31 11:38:21 +01:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function index(Request $request) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $search  = ['~', '#']; | 
					
						
							|  |  |  |         $replace = ['\~', '# ']; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $phpVersion     = str_replace($search, $replace, PHP_VERSION); | 
					
						
							| 
									
										
										
										
											2018-03-27 19:29:58 +02:00
										 |  |  |         $phpOs          = str_replace($search, $replace, PHP_OS); | 
					
						
							| 
									
										
										
										
											2017-12-31 11:38:21 +01:00
										 |  |  |         $interface      = PHP_SAPI; | 
					
						
							| 
									
										
										
										
											2018-08-04 17:30:06 +02:00
										 |  |  |         $now            = Carbon::now()->format('Y-m-d H:i:s e'); | 
					
						
							| 
									
										
										
										
											2018-03-27 19:29:58 +02:00
										 |  |  |         $extensions     = implode(', ', get_loaded_extensions()); | 
					
						
							|  |  |  |         $drivers        = implode(', ', DB::availableDrivers()); | 
					
						
							| 
									
										
										
										
											2017-12-31 11:38:21 +01:00
										 |  |  |         $currentDriver  = DB::getDriverName(); | 
					
						
							|  |  |  |         $userAgent      = $request->header('user-agent'); | 
					
						
							|  |  |  |         $isSandstorm    = var_export(env('IS_SANDSTORM', 'unknown'), true); | 
					
						
							|  |  |  |         $isDocker       = var_export(env('IS_DOCKER', 'unknown'), true); | 
					
						
							| 
									
										
										
										
											2018-06-01 22:04:52 +02:00
										 |  |  |         $toSandbox      = var_export(env('BUNQ_USE_SANDBOX', 'unknown'), true); | 
					
						
							| 
									
										
										
										
											2017-12-31 11:38:21 +01:00
										 |  |  |         $trustedProxies = env('TRUSTED_PROXIES', '(none)'); | 
					
						
							|  |  |  |         $displayErrors  = ini_get('display_errors'); | 
					
						
							| 
									
										
										
										
											2018-04-02 15:10:40 +02:00
										 |  |  |         $errorReporting = $this->errorReporting((int)ini_get('error_reporting')); | 
					
						
							| 
									
										
										
										
											2017-12-31 11:38:21 +01:00
										 |  |  |         $appEnv         = env('APP_ENV', ''); | 
					
						
							|  |  |  |         $appDebug       = var_export(env('APP_DEBUG', false), true); | 
					
						
							| 
									
										
										
										
											2018-08-17 21:51:15 +02:00
										 |  |  |         $logChannel     = env('LOG_CHANNEL', ''); | 
					
						
							|  |  |  |         $appLogLevel    = env('APP_LOG_LEVEL', 'info'); | 
					
						
							| 
									
										
										
										
											2017-12-31 11:38:21 +01:00
										 |  |  |         $packages       = $this->collectPackages(); | 
					
						
							| 
									
										
										
										
											2018-01-06 09:33:06 +01:00
										 |  |  |         $cacheDriver    = env('CACHE_DRIVER', 'unknown'); | 
					
						
							| 
									
										
										
										
											2017-12-31 11:38:21 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-10 07:15:21 +01:00
										 |  |  |         // set languages, see what happens:
 | 
					
						
							|  |  |  |         $original       = setlocale(LC_ALL, 0); | 
					
						
							|  |  |  |         $localeAttempts = []; | 
					
						
							| 
									
										
										
										
											2018-07-15 09:38:49 +02:00
										 |  |  |         $parts          = explode(',', (string)trans('config.locale')); | 
					
						
							| 
									
										
										
										
											2018-03-10 07:15:21 +01:00
										 |  |  |         foreach ($parts as $code) { | 
					
						
							|  |  |  |             $code                  = trim($code); | 
					
						
							|  |  |  |             $localeAttempts[$code] = var_export(setlocale(LC_ALL, $code), true); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         setlocale(LC_ALL, $original); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-31 11:38:21 +01:00
										 |  |  |         // get latest log file:
 | 
					
						
							| 
									
										
										
										
											2018-03-08 21:08:26 +01:00
										 |  |  |         $logger     = Log::driver(); | 
					
						
							| 
									
										
										
										
											2017-12-31 11:38:21 +01:00
										 |  |  |         $handlers   = $logger->getHandlers(); | 
					
						
							|  |  |  |         $logContent = ''; | 
					
						
							|  |  |  |         foreach ($handlers as $handler) { | 
					
						
							|  |  |  |             if ($handler instanceof RotatingFileHandler) { | 
					
						
							|  |  |  |                 $logFile = $handler->getUrl(); | 
					
						
							|  |  |  |                 if (null !== $logFile) { | 
					
						
							| 
									
										
										
										
											2018-01-12 21:43:04 +01:00
										 |  |  |                     try { | 
					
						
							| 
									
										
										
										
											2018-01-28 20:59:26 +01:00
										 |  |  |                         $logContent = file_get_contents($logFile); | 
					
						
							| 
									
										
										
										
											2018-06-01 22:04:52 +02:00
										 |  |  |                         // @codeCoverageIgnoreStart
 | 
					
						
							| 
									
										
										
										
											2018-01-28 20:59:26 +01:00
										 |  |  |                     } catch (Exception $e) { | 
					
						
							| 
									
										
										
										
											2018-01-12 21:43:04 +01:00
										 |  |  |                         // don't care
 | 
					
						
							| 
									
										
										
										
											2018-03-27 19:29:58 +02:00
										 |  |  |                         Log::debug(sprintf('Could not read log file. %s', $e->getMessage())); | 
					
						
							| 
									
										
										
										
											2018-01-12 21:43:04 +01:00
										 |  |  |                     } | 
					
						
							| 
									
										
										
										
											2018-06-01 22:04:52 +02:00
										 |  |  |                     // @codeCoverageIgnoreEnd
 | 
					
						
							| 
									
										
										
										
											2017-12-31 11:38:21 +01:00
										 |  |  |                 } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         // last few lines
 | 
					
						
							| 
									
										
										
										
											2018-06-01 22:04:52 +02:00
										 |  |  |         $logContent = 'Truncated from this point <----|' . substr($logContent, -8192); | 
					
						
							| 
									
										
										
										
											2017-12-31 11:38:21 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         return view( | 
					
						
							| 
									
										
										
										
											2018-06-01 22:04:52 +02:00
										 |  |  |             'debug', compact( | 
					
						
							| 
									
										
										
										
											2018-08-17 20:01:46 +02:00
										 |  |  |                        'phpVersion', 'extensions', 'localeAttempts', 'appEnv', 'appDebug', 'logChannel', 'appLogLevel', 'now', 'packages', 'drivers', | 
					
						
							| 
									
										
										
										
											2018-06-06 21:23:00 +02:00
										 |  |  |                        'currentDriver', | 
					
						
							|  |  |  |                        'userAgent', 'displayErrors', 'errorReporting', 'phpOs', 'interface', 'logContent', 'cacheDriver', 'isDocker', 'isSandstorm', | 
					
						
							|  |  |  |                        'trustedProxies', | 
					
						
							|  |  |  |                        'toSandbox' | 
					
						
							|  |  |  |                    ) | 
					
						
							| 
									
										
										
										
											2017-12-31 11:38:21 +01:00
										 |  |  |         ); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-15 22:06:33 +02:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2018-07-22 08:10:16 +02:00
										 |  |  |      * Return all possible routes. | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2018-06-15 22:06:33 +02:00
										 |  |  |      * @return string | 
					
						
							| 
									
										
										
										
											2018-07-20 14:34:56 +02:00
										 |  |  |      * | 
					
						
							|  |  |  |      * @SuppressWarnings(PHPMD.CyclomaticComplexity) | 
					
						
							| 
									
										
										
										
											2018-06-15 22:06:33 +02:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function routes(): string | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $set    = RouteFacade::getRoutes(); | 
					
						
							|  |  |  |         $ignore = ['chart.', 'javascript.', 'json.', 'report-data.', 'popup.', 'debugbar.', 'attachments.download', 'attachments.preview', | 
					
						
							|  |  |  |                    'bills.rescan', 'budgets.income', 'currencies.def', 'error', 'flush', 'help.show', 'import.file', | 
					
						
							|  |  |  |                    'login', 'logout', 'password.reset', 'profile.confirm-email-change', 'profile.undo-email-change', | 
					
						
							|  |  |  |                    'register', 'report.options', 'routes', 'rule-groups.down', 'rule-groups.up', 'rules.up', 'rules.down', | 
					
						
							|  |  |  |                    'rules.select', 'search.search', 'test-flash', 'transactions.link.delete', 'transactions.link.switch', | 
					
						
							|  |  |  |                    'two-factor.lost', 'reports.options', 'debug', 'import.create-job', 'import.download', 'import.start', 'import.status.json', | 
					
						
							|  |  |  |                    'preferences.delete-code', 'rules.test-triggers', 'piggy-banks.remove-money', 'piggy-banks.add-money', | 
					
						
							|  |  |  |                    'accounts.reconcile.transactions', 'accounts.reconcile.overview', 'export.download', | 
					
						
							| 
									
										
										
										
											2018-06-21 18:58:27 +02:00
										 |  |  |                    'transactions.clone', 'two-factor.index', 'api.v1', 'installer.', 'attachments.view', 'import.create', | 
					
						
							|  |  |  |                    'import.job.download', 'import.job.start', 'import.job.status.json', 'import.job.store', 'recurring.events', | 
					
						
							|  |  |  |                    'recurring.suggest', | 
					
						
							| 
									
										
										
										
											2018-06-15 22:06:33 +02:00
										 |  |  |         ]; | 
					
						
							|  |  |  |         $return = ' '; | 
					
						
							|  |  |  |         /** @var Route $route */ | 
					
						
							|  |  |  |         foreach ($set as $route) { | 
					
						
							| 
									
										
										
										
											2018-07-17 22:21:03 +02:00
										 |  |  |             $name = (string)$route->getName(); | 
					
						
							|  |  |  |             if (\in_array('GET', $route->methods(), true)) { | 
					
						
							| 
									
										
										
										
											2018-06-15 22:06:33 +02:00
										 |  |  |                 $found = false; | 
					
						
							|  |  |  |                 foreach ($ignore as $string) { | 
					
						
							|  |  |  |                     if (!(false === stripos($name, $string))) { | 
					
						
							|  |  |  |                         $found = true; | 
					
						
							|  |  |  |                         break; | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                 } | 
					
						
							| 
									
										
										
										
											2018-07-08 07:59:58 +02:00
										 |  |  |                 if (false === $found) { | 
					
						
							| 
									
										
										
										
											2018-06-15 22:06:33 +02:00
										 |  |  |                     $return .= 'touch ' . $route->getName() . '.md;'; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return $return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2018-07-22 08:10:16 +02:00
										 |  |  |      * Flash all types of messages. | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2018-06-15 22:06:33 +02:00
										 |  |  |      * @param Request $request | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @return \Illuminate\Http\RedirectResponse|\Illuminate\Routing\Redirector | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     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')); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-09 17:46:14 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-05 19:35:58 +01:00
										 |  |  | } |