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

Upcoming change to Cloudflare Pages projects #6441

Closed
jrf0110 opened this issue Aug 30, 2022 · 2 comments · Fixed by #6530
Closed

Upcoming change to Cloudflare Pages projects #6441

jrf0110 opened this issue Aug 30, 2022 · 2 comments · Fixed by #6530

Comments

@jrf0110
Copy link
Contributor

jrf0110 commented Aug 30, 2022

Describe the problem

👋

Hi there. John here from the Cloudflare Pages team.

When a SvelteKit project is deployed to Cloudflare Pages, the server-side code is supported through Pages Functions (currently in beta). Unfortunately, by using Functions, each request must go through the server-side Functions code even if it doesn't need to. For instance, an immutable asset request to https://kit.svelte.dev/_app/immutable/assets/_layout-ab34ca4f.css would first have to route through Functions.

This is problematic since the request would "count" as a request to Functions even though only a static asset was served. Further, there is a slight amount of added latency.

Describe the proposed solution

The Cloudflare Pages team has been rolling out support to customize how project Functions are mounted and thus can save money and latency by providing this metadata on build. The @sveltejs/adapter-cloudflare package should expose a set of includes and excludes based on static files generated. For the time being, I suggest we be conservative and include the Functions worker on all routes but exclude on /_app/immutable/.

If the SvelteKit user uses the hooks functionality, they may need to tune these patterns manually on a case-by-case basis.

Alternatives considered

No response

Importance

nice to have

Additional Information

We (the Cloudflare Pages team) will be contributing the relevant changes.

@Rich-Harris
Copy link
Member

Thank you for the heads up and the forthcoming contribution!

If the SvelteKit user uses the hooks functionality, they may need to tune these patterns manually on a case-by-case basis.

Just to clarify, hooks only apply to routes, not to static assets, so it's safe to bypass the worker for everything that matches the contents of static, and everything in config.kit.appDir (which defaults to _app) as long as it's still possible to configure the relevant cache headers.

@jrf0110
Copy link
Contributor Author

jrf0110 commented Aug 30, 2022

hooks only apply to routes, not to static assets

Ah that makes things much easier. Thank you. ❤️

as long as it's still possible to configure the relevant cache headers.

Indeed. We'll do that sort of statically via the _headers file. I say sort of statically because we do need to interpolate config.kit.appDir

it's safe to bypass the worker for everything that matches the contents of static

For now, we're going to be fairly conservative with this, matching only static assets that look like a favicon. The reason being that there may be content in that directory that the user does intend to run through functions (e.g. for gating access to a sensitive document). We may walk back on this in the future, but I think it's better to be conservative and not potentially break a deployment.

I'll have a PR ready soon.

jrf0110 added a commit to jrf0110/kit that referenced this issue Sep 2, 2022

Verified

This commit was created on GitHub.com and signed with GitHub’s verified signature. The key has expired.
jrf0110 added a commit to jrf0110/kit that referenced this issue Sep 2, 2022
When a SvelteKit project is deployed to Cloudflare Pages, the server-side code is supported through Pages Functions (currently in beta). Unfortunately, by using Functions, each request must go through the server-side Functions code even if it doesn't need to. For instance, an immutable asset request to https://kit.svelte.dev/_app/immutable/assets/_layout-ab34ca4f.css would first have to route through Functions.

This is problematic since the request would "count" as a request to Functions even though only a static asset was served. Further, there is a slight amount of added latency.

This change exposes a set of includes and excludes based on static files generated.
jrf0110 added a commit to jrf0110/kit that referenced this issue Sep 2, 2022
When a SvelteKit project is deployed to Cloudflare Pages, the server-side code is supported through Pages Functions (currently in beta). Unfortunately, by using Functions, each request must go through the server-side Functions code even if it doesn't need to. For instance, an immutable asset request to https://kit.svelte.dev/_app/immutable/assets/_layout-ab34ca4f.css would first have to route through Functions.

This is problematic since the request would "count" as a request to Functions even though only a static asset was served. Further, there is a slight amount of added latency.

This change exposes a set of includes and excludes based on static files generated.
jrf0110 added a commit to jrf0110/kit that referenced this issue Sep 2, 2022
When a SvelteKit project is deployed to Cloudflare Pages, the server-side code is supported through Pages Functions (currently in beta). Unfortunately, by using Functions, each request must go through the server-side Functions code even if it doesn't need to. For instance, an immutable asset request to https://kit.svelte.dev/_app/immutable/assets/_layout-ab34ca4f.css would first have to route through Functions.

This is problematic since the request would "count" as a request to Functions even though only a static asset was served. Further, there is a slight amount of added latency.

This change exposes a set of includes and excludes based on static files generated.
jrf0110 added a commit to jrf0110/kit that referenced this issue Sep 2, 2022
When a SvelteKit project is deployed to Cloudflare Pages, the server-side code is supported through Pages Functions (currently in beta). Unfortunately, by using Functions, each request must go through the server-side Functions code even if it doesn't need to. For instance, an immutable asset request to https://kit.svelte.dev/_app/immutable/assets/_layout-ab34ca4f.css would first have to route through Functions.

This is problematic since the request would "count" as a request to Functions even though only a static asset was served. Further, there is a slight amount of added latency.

This change exposes a set of includes and excludes based on static files generated.
@Rich-Harris Rich-Harris added this to the whenever milestone Sep 6, 2022
jrf0110 added a commit to jrf0110/kit that referenced this issue Sep 8, 2022
When a SvelteKit project is deployed to Cloudflare Pages, the server-side code is supported through Pages Functions (currently in beta). Unfortunately, by using Functions, each request must go through the server-side Functions code even if it doesn't need to. For instance, an immutable asset request to https://kit.svelte.dev/_app/immutable/assets/_layout-ab34ca4f.css would first have to route through Functions.

This is problematic since the request would "count" as a request to Functions even though only a static asset was served. Further, there is a slight amount of added latency.

This change exposes a set of includes and excludes based on static files generated.
jrf0110 added a commit to jrf0110/kit that referenced this issue Sep 8, 2022
When a SvelteKit project is deployed to Cloudflare Pages, the server-side code is supported through Pages Functions (currently in beta). Unfortunately, by using Functions, each request must go through the server-side Functions code even if it doesn't need to. For instance, an immutable asset request to https://kit.svelte.dev/_app/immutable/assets/_layout-ab34ca4f.css would first have to route through Functions.

This is problematic since the request would "count" as a request to Functions even though only a static asset was served. Further, there is a slight amount of added latency.

This change exposes a set of includes and excludes based on static files generated.
Rich-Harris added a commit that referenced this issue Sep 21, 2022
* feat: Cloudflare Pages _routes.json specification (#6441)
When a SvelteKit project is deployed to Cloudflare Pages, the server-side code is supported through Pages Functions (currently in beta). Unfortunately, by using Functions, each request must go through the server-side Functions code even if it doesn't need to. For instance, an immutable asset request to https://kit.svelte.dev/_app/immutable/assets/_layout-ab34ca4f.css would first have to route through Functions.

This is problematic since the request would "count" as a request to Functions even though only a static asset was served. Further, there is a slight amount of added latency.

This change exposes a set of includes and excludes based on static files generated.

* use writeFileSync over writeFile, for consistency with rest of codebase

* code style stuff

* tweak changeset

Co-authored-by: Rich Harris <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging a pull request may close this issue.

3 participants