the whole shebang
This commit is contained in:
		
							
								
								
									
										246
									
								
								vendor/symfony/routing/Symfony/Component/Routing/Loader/AnnotationClassLoader.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										246
									
								
								vendor/symfony/routing/Symfony/Component/Routing/Loader/AnnotationClassLoader.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,246 @@ | ||||
| <?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\Component\Routing\Loader; | ||||
|  | ||||
| use Doctrine\Common\Annotations\Reader; | ||||
| use Symfony\Component\Config\Resource\FileResource; | ||||
| use Symfony\Component\Routing\Route; | ||||
| use Symfony\Component\Routing\RouteCollection; | ||||
| use Symfony\Component\Config\Loader\LoaderInterface; | ||||
| use Symfony\Component\Config\Loader\LoaderResolverInterface; | ||||
|  | ||||
| /** | ||||
|  * AnnotationClassLoader loads routing information from a PHP class and its methods. | ||||
|  * | ||||
|  * You need to define an implementation for the getRouteDefaults() method. Most of the | ||||
|  * time, this method should define some PHP callable to be called for the route | ||||
|  * (a controller in MVC speak). | ||||
|  * | ||||
|  * The @Route annotation can be set on the class (for global parameters), | ||||
|  * and on each method. | ||||
|  * | ||||
|  * The @Route annotation main value is the route path. The annotation also | ||||
|  * recognizes several parameters: requirements, options, defaults, schemes, | ||||
|  * methods, host, and name. The name parameter is mandatory. | ||||
|  * Here is an example of how you should be able to use it: | ||||
|  * | ||||
|  *     /** | ||||
|  *      * @Route("/Blog") | ||||
|  *      * / | ||||
|  *     class Blog | ||||
|  *     { | ||||
|  *         /** | ||||
|  *          * @Route("/", name="blog_index") | ||||
|  *          * / | ||||
|  *         public function index() | ||||
|  *         { | ||||
|  *         } | ||||
|  * | ||||
|  *         /** | ||||
|  *          * @Route("/{id}", name="blog_post", requirements = {"id" = "\d+"}) | ||||
|  *          * / | ||||
|  *         public function show() | ||||
|  *         { | ||||
|  *         } | ||||
|  *     } | ||||
|  * | ||||
|  * @author Fabien Potencier <fabien@symfony.com> | ||||
|  */ | ||||
| abstract class AnnotationClassLoader implements LoaderInterface | ||||
| { | ||||
|     /** | ||||
|      * @var Reader | ||||
|      */ | ||||
|     protected $reader; | ||||
|  | ||||
|     /** | ||||
|      * @var string | ||||
|      */ | ||||
|     protected $routeAnnotationClass = 'Symfony\\Component\\Routing\\Annotation\\Route'; | ||||
|  | ||||
|     /** | ||||
|      * @var integer | ||||
|      */ | ||||
|     protected $defaultRouteIndex = 0; | ||||
|  | ||||
|     /** | ||||
|      * Constructor. | ||||
|      * | ||||
|      * @param Reader $reader | ||||
|      */ | ||||
|     public function __construct(Reader $reader) | ||||
|     { | ||||
|         $this->reader = $reader; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Sets the annotation class to read route properties from. | ||||
|      * | ||||
|      * @param string $class A fully-qualified class name | ||||
|      */ | ||||
|     public function setRouteAnnotationClass($class) | ||||
|     { | ||||
|         $this->routeAnnotationClass = $class; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Loads from annotations from a class. | ||||
|      * | ||||
|      * @param string      $class A class name | ||||
|      * @param string|null $type  The resource type | ||||
|      * | ||||
|      * @return RouteCollection A RouteCollection instance | ||||
|      * | ||||
|      * @throws \InvalidArgumentException When route can't be parsed | ||||
|      */ | ||||
|     public function load($class, $type = null) | ||||
|     { | ||||
|         if (!class_exists($class)) { | ||||
|             throw new \InvalidArgumentException(sprintf('Class "%s" does not exist.', $class)); | ||||
|         } | ||||
|  | ||||
|         $globals = array( | ||||
|             'path'         => '', | ||||
|             'requirements' => array(), | ||||
|             'options'      => array(), | ||||
|             'defaults'     => array(), | ||||
|             'schemes'      => array(), | ||||
|             'methods'      => array(), | ||||
|             'host'         => '', | ||||
|         ); | ||||
|  | ||||
|         $class = new \ReflectionClass($class); | ||||
|         if ($class->isAbstract()) { | ||||
|             throw new \InvalidArgumentException(sprintf('Annotations from class "%s" cannot be read as it is abstract.', $class)); | ||||
|         } | ||||
|  | ||||
|         if ($annot = $this->reader->getClassAnnotation($class, $this->routeAnnotationClass)) { | ||||
|             // for BC reasons | ||||
|             if (null !== $annot->getPath()) { | ||||
|                 $globals['path'] = $annot->getPath(); | ||||
|             } elseif (null !== $annot->getPattern()) { | ||||
|                 $globals['path'] = $annot->getPattern(); | ||||
|             } | ||||
|  | ||||
|             if (null !== $annot->getRequirements()) { | ||||
|                 $globals['requirements'] = $annot->getRequirements(); | ||||
|             } | ||||
|  | ||||
|             if (null !== $annot->getOptions()) { | ||||
|                 $globals['options'] = $annot->getOptions(); | ||||
|             } | ||||
|  | ||||
|             if (null !== $annot->getDefaults()) { | ||||
|                 $globals['defaults'] = $annot->getDefaults(); | ||||
|             } | ||||
|  | ||||
|             if (null !== $annot->getSchemes()) { | ||||
|                 $globals['schemes'] = $annot->getSchemes(); | ||||
|             } | ||||
|  | ||||
|             if (null !== $annot->getMethods()) { | ||||
|                 $globals['methods'] = $annot->getMethods(); | ||||
|             } | ||||
|  | ||||
|             if (null !== $annot->getHost()) { | ||||
|                 $globals['host'] = $annot->getHost(); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         $collection = new RouteCollection(); | ||||
|         $collection->addResource(new FileResource($class->getFileName())); | ||||
|  | ||||
|         foreach ($class->getMethods() as $method) { | ||||
|             $this->defaultRouteIndex = 0; | ||||
|             foreach ($this->reader->getMethodAnnotations($method) as $annot) { | ||||
|                 if ($annot instanceof $this->routeAnnotationClass) { | ||||
|                     $this->addRoute($collection, $annot, $globals, $class, $method); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return $collection; | ||||
|     } | ||||
|  | ||||
|     protected function addRoute(RouteCollection $collection, $annot, $globals, \ReflectionClass $class, \ReflectionMethod $method) | ||||
|     { | ||||
|         $name = $annot->getName(); | ||||
|         if (null === $name) { | ||||
|             $name = $this->getDefaultRouteName($class, $method); | ||||
|         } | ||||
|  | ||||
|         $defaults = array_replace($globals['defaults'], $annot->getDefaults()); | ||||
|         foreach ($method->getParameters() as $param) { | ||||
|             if (!isset($defaults[$param->getName()]) && $param->isOptional()) { | ||||
|                 $defaults[$param->getName()] = $param->getDefaultValue(); | ||||
|             } | ||||
|         } | ||||
|         $requirements = array_replace($globals['requirements'], $annot->getRequirements()); | ||||
|         $options = array_replace($globals['options'], $annot->getOptions()); | ||||
|         $schemes = array_replace($globals['schemes'], $annot->getSchemes()); | ||||
|         $methods = array_replace($globals['methods'], $annot->getMethods()); | ||||
|  | ||||
|         $host = $annot->getHost(); | ||||
|         if (null === $host) { | ||||
|             $host = $globals['host']; | ||||
|         } | ||||
|  | ||||
|         $route = new Route($globals['path'].$annot->getPath(), $defaults, $requirements, $options, $host, $schemes, $methods); | ||||
|  | ||||
|         $this->configureRoute($route, $class, $method, $annot); | ||||
|  | ||||
|         $collection->add($name, $route); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function supports($resource, $type = null) | ||||
|     { | ||||
|         return is_string($resource) && preg_match('/^(?:\\\\?[a-zA-Z_\x7f-\xff][a-zA-Z0-9_\x7f-\xff]*)+$/', $resource) && (!$type || 'annotation' === $type); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function setResolver(LoaderResolverInterface $resolver) | ||||
|     { | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getResolver() | ||||
|     { | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Gets the default route name for a class method. | ||||
|      * | ||||
|      * @param \ReflectionClass  $class | ||||
|      * @param \ReflectionMethod $method | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     protected function getDefaultRouteName(\ReflectionClass $class, \ReflectionMethod $method) | ||||
|     { | ||||
|         $name = strtolower(str_replace('\\', '_', $class->name).'_'.$method->name); | ||||
|         if ($this->defaultRouteIndex > 0) { | ||||
|             $name .= '_'.$this->defaultRouteIndex; | ||||
|         } | ||||
|         $this->defaultRouteIndex++; | ||||
|  | ||||
|         return $name; | ||||
|     } | ||||
|  | ||||
|     abstract protected function configureRoute(Route $route, \ReflectionClass $class, \ReflectionMethod $method, $annot); | ||||
| } | ||||
							
								
								
									
										77
									
								
								vendor/symfony/routing/Symfony/Component/Routing/Loader/AnnotationDirectoryLoader.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										77
									
								
								vendor/symfony/routing/Symfony/Component/Routing/Loader/AnnotationDirectoryLoader.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,77 @@ | ||||
| <?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\Component\Routing\Loader; | ||||
|  | ||||
| use Symfony\Component\Routing\RouteCollection; | ||||
| use Symfony\Component\Config\Resource\DirectoryResource; | ||||
|  | ||||
| /** | ||||
|  * AnnotationDirectoryLoader loads routing information from annotations set | ||||
|  * on PHP classes and methods. | ||||
|  * | ||||
|  * @author Fabien Potencier <fabien@symfony.com> | ||||
|  */ | ||||
| class AnnotationDirectoryLoader extends AnnotationFileLoader | ||||
| { | ||||
|     /** | ||||
|      * Loads from annotations from a directory. | ||||
|      * | ||||
|      * @param string      $path A directory path | ||||
|      * @param string|null $type The resource type | ||||
|      * | ||||
|      * @return RouteCollection A RouteCollection instance | ||||
|      * | ||||
|      * @throws \InvalidArgumentException When the directory does not exist or its routes cannot be parsed | ||||
|      */ | ||||
|     public function load($path, $type = null) | ||||
|     { | ||||
|         $dir = $this->locator->locate($path); | ||||
|  | ||||
|         $collection = new RouteCollection(); | ||||
|         $collection->addResource(new DirectoryResource($dir, '/\.php$/')); | ||||
|         $files = iterator_to_array(new \RecursiveIteratorIterator(new \RecursiveDirectoryIterator($dir), \RecursiveIteratorIterator::LEAVES_ONLY)); | ||||
|         usort($files, function (\SplFileInfo $a, \SplFileInfo $b) { | ||||
|             return (string) $a > (string) $b ? 1 : -1; | ||||
|         }); | ||||
|  | ||||
|         foreach ($files as $file) { | ||||
|             if (!$file->isFile() || '.php' !== substr($file->getFilename(), -4)) { | ||||
|                 continue; | ||||
|             } | ||||
|  | ||||
|             if ($class = $this->findClass($file)) { | ||||
|                 $refl = new \ReflectionClass($class); | ||||
|                 if ($refl->isAbstract()) { | ||||
|                     continue; | ||||
|                 } | ||||
|  | ||||
|                 $collection->addCollection($this->loader->load($class, $type)); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return $collection; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function supports($resource, $type = null) | ||||
|     { | ||||
|         try { | ||||
|             $path = $this->locator->locate($resource); | ||||
|         } catch (\Exception $e) { | ||||
|             return false; | ||||
|         } | ||||
|  | ||||
|         return is_string($resource) && is_dir($path) && (!$type || 'annotation' === $type); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										122
									
								
								vendor/symfony/routing/Symfony/Component/Routing/Loader/AnnotationFileLoader.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										122
									
								
								vendor/symfony/routing/Symfony/Component/Routing/Loader/AnnotationFileLoader.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,122 @@ | ||||
| <?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\Component\Routing\Loader; | ||||
|  | ||||
| use Symfony\Component\Routing\RouteCollection; | ||||
| use Symfony\Component\Config\Resource\FileResource; | ||||
| use Symfony\Component\Config\Loader\FileLoader; | ||||
| use Symfony\Component\Config\FileLocatorInterface; | ||||
|  | ||||
| /** | ||||
|  * AnnotationFileLoader loads routing information from annotations set | ||||
|  * on a PHP class and its methods. | ||||
|  * | ||||
|  * @author Fabien Potencier <fabien@symfony.com> | ||||
|  */ | ||||
| class AnnotationFileLoader extends FileLoader | ||||
| { | ||||
|     protected $loader; | ||||
|  | ||||
|     /** | ||||
|      * Constructor. | ||||
|      * | ||||
|      * @param FileLocatorInterface  $locator A FileLocator instance | ||||
|      * @param AnnotationClassLoader $loader  An AnnotationClassLoader instance | ||||
|      * @param string|array          $paths   A path or an array of paths where to look for resources | ||||
|      * | ||||
|      * @throws \RuntimeException | ||||
|      */ | ||||
|     public function __construct(FileLocatorInterface $locator, AnnotationClassLoader $loader, $paths = array()) | ||||
|     { | ||||
|         if (!function_exists('token_get_all')) { | ||||
|             throw new \RuntimeException('The Tokenizer extension is required for the routing annotation loaders.'); | ||||
|         } | ||||
|  | ||||
|         parent::__construct($locator, $paths); | ||||
|  | ||||
|         $this->loader = $loader; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Loads from annotations from a file. | ||||
|      * | ||||
|      * @param string      $file A PHP file path | ||||
|      * @param string|null $type The resource type | ||||
|      * | ||||
|      * @return RouteCollection A RouteCollection instance | ||||
|      * | ||||
|      * @throws \InvalidArgumentException When the file does not exist or its routes cannot be parsed | ||||
|      */ | ||||
|     public function load($file, $type = null) | ||||
|     { | ||||
|         $path = $this->locator->locate($file); | ||||
|  | ||||
|         $collection = new RouteCollection(); | ||||
|         if ($class = $this->findClass($path)) { | ||||
|             $collection->addResource(new FileResource($path)); | ||||
|             $collection->addCollection($this->loader->load($class, $type)); | ||||
|         } | ||||
|  | ||||
|         return $collection; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function supports($resource, $type = null) | ||||
|     { | ||||
|         return is_string($resource) && 'php' === pathinfo($resource, PATHINFO_EXTENSION) && (!$type || 'annotation' === $type); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Returns the full class name for the first class in the file. | ||||
|      * | ||||
|      * @param string $file A PHP file path | ||||
|      * | ||||
|      * @return string|false Full class name if found, false otherwise | ||||
|      */ | ||||
|     protected function findClass($file) | ||||
|     { | ||||
|         $class = false; | ||||
|         $namespace = false; | ||||
|         $tokens = token_get_all(file_get_contents($file)); | ||||
|         for ($i = 0, $count = count($tokens); $i < $count; $i++) { | ||||
|             $token = $tokens[$i]; | ||||
|  | ||||
|             if (!is_array($token)) { | ||||
|                 continue; | ||||
|             } | ||||
|  | ||||
|             if (true === $class && T_STRING === $token[0]) { | ||||
|                 return $namespace.'\\'.$token[1]; | ||||
|             } | ||||
|  | ||||
|             if (true === $namespace && T_STRING === $token[0]) { | ||||
|                 $namespace = ''; | ||||
|                 do { | ||||
|                     $namespace .= $token[1]; | ||||
|                     $token = $tokens[++$i]; | ||||
|                 } while ($i < $count && is_array($token) && in_array($token[0], array(T_NS_SEPARATOR, T_STRING))); | ||||
|             } | ||||
|  | ||||
|             if (T_CLASS === $token[0]) { | ||||
|                 $class = true; | ||||
|             } | ||||
|  | ||||
|             if (T_NAMESPACE === $token[0]) { | ||||
|                 $namespace = true; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return false; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										52
									
								
								vendor/symfony/routing/Symfony/Component/Routing/Loader/ClosureLoader.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										52
									
								
								vendor/symfony/routing/Symfony/Component/Routing/Loader/ClosureLoader.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,52 @@ | ||||
| <?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\Component\Routing\Loader; | ||||
|  | ||||
| use Symfony\Component\Config\Loader\Loader; | ||||
| use Symfony\Component\Routing\RouteCollection; | ||||
|  | ||||
| /** | ||||
|  * ClosureLoader loads routes from a PHP closure. | ||||
|  * | ||||
|  * The Closure must return a RouteCollection instance. | ||||
|  * | ||||
|  * @author Fabien Potencier <fabien@symfony.com> | ||||
|  * | ||||
|  * @api | ||||
|  */ | ||||
| class ClosureLoader extends Loader | ||||
| { | ||||
|     /** | ||||
|      * Loads a Closure. | ||||
|      * | ||||
|      * @param \Closure    $closure A Closure | ||||
|      * @param string|null $type    The resource type | ||||
|      * | ||||
|      * @return RouteCollection A RouteCollection instance | ||||
|      * | ||||
|      * @api | ||||
|      */ | ||||
|     public function load($closure, $type = null) | ||||
|     { | ||||
|         return call_user_func($closure); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      * | ||||
|      * @api | ||||
|      */ | ||||
|     public function supports($resource, $type = null) | ||||
|     { | ||||
|         return $resource instanceof \Closure && (!$type || 'closure' === $type); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										62
									
								
								vendor/symfony/routing/Symfony/Component/Routing/Loader/PhpFileLoader.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										62
									
								
								vendor/symfony/routing/Symfony/Component/Routing/Loader/PhpFileLoader.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,62 @@ | ||||
| <?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\Component\Routing\Loader; | ||||
|  | ||||
| use Symfony\Component\Config\Loader\FileLoader; | ||||
| use Symfony\Component\Config\Resource\FileResource; | ||||
| use Symfony\Component\Routing\RouteCollection; | ||||
|  | ||||
| /** | ||||
|  * PhpFileLoader loads routes from a PHP file. | ||||
|  * | ||||
|  * The file must return a RouteCollection instance. | ||||
|  * | ||||
|  * @author Fabien Potencier <fabien@symfony.com> | ||||
|  * | ||||
|  * @api | ||||
|  */ | ||||
| class PhpFileLoader extends FileLoader | ||||
| { | ||||
|     /** | ||||
|      * Loads a PHP file. | ||||
|      * | ||||
|      * @param string      $file A PHP file path | ||||
|      * @param string|null $type The resource type | ||||
|      * | ||||
|      * @return RouteCollection A RouteCollection instance | ||||
|      * | ||||
|      * @api | ||||
|      */ | ||||
|     public function load($file, $type = null) | ||||
|     { | ||||
|         // the loader variable is exposed to the included file below | ||||
|         $loader = $this; | ||||
|  | ||||
|         $path = $this->locator->locate($file); | ||||
|         $this->setCurrentDir(dirname($path)); | ||||
|  | ||||
|         $collection = include $path; | ||||
|         $collection->addResource(new FileResource($path)); | ||||
|  | ||||
|         return $collection; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      * | ||||
|      * @api | ||||
|      */ | ||||
|     public function supports($resource, $type = null) | ||||
|     { | ||||
|         return is_string($resource) && 'php' === pathinfo($resource, PATHINFO_EXTENSION) && (!$type || 'php' === $type); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										238
									
								
								vendor/symfony/routing/Symfony/Component/Routing/Loader/XmlFileLoader.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										238
									
								
								vendor/symfony/routing/Symfony/Component/Routing/Loader/XmlFileLoader.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,238 @@ | ||||
| <?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\Component\Routing\Loader; | ||||
|  | ||||
| use Symfony\Component\Routing\RouteCollection; | ||||
| use Symfony\Component\Routing\Route; | ||||
| use Symfony\Component\Config\Resource\FileResource; | ||||
| use Symfony\Component\Config\Loader\FileLoader; | ||||
| use Symfony\Component\Config\Util\XmlUtils; | ||||
|  | ||||
| /** | ||||
|  * XmlFileLoader loads XML routing files. | ||||
|  * | ||||
|  * @author Fabien Potencier <fabien@symfony.com> | ||||
|  * @author Tobias Schultze <http://tobion.de> | ||||
|  * | ||||
|  * @api | ||||
|  */ | ||||
| class XmlFileLoader extends FileLoader | ||||
| { | ||||
|     const NAMESPACE_URI = 'http://symfony.com/schema/routing'; | ||||
|     const SCHEME_PATH = '/schema/routing/routing-1.0.xsd'; | ||||
|  | ||||
|     /** | ||||
|      * Loads an XML file. | ||||
|      * | ||||
|      * @param string      $file An XML file path | ||||
|      * @param string|null $type The resource type | ||||
|      * | ||||
|      * @return RouteCollection A RouteCollection instance | ||||
|      * | ||||
|      * @throws \InvalidArgumentException When the file cannot be loaded or when the XML cannot be | ||||
|      *                                   parsed because it does not validate against the scheme. | ||||
|      * | ||||
|      * @api | ||||
|      */ | ||||
|     public function load($file, $type = null) | ||||
|     { | ||||
|         $path = $this->locator->locate($file); | ||||
|  | ||||
|         $xml = $this->loadFile($path); | ||||
|  | ||||
|         $collection = new RouteCollection(); | ||||
|         $collection->addResource(new FileResource($path)); | ||||
|  | ||||
|         // process routes and imports | ||||
|         foreach ($xml->documentElement->childNodes as $node) { | ||||
|             if (!$node instanceof \DOMElement) { | ||||
|                 continue; | ||||
|             } | ||||
|  | ||||
|             $this->parseNode($collection, $node, $path, $file); | ||||
|         } | ||||
|  | ||||
|         return $collection; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Parses a node from a loaded XML file. | ||||
|      * | ||||
|      * @param RouteCollection $collection Collection to associate with the node | ||||
|      * @param \DOMElement     $node       Element to parse | ||||
|      * @param string          $path       Full path of the XML file being processed | ||||
|      * @param string          $file       Loaded file name | ||||
|      * | ||||
|      * @throws \InvalidArgumentException When the XML is invalid | ||||
|      */ | ||||
|     protected function parseNode(RouteCollection $collection, \DOMElement $node, $path, $file) | ||||
|     { | ||||
|         if (self::NAMESPACE_URI !== $node->namespaceURI) { | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|         switch ($node->localName) { | ||||
|             case 'route': | ||||
|                 $this->parseRoute($collection, $node, $path); | ||||
|                 break; | ||||
|             case 'import': | ||||
|                 $this->parseImport($collection, $node, $path, $file); | ||||
|                 break; | ||||
|             default: | ||||
|                 throw new \InvalidArgumentException(sprintf('Unknown tag "%s" used in file "%s". Expected "route" or "import".', $node->localName, $path)); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      * | ||||
|      * @api | ||||
|      */ | ||||
|     public function supports($resource, $type = null) | ||||
|     { | ||||
|         return is_string($resource) && 'xml' === pathinfo($resource, PATHINFO_EXTENSION) && (!$type || 'xml' === $type); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Parses a route and adds it to the RouteCollection. | ||||
|      * | ||||
|      * @param RouteCollection $collection RouteCollection instance | ||||
|      * @param \DOMElement     $node       Element to parse that represents a Route | ||||
|      * @param string          $path       Full path of the XML file being processed | ||||
|      * | ||||
|      * @throws \InvalidArgumentException When the XML is invalid | ||||
|      */ | ||||
|     protected function parseRoute(RouteCollection $collection, \DOMElement $node, $path) | ||||
|     { | ||||
|         if ('' === ($id = $node->getAttribute('id')) || (!$node->hasAttribute('pattern') && !$node->hasAttribute('path'))) { | ||||
|             throw new \InvalidArgumentException(sprintf('The <route> element in file "%s" must have an "id" and a "path" attribute.', $path)); | ||||
|         } | ||||
|  | ||||
|         if ($node->hasAttribute('pattern')) { | ||||
|             if ($node->hasAttribute('path')) { | ||||
|                 throw new \InvalidArgumentException(sprintf('The <route> element in file "%s" cannot define both a "path" and a "pattern" attribute. Use only "path".', $path)); | ||||
|             } | ||||
|  | ||||
|             $node->setAttribute('path', $node->getAttribute('pattern')); | ||||
|             $node->removeAttribute('pattern'); | ||||
|         } | ||||
|  | ||||
|         $schemes = preg_split('/[\s,\|]++/', $node->getAttribute('schemes'), -1, PREG_SPLIT_NO_EMPTY); | ||||
|         $methods = preg_split('/[\s,\|]++/', $node->getAttribute('methods'), -1, PREG_SPLIT_NO_EMPTY); | ||||
|  | ||||
|         list($defaults, $requirements, $options) = $this->parseConfigs($node, $path); | ||||
|  | ||||
|         $route = new Route($node->getAttribute('path'), $defaults, $requirements, $options, $node->getAttribute('host'), $schemes, $methods); | ||||
|         $collection->add($id, $route); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Parses an import and adds the routes in the resource to the RouteCollection. | ||||
|      * | ||||
|      * @param RouteCollection $collection RouteCollection instance | ||||
|      * @param \DOMElement     $node       Element to parse that represents a Route | ||||
|      * @param string          $path       Full path of the XML file being processed | ||||
|      * @param string          $file       Loaded file name | ||||
|      * | ||||
|      * @throws \InvalidArgumentException When the XML is invalid | ||||
|      */ | ||||
|     protected function parseImport(RouteCollection $collection, \DOMElement $node, $path, $file) | ||||
|     { | ||||
|         if ('' === $resource = $node->getAttribute('resource')) { | ||||
|             throw new \InvalidArgumentException(sprintf('The <import> element in file "%s" must have a "resource" attribute.', $path)); | ||||
|         } | ||||
|  | ||||
|         $type = $node->getAttribute('type'); | ||||
|         $prefix = $node->getAttribute('prefix'); | ||||
|         $host = $node->hasAttribute('host') ? $node->getAttribute('host') : null; | ||||
|         $schemes = $node->hasAttribute('schemes') ? preg_split('/[\s,\|]++/', $node->getAttribute('schemes'), -1, PREG_SPLIT_NO_EMPTY) : null; | ||||
|         $methods = $node->hasAttribute('methods') ? preg_split('/[\s,\|]++/', $node->getAttribute('methods'), -1, PREG_SPLIT_NO_EMPTY) : null; | ||||
|  | ||||
|         list($defaults, $requirements, $options) = $this->parseConfigs($node, $path); | ||||
|  | ||||
|         $this->setCurrentDir(dirname($path)); | ||||
|  | ||||
|         $subCollection = $this->import($resource, ('' !== $type ? $type : null), false, $file); | ||||
|         /* @var $subCollection RouteCollection */ | ||||
|         $subCollection->addPrefix($prefix); | ||||
|         if (null !== $host) { | ||||
|             $subCollection->setHost($host); | ||||
|         } | ||||
|         if (null !== $schemes) { | ||||
|             $subCollection->setSchemes($schemes); | ||||
|         } | ||||
|         if (null !== $methods) { | ||||
|             $subCollection->setMethods($methods); | ||||
|         } | ||||
|         $subCollection->addDefaults($defaults); | ||||
|         $subCollection->addRequirements($requirements); | ||||
|         $subCollection->addOptions($options); | ||||
|  | ||||
|         $collection->addCollection($subCollection); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Loads an XML file. | ||||
|      * | ||||
|      * @param string $file An XML file path | ||||
|      * | ||||
|      * @return \DOMDocument | ||||
|      * | ||||
|      * @throws \InvalidArgumentException When loading of XML file fails because of syntax errors | ||||
|      *                                   or when the XML structure is not as expected by the scheme - | ||||
|      *                                   see validate() | ||||
|      */ | ||||
|     protected function loadFile($file) | ||||
|     { | ||||
|         return XmlUtils::loadFile($file, __DIR__.static::SCHEME_PATH); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Parses the config elements (default, requirement, option). | ||||
|      * | ||||
|      * @param \DOMElement $node Element to parse that contains the configs | ||||
|      * @param string      $path Full path of the XML file being processed | ||||
|      * | ||||
|      * @return array An array with the defaults as first item, requirements as second and options as third. | ||||
|      * | ||||
|      * @throws \InvalidArgumentException When the XML is invalid | ||||
|      */ | ||||
|     private function parseConfigs(\DOMElement $node, $path) | ||||
|     { | ||||
|         $defaults = array(); | ||||
|         $requirements = array(); | ||||
|         $options = array(); | ||||
|  | ||||
|         foreach ($node->getElementsByTagNameNS(self::NAMESPACE_URI, '*') as $n) { | ||||
|             switch ($n->localName) { | ||||
|                 case 'default': | ||||
|                     if ($n->hasAttribute('xsi:nil') && 'true' == $n->getAttribute('xsi:nil')) { | ||||
|                         $defaults[$n->getAttribute('key')] = null; | ||||
|                     } else { | ||||
|                         $defaults[$n->getAttribute('key')] = trim($n->textContent); | ||||
|                     } | ||||
|  | ||||
|                     break; | ||||
|                 case 'requirement': | ||||
|                     $requirements[$n->getAttribute('key')] = trim($n->textContent); | ||||
|                     break; | ||||
|                 case 'option': | ||||
|                     $options[$n->getAttribute('key')] = trim($n->textContent); | ||||
|                     break; | ||||
|                 default: | ||||
|                     throw new \InvalidArgumentException(sprintf('Unknown tag "%s" used in file "%s". Expected "default", "requirement" or "option".', $n->localName, $path)); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return array($defaults, $requirements, $options); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										212
									
								
								vendor/symfony/routing/Symfony/Component/Routing/Loader/YamlFileLoader.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										212
									
								
								vendor/symfony/routing/Symfony/Component/Routing/Loader/YamlFileLoader.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,212 @@ | ||||
| <?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\Component\Routing\Loader; | ||||
|  | ||||
| use Symfony\Component\Routing\RouteCollection; | ||||
| use Symfony\Component\Routing\Route; | ||||
| use Symfony\Component\Config\Resource\FileResource; | ||||
| use Symfony\Component\Yaml\Parser as YamlParser; | ||||
| use Symfony\Component\Config\Loader\FileLoader; | ||||
|  | ||||
| /** | ||||
|  * YamlFileLoader loads Yaml routing files. | ||||
|  * | ||||
|  * @author Fabien Potencier <fabien@symfony.com> | ||||
|  * @author Tobias Schultze <http://tobion.de> | ||||
|  * | ||||
|  * @api | ||||
|  */ | ||||
| class YamlFileLoader extends FileLoader | ||||
| { | ||||
|     private static $availableKeys = array( | ||||
|         'resource', 'type', 'prefix', 'pattern', 'path', 'host', 'schemes', 'methods', 'defaults', 'requirements', 'options', | ||||
|     ); | ||||
|     private $yamlParser; | ||||
|  | ||||
|     /** | ||||
|      * Loads a Yaml file. | ||||
|      * | ||||
|      * @param string      $file A Yaml file path | ||||
|      * @param string|null $type The resource type | ||||
|      * | ||||
|      * @return RouteCollection A RouteCollection instance | ||||
|      * | ||||
|      * @throws \InvalidArgumentException When a route can't be parsed because YAML is invalid | ||||
|      * | ||||
|      * @api | ||||
|      */ | ||||
|     public function load($file, $type = null) | ||||
|     { | ||||
|         $path = $this->locator->locate($file); | ||||
|  | ||||
|         if (!stream_is_local($path)) { | ||||
|             throw new \InvalidArgumentException(sprintf('This is not a local file "%s".', $path)); | ||||
|         } | ||||
|  | ||||
|         if (!file_exists($path)) { | ||||
|             throw new \InvalidArgumentException(sprintf('File "%s" not found.', $path)); | ||||
|         } | ||||
|  | ||||
|         if (null === $this->yamlParser) { | ||||
|             $this->yamlParser = new YamlParser(); | ||||
|         } | ||||
|  | ||||
|         $config = $this->yamlParser->parse(file_get_contents($path)); | ||||
|  | ||||
|         $collection = new RouteCollection(); | ||||
|         $collection->addResource(new FileResource($path)); | ||||
|  | ||||
|         // empty file | ||||
|         if (null === $config) { | ||||
|             return $collection; | ||||
|         } | ||||
|  | ||||
|         // not an array | ||||
|         if (!is_array($config)) { | ||||
|             throw new \InvalidArgumentException(sprintf('The file "%s" must contain a YAML array.', $path)); | ||||
|         } | ||||
|  | ||||
|         foreach ($config as $name => $config) { | ||||
|             if (isset($config['pattern'])) { | ||||
|                 if (isset($config['path'])) { | ||||
|                     throw new \InvalidArgumentException(sprintf('The file "%s" cannot define both a "path" and a "pattern" attribute. Use only "path".', $path)); | ||||
|                 } | ||||
|  | ||||
|                 $config['path'] = $config['pattern']; | ||||
|                 unset($config['pattern']); | ||||
|             } | ||||
|  | ||||
|             $this->validate($config, $name, $path); | ||||
|  | ||||
|             if (isset($config['resource'])) { | ||||
|                 $this->parseImport($collection, $config, $path, $file); | ||||
|             } else { | ||||
|                 $this->parseRoute($collection, $name, $config, $path); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return $collection; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      * | ||||
|      * @api | ||||
|      */ | ||||
|     public function supports($resource, $type = null) | ||||
|     { | ||||
|         return is_string($resource) && 'yml' === pathinfo($resource, PATHINFO_EXTENSION) && (!$type || 'yaml' === $type); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Parses a route and adds it to the RouteCollection. | ||||
|      * | ||||
|      * @param RouteCollection $collection A RouteCollection instance | ||||
|      * @param string          $name       Route name | ||||
|      * @param array           $config     Route definition | ||||
|      * @param string          $path       Full path of the YAML file being processed | ||||
|      */ | ||||
|     protected function parseRoute(RouteCollection $collection, $name, array $config, $path) | ||||
|     { | ||||
|         $defaults = isset($config['defaults']) ? $config['defaults'] : array(); | ||||
|         $requirements = isset($config['requirements']) ? $config['requirements'] : array(); | ||||
|         $options = isset($config['options']) ? $config['options'] : array(); | ||||
|         $host = isset($config['host']) ? $config['host'] : ''; | ||||
|         $schemes = isset($config['schemes']) ? $config['schemes'] : array(); | ||||
|         $methods = isset($config['methods']) ? $config['methods'] : array(); | ||||
|  | ||||
|         $route = new Route($config['path'], $defaults, $requirements, $options, $host, $schemes, $methods); | ||||
|  | ||||
|         $collection->add($name, $route); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Parses an import and adds the routes in the resource to the RouteCollection. | ||||
|      * | ||||
|      * @param RouteCollection $collection A RouteCollection instance | ||||
|      * @param array           $config     Route definition | ||||
|      * @param string          $path       Full path of the YAML file being processed | ||||
|      * @param string          $file       Loaded file name | ||||
|      */ | ||||
|     protected function parseImport(RouteCollection $collection, array $config, $path, $file) | ||||
|     { | ||||
|         $type = isset($config['type']) ? $config['type'] : null; | ||||
|         $prefix = isset($config['prefix']) ? $config['prefix'] : ''; | ||||
|         $defaults = isset($config['defaults']) ? $config['defaults'] : array(); | ||||
|         $requirements = isset($config['requirements']) ? $config['requirements'] : array(); | ||||
|         $options = isset($config['options']) ? $config['options'] : array(); | ||||
|         $host = isset($config['host']) ? $config['host'] : null; | ||||
|         $schemes = isset($config['schemes']) ? $config['schemes'] : null; | ||||
|         $methods = isset($config['methods']) ? $config['methods'] : null; | ||||
|  | ||||
|         $this->setCurrentDir(dirname($path)); | ||||
|  | ||||
|         $subCollection = $this->import($config['resource'], $type, false, $file); | ||||
|         /* @var $subCollection RouteCollection */ | ||||
|         $subCollection->addPrefix($prefix); | ||||
|         if (null !== $host) { | ||||
|             $subCollection->setHost($host); | ||||
|         } | ||||
|         if (null !== $schemes) { | ||||
|             $subCollection->setSchemes($schemes); | ||||
|         } | ||||
|         if (null !== $methods) { | ||||
|             $subCollection->setMethods($methods); | ||||
|         } | ||||
|         $subCollection->addDefaults($defaults); | ||||
|         $subCollection->addRequirements($requirements); | ||||
|         $subCollection->addOptions($options); | ||||
|  | ||||
|         $collection->addCollection($subCollection); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Validates the route configuration. | ||||
|      * | ||||
|      * @param array  $config A resource config | ||||
|      * @param string $name   The config key | ||||
|      * @param string $path   The loaded file path | ||||
|      * | ||||
|      * @throws \InvalidArgumentException If one of the provided config keys is not supported, | ||||
|      *                                   something is missing or the combination is nonsense | ||||
|      */ | ||||
|     protected function validate($config, $name, $path) | ||||
|     { | ||||
|         if (!is_array($config)) { | ||||
|             throw new \InvalidArgumentException(sprintf('The definition of "%s" in "%s" must be a YAML array.', $name, $path)); | ||||
|         } | ||||
|         if ($extraKeys = array_diff(array_keys($config), self::$availableKeys)) { | ||||
|             throw new \InvalidArgumentException(sprintf( | ||||
|                 'The routing file "%s" contains unsupported keys for "%s": "%s". Expected one of: "%s".', | ||||
|                 $path, $name, implode('", "', $extraKeys), implode('", "', self::$availableKeys) | ||||
|             )); | ||||
|         } | ||||
|         if (isset($config['resource']) && isset($config['path'])) { | ||||
|             throw new \InvalidArgumentException(sprintf( | ||||
|                 'The routing file "%s" must not specify both the "resource" key and the "path" key for "%s". Choose between an import and a route definition.', | ||||
|                 $path, $name | ||||
|             )); | ||||
|         } | ||||
|         if (!isset($config['resource']) && isset($config['type'])) { | ||||
|             throw new \InvalidArgumentException(sprintf( | ||||
|                 'The "type" key for the route definition "%s" in "%s" is unsupported. It is only available for imports in combination with the "resource" key.', | ||||
|                 $name, $path | ||||
|             )); | ||||
|         } | ||||
|         if (!isset($config['resource']) && !isset($config['path'])) { | ||||
|             throw new \InvalidArgumentException(sprintf( | ||||
|                 'You must define a "path" for the route "%s" in file "%s".', | ||||
|                 $name, $path | ||||
|             )); | ||||
|         } | ||||
|     } | ||||
| } | ||||
							
								
								
									
										64
									
								
								vendor/symfony/routing/Symfony/Component/Routing/Loader/schema/routing/routing-1.0.xsd
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										64
									
								
								vendor/symfony/routing/Symfony/Component/Routing/Loader/schema/routing/routing-1.0.xsd
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,64 @@ | ||||
| <?xml version="1.0" encoding="UTF-8" ?> | ||||
|  | ||||
| <xsd:schema xmlns="http://symfony.com/schema/routing" | ||||
|     xmlns:xsd="http://www.w3.org/2001/XMLSchema" | ||||
|     targetNamespace="http://symfony.com/schema/routing" | ||||
|     elementFormDefault="qualified"> | ||||
|  | ||||
|   <xsd:annotation> | ||||
|     <xsd:documentation><![CDATA[ | ||||
|       Symfony XML Routing Schema, version 1.0 | ||||
|       Authors: Fabien Potencier, Tobias Schultze | ||||
|  | ||||
|       This scheme defines the elements and attributes that can be used to define | ||||
|       routes. A route maps an HTTP request to a set of configuration variables. | ||||
|     ]]></xsd:documentation> | ||||
|   </xsd:annotation> | ||||
|  | ||||
|   <xsd:element name="routes" type="routes" /> | ||||
|  | ||||
|   <xsd:complexType name="routes"> | ||||
|     <xsd:choice minOccurs="0" maxOccurs="unbounded"> | ||||
|       <xsd:element name="import" type="import" /> | ||||
|       <xsd:element name="route" type="route" /> | ||||
|     </xsd:choice> | ||||
|   </xsd:complexType> | ||||
|  | ||||
|   <xsd:group name="configs"> | ||||
|     <xsd:choice> | ||||
|       <xsd:element name="default" nillable="true" type="element" /> | ||||
|       <xsd:element name="requirement" type="element" /> | ||||
|       <xsd:element name="option" type="element" /> | ||||
|     </xsd:choice> | ||||
|   </xsd:group> | ||||
|  | ||||
|   <xsd:complexType name="route"> | ||||
|     <xsd:group ref="configs" minOccurs="0" maxOccurs="unbounded" /> | ||||
|  | ||||
|     <xsd:attribute name="id" type="xsd:string" use="required" /> | ||||
|     <xsd:attribute name="path" type="xsd:string" /> | ||||
|     <xsd:attribute name="pattern" type="xsd:string" /> | ||||
|     <xsd:attribute name="host" type="xsd:string" /> | ||||
|     <xsd:attribute name="schemes" type="xsd:string" /> | ||||
|     <xsd:attribute name="methods" type="xsd:string" /> | ||||
|   </xsd:complexType> | ||||
|  | ||||
|   <xsd:complexType name="import"> | ||||
|     <xsd:group ref="configs" minOccurs="0" maxOccurs="unbounded" /> | ||||
|  | ||||
|     <xsd:attribute name="resource" type="xsd:string" use="required" /> | ||||
|     <xsd:attribute name="type" type="xsd:string" /> | ||||
|     <xsd:attribute name="prefix" type="xsd:string" /> | ||||
|     <xsd:attribute name="host" type="xsd:string" /> | ||||
|     <xsd:attribute name="schemes" type="xsd:string" /> | ||||
|     <xsd:attribute name="methods" type="xsd:string" /> | ||||
|   </xsd:complexType> | ||||
|  | ||||
|   <xsd:complexType name="element"> | ||||
|     <xsd:simpleContent> | ||||
|       <xsd:extension base="xsd:string"> | ||||
|         <xsd:attribute name="key" type="xsd:string" use="required" /> | ||||
|       </xsd:extension> | ||||
|     </xsd:simpleContent> | ||||
|   </xsd:complexType> | ||||
| </xsd:schema> | ||||
		Reference in New Issue
	
	Block a user