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

[labs/ssr] Lit SSR doesn't work in Cloudflare Workers #3907

Open
bluwy opened this issue May 18, 2023 · 4 comments
Open

[labs/ssr] Lit SSR doesn't work in Cloudflare Workers #3907

bluwy opened this issue May 18, 2023 · 4 comments
Assignees

Comments

@bluwy
Copy link

bluwy commented May 18, 2023

Which package(s) are affected?

Lit Core (lit / lit-html / lit-element / reactive-element), SSR (@lit-labs/ssr)

Description

Lit SSR doesn't work in Cloudflare Workers as they rely on the "workerd", "worker", "browser" export conditions for bundling with esbuild. In which case, the lit-html and @lit/reactive-element packages are bundled using the browser condition.

But because those two packages uses window in the browser condition (which is fair), it doesn't work in Cloudflare. We've found that using the node condition works since they don't seem to use actual Node-specific APIs.

Related withastro/astro#6915. We're fixing Astro's Lit + Cloudflare compatibility.

Reproduction

https://github.com/bluwy/cloudflare-lit-ssr-repro

  1. npm install
  2. npm run dev

The repo readme has some extra information of how to debug and patch it.

Workaround

Adding the "worker" condition that's an exact copy of the "node" condition to the aforementioned two packages fixes it.

The repro has a patch script to work around it.

Is this a regression?

No or unsure. This never worked, or I haven't tried before.

Affected versions

@lit-labs/ssr - 3.1.2, lit - 2.7.4

Browser/OS/Node environment

(I don't think these are related, but)

OS: macos 13.3
node: 16.19.1
npm: 6.19.3

@bluwy
Copy link
Author

bluwy commented May 18, 2023

Darn it, I think this is a duplicate of #1983. Sorry about it I'll make a comment there instead.

@bluwy bluwy closed this as not planned Won't fix, can't repro, duplicate, stale May 18, 2023
@augustjk augustjk reopened this May 19, 2023
@augustjk augustjk removed the status in Lit Project Board May 19, 2023
@augustjk augustjk changed the title Lit SSR doesn't work in Cloudflare Workers [labs/ssr] Lit SSR doesn't work in Cloudflare Workers May 19, 2023
@augustjk
Copy link
Member

There might be some overlap but I think it's valid to keep this a separate issue from #1983 which asks for Service Worker rendering (in the browser) versus handling non-browser worker/edge environments.

My biggest hesitation about adding something like this is we ourselves don't have any testing for whether our Node build actually works properly in these environments. We'd have to dig through our dependencies to make sure they don't require any Node specific things. We probably want to limit built-in APIs to these https://common-min-api.proposal.wintercg.org/.

We do have an import of buffer for a Node build here

// In the Node build, this import will be injected by Rollup:
// import {Buffer} from 'buffer';

but this actually might be unneeded as the hydrate function is always meant to be run in the client. That module is being removed from lit-html for v3 anyway.

Another question is whether worker is the right condition name to use. https://runtime-keys.proposal.wintercg.org/ lists workerd as the name for Cloudflare but has different ones for Netlify and Vercel. wintercg/runtime-keys#5 proposes wintercg as a common name for runtimes that meet the wintercg minimum API.

cc: @justinfagnani @kevinpschaaf @sorvell

@bluwy
Copy link
Author

bluwy commented May 20, 2023

Thanks. Yeah while investigating this, I didn't really check if all the node outputs support workers, just that some manual testing showed that it somewhat works. We could run workerd locally to test it, or maybe some sort of linter to check the common minimum API.

Re worker condition, I found that to be more commonly used as all worker/edge environments (even service workers and web workers) share a good portion of supported APIs. If we want to support all of them at once, the worker condition would be fine (imo).

wintercg does sound even ideal but I haven't seen ecosystem support for that yet. workerd would also be fine but that means repetitive exports for all the different (but similar) worker edge environments.

@jake-danton
Copy link

We would be very interested in this. For now, we are having to switch everything over to preact as it has full web component support and SSR everywhere (Cloudflare, Deno, you name it) but would love to bring lit back into our stack when this work is done!

And happy to help or test as needed.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
Status: 📋 Triaged
Development

No branches or pull requests

3 participants