Route injector annotation for Symfony 4.0+.
For Symfony 2.8 and 3.x please use the 1.x releases.
From the command line run
$ composer require secit-pl/route-injector-bundle
To inject route to the variable just add the @InjectRoute annotation to it. The the first argument is the route name. The second and other arguments are the optional configuration options.
use SecIT\RouteInjectorBundle\Mapping\Annotation\InjectRoute;
/**
* @InjectRoute("route_name", configuration options...);
*/
private $url;
Here is the basic usage example.
The class:
use SecIT\RouteInjectorBundle\Mapping\Annotation\InjectRoute;
class Example
{
/**
* @var string
*
* @InjectRoute("route_name", parametersMapping={"param": "getRouteParam"});
*/
private $url;
private $routeParam = '';
/**
* @return string
*/
public function getUrl()
{
return $this->url;
}
/**
* @return string
*/
public function getRouteParam()
{
return $this->routeParam;
}
/**
* @param string $value
*/
public function setRouteParam($value)
{
$this->routeParam = $value;
}
}
And how to manually run the injector.
$processor = $this->container->get('secit.route_injector.processor');
$exampleEbject = new Example();
$exampleEbject->setRouteParam('test');
$processor->injectRoutes($exampleEbject);
This bundle provides the Doctrine integration. So if you use the @InjectRoute annotation in the entity the injectRoutes processor method will be triggered on every (depending on the conditions) load, update and persist action.
Example entity:
namespace ExampleBundle\Entity;
use Doctrine\ORM\Mapping as ORM;
use SecIT\RouteInjectorBundle\Mapping\Annotation\InjectRoute;
/**
* @ORM\Table(name="example")
* @ORM\Entity()
*/
class Example
{
/**
* @var string
*
* @ORM\Column(name="param", type="string")
*/
private $param;
/**
* @var string
*
* @InjectRoute("route_name", parametersMapping={"param": "getParam"});
*/
private $url;
/**
* @return string
*/
public function getParam()
{
return $this->string;
}
/**
* @param string $param
*/
public function setParam($param)
{
$this->string = $param;
}
/**
* @return string
*/
public function getUrl()
{
return $this->url;
}
}
When you create a new Example entity instance the $url will be null. But just after persist the route will be automatically injected and accessible.
$exampleObject = new ExampleBundle\Entity\Example();
$this->getDoctrine()->getManager()->persist($exampleObject);
In the previous example the route will be injected on each time we will load, update or store the entity but in some cases we would like to store it in the database. To achieve this simply add the Doctrine @Column annotation to make it a database field.
namespace ExampleBundle\Entity;
use Doctrine\ORM\Mapping as ORM;
use SecIT\RouteInjectorBundle\Mapping\Annotation\InjectRoute;
/**
* @ORM\Table(name="example")
* @ORM\Entity()
*/
class Example
{
...
/**
* @var string
*
* @ORM\Column(name="url", type="string", length=255)
* @InjectRoute("route_name", parametersMapping={"param": "getParam"});
*/
private $url;
...
}
Here are all possible configuration options:
@InjectRoute("route_name", configuration options...);
The array of the route parameters mapped to the public class methods from which the parameters values should be taken.
@InjectRoute("route_name", parametersMapping={"param": "publicGetterMethodName"});
Warning! The route will not be injected if any of the parameters will be null.
Set to true if you'd like to have the generated URLs with the protocol and hostname prefix.
@InjectRoute("route_name", absolute=true);
By default the route will be injected only if the current value is empty (null, false, or the empty string). To make it updatable even if it's not empty set this option to true.
@InjectRoute("route_name", injectIfNotEmpty=true);