Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Percent sign in getStaticPaths params breaks astro build, throws a URI malformed error. #12847

Open
1 task
finpluto opened this issue Dec 28, 2024 · 3 comments
Open
1 task
Labels
- P4: important Violate documented behavior or significantly impacts performance (priority) feat: routing Related to Astro routing (scope)

Comments

@finpluto
Copy link

finpluto commented Dec 28, 2024

Astro Info

Astro                    v5.1.1
Node                     v22.12.0
System                   Windows (x64)
Package Manager          pnpm
Output                   static
Adapter                  none
Integrations             none

If this issue only occurs in one browser, which browser is a problem?

No browser involved.

Describe the Bug

When creating dynamic routing under SSG mode, if the params returned by getStaticPaths() contain a percent sign (%) in any of route parameters, astro build will throw an URI malformed error.

I create a minimal reproducing example at percent-in-route-parameter-bug-reproduce. When building with astro build, it will exit with belowing log:

 generating static routes 
22:30:44 ▶ src/pages/[name].astro
22:30:44   └─ /Astro%foobar/index.htmlURI malformed

I tried to resolve this issue and found there are two decodeURI invokes during the dynamic routing pages rendering:

  1. const params = getParams(route, decodeURI(pathname));

According to the docs about params in dynamic routing, we should call decodeURI on them before returning from getStaticPaths. But this decoded parameter will be decoded for 2 more times when render pages, one happens in creating RenderContext and the other happens in getProps call from the RenderContext.render.

I searched in issues and found similar one(#7374), but it's about double URI decoding in SSR mode, not SSG mode.

What's the expected result?

astro build completes without throwing error.

Link to Minimal Reproducible Example

https://github.com/finpluto/percent-in-route-parameter-bug-reproduce

Participation

  • I am willing to submit a pull request for this issue.
@github-actions github-actions bot added the needs triage Issue needs to be triaged label Dec 28, 2024
@ematipico
Copy link
Member

But this decoded parameter will be decoded for 2 more times when render pages, one happens in creating RenderContext and the other happens in getProps call from the RenderContext.render.

The code doesn't decode the parameters, the code decodes the pathname coming from the server.

However, I don't understand the bug because your reproduction doesn't use decodeURI as suggested by the docs.

@ematipico ematipico added the needs response Issue needs response from OP label Jan 3, 2025
@finpluto
Copy link
Author

finpluto commented Jan 3, 2025

To clarify your question, here is my usage of dynamic routing in SSG mode.

I'm building a list of pages, whose url is generated from a sqlite database, and the url may contains percent sign(%). For example, I want to access a page through url /mypage/astro%25foobar. To set the filename parameter in dynamic route /mypage/[filename], function getStaticPaths should return

{ params: { filename: decodeURI(`/mypage/astro%25foobar`) } }

which is the same as

{ params: { filename: `/mypage/astro%foobar` } }

Therefore in this case astro build will failed with URI malformed, because the decoded URI has a percent sign.

@ematipico
Copy link
Member

I see. The % is a tricky character, because it's the only one that can't be decoded twice. However, for this particular case, even decoding it once seems to raise a bug.

I'll need to actually study this use case, and make sure that it doesn't break other use case

@ematipico ematipico added - P4: important Violate documented behavior or significantly impacts performance (priority) feat: routing Related to Astro routing (scope) and removed needs response Issue needs response from OP labels Jan 3, 2025
@github-actions github-actions bot removed the needs triage Issue needs to be triaged label Jan 3, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
- P4: important Violate documented behavior or significantly impacts performance (priority) feat: routing Related to Astro routing (scope)
Projects
None yet
Development

No branches or pull requests

2 participants