2017 © Pedro Peláez
 

library symfony-di-annotation

Allows you to configure symfony dependency injections via annotations

image

christianblos/symfony-di-annotation

Allows you to configure symfony dependency injections via annotations

  • Wednesday, June 20, 2018
  • by christianblos
  • Repository
  • 2 Watchers
  • 1 Stars
  • 29 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 1 Forks
  • 0 Open issues
  • 12 Versions
  • 12 % Grown

The README.md

What's this?

This library is an extension of the Symfony DependencyInjection Component. It allows you to configure the DI Container using annotations directly in your classes., (*1)

Set up

1. Install via composer:

composer require christianblos/symfony-di-annotation, (*2)

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), (*3)

Basic Usage

Just add the @Service annotation to all of your services and they will be registered to the DIC automatically:, (*4)

<?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:, (*5)

$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)., (*6)

Inject params

You can also inject params by adding it to the annotation:, (*7)

<?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:, (*8)

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., (*9)

More examples

You can find some examples in the examples folder., (*10)

The Versions

20/06 2018

dev-master

9999999-dev

Allows you to configure symfony dependency injections via annotations

  Sources   Download

MIT

The Requires

 

The Development Requires

20/06 2018

0.11

0.11.0.0

Allows you to configure symfony dependency injections via annotations

  Sources   Download

MIT

The Requires

 

The Development Requires

04/05 2018

0.10

0.10.0.0

Allows you to configure symfony dependency injections via annotations

  Sources   Download

MIT

The Requires

 

The Development Requires

03/05 2018

0.9

0.9.0.0

Allows you to configure symfony dependency injections via annotations

  Sources   Download

MIT

The Requires

 

The Development Requires

27/02 2018

0.8

0.8.0.0

Allows you to configure symfony dependency injections via annotations

  Sources   Download

MIT

The Requires

 

The Development Requires

12/01 2018

0.7

0.7.0.0

Allows you to configure symfony dependency injections via annotations

  Sources   Download

MIT

The Requires

 

The Development Requires

02/01 2018

0.6

0.6.0.0

Allows you to configure symfony dependency injections via annotations

  Sources   Download

MIT

The Requires

 

The Development Requires

22/12 2017

0.5

0.5.0.0

Allows you to configure symfony dependency injections via annotations

  Sources   Download

MIT

The Requires

 

The Development Requires

29/09 2017

0.4

0.4.0.0

Allows you to configure symfony dependency injections via annotations

  Sources   Download

MIT

The Requires

 

The Development Requires

01/09 2017

0.3

0.3.0.0

Allows you to configure symfony dependency injections via annotations

  Sources   Download

MIT

The Requires

 

The Development Requires

05/08 2017

0.2

0.2.0.0

Allows you to configure symfony dependency injections via annotations

  Sources   Download

MIT

The Requires

 

The Development Requires