123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263 |
- <?php
- namespace Symfony\Component\Routing\Loader\Configurator\Traits;
- use Symfony\Component\Routing\Route;
- use Symfony\Component\Routing\RouteCollection;
- trait PrefixTrait
- {
- final protected function addPrefix(RouteCollection $routes, $prefix, bool $trailingSlashOnRoot)
- {
- if (\is_array($prefix)) {
- foreach ($prefix as $locale => $localePrefix) {
- $prefix[$locale] = trim(trim($localePrefix), '/');
- }
- foreach ($routes->all() as $name => $route) {
- if (null === $locale = $route->getDefault('_locale')) {
- $priority = $routes->getPriority($name) ?? 0;
- $routes->remove($name);
- foreach ($prefix as $locale => $localePrefix) {
- $localizedRoute = clone $route;
- $localizedRoute->setDefault('_locale', $locale);
- $localizedRoute->setRequirement('_locale', preg_quote($locale));
- $localizedRoute->setDefault('_canonical_route', $name);
- $localizedRoute->setPath($localePrefix.(!$trailingSlashOnRoot && '/' === $route->getPath() ? '' : $route->getPath()));
- $routes->add($name.'.'.$locale, $localizedRoute, $priority);
- }
- } elseif (!isset($prefix[$locale])) {
- throw new \InvalidArgumentException(sprintf('Route "%s" with locale "%s" is missing a corresponding prefix in its parent collection.', $name, $locale));
- } else {
- $route->setPath($prefix[$locale].(!$trailingSlashOnRoot && '/' === $route->getPath() ? '' : $route->getPath()));
- $routes->add($name, $route, $routes->getPriority($name) ?? 0);
- }
- }
- return;
- }
- $routes->addPrefix($prefix);
- if (!$trailingSlashOnRoot) {
- $rootPath = (new Route(trim(trim($prefix), '/').'/'))->getPath();
- foreach ($routes->all() as $route) {
- if ($route->getPath() === $rootPath) {
- $route->setPath(rtrim($rootPath, '/'));
- }
- }
- }
- }
- }
|