123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596 |
- <?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;
- use Symfony\Component\Routing\Exception\InvalidArgumentException;
- class Alias
- {
- private $id;
- private $deprecation = [];
- public function __construct(string $id)
- {
- $this->id = $id;
- }
- /**
- * @return static
- */
- public function withId(string $id): self
- {
- $new = clone $this;
- $new->id = $id;
- return $new;
- }
- /**
- * Returns the target name of this alias.
- *
- * @return string The target name
- */
- public function getId(): string
- {
- return $this->id;
- }
- /**
- * Whether this alias is deprecated, that means it should not be referenced anymore.
- *
- * @param string $package The name of the composer package that is triggering the deprecation
- * @param string $version The version of the package that introduced the deprecation
- * @param string $message The deprecation message to use
- *
- * @return $this
- *
- * @throws InvalidArgumentException when the message template is invalid
- */
- public function setDeprecated(string $package, string $version, string $message): self
- {
- if ('' !== $message) {
- if (preg_match('#[\r\n]|\*/#', $message)) {
- throw new InvalidArgumentException('Invalid characters found in deprecation template.');
- }
- if (!str_contains($message, '%alias_id%')) {
- throw new InvalidArgumentException('The deprecation template must contain the "%alias_id%" placeholder.');
- }
- }
- $this->deprecation = [
- 'package' => $package,
- 'version' => $version,
- 'message' => $message ?: 'The "%alias_id%" route alias is deprecated. You should stop using it, as it will be removed in the future.',
- ];
- return $this;
- }
- public function isDeprecated(): bool
- {
- return (bool) $this->deprecation;
- }
- /**
- * @param string $name Route name relying on this alias
- */
- public function getDeprecation(string $name): array
- {
- return [
- 'package' => $this->deprecation['package'],
- 'version' => $this->deprecation['version'],
- 'message' => str_replace('%alias_id%', $name, $this->deprecation['message']),
- ];
- }
- }
|