diff --git a/.github/workflows/run-tests.yml b/.github/workflows/run-tests.yml index 25ceba3b..fde2e9a7 100644 --- a/.github/workflows/run-tests.yml +++ b/.github/workflows/run-tests.yml @@ -37,3 +37,36 @@ jobs: - name: Execute Unit Tests run: composer test + + fix-style: + name: Fix Code Style + timeout-minutes: 15 + runs-on: ubuntu-latest + env: + COMPOSER_NO_INTERACTION: 1 + + steps: + - name: Checkout code + uses: actions/checkout@v2 + + - name: Setup PHP + uses: shivammathur/setup-php@v2 + with: + php-version: 7.4 + coverage: none + tools: composer:v2 + + - name: Install dependencies + run: | + composer update --prefer-dist --no-suggest --no-progress + + - run: composer fix-style + continue-on-error: true + + # Revert modifications so they don't get commited 💥 + - run: git checkout -- composer.json + + - uses: stefanzweifel/git-auto-commit-action@v4 + with: + commit_message: composer fix-style + commit_author: laravel-debugbar \ No newline at end of file diff --git a/composer.json b/composer.json index d4b2f640..6576f8ba 100644 --- a/composer.json +++ b/composer.json @@ -52,8 +52,8 @@ } }, "scripts": { - "check-style": "phpcs -p --standard=PSR12 config/ resources/ src/ tests/", - "fix-style": "phpcbf -p --standard=PSR12 config/ resources/ src/ tests/", + "check-style": "phpcs -p --standard=PSR12 config/ src/ tests/", + "fix-style": "phpcbf -p --standard=PSR12 config/ src/ tests/", "test": "phpunit" } } diff --git a/config/debugbar.php b/config/debugbar.php index 333cc3b1..ada83c6d 100644 --- a/config/debugbar.php +++ b/config/debugbar.php @@ -147,7 +147,7 @@ 'timeline' => false, // Add the queries to the timeline 'explain' => [ // Show EXPLAIN output on queries 'enabled' => false, - 'types' => ['SELECT'], // // workaround ['SELECT'] only. https://github.com/barryvdh/laravel-debugbar/issues/888 ['SELECT', 'INSERT', 'UPDATE', 'DELETE']; for MySQL 5.6.3+ + 'types' => ['SELECT'], // Deprecated setting, is always only SELECT ], 'hints' => false, // Show hints for common mistakes 'show_copy' => false, // Show copy button next to the query diff --git a/src/migrations/2014_12_01_120000_create_phpdebugbar_storage_table.php b/database/migrations/2014_12_01_120000_create_phpdebugbar_storage_table.php similarity index 98% rename from src/migrations/2014_12_01_120000_create_phpdebugbar_storage_table.php rename to database/migrations/2014_12_01_120000_create_phpdebugbar_storage_table.php index cb648707..7e2637ce 100644 --- a/src/migrations/2014_12_01_120000_create_phpdebugbar_storage_table.php +++ b/database/migrations/2014_12_01_120000_create_phpdebugbar_storage_table.php @@ -1,4 +1,5 @@ index('meta_uri'); $table->index('meta_ip'); $table->index('meta_method'); - }); + }); } /** * Reverse the migrations. diff --git a/src/Console/ClearCommand.php b/src/Console/ClearCommand.php index 64c7dd28..abafae91 100644 --- a/src/Console/ClearCommand.php +++ b/src/Console/ClearCommand.php @@ -1,4 +1,6 @@ -debugbar->boot(); if ($storage = $this->debugbar->getStorage()) { - try - { + try { $storage->clear(); - } catch(\InvalidArgumentException $e) { + } catch (\InvalidArgumentException $e) { // hide InvalidArgumentException if storage location does not exist - if(strpos($e->getMessage(), 'does not exist') === false) { + if (strpos($e->getMessage(), 'does not exist') === false) { throw $e; } } diff --git a/src/Controllers/AssetController.php b/src/Controllers/AssetController.php index 00c58300..646ab44a 100644 --- a/src/Controllers/AssetController.php +++ b/src/Controllers/AssetController.php @@ -1,4 +1,6 @@ -dumpAssetsToString('js'); $response = new Response( - $content, 200, [ + $content, + 200, + [ 'Content-Type' => 'text/javascript', ] ); @@ -36,7 +40,9 @@ public function css() $content = $renderer->dumpAssetsToString('css'); $response = new Response( - $content, 200, [ + $content, + 200, + [ 'Content-Type' => 'text/css', ] ); diff --git a/src/Controllers/BaseController.php b/src/Controllers/BaseController.php index 36dfe5b4..3d2f15f7 100644 --- a/src/Controllers/BaseController.php +++ b/src/Controllers/BaseController.php @@ -1,10 +1,13 @@ -debugbar = $debugbar; - if ($request->hasSession()){ + if ($request->hasSession()) { $request->session()->reflash(); } @@ -38,7 +41,7 @@ public function __construct(Request $request, LaravelDebugbar $debugbar) { $this->debugbar = $debugbar; - if ($request->hasSession()){ + if ($request->hasSession()) { $request->session()->reflash(); } } diff --git a/src/Controllers/CacheController.php b/src/Controllers/CacheController.php index 3d04305a..c347700b 100644 --- a/src/Controllers/CacheController.php +++ b/src/Controllers/CacheController.php @@ -1,4 +1,6 @@ -json(compact('success')); } - } diff --git a/src/Controllers/OpenHandlerController.php b/src/Controllers/OpenHandlerController.php index 77056f40..c2e95b30 100644 --- a/src/Controllers/OpenHandlerController.php +++ b/src/Controllers/OpenHandlerController.php @@ -1,4 +1,6 @@ -handle(null, false, false); return new Response( - $data, 200, [ + $data, + 200, + [ 'Content-Type' => 'application/json' ] ); diff --git a/src/Controllers/TelescopeController.php b/src/Controllers/TelescopeController.php index e98118ed..dcc4d2f6 100644 --- a/src/Controllers/TelescopeController.php +++ b/src/Controllers/TelescopeController.php @@ -1,4 +1,6 @@ - 'forgotten', ]; - public function __construct($requestStartTime = null, $collectValues) + public function __construct($requestStartTime, $collectValues) { parent::__construct(); diff --git a/src/DataCollector/EventCollector.php b/src/DataCollector/EventCollector.php index d3974a41..07b67af2 100644 --- a/src/DataCollector/EventCollector.php +++ b/src/DataCollector/EventCollector.php @@ -1,4 +1,5 @@ events->getListeners($name) as $i => $listener) { - // Check if it's an object + method name if (is_array($listener) && count($listener) > 1 && is_object($listener[0])) { list($class, $method) = $listener; @@ -53,7 +53,8 @@ public function onWildcardEvent($name = null, $data = []) // Format the closure to a readable format $filename = ltrim(str_replace(base_path(), '', $reflector->getFileName()), '/'); - $listener = $reflector->getName() . ' (' . $filename . ':' . $reflector->getStartLine() . '-' . $reflector->getEndLine() . ')'; + $lines = $reflector->getStartLine() . '-' . $reflector->getEndLine(); + $listener = $reflector->getName() . ' (' . $filename . ':' . $lines . ')'; } else { // Not sure if this is possible, but to prevent edge cases $listener = $this->getDataFormatter()->formatVar($listener); diff --git a/src/DataCollector/FilesCollector.php b/src/DataCollector/FilesCollector.php index 4c56837c..2371b95e 100644 --- a/src/DataCollector/FilesCollector.php +++ b/src/DataCollector/FilesCollector.php @@ -34,7 +34,8 @@ public function collect() foreach ($files as $file) { // Skip the files from Debugbar, they are only loaded for Debugging and confuse the output. // Of course some files are stil always loaded (ServiceProvider, Facade etc) - if (strpos($file, 'vendor/maximebf/debugbar/src') !== false || strpos( + if ( + strpos($file, 'vendor/maximebf/debugbar/src') !== false || strpos( $file, 'vendor/barryvdh/laravel-debugbar/src' ) !== false diff --git a/src/DataCollector/GateCollector.php b/src/DataCollector/GateCollector.php index f9dce319..e0823533 100644 --- a/src/DataCollector/GateCollector.php +++ b/src/DataCollector/GateCollector.php @@ -22,12 +22,12 @@ public function __construct(Gate $gate) { parent::__construct('gate'); $this->setDataFormatter(new SimpleFormatter()); - $gate->after(function ($user = null, $ability, $result, $arguments = []) { + $gate->after(function ($user, $ability, $result, $arguments = []) { $this->addCheck($user, $ability, $result, $arguments); }); } - public function addCheck($user = null, $ability, $result, $arguments = []) + public function addCheck($user, $ability, $result, $arguments = []) { $userKey = 'user'; $userId = null; diff --git a/src/DataCollector/LivewireCollector.php b/src/DataCollector/LivewireCollector.php index 800e9a96..fe8d29d8 100644 --- a/src/DataCollector/LivewireCollector.php +++ b/src/DataCollector/LivewireCollector.php @@ -23,12 +23,12 @@ class LivewireCollector extends DataCollector implements DataCollectorInterface, public function __construct(Request $request) { // Listen to Livewire views - Livewire::listen('view:render', function(View $view) use ($request) { + Livewire::listen('view:render', function (View $view) use ($request) { /** @var \Livewire\Component $component */ $component = $view->getData()['_instance']; // Create an unique name for each compoent - $key = $component->getName() . ' #' .$component->id; + $key = $component->getName() . ' #' . $component->id; $data = [ 'data' => $component->getPublicPropertiesDefinedBySubClass(), diff --git a/src/DataCollector/LogsCollector.php b/src/DataCollector/LogsCollector.php index 2950e950..28ed6e14 100644 --- a/src/DataCollector/LogsCollector.php +++ b/src/DataCollector/LogsCollector.php @@ -1,4 +1,5 @@ guards as $guardName => $config) { + foreach ($this->guards as $guardName => $config) { try { $guard = $this->auth->guard($guardName); if ($this->hasUser($guard)) { $user = $guard->user(); - if(!is_null($user)) { + if (!is_null($user)) { $data['guards'][$guardName] = $this->getUserInformation($user); $names .= $guardName . ": " . $data['guards'][$guardName]['name'] . ', '; } @@ -166,5 +165,4 @@ public function getWidgets() return $widgets; } - } diff --git a/src/DataCollector/PhpInfoCollector.php b/src/DataCollector/PhpInfoCollector.php index 764b9ccb..0c955e90 100644 --- a/src/DataCollector/PhpInfoCollector.php +++ b/src/DataCollector/PhpInfoCollector.php @@ -1,4 +1,5 @@ prepareBindings($bindings); // Run EXPLAIN on this query (if needed) - if ($this->explainQuery && $pdo && preg_match('/^\s*('.implode('|', $this->explainTypes).') /i', $query)) { + if ($this->explainQuery && $pdo && preg_match('/^\s*(' . implode('|', $this->explainTypes) . ') /i', $query)) { $statement = $pdo->prepare('EXPLAIN ' . $query); $statement->execute($bindings); $explainResults = $statement->fetchAll(\PDO::FETCH_CLASS); @@ -210,6 +210,7 @@ protected function emulateQuote($value) */ protected function performQueryAnalysis($query) { + // @codingStandardsIgnoreStart $hints = []; if (preg_match('/^\\s*SELECT\\s*`?[a-zA-Z0-9]*`?\\.?\\*/i', $query)) { $hints[] = 'Use SELECT * only if you need all columns from table'; @@ -229,10 +230,12 @@ protected function performQueryAnalysis($query) $hints[] = 'LIMIT without ORDER BY causes non-deterministic results, depending on the query execution plan'; } if (preg_match('/LIKE\\s[\'"](%.*?)[\'"]/i', $query, $matches)) { - $hints[] = 'An argument has a leading wildcard character: ' . $matches[1]. '. + $hints[] = 'An argument has a leading wildcard character: ' . $matches[1] . '. The predicate with this argument is not sargable and cannot use an index if one exists.'; } return $hints; + + // @codingStandardsIgnoreEnd } /** @@ -275,7 +278,8 @@ protected function parseTrace($index, array $trace) return $frame; } - if (isset($trace['class']) && + if ( + isset($trace['class']) && isset($trace['file']) && !$this->fileIsInExcludedPath($trace['file']) ) { @@ -369,7 +373,7 @@ protected function findViewFromHash($hash) $this->reflection['viewfinderViews'] = $property; } - foreach ($property->getValue($finder) as $name => $path){ + foreach ($property->getValue($finder) as $name => $path) { if (sha1($path) == $hash || md5($path) == $hash) { return $name; } @@ -476,9 +480,9 @@ public function collect() ]; //Add the results from the explain as new rows - foreach($query['explain'] as $explain){ + foreach ($query['explain'] as $explain) { $statements[] = [ - 'sql' => ' - EXPLAIN #' . $explain->id . ': `' . $explain->table . '` (' . $explain->select_type . ')', + 'sql' => " - EXPLAIN # {$explain->id}: `{$explain->table}` ({$explain->select_type})", 'type' => 'explain', 'params' => $explain, 'row_count' => $explain->rows, diff --git a/src/DataCollector/RequestCollector.php b/src/DataCollector/RequestCollector.php index 3a243781..25760a4e 100644 --- a/src/DataCollector/RequestCollector.php +++ b/src/DataCollector/RequestCollector.php @@ -30,7 +30,7 @@ class RequestCollector extends DataCollector implements DataCollectorInterface, * Create a new SymfonyRequestCollector * * @param \Symfony\Component\HttpFoundation\Request $request - * @param \Symfony\Component\HttpFoundation\Request $response + * @param \Symfony\Component\HttpFoundation\Response $response * @param \Symfony\Component\HttpFoundation\Session\SessionInterface $session */ public function __construct($request, $response, $session = null, $currentRequestId = null) @@ -116,8 +116,10 @@ public function collect() } foreach ($data['request_server'] as $key => $value) { - if (Str::is('*_KEY', $key) || Str::is('*_PASSWORD', $key) - || Str::is('*_SECRET', $key) || Str::is('*_PW', $key)) { + if ( + Str::is('*_KEY', $key) || Str::is('*_PASSWORD', $key) + || Str::is('*_SECRET', $key) || Str::is('*_PW', $key) + ) { $data['request_server'][$key] = '******'; } } @@ -129,7 +131,7 @@ public function collect() if (isset($data['request_server']['PHP_AUTH_PW'])) { $data['request_server']['PHP_AUTH_PW'] = '******'; } - ; + ; foreach ($data as $key => $var) { if (!is_string($data[$key])) { @@ -137,7 +139,6 @@ public function collect() } else { $data[$key] = e($data[$key]); } - } $htmlData = []; @@ -147,7 +148,7 @@ public function collect() ])->type('debugbar'); Telescope::$entriesQueue[] = $entry; $url = route('debugbar.telescope', [$entry->uuid]); - $htmlData['telescope'] = 'View in Telescope'; + $htmlData['telescope'] = 'View in Telescope'; } return $htmlData + $data; @@ -172,10 +173,10 @@ private function getCookieHeader($name, $value, $expires, $path, $domain, $secur } $cookie .= '; expires=' . substr( - \DateTime::createFromFormat('U', $expires, new \DateTimeZone('UTC'))->format('D, d-M-Y H:i:s T'), - 0, - -5 - ); + \DateTime::createFromFormat('U', $expires, new \DateTimeZone('UTC'))->format('D, d-M-Y H:i:s T'), + 0, + -5 + ); } if ($domain) { diff --git a/src/DataCollector/RouteCollector.php b/src/DataCollector/RouteCollector.php index 2df08fbb..53c9b673 100644 --- a/src/DataCollector/RouteCollector.php +++ b/src/DataCollector/RouteCollector.php @@ -49,22 +49,26 @@ protected function getRouteInformation($route) return []; } $uri = head($route->methods()) . ' ' . $route->uri(); - $action = $route->getAction(); + $action = $route->getAction(); $result = [ - 'uri' => $uri ?: '-', + 'uri' => $uri ?: '-', ]; $result = array_merge($result, $action); - if (isset($action['controller']) && is_string($action['controller']) && strpos($action['controller'], '@') !== false) { - list($controller, $method) = explode('@', $action['controller']); - if(class_exists($controller) && method_exists($controller, $method)) { - $reflector = new \ReflectionMethod($controller, $method); - } + if ( + isset($action['controller']) + && is_string($action['controller']) + && strpos($action['controller'], '@') !== false + ) { + list($controller, $method) = explode('@', $action['controller']); + if (class_exists($controller) && method_exists($controller, $method)) { + $reflector = new \ReflectionMethod($controller, $method); + } unset($result['uses']); - } elseif (isset($action['uses']) && $action['uses'] instanceof \Closure) { + } elseif (isset($action['uses']) && $action['uses'] instanceof \Closure) { $reflector = new \ReflectionFunction($action['uses']); $result['uses'] = $this->formatVar($result['uses']); } @@ -74,9 +78,9 @@ protected function getRouteInformation($route) $result['file'] = $filename . ':' . $reflector->getStartLine() . '-' . $reflector->getEndLine(); } - if ($middleware = $this->getMiddleware($route)) { - $result['middleware'] = $middleware; - } + if ($middleware = $this->getMiddleware($route)) { + $result['middleware'] = $middleware; + } diff --git a/src/DataCollector/ViewCollector.php b/src/DataCollector/ViewCollector.php index b7c657e1..46a33166 100644 --- a/src/DataCollector/ViewCollector.php +++ b/src/DataCollector/ViewCollector.php @@ -88,7 +88,7 @@ public function addView(View $view) 'type' => $type, ]; - if ( $this->getXdebugLink($path)) { + if ($this->getXdebugLink($path)) { $template['xdebug_link'] = $this->getXdebugLink($path); } diff --git a/src/DataFormatter/QueryFormatter.php b/src/DataFormatter/QueryFormatter.php index 0ad33bc0..8b77c614 100644 --- a/src/DataFormatter/QueryFormatter.php +++ b/src/DataFormatter/QueryFormatter.php @@ -15,10 +15,10 @@ class QueryFormatter extends DataFormatter */ public function formatSql($sql) { - $sql = preg_replace("/\?(?=(?:[^'\\\']*'[^'\\']*')*[^'\\\']*$)(?:\?)/", '?', $sql); - $sql = trim(preg_replace("/\s*\n\s*/", "\n", $sql)); + $sql = preg_replace("/\?(?=(?:[^'\\\']*'[^'\\']*')*[^'\\\']*$)(?:\?)/", '?', $sql); + $sql = trim(preg_replace("/\s*\n\s*/", "\n", $sql)); - return $sql; + return $sql; } /** diff --git a/src/DataFormatter/SimpleFormatter.php b/src/DataFormatter/SimpleFormatter.php index 0a1fc938..0b06c2bb 100644 --- a/src/DataFormatter/SimpleFormatter.php +++ b/src/DataFormatter/SimpleFormatter.php @@ -60,7 +60,8 @@ private function exportValue($value, $depth = 1, $deep = false) } if ($deep) { - return sprintf("[\n%s%s\n%s]", $indent, implode(sprintf(", \n%s", $indent), $a), str_repeat(' ', $depth - 1)); + $args = [$indent, implode(sprintf(", \n%s", $indent), $a), str_repeat(' ', $depth - 1)]; + return sprintf("[\n%s%s\n%s]", $args); } $s = sprintf('[%s]', implode(', ', $a)); diff --git a/src/Facade.php b/src/Facade.php index 510e9398..a4e15b4b 100644 --- a/src/Facade.php +++ b/src/Facade.php @@ -1,14 +1,18 @@ -app; // Set custom error handler - if ($app['config']->get('debugbar.error_handler' , false)) { + if ($app['config']->get('debugbar.error_handler', false)) { set_error_handler([$this, 'handleError']); } @@ -147,7 +148,7 @@ public function boot() if ($this->shouldCollect('time', true)) { $this->addCollector(new TimeDataCollector()); - if ( ! $this->isLumen()) { + if (! $this->isLumen()) { $this->app->booted( function () use ($debugbar) { $startTime = $this->app['request']->server('REQUEST_TIME_FLOAT'); @@ -190,7 +191,6 @@ function () use ($debugbar) { $eventCollector = new EventCollector($startTime); $this->addCollector($eventCollector); $this->app['events']->subscribe($eventCollector); - } catch (\Exception $e) { $this->addThrowable( new Exception( @@ -218,7 +218,9 @@ function ($view, $data = []) use ($debugbar) { } catch (\Exception $e) { $this->addThrowable( new Exception( - 'Cannot add ViewCollector to Laravel Debugbar: ' . $e->getMessage(), $e->getCode(), $e + 'Cannot add ViewCollector to Laravel Debugbar: ' . $e->getMessage(), + $e->getCode(), + $e ) ); } @@ -277,7 +279,9 @@ function ($level, $message = null, $context = null) use ($logger) { } catch (\Exception $e) { $this->addThrowable( new Exception( - 'Cannot add LogsCollector to Laravel Debugbar: ' . $e->getMessage(), $e->getCode(), $e + 'Cannot add LogsCollector to Laravel Debugbar: ' . $e->getMessage(), + $e->getCode(), + $e ) ); } @@ -285,7 +289,8 @@ function ($level, $message = null, $context = null) use ($logger) { if ($this->shouldCollect('db', true) && isset($this->app['db'])) { $db = $this->app['db']; - if ($debugbar->hasCollector('time') && $this->app['config']->get( + if ( + $debugbar->hasCollector('time') && $this->app['config']->get( 'debugbar.options.db.timeline', false ) @@ -329,14 +334,22 @@ function ($level, $message = null, $context = null) use ($logger) { try { $db->listen( - function ($query, $bindings = null, $time = null, $connectionName = null) use ($db, $queryCollector) { + function ( + $query, + $bindings = null, + $time = null, + $connectionName = null + ) use ( + $db, + $queryCollector + ) { if (!$this->shouldCollect('db', true)) { return; // Issue 776 : We've turned off collecting after the listener was attached } // Laravel 5.2 changed the way some core events worked. We must account for // the first argument being an "event object", where arguments are passed // via object properties, instead of individual arguments. - if ( $query instanceof \Illuminate\Database\Events\QueryExecuted ) { + if ($query instanceof \Illuminate\Database\Events\QueryExecuted) { $bindings = $query->bindings; $time = $query->time; $connection = $query->connection; @@ -420,7 +433,7 @@ function ($event, $params) use ($queryCollector) { try { $modelsCollector = $this->app->make('Barryvdh\Debugbar\DataCollector\ModelsCollector'); $this->addCollector($modelsCollector); - } catch (\Exception $e){ + } catch (\Exception $e) { // No Models collector } } @@ -429,7 +442,7 @@ function ($event, $params) use ($queryCollector) { try { $livewireCollector = $this->app->make('Barryvdh\Debugbar\DataCollector\LivewireCollector'); $this->addCollector($livewireCollector); - } catch (\Exception $e){ + } catch (\Exception $e) { $this->addThrowable( new Exception('Cannot add Livewire Collector: ' . $e->getMessage(), $e->getCode(), $e) ); @@ -440,7 +453,8 @@ function ($event, $params) use ($queryCollector) { try { $mailer = $this->app['mailer']->getSwiftMailer(); $this->addCollector(new SwiftMailCollector($mailer)); - if ($this->app['config']->get('debugbar.options.mail.full_log') && $this->hasCollector( + if ( + $this->app['config']->get('debugbar.options.mail.full_log') && $this->hasCollector( 'messages' ) ) { @@ -449,7 +463,9 @@ function ($event, $params) use ($queryCollector) { } catch (\Exception $e) { $this->addThrowable( new Exception( - 'Cannot add MailCollector to Laravel Debugbar: ' . $e->getMessage(), $e->getCode(), $e + 'Cannot add MailCollector to Laravel Debugbar: ' . $e->getMessage(), + $e->getCode(), + $e ) ); } @@ -462,7 +478,9 @@ function ($event, $params) use ($queryCollector) { } catch (\Exception $e) { $this->addThrowable( new Exception( - 'Cannot add LogsCollector to Laravel Debugbar: ' . $e->getMessage(), $e->getCode(), $e + 'Cannot add LogsCollector to Laravel Debugbar: ' . $e->getMessage(), + $e->getCode(), + $e ) ); } @@ -471,29 +489,31 @@ function ($event, $params) use ($queryCollector) { $this->addCollector(new FilesCollector($app)); } - if ($this->shouldCollect('auth', false)) { - try { - $guards = $this->app['config']->get('auth.guards', []); - $authCollector = new MultiAuthCollector($app['auth'], $guards); - - $authCollector->setShowName( - $this->app['config']->get('debugbar.options.auth.show_name') - ); - $this->addCollector($authCollector); - } catch (\Exception $e) { - $this->addThrowable( - new Exception( - 'Cannot add AuthCollector to Laravel Debugbar: ' . $e->getMessage(), $e->getCode(), $e - ) - ); - } - } + if ($this->shouldCollect('auth', false)) { + try { + $guards = $this->app['config']->get('auth.guards', []); + $authCollector = new MultiAuthCollector($app['auth'], $guards); + + $authCollector->setShowName( + $this->app['config']->get('debugbar.options.auth.show_name') + ); + $this->addCollector($authCollector); + } catch (\Exception $e) { + $this->addThrowable( + new Exception( + 'Cannot add AuthCollector to Laravel Debugbar: ' . $e->getMessage(), + $e->getCode(), + $e + ) + ); + } + } if ($this->shouldCollect('gate', false)) { try { $gateCollector = $this->app->make('Barryvdh\Debugbar\DataCollector\GateCollector'); $this->addCollector($gateCollector); - } catch (\Exception $e){ + } catch (\Exception $e) { // No Gate collector } } @@ -505,7 +525,6 @@ function ($event, $params) use ($queryCollector) { $cacheCollector = new CacheCollector($startTime, $collectValues); $this->addCollector($cacheCollector); $this->app['events']->subscribe($cacheCollector); - } catch (\Exception $e) { $this->addThrowable( new Exception( @@ -676,7 +695,7 @@ public function modifyResponse(Request $request, Response $response) } } - if ($this->app->bound(SessionManager::class)){ + if ($this->app->bound(SessionManager::class)) { /** @var \Illuminate\Session\SessionManager $sessionManager */ $sessionManager = $app->make(SessionManager::class); @@ -702,7 +721,8 @@ public function modifyResponse(Request $request, Response $response) if ($this->shouldCollect('symfony_request', true) && !$this->hasCollector('request')) { try { - $this->addCollector(new RequestCollector($request, $response, $sessionManager, $this->getCurrentRequestId())); + $reqId = $this->getCurrentRequestId(); + $this->addCollector(new RequestCollector($request, $response, $sessionManager, $reqId)); } catch (\Exception $e) { $this->addThrowable( new Exception( @@ -715,7 +735,6 @@ public function modifyResponse(Request $request, Response $response) } if ($app['config']->get('debugbar.clockwork') && ! $this->hasCollector('clockwork')) { - try { $this->addCollector(new ClockworkCollector($request, $response, $sessionManager)); } catch (\Exception $e) { @@ -747,16 +766,15 @@ public function modifyResponse(Request $request, Response $response) if ($app['config']->get('debugbar.add_ajax_timing', false)) { $this->addServerTimingHeaders($response); } - } catch (\Exception $e) { $app['log']->error('Debugbar exception: ' . $e->getMessage()); } } elseif ( ($response->headers->has('Content-Type') && - strpos($response->headers->get('Content-Type'), 'html') === false) - || $request->getRequestFormat() !== 'html' - || $response->getContent() === false - || $this->isJsonRequest($request) + strpos($response->headers->get('Content-Type'), 'html') === false) || + $request->getRequestFormat() !== 'html' || + $response->getContent() === false || + $this->isJsonRequest($request) ) { try { // Just collect + store data, don't inject it. @@ -1013,7 +1031,7 @@ public function __call($method, $args) { $messageLevels = ['emergency', 'alert', 'critical', 'error', 'warning', 'notice', 'info', 'debug', 'log']; if (in_array($method, $messageLevels)) { - foreach($args as $arg) { + foreach ($args as $arg) { $this->addMessage($arg, $method); } } @@ -1097,7 +1115,7 @@ protected function addClockworkHeaders(Response $response) $prefix = $this->app['config']->get('debugbar.route_prefix'); $response->headers->set('X-Clockwork-Id', $this->getCurrentRequestId(), true); $response->headers->set('X-Clockwork-Version', 1, true); - $response->headers->set('X-Clockwork-Path', $prefix .'/clockwork/', true); + $response->headers->set('X-Clockwork-Path', $prefix . '/clockwork/', true); } /** diff --git a/src/LumenServiceProvider.php b/src/LumenServiceProvider.php index a3542753..ed629711 100644 --- a/src/LumenServiceProvider.php +++ b/src/LumenServiceProvider.php @@ -1,4 +1,6 @@ -debugbar->modifyResponse($request, $response); return $response; - } /** diff --git a/src/Resources/cache/widget.js b/src/Resources/cache/widget.js index ad7d967f..5314eace 100644 --- a/src/Resources/cache/widget.js +++ b/src/Resources/cache/widget.js @@ -1,4 +1,4 @@ -(function($) { +(function ($) { var csscls = PhpDebugBar.utils.makecsscls('phpdebugbar-widgets-'); @@ -14,39 +14,39 @@ className: csscls('timeline cache'), - onForgetClick: function(e, el) { + onForgetClick: function (e, el) { e.stopPropagation(); $.ajax({ url: $(el).attr("data-url"), type: 'DELETE', - success: function(result) { + success: function (result) { $(el).fadeOut(200); } }); }, - render: function() { + render: function () { LaravelCacheWidget.__super__.render.apply(this); - this.bindAttr('data', function(data) { + this.bindAttr('data', function (data) { if (data.measures) { var self = this; - var lines = this.$el.find('.'+csscls('measure')); + var lines = this.$el.find('.' + csscls('measure')); for (var i = 0; i < data.measures.length; i++) { var measure = data.measures[i]; var m = lines[i]; if (measure.params && !$.isEmptyObject(measure.params)) { - if (measure.params.delete && measure.params.key) { $('') .addClass(csscls('forget')) .text('forget') .attr('data-url', measure.params.delete) - .one('click', function(e) { self.onForgetClick(e, this); }) + .one('click', function (e) { + self.onForgetClick(e, this); }) .appendTo(m); } } diff --git a/src/Resources/sqlqueries/widget.js b/src/Resources/sqlqueries/widget.js index 0b110447..189da8cb 100644 --- a/src/Resources/sqlqueries/widget.js +++ b/src/Resources/sqlqueries/widget.js @@ -1,4 +1,4 @@ -(function($) { +(function ($) { var csscls = PhpDebugBar.utils.makecsscls('phpdebugbar-widgets-'); @@ -12,11 +12,11 @@ className: csscls('sqlqueries'), - onFilterClick: function(el) { + onFilterClick: function (el) { $(el).toggleClass(csscls('excluded')); var excludedLabels = []; - this.$toolbar.find(csscls('.filter') + csscls('.excluded')).each(function() { + this.$toolbar.find(csscls('.filter') + csscls('.excluded')).each(function () { excludedLabels.push(this.rel); }); @@ -52,14 +52,14 @@ select(code); }, - render: function() { + render: function () { this.$status = $('
').addClass(csscls('status')).appendTo(this.$el); this.$toolbar = $('
').addClass(csscls('toolbar')).appendTo(this.$el); var filters = [], self = this; - this.$list = new PhpDebugBar.Widgets.ListWidget({ itemRenderer: function(li, stmt) { + this.$list = new PhpDebugBar.Widgets.ListWidget({ itemRenderer: function (li, stmt) { if (stmt.type === 'transaction') { $('').addClass(csscls('sql')).addClass(csscls('name')).text(stmt.sql).appendTo(li); } else { @@ -86,9 +86,10 @@ .addClass(csscls('filter')) .text(stmt.connection) .attr('rel', stmt.connection) - .on('click', function() { self.onFilterClick(this); }) + .on('click', function () { + self.onFilterClick(this); }) .appendTo(self.$toolbar); - if (filters.length>1) { + if (filters.length > 1) { self.$toolbar.show(); self.$list.$el.css("margin-bottom","20px"); } @@ -120,7 +121,7 @@ var $span = $('').addClass('phpdebugbar-text-muted'); var index = 0; - var $bindings = new PhpDebugBar.Widgets.ListWidget({ itemRenderer: function(li, binding) { + var $bindings = new PhpDebugBar.Widgets.ListWidget({ itemRenderer: function (li, binding) { var $index = $span.clone().text(index++ + '.'); li.append($index, ' ', binding).removeClass(csscls('list-item')).addClass(csscls('table-list-item')); }}); @@ -143,7 +144,7 @@ var $name = $('').addClass(csscls('name')).html('Hints ' + $icon); var $value = $('').addClass(csscls('value')); - var $hints = new PhpDebugBar.Widgets.ListWidget({ itemRenderer: function(li, hint) { + var $hints = new PhpDebugBar.Widgets.ListWidget({ itemRenderer: function (li, hint) { li.append(hint).removeClass(csscls('list-item')).addClass(csscls('table-list-item')); }}); @@ -165,7 +166,7 @@ var $value = $('').addClass(csscls('value')); var $span = $('').addClass('phpdebugbar-text-muted'); - var $backtrace = new PhpDebugBar.Widgets.ListWidget({ itemRenderer: function(li, source) { + var $backtrace = new PhpDebugBar.Widgets.ListWidget({ itemRenderer: function (li, source) { var $parts = [ $span.clone().text(source.index + '.'), ' ', @@ -201,7 +202,7 @@ } } - li.css('cursor', 'pointer').click(function() { + li.css('cursor', 'pointer').click(function () { if (table.is(':visible')) { table.hide(); } else { @@ -211,14 +212,14 @@ }}); this.$list.$el.appendTo(this.$el); - this.bindAttr('data', function(data) { + this.bindAttr('data', function (data) { this.$list.set('data', data.statements); this.$status.empty(); var stmt; // Search for duplicate statements. for (var sql = {}, duplicate = 0, i = 0; i < data.statements.length; i++) { - if(data.statements[i].type === 'query') { + if (data.statements[i].type === 'query') { stmt = data.statements[i].sql; if (data.statements[i].bindings && data.statements[i].bindings.length) { stmt += JSON.stringify(data.statements[i].bindings); @@ -238,7 +239,7 @@ for (i = 0; i < sql[stmt].keys.length; i++) { this.$list.$el.find('.' + csscls('list-item')).eq(sql[stmt].keys[i]) .addClass(csscls('sql-duplicate')) - .addClass(csscls('sql-duplicate-'+duplicate)); + .addClass(csscls('sql-duplicate-' + duplicate)); } } } diff --git a/src/ServiceProvider.php b/src/ServiceProvider.php index a3975ee6..ef9ecc43 100644 --- a/src/ServiceProvider.php +++ b/src/ServiceProvider.php @@ -1,4 +1,6 @@ -mergeConfigFrom($configPath, 'debugbar'); - $this->loadRoutesFrom(realpath(__DIR__.'/debugbar-routes.php')); + $this->loadRoutesFrom(realpath(__DIR__ . '/debugbar-routes.php')); $this->app->alias( DataFormatter::class, @@ -37,19 +39,19 @@ public function register() $this->app->singleton(LaravelDebugbar::class, function () { $debugbar = new LaravelDebugbar($this->app); - if ($this->app->bound(SessionManager::class)) { - $sessionManager = $this->app->make(SessionManager::class); - $httpDriver = new SymfonyHttpDriver($sessionManager); - $debugbar->setHttpDriver($httpDriver); - } + if ($this->app->bound(SessionManager::class)) { + $sessionManager = $this->app->make(SessionManager::class); + $httpDriver = new SymfonyHttpDriver($sessionManager); + $debugbar->setHttpDriver($httpDriver); + } return $debugbar; - } - ); + }); $this->app->alias(LaravelDebugbar::class, 'debugbar'); - $this->app->singleton('command.debugbar.clear', + $this->app->singleton( + 'command.debugbar.clear', function ($app) { return new Console\ClearCommand($app['debugbar']); } diff --git a/src/Storage/FilesystemStorage.php b/src/Storage/FilesystemStorage.php index 1ea11aee..327f2ebd 100644 --- a/src/Storage/FilesystemStorage.php +++ b/src/Storage/FilesystemStorage.php @@ -67,9 +67,11 @@ public function makeFilename($id) */ protected function garbageCollect() { - foreach (Finder::create()->files()->name('*.json')->date('< ' . $this->gc_lifetime . ' hour ago')->in( - $this->dirname - ) as $file) { + foreach ( + Finder::create()->files()->name('*.json')->date('< ' . $this->gc_lifetime . ' hour ago')->in( + $this->dirname + ) as $file + ) { $this->files->delete($file->getRealPath()); } } diff --git a/src/Support/Clockwork/ClockworkCollector.php b/src/Support/Clockwork/ClockworkCollector.php index 752132b2..3923a9fe 100644 --- a/src/Support/Clockwork/ClockworkCollector.php +++ b/src/Support/Clockwork/ClockworkCollector.php @@ -87,5 +87,4 @@ public function collect() return $data; } - } diff --git a/src/Support/Clockwork/Converter.php b/src/Support/Clockwork/Converter.php index 409cdf84..79dfb695 100644 --- a/src/Support/Clockwork/Converter.php +++ b/src/Support/Clockwork/Converter.php @@ -1,6 +1,9 @@ - [], 'description' => $measure['label'], @@ -79,7 +82,7 @@ public function convert($data) } if (isset($data['messages'])) { - foreach($data['messages']['messages'] as $message) { + foreach ($data['messages']['messages'] as $message) { $output['log'][] = [ 'message' => $message['message'], 'time' => $message['time'], @@ -90,7 +93,7 @@ public function convert($data) if (isset($data['queries'])) { $queries = $data['queries']; - foreach($queries['statements'] as $statement){ + foreach ($queries['statements'] as $statement) { if ($statement['type'] === 'explain') { continue; } @@ -121,7 +124,7 @@ public function convert($data) } if (isset($data['swiftmailer_mails'])) { - foreach($data['swiftmailer_mails']['mails'] as $mail) { + foreach ($data['swiftmailer_mails']['mails'] as $mail) { $output['emailsData'][] = [ 'data' => [ 'to' => $mail['to'], @@ -134,5 +137,4 @@ public function convert($data) return $output; } - } diff --git a/src/Twig/Extension/Debug.php b/src/Twig/Extension/Debug.php index 1b815e53..42bc2cb3 100644 --- a/src/Twig/Extension/Debug.php +++ b/src/Twig/Extension/Debug.php @@ -1,4 +1,6 @@ - true, 'needs_environment' => true] + 'debug', + [$this, 'debug'], + ['needs_context' => true, 'needs_environment' => true] ), ]; } diff --git a/src/Twig/Extension/Dump.php b/src/Twig/Extension/Dump.php index 4a4f697e..b42fafa4 100644 --- a/src/Twig/Extension/Dump.php +++ b/src/Twig/Extension/Dump.php @@ -1,4 +1,6 @@ - ['html'], 'needs_context' => true, 'needs_environment' => true] + 'dump', + [$this, 'dump'], + ['is_safe' => ['html'], 'needs_context' => true, 'needs_environment' => true] ), ]; } @@ -79,6 +83,6 @@ public function dump(Twig_Environment $env, $context) } } - return '
'.$output.'
'; + return '
' . $output . '
'; } } diff --git a/src/Twig/Extension/Stopwatch.php b/src/Twig/Extension/Stopwatch.php index 993d8ddb..80a012bd 100644 --- a/src/Twig/Extension/Stopwatch.php +++ b/src/Twig/Extension/Stopwatch.php @@ -1,4 +1,6 @@ - [\Barryvdh\Debugbar\Middleware\DebugbarEnabled::class], ]; -app('router')->group($routeConfig, function($router) { +app('router')->group($routeConfig, function ($router) { $router->get('open', [ 'uses' => 'OpenHandlerController@handle', 'as' => 'debugbar.openhandler', diff --git a/tests/DataCollector/ModelsCollectorTest.php b/tests/DataCollector/ModelsCollectorTest.php index e96d4c0a..1a4925eb 100644 --- a/tests/DataCollector/ModelsCollectorTest.php +++ b/tests/DataCollector/ModelsCollectorTest.php @@ -2,8 +2,9 @@ namespace Barryvdh\Debugbar\Tests\DataCollector; +use Barryvdh\Debugbar\Tests\Models\Person; +use Barryvdh\Debugbar\Tests\Models\User; use Barryvdh\Debugbar\Tests\TestCase; -use Illuminate\Database\Eloquent\Model; use Illuminate\Foundation\Testing\RefreshDatabase; use Illuminate\Support\Facades\Hash; @@ -11,8 +12,7 @@ class ModelsCollectorTest extends TestCase { use RefreshDatabase; - /** @test */ - public function it_collects_retrieved_models() + public function testItCollectsRetrievedModels() { $this->loadLaravelMigrations(); @@ -53,13 +53,3 @@ public function it_collects_retrieved_models() ); } } - -class User extends Model -{ - protected $table = 'users'; - protected $guarded = []; -} - -class Person extends User -{ -} diff --git a/tests/DataCollector/QueryCollectorTest.php b/tests/DataCollector/QueryCollectorTest.php index 16bcc594..e4127fea 100644 --- a/tests/DataCollector/QueryCollectorTest.php +++ b/tests/DataCollector/QueryCollectorTest.php @@ -10,8 +10,7 @@ class QueryCollectorTest extends TestCase { use RefreshDatabase; - /** @test */ - public function it_replaces_question_marks_bindings_correctly() + public function testItReplacesQuestionMarksBindingsCorrectly() { $this->loadLaravelMigrations(); @@ -31,7 +30,10 @@ public function it_replaces_question_marks_bindings_correctly() tap(Arr::first($collection['statements']), function (array $statement) { $this->assertEquals([3, '{4}'], $statement['bindings']); - $this->assertEquals("SELECT ('[1, 2, 3]'::jsonb ? 3) as a, ('[4, 5, 6]'::jsonb ?| '{4}') as b, 'hello world ? example ??' as c", $statement['sql']); + $this->assertEquals(<<