seeren / container
Autowire and configure dependencies
3.0.1
2022-06-23 14:18 UTC
Requires
- php: >=8.0.1
- psr/container: ^2.0
Requires (Dev)
- php-coveralls/php-coveralls: ^v2.5.2
- phpunit/phpunit: ^9.5
README
Autowire and configure dependencies
Installation
Seeren\Container is a PSR-11 container interfaces implementation
composer require seeren/container
Seeren\Container\Container
The container create, build, store and share instances
use Seeren\Container\Container; $container = new Container(); $foo = $container->get('Dummy\Foo');
Autowiring
Dependencies are resolved using type declaration
namespace Dummy; class Foo { public function __construct(Bar $bar){} } class Bar { public function __construct(Baz $baz){} } class Baz {}
Interfaces
namespace Dummy; class Foo { public function __construct(BarInterface $bar){} }
Interfaces are resolved using configuration file by default in /config/services.json
{ "parameters": {}, "services": { "Dummy\\Foo": { "Dummy\\BarInterface": "Dummy\\Bar" } } }
Include path can be specified at construction
project/ └─ config/ └─ services.json
Parameters
Parameters and primitives are resolved using configuration file
namespace Dummy; class Foo { public function __construct(string $bar){} }
{ "parameters": { "message": "Hello" }, "services": { "Dummy\\Foo": { "bar": ":message" } } }
Methods
Methods can use autowiring
namespace Dummy; class Foo { public function __construct(BarInterface $bar){} public function action(int $id, Baz $baz) { return 'Hello'; } }
use Seeren\Container\Container; $container = new Container(); $message = $container->call('Dummy\Foo', 'action', [7]); echo $message; // Hello
License
This project is licensed under the MIT License