cleancode / injectable-bundle
Injectable-bundle is responsible for injecting array of objects into your class. By tagging you mark an service to be injected into your target service.
1.0.1
2017-02-26 17:34 UTC
Requires
- php: >=7.0.0
- symfony/framework-bundle: ~3.0
This package is auto-updated.
Last update: 2024-11-29 05:20:38 UTC
README
Description
Injectable-bundle
is responsible for injecting array of objects into your class.
By tagging you mark an service to be injected into your target service.
Example use JMSDiExtraBundle, but you can
easily configure it with services.yml
Target Service
/**
* @DI\Service("template_factory")
*/
class TemplateFactory
{
/**
* @param array|Template[] $providers
*/
private $providers;
/**
* @DI\InjectParams({
* "providers" = @DI\Inject("%empty_array%")
* })
*/
public function __construct(array $providers)
{
$this->providers = $providers;
}
public function createFor(string $type) : Template
{
foreach ($this->providers as $provider) {
if ($provider->isHandling($type)) {
return $provider;
}
}
throw new \Exception("Template for {$type} doesn't exists!");
}
}
interface Template
{
public function render() : string
public function isHandling(string $type) : bool;
}
Injected Services
/**
* @DI\Service()
* @DI\Tag(name="injectable", attributes={"to"="template_factory", "index"="0"})
*/
class NiceTemplate implements Template
{
public function render()
{
return "nice template";
}
public function isHandling(string $type) : bool
{
return $type === 'nice';
}
}
/**
* @DI\Service()
* @DI\Tag(name="injectable", attributes={"to"="template_factory", "index"="0"})
*/
class UglyTemplate implements Template
{
public function render()
{
return "ugly template";
}
public function isHandling(string $type) : bool
{
return $type === 'ugly';
}
}
Above service will be injected into TemplateFactory.
If there will be no services tagged as injectable for template_factory
, template factory
will use of empty array.
Understanding the annotations
@DI\Tag(name="injectable", attributes={"to"="template_factory", "index"="0"})
name="injectable"
- Marks serviceto be used
by InjectableBundle"to"="template_factory"
- Sets target service"index"="0"
- Sets target service constructor argument index