@remix-run/cloudflare-pages
Advanced tools
Comparing version 0.0.0-nightly-6ec38fa-20240125 to 0.0.0-nightly-6ee69c13d-20241003
188
CHANGELOG.md
# `@remix-run/cloudflare-pages` | ||
## 2.12.1 | ||
### Patch Changes | ||
- Updated dependencies: | ||
- `@remix-run/cloudflare@2.12.1` | ||
## 2.12.0 | ||
### Patch Changes | ||
- Updated dependencies: | ||
- `@remix-run/cloudflare@2.12.0` | ||
## 2.11.2 | ||
### Patch Changes | ||
- Updated dependencies: | ||
- `@remix-run/cloudflare@2.11.2` | ||
## 2.11.1 | ||
### Patch Changes | ||
- Updated dependencies: | ||
- `@remix-run/cloudflare@2.11.1` | ||
## 2.11.0 | ||
### Patch Changes | ||
- Updated dependencies: | ||
- `@remix-run/cloudflare@2.11.0` | ||
## 2.10.3 | ||
### Patch Changes | ||
- Updated dependencies: | ||
- `@remix-run/cloudflare@2.10.3` | ||
## 2.10.2 | ||
### Patch Changes | ||
- Updated dependencies: | ||
- `@remix-run/cloudflare@2.10.2` | ||
## 2.10.1 | ||
### Patch Changes | ||
- Updated dependencies: | ||
- `@remix-run/cloudflare@2.10.1` | ||
## 2.10.0 | ||
### Patch Changes | ||
- Updated dependencies: | ||
- `@remix-run/cloudflare@2.10.0` | ||
## 2.9.2 | ||
### Patch Changes | ||
- Updated dependencies: | ||
- `@remix-run/cloudflare@2.9.2` | ||
## 2.9.1 | ||
### Patch Changes | ||
- Updated dependencies: | ||
- `@remix-run/cloudflare@2.9.1` | ||
## 2.9.0 | ||
### Patch Changes | ||
- Updated dependencies: | ||
- `@remix-run/cloudflare@2.9.0` | ||
## 2.8.1 | ||
### Patch Changes | ||
- Updated dependencies: | ||
- `@remix-run/cloudflare@2.8.1` | ||
## 2.8.0 | ||
### Patch Changes | ||
- Updated dependencies: | ||
- `@remix-run/cloudflare@2.8.0` | ||
## 2.7.2 | ||
### Patch Changes | ||
- Updated dependencies: | ||
- `@remix-run/cloudflare@2.7.2` | ||
## 2.7.1 | ||
### Patch Changes | ||
- Fix breaking change for `@remix-run/cloudflare-pages` ([#8819](https://github.com/remix-run/remix/pull/8819)) | ||
Restore Cloudflare event context fields in `getLoadContext` argument for backwards compatibility. | ||
- Updated dependencies: | ||
- `@remix-run/cloudflare@2.7.1` | ||
## 2.7.0 | ||
### Minor Changes | ||
- Make `getLoadContext` optional for Cloudflare Pages ([#8701](https://github.com/remix-run/remix/pull/8701)) | ||
Defaults to `(context) => ({ env: context })`, which is what we used to have in all the templates. | ||
This gives parity with the Cloudflare preset for the Remix Vite plugin and keeps our templates leaner. | ||
- Vite: Cloudflare Proxy as a Vite plugin ([#8749](https://github.com/remix-run/remix/pull/8749)) | ||
**This is a breaking change for projects relying on Cloudflare support from the unstable Vite plugin** | ||
The Cloudflare preset (`unstable_cloudflarePreset`) as been removed and replaced with a new Vite plugin: | ||
```diff | ||
import { | ||
unstable_vitePlugin as remix, | ||
- unstable_cloudflarePreset as cloudflare, | ||
+ cloudflareDevProxyVitePlugin as remixCloudflareDevProxy, | ||
} from "@remix-run/dev"; | ||
import { defineConfig } from "vite"; | ||
export default defineConfig({ | ||
plugins: [ | ||
+ remixCloudflareDevProxy(), | ||
+ remix(), | ||
- remix({ | ||
- presets: [cloudflare()], | ||
- }), | ||
], | ||
- ssr: { | ||
- resolve: { | ||
- externalConditions: ["workerd", "worker"], | ||
- }, | ||
- }, | ||
}); | ||
``` | ||
`remixCloudflareDevProxy` must come _before_ the `remix` plugin so that it can override Vite's dev server middleware to be compatible with Cloudflare's proxied environment. | ||
Because it is a Vite plugin, `remixCloudflareDevProxy` can set `ssr.resolve.externalConditions` to be `workerd`-compatible for you. | ||
`remixCloudflareDevProxy` accepts a `getLoadContext` function that replaces the old `getRemixDevLoadContext`. | ||
If you were using a `nightly` version that required `getBindingsProxy` or `getPlatformProxy`, that is no longer required. | ||
Any options you were passing to `getBindingsProxy` or `getPlatformProxy` should now be passed to `remixCloudflareDevProxy` instead. | ||
This API also better aligns with future plans to support Cloudflare with a framework-agnostic Vite plugin that makes use of Vite's (experimental) Runtime API. | ||
### Patch Changes | ||
- Updated dependencies: | ||
- `@remix-run/cloudflare@2.7.0` | ||
## 2.6.0 | ||
### Patch Changes | ||
- Vite: Cloudflare Pages support ([#8531](https://github.com/remix-run/remix/pull/8531)) | ||
To get started with Cloudflare, you can use the \[`unstable-vite-cloudflare`]\[template-vite-cloudflare] template: | ||
```shellscript nonumber | ||
npx create-remix@latest --template remix-run/remix/templates/unstable-vite-cloudflare | ||
``` | ||
Or read the new docs at [Future > Vite > Cloudflare](https://remix.run/docs/en/main/future/vite#cloudflare) and | ||
[Future > Vite > Migrating > Migrating Cloudflare Functions](https://remix.run/docs/en/main/future/vite#migrating-cloudflare-functions). | ||
- Updated dependencies: | ||
- `@remix-run/cloudflare@2.6.0` | ||
## 2.5.1 | ||
@@ -4,0 +192,0 @@ |
/** | ||
* @remix-run/cloudflare-pages v0.0.0-nightly-6ec38fa-20240125 | ||
* @remix-run/cloudflare-pages v0.0.0-nightly-6ee69c13d-20241003 | ||
* | ||
@@ -4,0 +4,0 @@ * Copyright (c) Remix Software Inc. |
/** | ||
* @remix-run/cloudflare-pages v0.0.0-nightly-6ec38fa-20240125 | ||
* @remix-run/cloudflare-pages v0.0.0-nightly-6ee69c13d-20241003 | ||
* | ||
@@ -23,9 +23,32 @@ * Copyright (c) Remix Software Inc. | ||
build, | ||
getLoadContext, | ||
mode | ||
mode, | ||
getLoadContext = ({ | ||
context | ||
}) => ({ | ||
...context, | ||
cloudflare: { | ||
...context.cloudflare, | ||
cf: context.cloudflare.request.cf | ||
} | ||
}) | ||
}) { | ||
let handleRequest = createRequestHandler$1(build, mode); | ||
return async context => { | ||
let loadContext = await (getLoadContext === null || getLoadContext === void 0 ? void 0 : getLoadContext(context)); | ||
return handleRequest(context.request, loadContext); | ||
return async cloudflare => { | ||
let loadContext = await getLoadContext({ | ||
...cloudflare, | ||
// Backcompat, remove in v3 | ||
request: cloudflare.request, | ||
context: { | ||
cloudflare: { | ||
...cloudflare, | ||
cf: cloudflare.request.cf, | ||
ctx: { | ||
waitUntil: cloudflare.waitUntil, | ||
passThroughOnException: cloudflare.passThroughOnException | ||
}, | ||
caches | ||
} | ||
} | ||
}); | ||
return handleRequest(cloudflare.request, loadContext); | ||
}; | ||
@@ -32,0 +55,0 @@ } |
/** | ||
* @remix-run/cloudflare-pages v0.0.0-nightly-6ec38fa-20240125 | ||
* @remix-run/cloudflare-pages v0.0.0-nightly-6ee69c13d-20241003 | ||
* | ||
@@ -4,0 +4,0 @@ * Copyright (c) Remix Software Inc. |
@@ -1,3 +0,3 @@ | ||
/// <reference types="@cloudflare/workers-types" /> | ||
import type { AppLoadContext, ServerBuild } from "@remix-run/cloudflare"; | ||
import { type CacheStorage } from "@cloudflare/workers-types"; | ||
/** | ||
@@ -10,10 +10,36 @@ * A function that returns the value to use as `context` in route `loader` and | ||
*/ | ||
export type GetLoadContextFunction<Env = unknown> = (context: Parameters<PagesFunction<Env>>[0]) => Promise<AppLoadContext> | AppLoadContext; | ||
export type GetLoadContextFunction<Env = unknown, Params extends string = any, Data extends Record<string, unknown> = Record<string, unknown>> = (args: { | ||
/** @deprecated use `context.cloudflare.env` instead */ | ||
env: EventContext<Env, Params, Data>["env"]; | ||
/** @deprecated use `context.cloudflare.functionPath` instead */ | ||
functionPath: EventContext<Env, Params, Data>["functionPath"]; | ||
/** @deprecated use `context.cloudflare.waitUntil` instead */ | ||
waitUntil: EventContext<Env, Params, Data>["waitUntil"]; | ||
/** @deprecated use `context.cloudflare.passThroughOnException` instead */ | ||
passThroughOnException: EventContext<Env, Params, Data>["passThroughOnException"]; | ||
/** @deprecated use `context.cloudflare.next` instead */ | ||
next: EventContext<Env, Params, Data>["next"]; | ||
/** @deprecated use `context.cloudflare.params` instead */ | ||
params: EventContext<Env, Params, Data>["params"]; | ||
/** @deprecated use `context.cloudflare.data` instead */ | ||
data: EventContext<Env, Params, Data>["data"]; | ||
request: Request; | ||
context: { | ||
cloudflare: EventContext<Env, Params, Data> & { | ||
cf: EventContext<Env, Params, Data>["request"]["cf"]; | ||
ctx: { | ||
waitUntil: EventContext<Env, Params, Data>["waitUntil"]; | ||
passThroughOnException: EventContext<Env, Params, Data>["passThroughOnException"]; | ||
}; | ||
caches: CacheStorage; | ||
}; | ||
}; | ||
}) => AppLoadContext | Promise<AppLoadContext>; | ||
export type RequestHandler<Env = any> = PagesFunction<Env>; | ||
export interface createPagesFunctionHandlerParams<Env = any> { | ||
build: ServerBuild; | ||
build: ServerBuild | (() => ServerBuild | Promise<ServerBuild>); | ||
getLoadContext?: GetLoadContextFunction<Env>; | ||
mode?: string; | ||
} | ||
export declare function createRequestHandler<Env = any>({ build, getLoadContext, mode, }: createPagesFunctionHandlerParams<Env>): RequestHandler<Env>; | ||
export declare function createRequestHandler<Env = any>({ build, mode, getLoadContext, }: createPagesFunctionHandlerParams<Env>): RequestHandler<Env>; | ||
export declare function createPagesFunctionHandler<Env = any>({ build, getLoadContext, mode, }: createPagesFunctionHandlerParams<Env>): (context: EventContext<Env, any, any>) => Promise<Response>; |
/** | ||
* @remix-run/cloudflare-pages v0.0.0-nightly-6ec38fa-20240125 | ||
* @remix-run/cloudflare-pages v0.0.0-nightly-6ee69c13d-20241003 | ||
* | ||
@@ -27,9 +27,32 @@ * Copyright (c) Remix Software Inc. | ||
build, | ||
getLoadContext, | ||
mode | ||
mode, | ||
getLoadContext = ({ | ||
context | ||
}) => ({ | ||
...context, | ||
cloudflare: { | ||
...context.cloudflare, | ||
cf: context.cloudflare.request.cf | ||
} | ||
}) | ||
}) { | ||
let handleRequest = cloudflare.createRequestHandler(build, mode); | ||
return async context => { | ||
let loadContext = await (getLoadContext === null || getLoadContext === void 0 ? void 0 : getLoadContext(context)); | ||
return handleRequest(context.request, loadContext); | ||
return async cloudflare => { | ||
let loadContext = await getLoadContext({ | ||
...cloudflare, | ||
// Backcompat, remove in v3 | ||
request: cloudflare.request, | ||
context: { | ||
cloudflare: { | ||
...cloudflare, | ||
cf: cloudflare.request.cf, | ||
ctx: { | ||
waitUntil: cloudflare.waitUntil, | ||
passThroughOnException: cloudflare.passThroughOnException | ||
}, | ||
caches | ||
} | ||
} | ||
}); | ||
return handleRequest(cloudflare.request, loadContext); | ||
}; | ||
@@ -36,0 +59,0 @@ } |
{ | ||
"name": "@remix-run/cloudflare-pages", | ||
"version": "0.0.0-nightly-6ec38fa-20240125", | ||
"version": "0.0.0-nightly-6ee69c13d-20241003", | ||
"description": "Cloudflare Pages request handler for Remix", | ||
@@ -18,3 +18,3 @@ "bugs": { | ||
"dependencies": { | ||
"@remix-run/cloudflare": "0.0.0-nightly-6ec38fa-20240125" | ||
"@remix-run/cloudflare": "0.0.0-nightly-6ee69c13d-20241003" | ||
}, | ||
@@ -24,2 +24,3 @@ "devDependencies": { | ||
"@types/mime": "^2.0.3", | ||
"@types/node": "^18.17.1", | ||
"typescript": "^5.1.0" | ||
@@ -44,3 +45,6 @@ }, | ||
"README.md" | ||
] | ||
} | ||
], | ||
"scripts": { | ||
"tsc": "tsc" | ||
} | ||
} |
259
20223
4
10
+ Added@remix-run/cloudflare@0.0.0-nightly-6ee69c13d-20241003(transitive)
+ Added@remix-run/router@1.19.2(transitive)
+ Added@remix-run/server-runtime@0.0.0-nightly-6ee69c13d-20241003(transitive)
+ Addedturbo-stream@2.4.0(transitive)
- Removed@remix-run/cloudflare@0.0.0-nightly-6ec38fa-20240125(transitive)
- Removed@remix-run/router@1.14.2(transitive)
- Removed@remix-run/server-runtime@0.0.0-nightly-6ec38fa-20240125(transitive)
Updated@remix-run/cloudflare@0.0.0-nightly-6ee69c13d-20241003