Headline
GHSA-9x9c-ghc5-jhw9: @astrojs/node's trailing slash handling causes open redirect issue
Summary
Following https://github.com/withastro/astro/security/advisories/GHSA-cq8c-xv66-36gw, there’s still an Open Redirect vulnerability in a subset of Astro deployment scenarios.
Details
Astro 5.12.8 fixed a case where https://example.com//astro.build/press
would redirect to the external origin //astro.build/press
. However, with the Node deployment adapter in standalone mode and trailingSlash
set to "always"
in the Astro configuration, https://example.com//astro.build/press
still redirects to //astro.build/press
.
Proof of Concept
- Create a new minimal Astro project (
astro@5.12.8
) - Configure it to use the Node adapter (
@astrojs/node@9.4.0
) and force trailing slashes:// astro.config.mjs import { defineConfig } from 'astro/config'; import node from '@astrojs/node'; export default defineConfig({ trailingSlash: 'always', adapter: node({ mode: 'standalone' }), });
- Build the site by running
astro build
. - Run the server, e.g. with
astro preview
. - Append
//astro.build/press
to the preview URL, e.g. http://localhost:4321//astro.build/press - The site will redirect to the external Astro Build origin.
Example reproduction
- Open this StackBlitz reproduction.
- Open the preview in a separate window so the StackBlitz embed doesn’t cause security errors.
- Append
//astro.build/press
to the preview URL, e.g.https://x.local-corp.webcontainer.io//astro.build/press
. - See it redirect to the external Astro Build origin.
Impact
This is classified as an Open Redirection vulnerability (CWE-601). It affects any user who clicks on a specially crafted link pointing to the affected domain. Since the domain appears legitimate, victims may be tricked into trusting the redirected page, leading to possible credential theft, malware distribution, or other phishing-related attacks.
No authentication is required to exploit this vulnerability. Any unauthenticated user can trigger the redirect by clicking a malicious link.
Summary
Following GHSA-cq8c-xv66-36gw, there’s still an Open Redirect vulnerability in a subset of Astro deployment scenarios.
Details
Astro 5.12.8 fixed a case where https://example.com//astro.build/press would redirect to the external origin //astro.build/press. However, with the Node deployment adapter in standalone mode and trailingSlash set to “always” in the Astro configuration, https://example.com//astro.build/press still redirects to //astro.build/press.
Proof of Concept
Create a new minimal Astro project (astro@5.12.8)
Configure it to use the Node adapter (@astrojs/node@9.4.0) and force trailing slashes:
// astro.config.mjs import { defineConfig } from 'astro/config’; import node from '@astrojs/node’;
export default defineConfig({ trailingSlash: 'always’, adapter: node({ mode: ‘standalone’ }), });
Build the site by running astro build.
Run the server, e.g. with astro preview.
Append //astro.build/press to the preview URL, e.g. http://localhost:4321//astro.build/press
The site will redirect to the external Astro Build origin.
Example reproduction
- Open this StackBlitz reproduction.
- Open the preview in a separate window so the StackBlitz embed doesn’t cause security errors.
- Append //astro.build/press to the preview URL, e.g. https://x.local-corp.webcontainer.io//astro.build/press.
- See it redirect to the external Astro Build origin.
Impact
This is classified as an Open Redirection vulnerability (CWE-601). It affects any user who clicks on a specially crafted link pointing to the affected domain. Since the domain appears legitimate, victims may be tricked into trusting the redirected page, leading to possible credential theft, malware distribution, or other phishing-related attacks.
No authentication is required to exploit this vulnerability. Any unauthenticated user can trigger the redirect by clicking a malicious link.
References
- GHSA-9x9c-ghc5-jhw9
- withastro/astro@5fc3c59