diff --git a/src/Controllers/ShareDraftController.php b/src/Controllers/ShareDraftController.php index 282713c..84607d9 100644 --- a/src/Controllers/ShareDraftController.php +++ b/src/Controllers/ShareDraftController.php @@ -51,6 +51,8 @@ class ShareDraftController extends Controller */ protected static $isViewingPreview = false; + private array $redirectRecursionIterations = []; + /** * @return bool */ @@ -144,8 +146,8 @@ private function getRenderedPageByURL(string $url): HTTPResponse $variables['_SERVER']['HTTP_USER_AGENT'] = isset($variables['_SERVER']['HTTP_USER_AGENT']) && $variables['_SERVER']['HTTP_USER_AGENT'] - ? $variables['_SERVER']['HTTP_USER_AGENT'] - : 'CLI'; + ? $variables['_SERVER']['HTTP_USER_AGENT'] + : 'CLI'; Environment::setVariables($variables); @@ -155,6 +157,15 @@ private function getRenderedPageByURL(string $url): HTTPResponse $response = Director::singleton()->handleRequest($pageRequest); if ($response->isRedirect()) { + if (in_array($url, $this->redirectRecursionIterations)) { + throw new \Exception("Infinite recursion detected." . $this->getRedirectRecursionIterationsLog($url)); + } + + $this->redirectRecursionIterations[] = $url; + if (count($this->redirectRecursionIterations) >= 30) { + throw new \Exception("Max redirect recursions reached." . $this->getRedirectRecursionIterationsLog()); + } + // The redirect will probably be Absolute URL so just want the path $newUrl = parse_url($response->getHeader('location') ?? '', PHP_URL_PATH); @@ -164,6 +175,13 @@ private function getRenderedPageByURL(string $url): HTTPResponse return $response; } + private function getRedirectRecursionIterationsLog(string $appendUrl = ''): string + { + return "\n\nRedirected URLs stack: \n" + . implode("\n", $this->redirectRecursionIterations) + . ($appendUrl ? "\n$appendUrl" : ''); + } + /** * @return DBHTMLText */