nayjest / di-hub
Dependency injection library for PHP with links consistency maintaining mechanism
Requires
- php: ^5.5||^7
- container-interop/container-interop: ^1.1
Requires (Dev)
- phpunit/phpunit: ^5.7
- squizlabs/php_codesniffer: ~2.3
- symfony/var-dumper: ^3.2
Provides
This package is auto-updated.
Last update: 2024-10-17 23:52:57 UTC
README
IoC container for PHP with hierarchy and links consistency maintaining mechanism
Table of Contents
Requirements
- PHP 5.5+ (HHVM & PHP7 are supported)
Installation
The recommended way of installing this package is through Composer.
Run following command from your project folder:
composer require nayjest/di-hub
Usage
Creating hub
Class Nayjest\DI\Hub represents IoC container. This class implements ContainerInterface from container-interop/container-interop package.
Hub can be instantiated without arguments or with array containing definitions.
use Nayjest\DI\Hub; # Empty hub $hub = new Hub; # Hub with definitions $hub = new Hub([ new Value('item1', $item1), new Value('item2', $item2), new Relation('item1', 'item2', $handler), ]);
Definitions
There are several types of definitions that can be added to hub:
- Values
- Relations
- Items
Definitions should implement Nayjest\DI\Definition\DefinitionInterface
.
This intarface don't contains any methods, it's used only to signalize that instances of target class defines data or relations inside container.
Definitions can be added to container(hub) in following ways:
- Inject array of definition instances into hub constructor
- Add definition instance to existing hub via
$hub->addDefinition(DefinitionInterface $definition)
- Add array of definition instances to existing hub via
$hub->addDefinitions(DefinitionInterface[] $definitions)
- Create definitions via DefinitionBuilder:
$hub->builder()->define($id $source)
Value Definitions
Instance of Nayjest\DI\Definition\Value represent single value in container that can be accessed by it's id. Nayjest\DI\Definition\Value accepts two arguments: id and source. source can contain value to store inside hub or callable that returns target value.
# Add data directly to definition $hub->addDefinition(new Value('item1', $data)); # Add data via callable $hub->addDefinition(new Value('item2', function(){ return $data; }));
Relation Definitions
@todo
Item Definitions
Item is a combination of value & it's initial dependencies. May be useful to store class instances that require DI in constructor.
@todo
Hierarchy of hubs
@todo
Testing
This package bundled with unit tests (PHPUnit).
- Install nayjest/di-hub as stand-alone project
composer create-project nayjest/di-hub -s dev
- Run tests from package folder
cd di-hub composer test
Also it's possible to check code style (PSR-2):
composer code-style
Contributing
Please see Contributing Guidelines and Code of Conduct for details.
Security
If you discover any security related issues, please email mail@vitaliy.in instead of using the issue tracker.
License
© 2016—2017 Vitalii Stepanenko
Licensed under the MIT License.
Please see License File for more information.