diff --git a/modules/oe_theme_helper/src/ExternalLinks.php b/modules/oe_theme_helper/src/ExternalLinks.php index 77e575248..3b38dacbc 100644 --- a/modules/oe_theme_helper/src/ExternalLinks.php +++ b/modules/oe_theme_helper/src/ExternalLinks.php @@ -14,11 +14,11 @@ class ExternalLinks implements ExternalLinksInterface { /** - * The configuration factory. + * The internal domain regex. * - * @var \Drupal\Core\Config\ConfigFactoryInterface + * @var string */ - protected $configFactory; + protected string $internalDomainExpression; /** * Constructs an ExternalLinks object. @@ -27,13 +27,18 @@ class ExternalLinks implements ExternalLinksInterface { * The configuration factory. */ public function __construct(ConfigFactoryInterface $config_factory) { - $this->configFactory = $config_factory; + $this->internalDomainExpression = $config_factory->get('oe_theme_helper.internal_domains')->get('internal_domain') ?? ''; } /** * {@inheritdoc} */ - public function isExternalLink($url): bool { + public function isExternalLink($url = NULL): bool { + // If no value is provided or the value si not a proper link, we'll + // return FALSE as it can't be evaluated. + if (!$url) { + return FALSE; + } if ($url instanceof Url) { $external = $url->isExternal(); $path = UrlHelper::parse($url->toString())['path']; @@ -47,11 +52,10 @@ public function isExternalLink($url): bool { } // If it's an external link, make sure its domain is not internal. - $internal_domain_expression = $this->configFactory->get('oe_theme_helper.internal_domains')->get('internal_domain'); - if (!$internal_domain_expression) { + if (!$this->internalDomainExpression) { return $external; } - return !preg_match_all($internal_domain_expression, $path); + return !preg_match_all($this->internalDomainExpression, $path); } } diff --git a/modules/oe_theme_helper/tests/src/Kernel/ExternalLinksTest.php b/modules/oe_theme_helper/tests/src/Kernel/ExternalLinksTest.php new file mode 100644 index 000000000..fcdcf10a9 --- /dev/null +++ b/modules/oe_theme_helper/tests/src/Kernel/ExternalLinksTest.php @@ -0,0 +1,37 @@ +container->get('oe_theme_helper.external_links'); + // Assert internal URL. + $this->assertFalse($external_links->isExternalLink(Url::fromUserInput('/user'))); + // Assert external string path. + $this->assertTrue($external_links->isExternalLink('https://example.com')); + // Assert external string path under EU domain. + $this->assertFalse($external_links->isExternalLink('https://example.europa.eu')); + $this->assertFalse($external_links->isExternalLink('www.ec.europa.eu/info')); + // Assert null and empty value. + $this->assertFalse($external_links->isExternalLink()); + $this->assertFalse($external_links->isExternalLink('')); + // Assert incorrect paths. + $this->assertFalse($external_links->isExternalLink('www. incorrect . com')); + $this->assertFalse($external_links->isExternalLink('www. ec . europa . eu')); + } + +}