djuricmilos / container
Dependency injection container
Requires
- php: ^7.3
- php-di/phpdoc-reader: ^2.1
- phpdocumentor/reflection-docblock: ^4.3
- psr/container: ^1.0
Requires (Dev)
- phpunit/phpunit: ^8.0
Provides
This package is auto-updated.
Last update: 2024-12-09 07:44:00 UTC
README
Installation
The preferred method of installation is via Composer. Run the following command to install the latest version of a package and add it to your project's composer.json
:
composer require djuricmilos/container
Usage
Simple container
The fastest way to create container is to instantiate Laganica\Di\Container
class.
use Laganica\Di\Container; $container = new Container();
By default, autowiring is enabled and annotations are disabled.
Configuring the container
use Laganica\Di\ContainerBuilder; $builder = new ContainerBuilder(); $builder->useAutowiring(false); $builder->useAnnotations(false); $container = $builder->build();
Definitions
If object of service class cannot be created by using autowiring we have to create a definition for that service. Definition is telling the container how to instantiate a service class.
Interface to Class binding
Container will use class name passed to bind method to create instance of that class.
use Laganica\Di\ContainerBuilder; use function Laganica\Di\bind; $builder = new ContainerBuilder(); $builder->addDefinitions([ ServiceInterface::class => bind(Service::class) ]); $container = $builder->build(); $service = $container->get(ServiceInterface::class);
Class name
The same as bind, just shorter.
use Laganica\Di\ContainerBuilder; $builder = new ContainerBuilder(); $builder->addDefinitions([ ServiceInterface::class => Service::class ]); $container = $builder->build(); $service = $container->get(ServiceInterface::class);
Closure
Container will invoke closure to create service instance.
Note that $container
is available as closure parameter.
use Laganica\Di\ContainerBuilder; use Psr\Container\ContainerInterface; use function Laganica\Di\closure; $builder = new ContainerBuilder(); $builder->addDefinitions([ ServiceInterface::class => closure(static function (ContainerInterface $container) { return new Service($container->get(Dependency::class)); }) ]); $container = $builder->build(); $service = $container->get(ServiceInterface::class);
Inline factory
The same as closure, just shorter.
use Laganica\Di\ContainerBuilder; use Psr\Container\ContainerInterface; $builder = new ContainerBuilder(); $builder->addDefinitions([ ServiceInterface::class => static function (ContainerInterface $container) { return new Service($container->get(Dependency::class)); } ]); $container = $builder->build(); $service = $container->get(ServiceInterface::class);
Factory
Container will invoke object of factory class to create service instance.
use Laganica\Di\ContainerBuilder; use function Laganica\Di\factory; $builder = new ContainerBuilder(); $builder->addDefinitions([ ServiceInterface::class => factory(ServiceFactory::class) ]); $container = $builder->build(); $service = $container->get(ServiceInterface::class);
ServiceFactory is class that implements Laganica\Di\FactoryInterface
interface and whose __invoke method is used to define how service is created.
use Laganica\Di\FactoryInterface; use Psr\Container\ContainerInterface; class ServiceFactory implements FactoryInterface { public function __invoke(ContainerInterface $container) { return new Service($container->get(Dependency::class)); } }
Alias
Container will use entry name passed to alias method to find other entry and use it to create service instance.
use Laganica\Di\ContainerBuilder; use function Laganica\Di\alias; $builder = new ContainerBuilder(); $builder->addDefinitions([ ServiceInterface::class => Service::class, 'service-alias' => alias(ServiceInterface::class) ]); $container = $builder->build(); $service = $container->get('service-alias');
Values
Container will return value passed to value method.
use Laganica\Di\ContainerBuilder; use function Laganica\Di\value; $builder = new ContainerBuilder(); $builder->addDefinitions([ 'count' => value(100) ]); $container = $builder->build(); $count = $container->get('count');
Make
Sometimes we don't want to share the service from container. For that purpose we can use make()
method.
use Laganica\Di\ContainerBuilder; use function Laganica\Di\bind; $builder = new ContainerBuilder(); $builder->addDefinitions([ ServiceInterface::class => bind(Service::class) ]); $container = $builder->build(); $service = $container->make(ServiceInterface::class);
Annotations
Container will use @Inject
annotation on $dependency
property in Service
class to inject Dependency
.
As autowiring is enabled by default, it will be used to create instance of Dependency
class.
use Laganica\Di\ContainerBuilder; class Service { /** * @Inject * @var Dependency */ private $dependency; } $builder = new ContainerBuilder(); $builder->useAnnotations(true); $container = $builder->build(); $service = $container->get(Service::class);
Credits
License
Released under MIT License - see the License File for details.