Next.js middleware run in an environment that's neither Node.js nor browser a browser environment. Some of Node’s API is supported, some isn’t.
Our logging breaks in middleware.ts because we flush logs using a Node.js worker. Code that works in other parts of Next.js suddenly doesn’t work anymore. It’s easy to use Node API by accident.
I hope we’ll get a choice to run middleware.ts in Node.js at some point. Vercel already figured out how to make Node.js functions cheap and fast.
The docs mention that you should treat Server Actions like public API endpoints and Next.js 15 makes exploitation harder. However, this is still a major footgun.
I have following mental model about components: Client Components should be leaves in a tree of Server Components. Seems reasonable, but there is caveat.
Did you know that promises can be passed down from Server Components to Client Components but zod schemas can't? Intuitively, a promise shouldn’t be “more” serializable than a pervasive z.ZodObject.