| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990 |
- <?php
- /*
- * Copyright (c) Alexandre Gomes Gaigalas <alganet@gmail.com>
- * SPDX-License-Identifier: MIT
- */
- declare(strict_types=1);
- namespace Respect\Validation\Rules;
- use Respect\Validation\Exceptions\ComponentException;
- use function array_keys;
- use function is_string;
- use function mb_strtolower;
- use function preg_match;
- use function sprintf;
- /**
- * Validates if the input is a video URL value.
- *
- * @author Danilo Correa <danilosilva87@gmail.com>
- * @author Emmerson Siqueira <emmersonsiqueira@gmail.com>
- * @author Henrique Moody <henriquemoody@gmail.com>
- * @author Ricardo Gobbo <ricardo@clicknow.com.br>
- */
- final class VideoUrl extends AbstractRule
- {
- private const SERVICES = [
- // phpcs:disable Generic.Files.LineLength.TooLong
- 'youtube' => '@^https?://(www\.)?(?:youtube\.com/(?:[^/]+/.+/|(?:v|e(?:mbed)?)/|.*[?&]v=)|youtu\.be/)([^\"&?/]{11})@i',
- 'vimeo' => '@^https?://(www\.)?(player\.)?(vimeo\.com/)((channels/[A-z]+/)|(groups/[A-z]+/videos/)|(video/))?([0-9]+)@i',
- 'twitch' => '@^https?://(((www\.)?twitch\.tv/videos/[0-9]+)|clips\.twitch\.tv/[a-zA-Z]+)$@i',
- // phpcs:enable Generic.Files.LineLength.TooLong
- ];
- /**
- * @var string|null
- */
- private $service;
- /**
- * Create a new instance VideoUrl.
- *
- * @throws ComponentException when the given service is not supported
- */
- public function __construct(?string $service = null)
- {
- if ($service !== null && !$this->isSupportedService($service)) {
- throw new ComponentException(sprintf('"%s" is not a recognized video service.', $service));
- }
- $this->service = $service;
- }
- /**
- * {@inheritDoc}
- */
- public function validate($input): bool
- {
- if (!is_string($input)) {
- return false;
- }
- if ($this->service !== null) {
- return $this->isValid($this->service, $input);
- }
- foreach (array_keys(self::SERVICES) as $service) {
- if (!$this->isValid($service, $input)) {
- continue;
- }
- return true;
- }
- return false;
- }
- private function isSupportedService(string $service): bool
- {
- return isset(self::SERVICES[mb_strtolower($service)]);
- }
- private function isValid(string $service, string $input): bool
- {
- return preg_match(self::SERVICES[mb_strtolower($service)], $input) > 0;
- }
- }
|