struggle-for-php / sfp-phpstan-psr-log
Extra strict and opinionated psr/log (psr-3) rules for PHPStan
Installs: 83 615
Dependents: 12
Suggesters: 0
Security: 0
Stars: 36
Watchers: 2
Forks: 2
Open Issues: 6
Type:phpstan-extension
Requires
- php: ^7.2.0 || ~8.0.0 || ~8.1.0 || ~8.2.0 || ~8.3.0 || ~8.4.0
- phpstan/phpstan: ^1.12 || ^2.0
- struggle-for-php/sfp-stubs-psr-log: ^1.0.1 || ^2 || ^3.0.1
Requires (Dev)
- laminas/laminas-coding-standard: ^2.0.0
- maglnet/composer-require-checker: ^2|^3|^4
- phpstan/phpstan-phpunit: ^1.3 || ^2.0
- phpstan/phpstan-strict-rules: ^1.5 || ^2.0
- phpunit/phpunit: ^8.5.31 || ^9.5.10 || ^10.5.35
- roave/security-advisories: dev-master
- squizlabs/php_codesniffer: ^3.7
- vimeo/psalm: ^4 || ^5.26
Conflicts
- nikic/php-parser: <4.13.0
- 0.24.x-dev
- 0.23.x-dev
- 0.23.0
- 0.22.x-dev
- 0.22.0
- 0.21.x-dev
- 0.21.0
- 0.20.x-dev
- 0.20.0
- 0.19.x-dev
- 0.19.1
- 0.19.0
- 0.18.x-dev
- 0.18.0
- 0.17.x-dev
- 0.17.0
- 0.16.x-dev
- 0.16.1
- 0.16.0
- 0.15.x-dev
- 0.15.0
- 0.14.x-dev
- 0.14.0
- 0.13.x-dev
- 0.13.0
- 0.12.x-dev
- 0.12.0
- 0.11.x-dev
- 0.11.1
- 0.11.0
- 0.10.x-dev
- 0.10.0
- 0.9.x-dev
- 0.9.0
- 0.8.x-dev
- 0.8.0
- 0.7.x-dev
- 0.7.0
- 0.6.x-dev
- 0.6.1
- 0.6.0
- 0.5.x-dev
- 0.5.1
- 0.5.0
- 0.4.x-dev
- 0.4.0
- 0.3.x-dev
- 0.3.0
- 0.2.0
- 0.1.3
- 0.1.1
- dev-0.19.x-merge-up-into-0.20.x_IP1y7DAg
- dev-0.16.x-merge-up-into-0.17.x_qOZ4ADjn
- dev-0.11.x-merge-up-into-0.12.x_SCGC4fyT
- dev-0.6.x-merge-up-into-0.7.x_eUsEFTZC
- dev-0.5.x-merge-up-into-0.6.x_vhfEH4wk
This package is auto-updated.
Last update: 2025-01-19 02:00:51 UTC
README
Important
The next version 0.25.0
will have a BC break. Please refer Stubs
section.
struggle-for-php/sfp-phpstan-psr-log
is extra strict and opinionated psr/log (psr-3) rules for PHPStan.
Recommendation Settings
Write these parameters to your project's phpstan.neon
.
parameters: sfpPsrLog: enableMessageStaticStringRule: false # default:true enableContextRequireExceptionKeyRule: true reportContextExceptionLogLevel: 'info' contextKeyOriginalPattern: '#\A[A-Za-z0-9-_]+\z#'
Stubs
Important
include psr/log stub be planned to dropped in next release.
To try out the changes in the next version,
DELETE vendor/struggle-for-php/sfp-phpstan-psr-log/extension.neon
line from your phpstan.neon
includes: - vendor/struggle-for-php/sfp-phpstan-psr-log/extension.neon
and, set parameters enableLogLevelMethodRule
and enableContextTypeRule
parameters: sfpPsrLog: enableLogLevelMethodRule: true # default:false enableContextTypeRule: true # default:false
About stub
Currently, this extension depends on our psr/log stub to serve strictness.
- eg.
@param LogLevel::* $level
atlog()
method@param array{exception?: \Throwable} $context
See psr/log stub repository page to get more detail.
Rules
This package provides the following rules.
PlaceholderCharactersRule
Placeholder names SHOULD be composed only of the characters A-Z, a-z, 0-9, underscore _, and period .
- reports when placeholder in
$message
characters are not,A-Z
,a-z
,0-9
, underscore_
, and period.
// bad $logger->info('message are {foo-hyphen}');
- reports when double braces pair
{{
}}
are used.
// bad $logger->info('message are {{foo}}');
PlaceholderCorrespondToKeysRule
Placeholder names MUST correspond to keys in the context array.
- reports when placeholder exists in message, but
$context
parameter is missed.
// bad $logger->info('message has {nonContext} .');
- reports when placeholder exists in message, but key in
$context
does not exist against them.
// bad $logger->info('user {user_id} gets an error {error} .', ['user_id' => $user_id]);
ContextKeyRule
Note
PSR-3 has no provisions for array keys, but this is useful in many cases.
- reports when context key is not non-empty-string.
// bad [123 => 'foo']`, `['' => 'bar']`, `['baz']
- reports when context key is not matched you defined pattern.
- if
contextKeyOriginalPattern
parameter is not set, this check would be ignored.
- if
Configuration
- You can set specific key pattern by regex.(
preg_match()
)
parameters: sfpPsrLog: contextKeyOriginalPattern: '#\A[A-Za-z0-9-]+\z#'
ContextRequireExceptionKeyRule
Note
This is not a rule for along with PSR-3 specification, but provides best practices.
- It forces
exception
key into context parameter when current scope has\Throwable
object.
Example
<?php /** @var \Psr\Log\LoggerInterface $logger */ try { // } catch (LogicException $exception) { $logger->warning("foo"); }
$ ../vendor/bin/phpstan analyse Note: Using configuration file /tmp/your-project/phpstan.neon. 2/2 [▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓] 100% ------ ------------------------------------------------------------- Line Demo.php ------ ------------------------------------------------------------- 6 Parameter $context of logger method Psr\Log\LoggerInterface::warning() requires \'exception\' key. Current scope has Throwable variable - $exception ------ ------------------------------------------------------------- [ERROR] Found 1 error
Configuration
- You can set the minimum required level to report. (default level is
debug
)
parameters: sfpPsrLog: reportContextExceptionLogLevel: 'warning'
Then, debug
| info
| notice
LogLevel is ignored for report.
} catch (\Exception $e) { $logger->info('more info'); // allow $logger->warning($e->getMessage(), ['exception' => $e]); }
- If you want to enable this rule, please add
enableContextRequireExceptionKeyRule
as true.
parameters: sfpPsrLog: enableContextRequireExceptionKeyRule: true
MessageStaticStringRule
- reports when $message is not static string value.
// bad $logger->info(sprintf('Message contains %s variable', $var));
Configuration
- If you want to disable this rule, please add
enableMessageStaticStringRule
as false.
parameters: sfpPsrLog: enableMessageStaticStringRule: false
Installation
To use this extension, require it in Composer:
composer require --dev struggle-for-php/sfp-phpstan-psr-log
Manual installation
include extension.neon & rules.neon in your project's PHPStan config:
includes: - vendor/struggle-for-php/sfp-phpstan-psr-log/extension.neon - vendor/struggle-for-php/sfp-phpstan-psr-log/rules.neon