/vendor/symfony/symfony/src/Symfony/Bundle/FrameworkBundle/Routing/Router.php
https://github.com/nattaphat/hgis · PHP · 158 lines · 83 code · 26 blank · 49 comment · 7 complexity · 04678f6879452d110b5874ace0960fa3 MD5 · raw file
- <?php
- /*
- * This file is part of the Symfony package.
- *
- * (c) Fabien Potencier <fabien@symfony.com>
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
- namespace Symfony\Bundle\FrameworkBundle\Routing;
- use Symfony\Component\Routing\Router as BaseRouter;
- use Symfony\Component\Routing\RequestContext;
- use Symfony\Component\DependencyInjection\ContainerInterface;
- use Symfony\Component\Routing\RouteCollection;
- use Symfony\Component\HttpKernel\CacheWarmer\WarmableInterface;
- use Symfony\Component\DependencyInjection\Exception\ParameterNotFoundException;
- use Symfony\Component\DependencyInjection\Exception\RuntimeException;
- /**
- * This Router creates the Loader only when the cache is empty.
- *
- * @author Fabien Potencier <fabien@symfony.com>
- */
- class Router extends BaseRouter implements WarmableInterface
- {
- private $container;
- /**
- * Constructor.
- *
- * @param ContainerInterface $container A ContainerInterface instance
- * @param mixed $resource The main resource to load
- * @param array $options An array of options
- * @param RequestContext $context The context
- */
- public function __construct(ContainerInterface $container, $resource, array $options = array(), RequestContext $context = null)
- {
- $this->container = $container;
- $this->resource = $resource;
- $this->context = null === $context ? new RequestContext() : $context;
- $this->setOptions($options);
- }
- /**
- * {@inheritdoc}
- */
- public function getRouteCollection()
- {
- if (null === $this->collection) {
- $this->collection = $this->container->get('routing.loader')->load($this->resource, $this->options['resource_type']);
- $this->resolveParameters($this->collection);
- }
- return $this->collection;
- }
- /**
- * {@inheritdoc}
- */
- public function warmUp($cacheDir)
- {
- $currentDir = $this->getOption('cache_dir');
- // force cache generation
- $this->setOption('cache_dir', $cacheDir);
- $this->getMatcher();
- $this->getGenerator();
- $this->setOption('cache_dir', $currentDir);
- }
- /**
- * Replaces placeholders with service container parameter values in:
- * - the route defaults,
- * - the route requirements,
- * - the route pattern.
- * - the route host.
- *
- * @param RouteCollection $collection
- */
- private function resolveParameters(RouteCollection $collection)
- {
- foreach ($collection as $route) {
- foreach ($route->getDefaults() as $name => $value) {
- $route->setDefault($name, $this->resolve($value));
- }
- foreach ($route->getRequirements() as $name => $value) {
- $route->setRequirement($name, $this->resolve($value));
- }
- $route->setPath($this->resolve($route->getPath()));
- $route->setHost($this->resolve($route->getHost()));
- }
- }
- /**
- * Recursively replaces placeholders with the service container parameters.
- *
- * @param mixed $value The source which might contain "%placeholders%"
- *
- * @return mixed The source with the placeholders replaced by the container
- * parameters. Array are resolved recursively.
- *
- * @throws ParameterNotFoundException When a placeholder does not exist as a container parameter
- * @throws RuntimeException When a container value is not a string or a numeric value
- */
- private function resolve($value)
- {
- if (is_array($value)) {
- foreach ($value as $key => $val) {
- $value[$key] = $this->resolve($val);
- }
- return $value;
- }
- if (!is_string($value)) {
- return $value;
- }
- $container = $this->container;
- $escapedValue = preg_replace_callback('/%%|%([^%\s]+)%/', function ($match) use ($container, $value) {
- // skip %%
- if (!isset($match[1])) {
- return '%%';
- }
- $key = strtolower($match[1]);
- if (!$container->hasParameter($key)) {
- throw new ParameterNotFoundException($key);
- }
- $resolved = $container->getParameter($key);
- if (is_string($resolved) || is_numeric($resolved)) {
- return (string) $resolved;
- }
- throw new RuntimeException(sprintf(
- 'A string value must be composed of strings and/or numbers,' .
- 'but found parameter "%s" of type %s inside string value "%s".',
- $key,
- gettype($resolved),
- $value)
- );
- }, $value);
- return str_replace('%%', '%', $escapedValue);
- }
- }