Package Data | |
---|---|
Maintainer Username: | canvural |
Package Create Date: | 2020-06-20 |
Package Last Update: | 2025-04-29 |
Home Page: | |
Language: | PHP |
License: | MIT |
Last Refreshed: | 2025-06-04 15:00:05 |
Package Statistics | |
---|---|
Total Downloads: | 712,235 |
Monthly Downloads: | 60,628 |
Daily Downloads: | 2,357 |
Total Stars: | 84 |
Total Watchers: | 2 |
Total Forks: | 5 |
Total Open Issues: | 3 |
Extra strict and opinionated PHPStan rules for Laravel.
You can install the package via composer:
composer require --dev canvural/larastan-strict-rules
To enable all the rules, include rules.neon
in your project's PHPStan config:
includes:
- vendor/canvural/larastan-strict-rules/rules.neon
You can disable rules using configuration parameters:
parameters:
larastanStrictRules:
noDynamicWhere: false
noFacade: false
noGlobalLaravelFunction: false
noLocalQueryScope: false
noPropertyAccessor: false
noValidationInController: false
scopeShouldReturnQueryBuilder: false
listenerShouldHaveVoidReturnType: false
If you don't want to start using all the available strict rules at once but only one or two, you can!
You can disable all rules from the included rules.neon
with:
parameters:
larastanStrictRules:
allRules: false
Then you can re-enable individual rules with configuration parameters:
parameters:
larastanStrictRules:
allRules: false
noDynamicWhere: true
NoDynamicWhereRule
This rule disallows the usage of dynamic where methods on Eloquent query builder.
NoFacadeRule
This rule disallows the usage of Laravel Facades. Also, checks for the real time facade usage.
NoGlobalLaravelFunctionRule
This rule disallows the usage of global helper functions that comes with Laravel.
If you want to allow some functions, you can use the allowedGlobalFunctions
parameter. Like so:
parameters:
allowedGlobalFunctions:
- app
- event
NoValidationInControllerRule
This rule disallows validating the request in controllers.
ScopeShouldReturnQueryBuilderRule
This rule makes sure Illuminate\Database\Eloquent\Builder
instance is returned from Eloquent
local query scopes.
NoLocalQueryScopeRule
This rule disallows the usage of local model query scopes all together.
NoPropertyAccessorRule
This rule disallows the usage of model property accessors.
ListenerShouldHaveVoidReturnTypeRule
This rule makes sure your event listeners have a void return type.
If you return false
from an event listener, Laravel will stop the propagation of an event to other listeners. Sometimes this can be useful. But other time it can cause bugs that you will need to debug for hours. So this opinionated rule makes sure you always have void
return type for your event listeners.
You need to configure this rule by adding the directories that your event listeners are in to the listenerPaths
parameter:
parameters:
listenerPaths:
- app/Listeners
- app/DomainA/Listeners
Please see CHANGELOG for more information on what has changed recently.
Please see CONTRIBUTING for details.
People:
The MIT License (MIT). Please see License File for more information.