Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/codeigniter/phpstan-codeigniter
CodeIgniter extensions and rules for PHPStan
https://github.com/codeigniter/phpstan-codeigniter
codeigniter codeigniter4 php phpstan-extension static-analysis
Last synced: 19 days ago
JSON representation
CodeIgniter extensions and rules for PHPStan
- Host: GitHub
- URL: https://github.com/codeigniter/phpstan-codeigniter
- Owner: CodeIgniter
- License: mit
- Created: 2023-07-14T07:16:13.000Z (over 1 year ago)
- Default Branch: 1.x
- Last Pushed: 2024-12-02T15:33:49.000Z (about 1 month ago)
- Last Synced: 2024-12-19T19:07:21.094Z (19 days ago)
- Topics: codeigniter, codeigniter4, php, phpstan-extension, static-analysis
- Language: PHP
- Homepage: https://codeigniter.com/
- Size: 210 KB
- Stars: 15
- Watchers: 6
- Forks: 1
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# CodeIgniter extensions and rules for PHPStan
[![Extension Tests](https://github.com/CodeIgniter/phpstan-codeigniter/actions/workflows/test-phpunit.yml/badge.svg)](https://github.com/CodeIgniter/phpstan-codeigniter/actions/workflows/test-phpunit.yml)
[![Coding Standards Check](https://github.com/CodeIgniter/phpstan-codeigniter/actions/workflows/test-coding-standards.yml/badge.svg)](https://github.com/CodeIgniter/phpstan-codeigniter/actions/workflows/test-coding-standards.yml)
[![PHPStan Static Analysis](https://github.com/CodeIgniter/phpstan-codeigniter/actions/workflows/test-phpstan.yml/badge.svg)](https://github.com/CodeIgniter/phpstan-codeigniter/actions/workflows/test-phpstan.yml)* [PHPStan](https://phpstan.org/)
* [CodeIgniter](https://codeigniter.com/)This extension provides the following features:
### Type Inference
* Provides precise return types for `config()` and `model()` functions.
* Provides precise return types for `service()` and `single_service()` functions.
* Provides precise return types for `fake()` helper function.
* Provides precise return types for `CodeIgniter\Model`'s `find()`, `findAll()`, and `first()` methods.
* Allows dynamic return type transformation of `CodeIgniter\Model` when `asArray()` or `asObject()` is called.### Rules
* Checks if the string argument passed to `config()` or `model()` function is a valid class string extending
`CodeIgniter\Config\BaseConfig` or `CodeIgniter\Model`, respectively. This can be turned off by setting
`codeigniter.checkArgumentTypeOfFactories: false` in your `phpstan.neon`. For fine-grained control, you can
individually choose which factory function to disable using `codeigniter.checkArgumentTypeOfConfig` and
`codeigniter.checkArgumentTypeOfModel`. **NOTE:** Setting `codeigniter.checkArgumentTypeOfFactories: false` will effectively
bypass the two specific options.
* Checks if the string argument passed to `service()` or `single_service()` function is a valid service name. This can be turned off by setting `codeigniter.checkArgumentTypeOfServices: false` in your `phpstan.neon`.
* Disallows instantiating cache handlers using `new` and suggests to use the `CacheFactory` class instead.
* Disallows instantiating `FrameworkException` classes using `new`.
* Disallows direct re-assignment or access of `$_SERVER` and `$_GET` and suggests to use the `Superglobals` class instead.
* Disallows use of `::class` fetch on `config()` and `model()` and suggests to use the short form of the class instead.## Installation
To use this extension, require it in [Composer](https://getcomposer.org/):
```
composer require --dev codeigniter/phpstan-codeigniter
```If you also install [phpstan/extension-installer](https://github.com/phpstan/extension-installer) then you're all set!
Manual installation
If you don't want to use `phpstan/extension-installer`, include extension.neon in your project's PHPStan config:
```yml
includes:
- vendor/codeigniter/phpstan-codeigniter/extension.neon
```Development in this repository uses **PHP 8.1+**.
Starting [v1.1.0](https://github.com/CodeIgniter/phpstan-codeigniter/releases/tag/v1.1.0), releases come with a downgraded
version to suit lower PHP versions. Currently, lowest supported downgraded PHP version is **PHP 7.4**.## Configuration
This extension adds the default namespace for `config()` and `model()` functions as `Config\` and `App\Models\`, respectively,
when searching for possible classes. If your application uses other namespaces, you can configure this extension
in your `phpstan.neon` to recognize those namespaces:```yml
parameters:
codeigniter:
additionalConfigNamespaces:
- Acme\Blog\Config\
- Foo\Bar\Config\
additionalModelNamespaces:
- Acme\Blog\Models\```
For the `service()` and `single_service()` functions, you can instruct PHPStan to consider your own
services factory classes. **Please note that it should be a valid class extending `CodeIgniter\Config\BaseService`!**```yml
parameters:
codeigniter:
additionalServices:
- Acme\Blog\Config\ServiceFactory
```When the model passed to `fake()` has the property `$returnType` set to `array`, this extension will give a precise
array shape based on the allowed fields of the model. Most of the time, the formatted fields are strings. If not a string,
you can indicate the format return type for the particular field.```yml
parameters:
codeigniter:
notStringFormattedFields: # key-value pair of field => format
success: bool
user_id: int
```## Caveats
1. The behavior of factories functions relative to how they load classes is based on codeigniter4/framework v4.4. If you are
relying on the behavior of < v4.4, this may not work out for you.## Contributing
Any contributions are welcome.
If you want to see a new rule or extension specific to CodeIgniter, please open a
[feature request](https://github.com/CodeIgniter/phpstan-codeigniter/issues/new?assignees=&labels=feature+request&projects=&template=feature_request.yml). If you can contribute the code yourself, please open a pull request instead.Before reporting any bugs, please check if the bug occurs only if using this extension with PHPStan. If the bug is
reproducible in PHPStan alone, please open a bug report there instead. Thank you!## License
PHPStan CodeIgniter is an open source library licensed under [MIT](LICENSE).