christianblos / symfony-di-annotation
Allows you to configure symfony dependency injections via annotations
Requires
- php: ^7.4|^8.0
- doctrine/annotations: ~1.0
- symfony/config: >=4.0
- symfony/dependency-injection: >=4.0
Requires (Dev)
- phpunit/phpunit: ^9.0
README
This library is an extension of the Symfony DependencyInjection Component. It allows you to configure the DI Container using annotations directly in your classes.
Set up
1. Install via composer:
composer require christianblos/symfony-di-annotation
2. Add compiler pass to the ContainerBuilder
<?php use Symfony\Component\DependencyInjection\Annotation\Compiler\AnnotationPass; use Symfony\Component\DependencyInjection\ContainerBuilder; $containerBuilder = new ContainerBuilder(); $srcDirs = ['path/to/classes']; // the path(s) to your classes which contain annotations $containerBuilder->addCompilerPass(AnnotationPass::createDefault($srcDirs));
(see symfony documentation for more information about the ContainerBuilder)
Basic Usage
Just add the @Service
annotation to all of your services and they will be registered to the DIC automatically:
<?php use Symfony\Component\DependencyInjection\Annotation\Service; /** * @Service */ class SomeRepository { }
<?php use Symfony\Component\DependencyInjection\Annotation\Service; /** * @Service(public=true) */ class SomeService { public function __construct(SomeRepository $repo) { // $repo will be injected automatically } }
Now you can simply retrieve the service from the container:
$someService = $container->get(SomeService::class);
Note: You can also add multiple
@Service
annotations if you want to configure two services of the same class. Then you also need to set the id of the service like@Service(id="myService")
because you can not have two services with the same id (By default, the id is the full class name).
Inject params
You can also inject params by adding it to the annotation:
<?php use Symfony\Component\DependencyInjection\Annotation\Service; /** * @Service( * inject={ * "someParam"="%foo%" * } * ) */ class SomeService { public function __construct($someParam) { // - "someParam" ist the name of the variable // - "%foo%" means you want to inject the "foo" parameter from the container } }
Modify container
It is possible to modify the whole container by using method annotations. One possible use case is an event listener. Depending on your implementation it could look like this:
class MyListener
{
/**
* @ListenTo(UserRegistered::class)
*/
public function doSomethingWhenUserRegistered($event)
{
}
}
Note: This is just an example of what is possible. The "ListenTo" Annotation is not implemented in this library! See the example of how you can implement it.
More examples
You can find some examples in the examples folder.