0
Fork 0
mirror of https://github.com/TryGhost/Ghost.git synced 2025-01-06 22:40:14 -05:00
ghost/test/regression/site
Fabien O'Carroll c5b8dab523 🐛 Fixed custom redirects for subdirectory setups
no-issue

This issue only occurs when using custom redirects with a subdirectory
setup, and the path to be redirected from is expressed as a regex, and
the url that is being redirected to is not an external url.

The issue has a few components:

- Redirect paths as a regex generally use the ^ to ensure that they
  match the beginning of the path.

- The path that the regex is matched against conditionally excludes the
  subdirectory, specifically, the subdirectory is excluded for external
  urls

These combined means you end up with a regex like /^\/custom-redirect/
and a path like /subdir/custom-redirect, these will not match/replace
correctly, and you'll end in an infinite redirect loop.

The fix here is to *always* remove the subdirectory when testing regex's
and then conditionally adding it back *only* for the redirect, and only
if it is an internal redirect
2020-06-16 10:24:13 +02:00
..
dynamic_routing_spec.js Moved config from server to shared (#11850) 2020-05-27 18:47:53 +01:00
frontend_spec.js 🐛 Fixed custom redirects for subdirectory setups 2020-06-16 10:24:13 +02:00
site_spec.js Updated var declarations to const/let and no lists 2020-04-29 16:51:13 +01:00
UrlService_spec.js Refactored tests to destructure common lib import (#11838) 2020-05-25 09:49:38 +01:00