-
Notifications
You must be signed in to change notification settings - Fork 22
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
[Feature request]: Support @astrojs/cloudflare SRR Adapter #35
Comments
deterministic-object-hash released the version 2.0.1 so now it's compatible with web workers! |
With the new version cryto error it's fixed. Now the errors are: X [ERROR] Could not resolve "path"
dist/$server_build/chunks/pages/__30458630.mjs:2:25:
2 │ import require$$0$1 from 'path';
╵ ~~~~~~
The package "path" wasn't found on the file system but is built into node. Are you trying to
bundle for node? You can use "platform: 'node'" to do that, which will remove this error.
X [ERROR] Could not resolve "fs"
dist/$server_build/chunks/pages/__30458630.mjs:3:23:
3 │ import require$$1 from 'fs';
╵ ~~~~
The package "fs" wasn't found on the file system but is built into node. Are you trying to bundle
for node? You can use "platform: 'node'" to do that, which will remove this error.
X [ERROR] Could not resolve "node:fs/promises"
dist/$server_build/chunks/pages/__30458630.mjs:4:15:
4 │ import fs from 'node:fs/promises';
╵ ~~~~~~~~~~~~~~~~~~
The package "node:fs/promises" wasn't found on the file system but is built into node. Are you
trying to bundle for node? You can use "platform: 'node'" to do that, which will remove this
error.
X [ERROR] Could not resolve "node:module"
dist/$server_build/chunks/pages/__30458630.mjs:7:30:
7 │ import { createRequire } from 'node:module';
╵ ~~~~~~~~~~~~~
The package "node:module" wasn't found on the file system but is built into node. Are you trying
to bundle for node? You can use "platform: 'node'" to do that, which will remove this error.
error Could not resolve "path"
File:
dist/$server_build/chunks/pages/__30458630.mjs:2:25
Code:
1649 | }).join("");
> 1650 | let error = new Error(text);
| ^
1651 | for (const [key, value] of [["errors", errors], ["warnings", warnings]]) {
1652 | Object.defineProperty(error, key, {
1653 | configurable: true,
Stacktrace:
Error: Build failed with 4 errors:
dist/$server_build/chunks/pages/__30458630.mjs:2:25: ERROR: Could not resolve "path"
dist/$server_build/chunks/pages/__30458630.mjs:3:23: ERROR: Could not resolve "fs"
dist/$server_build/chunks/pages/__30458630.mjs:4:15: ERROR: Could not resolve "node:fs/promises"
dist/$server_build/chunks/pages/__30458630.mjs:7:30: ERROR: Could not resolve "node:module"
at failureErrorWithLog (E:\Datos\Sites\Projects\rodrigotome.es\node_modules\esbuild\lib\main.js:1650:15)
at E:\Datos\Sites\Projects\rodrigotome.es\node_modules\esbuild\lib\main.js:1059:25
at E:\Datos\Sites\Projects\rodrigotome.es\node_modules\esbuild\lib\main.js:1004:52
at buildResponseToResult (E:\Datos\Sites\Projects\rodrigotome.es\node_modules\esbuild\lib\main.js:1057:7)
at E:\Datos\Sites\Projects\rodrigotome.es\node_modules\esbuild\lib\main.js:1086:16
at responseCallbacks.<computed> (E:\Datos\Sites\Projects\rodrigotome.es\node_modules\esbuild\lib\main.js:703:9)
at handleIncomingPacket (E:\Datos\Sites\Projects\rodrigotome.es\node_modules\esbuild\lib\main.js:763:9)
at Socket.readFromStdout (E:\Datos\Sites\Projects\rodrigotome.es\node_modules\esbuild\lib\main.js:679:7)
at Socket.emit (node:events:514:28)
at addChunk (node:internal/streams/readable:376:12) |
Thanks for the update @RodrigoTomeES! Yeah, we’d need to figure out a way to load things without relying on Node’s filesystem APIs. I’m not super experienced in debugging for these serverless environments and there’s some annoying corners here, like how to load the WASM for canvaskit. Hopefully someone else has some good ideas! |
Hi @delucis I think this issue is similar withastro/astro#6529 I checked it yesterday but I don't understand how they implemented. I think they include the node libraries 🤔 |
Once I have some bandwidth, I promised @delucis to debug this. But I don't have any timing, yet. |
@alexanderniebuhr could you take a look at the problem? |
@RodrigoTomeES I'll take a look, once I have bandwidth for it, not sure if it's this week. |
Hi!, @alexanderniebuhr could you take a look at it? 😄 |
Yeah I looked at this. The issue is we need to refactor this completely to not rely on file system APIs anymore, or at least make sure it doesn't get bundled, if this integration could be doing build time operations only. Those two things are not trivial, so we kinda need to first decide how to move forward cc @delucis |
@alexanderniebuhr I would love some guidance here on architectures that could work. Avoiding FS calls for images and fonts could be possible by requiring users to import and pass them potentially (although I'm not 100% sure how that would work for fonts). I'm not sure about the loading of wasm that is inside our canvaskit dependency. I did try over the Christmas holidays whether I could refactor to a style more like Astro's image services. It's more complex (and a breaking change) but I did get some of it working. Not sure that necessarily would help — it was actually creating an endpoint that rendered images on demand in SSR that worked in Node but I guess might have the same issues on Cloudflare? |
The open question for me is, do we need to load images from file tree runtime or build time? |
I think it’s fairly safe to assume people aren’t using this in SSR currently as the fs stuff would probably break in any SSR set-up (even if Node supports So that means it’s up to us what a future version that supports SSR would look like. My assumption is we’d need a way to get runtime access to an image to support full on-demand SSR just like you would with Astro’s assets support. But we can impose restrictions like that does to e.g. import an image so we get a resolved path to it etc. |
Ok SSR support is wanted.. I can't promise anything, but I'll take a session to find some smart way which works on all runtimes :) |
I'd definitely love to see this! I currently use it in a component that injects the OG image link in the head and writes it to a custom path... I didn't very much like a separate route as I wanted to have some sort of hashing for caching puposes. Not even sure it works at all in SSR, even if in a prerendered route. I might try. |
@delucis @alexanderniebuhr hi! There are very pretty news, Cloudflare add a lot of compatibilities in workes with Node.js maybe now it would be easy to add support! |
Hi,
This package is awesome!! But it is incompatible with @astrojs/cloudflare SRR Adapter. When you deploy it I recieve this error:
In cloudflare
In local build
It's seem like the package has a lot of code depending of node 🤔
List of dependencies that requiere a node enviroment:
deterministic-object-hash #1 PRThe text was updated successfully, but these errors were encountered: