create-cloudflare 0.0.0-e5cdd7fa → 0.0.0-e5ebdb143
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/dist/cli.js +61432 -60289
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/package.json +34 -25
- package/templates/analog/c3.ts +135 -0
- package/templates/analog/snippets/devBindingsModule.ts +7 -0
- package/templates/analog/templates/env.d.ts +13 -0
- package/templates/analog/templates/src/dev-bindings.ts +18 -0
- package/templates/analog/templates/worker-configuration.d.ts +4 -0
- package/templates/analog/templates/wrangler.json +5 -0
- package/templates/angular/c3.ts +37 -22
- package/templates/angular/templates/src/server.ts +15 -0
- package/templates/angular/templates/tools/copy-files.mjs +8 -2
- package/templates/astro/c3.ts +66 -19
- package/templates/astro/templates/js/wrangler.json +8 -0
- package/templates/astro/templates/ts/src/env.d.ts +5 -0
- package/templates/astro/templates/ts/worker-configuration.d.ts +4 -0
- package/templates/astro/templates/ts/wrangler.json +8 -0
- package/templates/common/c3.ts +10 -5
- package/templates/common/js/.editorconfig +0 -1
- package/templates/common/js/package.json +1 -1
- package/templates/common/js/wrangler.json +8 -0
- package/templates/common/ts/.editorconfig +0 -1
- package/templates/common/ts/package.json +4 -3
- package/templates/common/ts/src/ab-test.ts +2 -2
- package/templates/common/ts/src/index.ts +5 -2
- package/templates/common/ts/src/proxy.ts +2 -2
- package/templates/common/ts/src/redirect.ts +2 -2
- package/templates/common/ts/tsconfig.json +37 -95
- package/templates/common/ts/worker-configuration.d.ts +2 -14
- package/templates/common/ts/wrangler.json +8 -0
- package/templates/docusaurus/c3.ts +7 -6
- package/templates/gatsby/c3.ts +8 -5
- package/templates/hello-world/c3.ts +12 -6
- package/templates/hello-world/js/.editorconfig +0 -1
- package/templates/hello-world/js/package.json +5 -2
- package/templates/hello-world/js/test/index.spec.js +20 -0
- package/templates/hello-world/js/vitest.config.js +11 -0
- package/templates/hello-world/js/wrangler.json +8 -0
- package/templates/hello-world/py/__dot__gitignore +68 -0
- package/templates/hello-world/py/package.json +13 -0
- package/templates/hello-world/py/src/entry.py +4 -0
- package/templates/hello-world/py/wrangler.json +9 -0
- package/templates/hello-world/ts/.editorconfig +0 -1
- package/templates/hello-world/ts/package.json +7 -3
- package/templates/hello-world/ts/src/index.ts +5 -19
- package/templates/hello-world/ts/test/index.spec.ts +25 -0
- package/templates/hello-world/ts/test/tsconfig.json +8 -0
- package/templates/hello-world/ts/tsconfig.json +39 -96
- package/templates/hello-world/ts/vitest.config.mts +11 -0
- package/templates/hello-world/ts/worker-configuration.d.ts +4 -0
- package/templates/hello-world/ts/wrangler.json +8 -0
- package/templates/hello-world-durable-object/c3.ts +10 -6
- package/templates/hello-world-durable-object/js/.editorconfig +0 -1
- package/templates/hello-world-durable-object/js/package.json +1 -1
- package/templates/hello-world-durable-object/js/src/index.js +21 -17
- package/templates/hello-world-durable-object/js/wrangler.json +24 -0
- package/templates/hello-world-durable-object/ts/.editorconfig +0 -1
- package/templates/hello-world-durable-object/ts/package.json +4 -4
- package/templates/hello-world-durable-object/ts/src/index.ts +26 -39
- package/templates/hello-world-durable-object/ts/tsconfig.json +36 -95
- package/templates/hello-world-durable-object/ts/worker-configuration.d.ts +5 -0
- package/templates/hello-world-durable-object/ts/wrangler.json +24 -0
- package/templates/hono/c3.ts +45 -1
- package/templates/hono/snippets/appDeclaration.ts +1 -0
- package/templates/hono/templates/worker-configuration.d.ts +4 -0
- package/templates/hono/templates/wrangler.json +8 -0
- package/templates/next/README.md +67 -0
- package/templates/next/app/js/app/api/hello/route.js +21 -0
- package/templates/next/app/js/app/not-found.js +58 -0
- package/templates/next/app/ts/app/api/hello/route.ts +21 -0
- package/templates/next/app/ts/app/not-found.tsx +58 -0
- package/templates/next/c3.ts +92 -85
- package/templates/next/env.d.ts +5 -0
- package/templates/next/pages/js/pages/api/hello.js +23 -0
- package/templates/next/pages/ts/pages/api/hello.ts +24 -0
- package/templates/next/wrangler.json +8 -0
- package/templates/nuxt/c3.ts +95 -20
- package/templates/nuxt/templates/env.d.ts +14 -0
- package/templates/nuxt/templates/worker-configuration.d.ts +4 -0
- package/templates/nuxt/templates/wrangler.json +8 -0
- package/templates/openapi/c3.ts +1 -0
- package/templates/openapi/ts/README.md +3 -3
- package/templates/openapi/ts/package.json +7 -4
- package/templates/openapi/ts/src/endpoints/taskCreate.ts +26 -16
- package/templates/openapi/ts/src/endpoints/taskDelete.ts +20 -19
- package/templates/openapi/ts/src/endpoints/taskFetch.ts +30 -23
- package/templates/openapi/ts/src/endpoints/taskList.ts +27 -24
- package/templates/openapi/ts/src/index.ts +14 -20
- package/templates/openapi/ts/src/types.ts +9 -8
- package/templates/openapi/ts/worker-configuration.d.ts +4 -0
- package/templates/openapi/ts/wrangler.json +8 -0
- package/templates/pre-existing/c3.ts +37 -18
- package/templates/pre-existing/js/.editorconfig +0 -1
- package/templates/pre-existing/js/package.json +1 -1
- package/templates/pre-existing/js/wrangler.json +5 -0
- package/templates/queues/c3.ts +9 -5
- package/templates/queues/js/.editorconfig +0 -1
- package/templates/queues/js/package.json +1 -1
- package/templates/queues/js/wrangler.json +21 -0
- package/templates/queues/ts/.editorconfig +0 -1
- package/templates/queues/ts/package.json +4 -3
- package/templates/queues/ts/src/index.ts +6 -8
- package/templates/queues/ts/tsconfig.json +36 -95
- package/templates/queues/ts/worker-configuration.d.ts +5 -0
- package/templates/queues/ts/wrangler.json +21 -0
- package/templates/qwik/c3.ts +85 -30
- package/templates/qwik/snippets/getPlatformProxy.ts +6 -0
- package/templates/qwik/templates/worker-configuration.d.ts +4 -0
- package/templates/qwik/templates/wrangler.json +8 -0
- package/templates/react/c3.ts +38 -6
- package/templates/remix/c3.ts +40 -6
- package/templates/remix/templates/worker-configuration.d.ts +4 -0
- package/templates/remix/templates/wrangler.json +5 -0
- package/templates/scheduled/c3.ts +9 -5
- package/templates/scheduled/js/.editorconfig +0 -1
- package/templates/scheduled/js/package.json +3 -3
- package/templates/scheduled/js/src/index.js +9 -2
- package/templates/scheduled/js/wrangler.json +13 -0
- package/templates/scheduled/ts/.editorconfig +0 -1
- package/templates/scheduled/ts/package.json +5 -4
- package/templates/scheduled/ts/src/index.ts +8 -25
- package/templates/scheduled/ts/tsconfig.json +36 -95
- package/templates/scheduled/ts/worker-configuration.d.ts +4 -0
- package/templates/scheduled/ts/wrangler.json +13 -0
- package/templates/solid/c3.ts +62 -12
- package/templates/solid/templates/wrangler.json +8 -0
- package/templates/svelte/c3.ts +111 -30
- package/templates/svelte/templates/wrangler.json +5 -0
- package/templates/vue/c3.ts +8 -6
- package/templates-experimental/angular/c3.ts +112 -0
- package/templates-experimental/angular/templates/src/server.ts +15 -0
- package/templates-experimental/angular/templates/wrangler.json +12 -0
- package/templates-experimental/astro/c3.ts +98 -0
- package/templates-experimental/astro/templates/js/public/.assetsignore +4 -0
- package/templates-experimental/astro/templates/js/wrangler.json +15 -0
- package/templates-experimental/astro/templates/ts/public/.assetsignore +4 -0
- package/templates-experimental/astro/templates/ts/src/env.d.ts +5 -0
- package/templates-experimental/astro/templates/ts/worker-configuration.d.ts +4 -0
- package/templates-experimental/astro/templates/ts/wrangler.json +15 -0
- package/templates-experimental/docusaurus/c3.ts +32 -0
- package/templates-experimental/docusaurus/templates/wrangler.json +10 -0
- package/templates-experimental/gatsby/c3.ts +53 -0
- package/templates-experimental/gatsby/templates/wrangler.json +10 -0
- package/templates-experimental/hello-world-assets-only/c3.ts +15 -0
- package/templates-experimental/hello-world-assets-only/templates/package.json +13 -0
- package/templates-experimental/hello-world-assets-only/templates/public/index.html +11 -0
- package/templates-experimental/hello-world-assets-only/templates/wrangler.json +10 -0
- package/templates-experimental/hello-world-durable-object-with-assets/c3.ts +23 -0
- package/templates-experimental/hello-world-durable-object-with-assets/js/.editorconfig +12 -0
- package/templates-experimental/hello-world-durable-object-with-assets/js/.prettierrc +6 -0
- package/templates-experimental/hello-world-durable-object-with-assets/js/__dot__gitignore +172 -0
- package/templates-experimental/hello-world-durable-object-with-assets/js/package.json +13 -0
- package/templates-experimental/hello-world-durable-object-with-assets/js/public/index.html +19 -0
- package/templates-experimental/hello-world-durable-object-with-assets/js/src/index.js +69 -0
- package/templates-experimental/hello-world-durable-object-with-assets/js/wrangler.json +28 -0
- package/templates-experimental/hello-world-durable-object-with-assets/ts/.editorconfig +12 -0
- package/templates-experimental/hello-world-durable-object-with-assets/ts/.prettierrc +6 -0
- package/templates-experimental/hello-world-durable-object-with-assets/ts/__dot__gitignore +172 -0
- package/templates-experimental/hello-world-durable-object-with-assets/ts/package.json +15 -0
- package/templates-experimental/hello-world-durable-object-with-assets/ts/public/index.html +19 -0
- package/templates-experimental/hello-world-durable-object-with-assets/ts/src/index.ts +66 -0
- package/templates-experimental/hello-world-durable-object-with-assets/ts/tsconfig.json +42 -0
- package/templates-experimental/hello-world-durable-object-with-assets/ts/worker-configuration.d.ts +5 -0
- package/templates-experimental/hello-world-durable-object-with-assets/ts/wrangler.json +28 -0
- package/templates-experimental/hello-world-with-assets/c3.ts +22 -0
- package/templates-experimental/hello-world-with-assets/js/.editorconfig +12 -0
- package/templates-experimental/hello-world-with-assets/js/.prettierrc +6 -0
- package/templates-experimental/hello-world-with-assets/js/__dot__gitignore +172 -0
- package/templates-experimental/hello-world-with-assets/js/package.json +16 -0
- package/templates-experimental/hello-world-with-assets/js/public/index.html +31 -0
- package/templates-experimental/hello-world-with-assets/js/src/index.js +23 -0
- package/templates-experimental/hello-world-with-assets/js/test/index.spec.js +41 -0
- package/templates-experimental/hello-world-with-assets/js/vitest.config.js +11 -0
- package/templates-experimental/hello-world-with-assets/js/wrangler.json +15 -0
- package/templates-experimental/hello-world-with-assets/py/__dot__gitignore +68 -0
- package/templates-experimental/hello-world-with-assets/py/package.json +13 -0
- package/templates-experimental/hello-world-with-assets/py/public/index.html +31 -0
- package/templates-experimental/hello-world-with-assets/py/src/entry.py +9 -0
- package/templates-experimental/hello-world-with-assets/py/wrangler.json +15 -0
- package/templates-experimental/hello-world-with-assets/ts/.editorconfig +12 -0
- package/templates-experimental/hello-world-with-assets/ts/.prettierrc +6 -0
- package/templates-experimental/hello-world-with-assets/ts/__dot__gitignore +172 -0
- package/templates-experimental/hello-world-with-assets/ts/package.json +18 -0
- package/templates-experimental/hello-world-with-assets/ts/public/index.html +31 -0
- package/templates-experimental/hello-world-with-assets/ts/src/index.ts +26 -0
- package/templates-experimental/hello-world-with-assets/ts/test/index.spec.ts +41 -0
- package/templates-experimental/hello-world-with-assets/ts/test/tsconfig.json +8 -0
- package/templates-experimental/hello-world-with-assets/ts/tsconfig.json +44 -0
- package/templates-experimental/hello-world-with-assets/ts/vitest.config.mts +11 -0
- package/templates-experimental/hello-world-with-assets/ts/worker-configuration.d.ts +4 -0
- package/templates-experimental/hello-world-with-assets/ts/wrangler.json +15 -0
- package/templates-experimental/hono/c3.ts +43 -0
- package/templates-experimental/hono/templates/public/index.html +19 -0
- package/templates-experimental/hono/templates/src/index.ts +9 -0
- package/templates-experimental/hono/templates/worker-configuration.d.ts +4 -0
- package/templates-experimental/hono/templates/wrangler.json +9 -0
- package/templates-experimental/next/c3.ts +59 -0
- package/templates-experimental/next/templates/.dev.vars +2 -0
- package/templates-experimental/next/templates/__dot__gitignore +39 -0
- package/templates-experimental/next/templates/cloudflare-env.d.ts +5 -0
- package/templates-experimental/next/templates/open-next.config.ts +28 -0
- package/templates-experimental/next/templates/wrangler.json +13 -0
- package/templates-experimental/nuxt/c3.ts +135 -0
- package/templates-experimental/nuxt/templates/env.d.ts +14 -0
- package/templates-experimental/nuxt/templates/worker-configuration.d.ts +4 -0
- package/templates-experimental/nuxt/templates/wrangler.json +12 -0
- package/templates-experimental/qwik/c3.ts +153 -0
- package/templates-experimental/qwik/snippets/getPlatformProxy.ts +6 -0
- package/templates-experimental/qwik/templates/public/.assetsignore +4 -0
- package/templates-experimental/qwik/templates/worker-configuration.d.ts +4 -0
- package/templates-experimental/qwik/templates/wrangler.json +15 -0
- package/templates-experimental/remix/c3.ts +52 -0
- package/templates-experimental/remix/templates/public/.assetsignore +0 -0
- package/templates-experimental/remix/templates/worker-configuration.d.ts +4 -0
- package/templates-experimental/remix/templates/wrangler.toml +11 -0
- package/templates-experimental/solid/c3.ts +94 -0
- package/templates-experimental/solid/templates/wrangler.json +15 -0
- package/templates-experimental/svelte/c3.ts +129 -0
- package/templates-experimental/svelte/templates/static/.assetsignore +4 -0
- package/templates-experimental/svelte/templates/wrangler.json +12 -0
- package/templates-experimental/vue/c3.ts +33 -0
- package/templates-experimental/vue/templates/wrangler.json +10 -0
- package/templates/angular/templates/server.ts +0 -34
- package/templates/angular/templates/tools/alter-polyfills.mjs +0 -27
- package/templates/angular/templates/tools/paths.mjs +0 -9
- package/templates/common/js/wrangler.toml +0 -51
- package/templates/common/ts/wrangler.toml +0 -51
- package/templates/hello-world/js/wrangler.toml +0 -51
- package/templates/hello-world/ts/wrangler.toml +0 -51
- package/templates/hello-world-durable-object/js/wrangler.toml +0 -51
- package/templates/hello-world-durable-object/ts/wrangler.toml +0 -51
- package/templates/next/templates.ts +0 -281
- package/templates/openapi/ts/wrangler.toml +0 -3
- package/templates/pre-existing/js/wrangler.toml +0 -3
- package/templates/queues/js/wrangler.toml +0 -19
- package/templates/queues/ts/wrangler.toml +0 -19
- package/templates/scheduled/js/wrangler.toml +0 -9
- package/templates/scheduled/ts/wrangler.toml +0 -9
- package/templates/solid/js/vite.config.js +0 -12
- package/templates/solid/ts/vite.config.ts +0 -12
- package/templates/svelte/templates.ts +0 -13
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
export const runtime = "edge";
|
|
2
|
+
|
|
3
|
+
export default function NotFound() {
|
|
4
|
+
return (
|
|
5
|
+
<>
|
|
6
|
+
<title>404: This page could not be found.</title>
|
|
7
|
+
<div style={styles.error}>
|
|
8
|
+
<div>
|
|
9
|
+
<style
|
|
10
|
+
dangerouslySetInnerHTML={{
|
|
11
|
+
__html: `body{color:#000;background:#fff;margin:0}.next-error-h1{border-right:1px solid rgba(0,0,0,.3)}@media (prefers-color-scheme:dark){body{color:#fff;background:#000}.next-error-h1{border-right:1px solid rgba(255,255,255,.3)}}`,
|
|
12
|
+
}}
|
|
13
|
+
/>
|
|
14
|
+
<h1 className="next-error-h1" style={styles.h1}>
|
|
15
|
+
404
|
|
16
|
+
</h1>
|
|
17
|
+
<div style={styles.desc}>
|
|
18
|
+
<h2 style={styles.h2}>This page could not be found.</h2>
|
|
19
|
+
</div>
|
|
20
|
+
</div>
|
|
21
|
+
</div>
|
|
22
|
+
</>
|
|
23
|
+
);
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
const styles = {
|
|
27
|
+
error: {
|
|
28
|
+
fontFamily:
|
|
29
|
+
'system-ui,"Segoe UI",Roboto,Helvetica,Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji"',
|
|
30
|
+
height: "100vh",
|
|
31
|
+
textAlign: "center",
|
|
32
|
+
display: "flex",
|
|
33
|
+
flexDirection: "column",
|
|
34
|
+
alignItems: "center",
|
|
35
|
+
justifyContent: "center",
|
|
36
|
+
},
|
|
37
|
+
|
|
38
|
+
desc: {
|
|
39
|
+
display: "inline-block",
|
|
40
|
+
},
|
|
41
|
+
|
|
42
|
+
h1: {
|
|
43
|
+
display: "inline-block",
|
|
44
|
+
margin: "0 20px 0 0",
|
|
45
|
+
padding: "0 23px 0 0",
|
|
46
|
+
fontSize: 24,
|
|
47
|
+
fontWeight: 500,
|
|
48
|
+
verticalAlign: "top",
|
|
49
|
+
lineHeight: "49px",
|
|
50
|
+
},
|
|
51
|
+
|
|
52
|
+
h2: {
|
|
53
|
+
fontSize: 14,
|
|
54
|
+
fontWeight: 400,
|
|
55
|
+
lineHeight: "49px",
|
|
56
|
+
margin: 0,
|
|
57
|
+
},
|
|
58
|
+
};
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
// import { getRequestContext } from '@cloudflare/next-on-pages'
|
|
2
|
+
|
|
3
|
+
export const runtime = 'edge'
|
|
4
|
+
|
|
5
|
+
export async function GET() {
|
|
6
|
+
const responseText = 'Hello World'
|
|
7
|
+
|
|
8
|
+
// In the edge runtime you can use Bindings that are available in your application
|
|
9
|
+
// (for more details see:
|
|
10
|
+
// - https://developers.cloudflare.com/pages/framework-guides/deploy-a-nextjs-site/#use-bindings-in-your-nextjs-application
|
|
11
|
+
// - https://developers.cloudflare.com/pages/functions/bindings/
|
|
12
|
+
// )
|
|
13
|
+
//
|
|
14
|
+
// KV Example:
|
|
15
|
+
// const myKv = getRequestContext().env.MY_KV_NAMESPACE
|
|
16
|
+
// await myKv.put('suffix', ' from a KV store!')
|
|
17
|
+
// const suffix = await myKv.get('suffix')
|
|
18
|
+
// return new Response(responseText + suffix)
|
|
19
|
+
|
|
20
|
+
return new Response(responseText)
|
|
21
|
+
}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
export const runtime = "edge";
|
|
2
|
+
|
|
3
|
+
export default function NotFound() {
|
|
4
|
+
return (
|
|
5
|
+
<>
|
|
6
|
+
<title>404: This page could not be found.</title>
|
|
7
|
+
<div style={styles.error}>
|
|
8
|
+
<div>
|
|
9
|
+
<style
|
|
10
|
+
dangerouslySetInnerHTML={{
|
|
11
|
+
__html: `body{color:#000;background:#fff;margin:0}.next-error-h1{border-right:1px solid rgba(0,0,0,.3)}@media (prefers-color-scheme:dark){body{color:#fff;background:#000}.next-error-h1{border-right:1px solid rgba(255,255,255,.3)}}`,
|
|
12
|
+
}}
|
|
13
|
+
/>
|
|
14
|
+
<h1 className="next-error-h1" style={styles.h1}>
|
|
15
|
+
404
|
|
16
|
+
</h1>
|
|
17
|
+
<div style={styles.desc}>
|
|
18
|
+
<h2 style={styles.h2}>This page could not be found.</h2>
|
|
19
|
+
</div>
|
|
20
|
+
</div>
|
|
21
|
+
</div>
|
|
22
|
+
</>
|
|
23
|
+
);
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
const styles = {
|
|
27
|
+
error: {
|
|
28
|
+
fontFamily:
|
|
29
|
+
'system-ui,"Segoe UI",Roboto,Helvetica,Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji"',
|
|
30
|
+
height: "100vh",
|
|
31
|
+
textAlign: "center",
|
|
32
|
+
display: "flex",
|
|
33
|
+
flexDirection: "column",
|
|
34
|
+
alignItems: "center",
|
|
35
|
+
justifyContent: "center",
|
|
36
|
+
},
|
|
37
|
+
|
|
38
|
+
desc: {
|
|
39
|
+
display: "inline-block",
|
|
40
|
+
},
|
|
41
|
+
|
|
42
|
+
h1: {
|
|
43
|
+
display: "inline-block",
|
|
44
|
+
margin: "0 20px 0 0",
|
|
45
|
+
padding: "0 23px 0 0",
|
|
46
|
+
fontSize: 24,
|
|
47
|
+
fontWeight: 500,
|
|
48
|
+
verticalAlign: "top",
|
|
49
|
+
lineHeight: "49px",
|
|
50
|
+
},
|
|
51
|
+
|
|
52
|
+
h2: {
|
|
53
|
+
fontSize: 14,
|
|
54
|
+
fontWeight: 400,
|
|
55
|
+
lineHeight: "49px",
|
|
56
|
+
margin: 0,
|
|
57
|
+
},
|
|
58
|
+
} as const;
|
package/templates/next/c3.ts
CHANGED
|
@@ -1,31 +1,23 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
import { processArgument } from "@cloudflare/cli/args";
|
|
1
|
+
import { join } from "path";
|
|
2
|
+
import { updateStatus, warn } from "@cloudflare/cli";
|
|
4
3
|
import { brandColor, dim } from "@cloudflare/cli/colors";
|
|
5
|
-
import {
|
|
4
|
+
import { inputPrompt, spinner } from "@cloudflare/cli/interactive";
|
|
5
|
+
import { runFrameworkGenerator } from "frameworks/index";
|
|
6
6
|
import {
|
|
7
|
-
|
|
7
|
+
copyFile,
|
|
8
8
|
probePaths,
|
|
9
|
+
readFile,
|
|
9
10
|
readJSON,
|
|
10
11
|
usesEslint,
|
|
11
12
|
usesTypescript,
|
|
12
13
|
writeFile,
|
|
13
14
|
writeJSON,
|
|
14
15
|
} from "helpers/files";
|
|
15
|
-
import { detectPackageManager } from "helpers/
|
|
16
|
-
import {
|
|
17
|
-
|
|
18
|
-
apiAppDirHelloTs,
|
|
19
|
-
apiPagesDirHelloJs,
|
|
20
|
-
apiPagesDirHelloTs,
|
|
21
|
-
appDirNotFoundJs,
|
|
22
|
-
appDirNotFoundTs,
|
|
23
|
-
envDts,
|
|
24
|
-
nextConfig,
|
|
25
|
-
readme,
|
|
26
|
-
} from "./templates";
|
|
16
|
+
import { detectPackageManager } from "helpers/packageManagers";
|
|
17
|
+
import { installPackages } from "helpers/packages";
|
|
18
|
+
import { getTemplatePath } from "../../src/templates";
|
|
27
19
|
import type { TemplateConfig } from "../../src/templates";
|
|
28
|
-
import type {
|
|
20
|
+
import type { C3Context } from "types";
|
|
29
21
|
|
|
30
22
|
const { npm, npx } = detectPackageManager();
|
|
31
23
|
|
|
@@ -33,27 +25,35 @@ const generate = async (ctx: C3Context) => {
|
|
|
33
25
|
const projectName = ctx.project.name;
|
|
34
26
|
|
|
35
27
|
await runFrameworkGenerator(ctx, [projectName]);
|
|
28
|
+
|
|
29
|
+
const wranglerConfig = readFile(join(getTemplatePath(ctx), "wrangler.json"));
|
|
30
|
+
writeFile(join(ctx.project.path, "wrangler.json"), wranglerConfig);
|
|
31
|
+
updateStatus("Created wrangler.json file");
|
|
36
32
|
};
|
|
37
33
|
|
|
38
|
-
const
|
|
39
|
-
|
|
40
|
-
isTypescript: boolean
|
|
41
|
-
): [string, string] => {
|
|
42
|
-
const isAppDir = /\/app\/api$/.test(apiPath);
|
|
34
|
+
const updateNextConfig = (usesTs: boolean) => {
|
|
35
|
+
const s = spinner();
|
|
43
36
|
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
const routeHandlerPath = `${apiPath}/hello`;
|
|
47
|
-
mkdirSync(routeHandlerPath, { recursive: true });
|
|
37
|
+
const configFile = `next.config.${usesTs ? "ts" : "mjs"}`;
|
|
38
|
+
s.start(`Updating \`${configFile}\``);
|
|
48
39
|
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
40
|
+
const configContent = readFile(configFile);
|
|
41
|
+
|
|
42
|
+
const updatedConfigFile =
|
|
43
|
+
`import { setupDevPlatform } from '@cloudflare/next-on-pages/next-dev';
|
|
44
|
+
|
|
45
|
+
// Here we use the @cloudflare/next-on-pages next-dev module to allow us to use bindings during local development
|
|
46
|
+
// (when running the application with \`next dev\`), for more information see:
|
|
47
|
+
// https://github.com/cloudflare/next-on-pages/blob/main/internal-packages/next-dev/README.md
|
|
48
|
+
if (process.env.NODE_ENV === 'development') {
|
|
49
|
+
await setupDevPlatform();
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
`.replace(/\n\t*/g, "\n") + configContent;
|
|
53
|
+
|
|
54
|
+
writeFile(configFile, updatedConfigFile);
|
|
53
55
|
|
|
54
|
-
|
|
55
|
-
? [`${apiPath}/hello.ts`, apiPagesDirHelloTs]
|
|
56
|
-
: [`${apiPath}/hello.js`, apiPagesDirHelloJs];
|
|
56
|
+
s.stop(`${brandColor(`updated`)} ${dim(`\`${configFile}\``)}`);
|
|
57
57
|
};
|
|
58
58
|
|
|
59
59
|
const configure = async (ctx: C3Context) => {
|
|
@@ -70,39 +70,16 @@ const configure = async (ctx: C3Context) => {
|
|
|
70
70
|
]);
|
|
71
71
|
|
|
72
72
|
if (!path) {
|
|
73
|
-
|
|
73
|
+
throw new Error("Could not find the `/api` or `/app` directory");
|
|
74
74
|
}
|
|
75
75
|
|
|
76
|
-
// App directory template may not generate an API route handler, so we update the path to add an `api` directory.
|
|
77
|
-
const apiPath = path.replace(/\/app$/, "/app/api");
|
|
78
|
-
|
|
79
76
|
const usesTs = usesTypescript(ctx);
|
|
80
77
|
|
|
81
|
-
const appDirPath = probePaths([
|
|
82
|
-
`${projectPath}/src/app`,
|
|
83
|
-
`${projectPath}/app`,
|
|
84
|
-
]);
|
|
85
|
-
|
|
86
|
-
if (appDirPath) {
|
|
87
|
-
// Add a custom app not-found edge route as recommended in next-on-pages
|
|
88
|
-
// (see: https://github.com/cloudflare/next-on-pages/blob/2b5c8f25/packages/next-on-pages/docs/gotchas.md#not-found)
|
|
89
|
-
const notFoundPath = `${appDirPath}/not-found.${usesTs ? "tsx" : "js"}`;
|
|
90
|
-
if (!existsSync(notFoundPath)) {
|
|
91
|
-
const notFoundContent = usesTs ? appDirNotFoundTs : appDirNotFoundJs;
|
|
92
|
-
writeFile(notFoundPath, notFoundContent);
|
|
93
|
-
updateStatus("Created a custom edge not-found route");
|
|
94
|
-
}
|
|
95
|
-
}
|
|
96
|
-
|
|
97
|
-
const [handlerPath, handlerFile] = getApiTemplate(
|
|
98
|
-
apiPath,
|
|
99
|
-
usesTypescript(ctx)
|
|
100
|
-
);
|
|
101
|
-
writeFile(handlerPath, handlerFile);
|
|
102
|
-
updateStatus("Created an example API route handler");
|
|
103
|
-
|
|
104
78
|
if (usesTs) {
|
|
105
|
-
|
|
79
|
+
copyFile(
|
|
80
|
+
join(getTemplatePath(ctx), "env.d.ts"),
|
|
81
|
+
join(projectPath, "env.d.ts"),
|
|
82
|
+
);
|
|
106
83
|
updateStatus("Created an env.d.ts file");
|
|
107
84
|
}
|
|
108
85
|
|
|
@@ -112,30 +89,34 @@ const configure = async (ctx: C3Context) => {
|
|
|
112
89
|
await writeEslintrc(ctx);
|
|
113
90
|
}
|
|
114
91
|
|
|
115
|
-
|
|
116
|
-
updateStatus("Updated the next.config.js file");
|
|
92
|
+
updateNextConfig(usesTs);
|
|
117
93
|
|
|
118
|
-
|
|
94
|
+
copyFile(
|
|
95
|
+
join(getTemplatePath(ctx), "README.md"),
|
|
96
|
+
join(projectPath, "README.md"),
|
|
97
|
+
);
|
|
119
98
|
updateStatus("Updated the README file");
|
|
120
99
|
|
|
121
100
|
await addDevDependencies(installEslintPlugin);
|
|
122
101
|
};
|
|
123
102
|
|
|
124
103
|
export const shouldInstallNextOnPagesEslintPlugin = async (
|
|
125
|
-
ctx: C3Context
|
|
104
|
+
ctx: C3Context,
|
|
126
105
|
): Promise<boolean> => {
|
|
127
106
|
const eslintUsage = usesEslint(ctx);
|
|
128
107
|
|
|
129
|
-
if (!eslintUsage.used)
|
|
108
|
+
if (!eslintUsage.used) {
|
|
109
|
+
return false;
|
|
110
|
+
}
|
|
130
111
|
|
|
131
112
|
if (eslintUsage.configType !== ".eslintrc.json") {
|
|
132
113
|
warn(
|
|
133
|
-
`Expected .eslintrc.json from Next.js scaffolding but found ${eslintUsage.configType} instead
|
|
114
|
+
`Expected .eslintrc.json from Next.js scaffolding but found ${eslintUsage.configType} instead`,
|
|
134
115
|
);
|
|
135
116
|
return false;
|
|
136
117
|
}
|
|
137
118
|
|
|
138
|
-
return await
|
|
119
|
+
return await inputPrompt({
|
|
139
120
|
type: "confirm",
|
|
140
121
|
question: "Do you want to use the next-on-pages eslint-plugin?",
|
|
141
122
|
label: "eslint-plugin",
|
|
@@ -175,13 +156,43 @@ const addDevDependencies = async (installEslintPlugin: boolean) => {
|
|
|
175
156
|
export default {
|
|
176
157
|
configVersion: 1,
|
|
177
158
|
id: "next",
|
|
159
|
+
frameworkCli: "create-next-app",
|
|
178
160
|
platform: "pages",
|
|
179
|
-
displayName: "Next",
|
|
180
|
-
devScript: "dev",
|
|
181
|
-
previewScript: "pages:preview",
|
|
161
|
+
displayName: "Next.js",
|
|
182
162
|
generate,
|
|
183
163
|
configure,
|
|
184
|
-
|
|
164
|
+
copyFiles: {
|
|
165
|
+
async selectVariant(ctx) {
|
|
166
|
+
const isApp = probePaths([
|
|
167
|
+
`${ctx.project.path}/src/app`,
|
|
168
|
+
`${ctx.project.path}/app`,
|
|
169
|
+
]);
|
|
170
|
+
|
|
171
|
+
const isTypescript = usesTypescript(ctx);
|
|
172
|
+
|
|
173
|
+
const dir = isApp ? "app" : "pages";
|
|
174
|
+
return `${dir}/${isTypescript ? "ts" : "js"}`;
|
|
175
|
+
},
|
|
176
|
+
destinationDir(ctx) {
|
|
177
|
+
const srcPath = probePaths([`${ctx.project.path}/src`]);
|
|
178
|
+
return srcPath ? "./src" : "./";
|
|
179
|
+
},
|
|
180
|
+
variants: {
|
|
181
|
+
"app/ts": {
|
|
182
|
+
path: "./app/ts",
|
|
183
|
+
},
|
|
184
|
+
"app/js": {
|
|
185
|
+
path: "./app/js",
|
|
186
|
+
},
|
|
187
|
+
"pages/ts": {
|
|
188
|
+
path: "./pages/ts",
|
|
189
|
+
},
|
|
190
|
+
"pages/js": {
|
|
191
|
+
path: "./pages/js",
|
|
192
|
+
},
|
|
193
|
+
},
|
|
194
|
+
},
|
|
195
|
+
transformPackageJson: async (_, ctx) => {
|
|
185
196
|
const isNpm = npm === "npm";
|
|
186
197
|
const isBun = npm === "bun";
|
|
187
198
|
const isNpmOrBun = isNpm || isBun;
|
|
@@ -194,20 +205,16 @@ export default {
|
|
|
194
205
|
return {
|
|
195
206
|
scripts: {
|
|
196
207
|
"pages:build": `${pmCommand} ${nextOnPagesCommand}`,
|
|
197
|
-
|
|
198
|
-
|
|
208
|
+
preview: `${pagesBuildRunCommand} && wrangler pages dev`,
|
|
209
|
+
deploy: `${pagesBuildRunCommand} && wrangler pages deploy`,
|
|
210
|
+
...(usesTypescript(ctx) && {
|
|
211
|
+
"cf-typegen": `wrangler types --env-interface CloudflareEnv env.d.ts`,
|
|
212
|
+
}),
|
|
199
213
|
},
|
|
200
214
|
};
|
|
201
215
|
},
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
"--eslint",
|
|
206
|
-
"--tailwind",
|
|
207
|
-
"--src-dir",
|
|
208
|
-
"--app",
|
|
209
|
-
"--import-alias",
|
|
210
|
-
"@/*",
|
|
211
|
-
],
|
|
216
|
+
devScript: "dev",
|
|
217
|
+
previewScript: "preview",
|
|
218
|
+
deployScript: "deploy",
|
|
212
219
|
compatibilityFlags: ["nodejs_compat"],
|
|
213
220
|
} as TemplateConfig;
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { getRequestContext } from '@cloudflare/next-on-pages'
|
|
2
|
+
|
|
3
|
+
export const config = {
|
|
4
|
+
runtime: 'edge',
|
|
5
|
+
}
|
|
6
|
+
|
|
7
|
+
export default async function handler(req) {
|
|
8
|
+
let responseText = 'Hello World'
|
|
9
|
+
|
|
10
|
+
// In the edge runtime you can use Bindings that are available in your application
|
|
11
|
+
// (for more details see:
|
|
12
|
+
// - https://developers.cloudflare.com/pages/framework-guides/deploy-a-nextjs-site/#use-bindings-in-your-nextjs-application
|
|
13
|
+
// - https://developers.cloudflare.com/pages/functions/bindings/
|
|
14
|
+
// )
|
|
15
|
+
//
|
|
16
|
+
// KV Example:
|
|
17
|
+
// const myKv = getRequestContext().env.MY_KV_NAMESPACE
|
|
18
|
+
// await myKv.put('suffix', ' from a KV store!')
|
|
19
|
+
// const suffix = await myKv.get('suffix')
|
|
20
|
+
// responseText += suffix
|
|
21
|
+
|
|
22
|
+
return new Response(responseText)
|
|
23
|
+
}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import type { NextRequest } from 'next/server'
|
|
2
|
+
import { getRequestContext } from '@cloudflare/next-on-pages'
|
|
3
|
+
|
|
4
|
+
export const config = {
|
|
5
|
+
runtime: 'edge',
|
|
6
|
+
}
|
|
7
|
+
|
|
8
|
+
export default async function handler(req: NextRequest) {
|
|
9
|
+
let responseText = 'Hello World'
|
|
10
|
+
|
|
11
|
+
// In the edge runtime you can use Bindings that are available in your application
|
|
12
|
+
// (for more details see:
|
|
13
|
+
// - https://developers.cloudflare.com/pages/framework-guides/deploy-a-nextjs-site/#use-bindings-in-your-nextjs-application
|
|
14
|
+
// - https://developers.cloudflare.com/pages/functions/bindings/
|
|
15
|
+
// )
|
|
16
|
+
//
|
|
17
|
+
// KV Example:
|
|
18
|
+
// const myKv = getRequestContext().env.MY_KV_NAMESPACE
|
|
19
|
+
// await myKv.put('suffix', ' from a KV store!')
|
|
20
|
+
// const suffix = await myKv.get('suffix')
|
|
21
|
+
// responseText += suffix
|
|
22
|
+
|
|
23
|
+
return new Response(responseText)
|
|
24
|
+
}
|
package/templates/nuxt/c3.ts
CHANGED
|
@@ -1,15 +1,17 @@
|
|
|
1
|
-
import { readFileSync } from "node:fs";
|
|
2
|
-
import { resolve } from "node:path";
|
|
3
1
|
import { logRaw } from "@cloudflare/cli";
|
|
4
2
|
import { brandColor, dim } from "@cloudflare/cli/colors";
|
|
5
3
|
import { spinner } from "@cloudflare/cli/interactive";
|
|
6
|
-
import { runFrameworkGenerator } from "
|
|
7
|
-
import {
|
|
8
|
-
import {
|
|
4
|
+
import { runFrameworkGenerator } from "frameworks/index";
|
|
5
|
+
import { mergeObjectProperties, transformFile } from "helpers/codemod";
|
|
6
|
+
import { getLatestTypesEntrypoint } from "helpers/compatDate";
|
|
7
|
+
import { readFile, writeFile } from "helpers/files";
|
|
8
|
+
import { detectPackageManager } from "helpers/packageManagers";
|
|
9
|
+
import { installPackages } from "helpers/packages";
|
|
10
|
+
import * as recast from "recast";
|
|
9
11
|
import type { TemplateConfig } from "../../src/templates";
|
|
10
12
|
import type { C3Context } from "types";
|
|
11
13
|
|
|
12
|
-
const { npm } = detectPackageManager();
|
|
14
|
+
const { npm, name: pm } = detectPackageManager();
|
|
13
15
|
|
|
14
16
|
const generate = async (ctx: C3Context) => {
|
|
15
17
|
const gitFlag = ctx.args.git ? `--gitInit` : `--no-gitInit`;
|
|
@@ -22,38 +24,111 @@ const generate = async (ctx: C3Context) => {
|
|
|
22
24
|
gitFlag,
|
|
23
25
|
]);
|
|
24
26
|
|
|
25
|
-
writeFile("./.node-version", "
|
|
27
|
+
writeFile("./.node-version", "18");
|
|
26
28
|
|
|
27
29
|
logRaw(""); // newline
|
|
28
30
|
};
|
|
29
31
|
|
|
30
|
-
const configure = async () => {
|
|
31
|
-
const
|
|
32
|
-
|
|
32
|
+
const configure = async (ctx: C3Context) => {
|
|
33
|
+
const packages = ["nitro-cloudflare-dev"];
|
|
34
|
+
|
|
35
|
+
// When using pnpm, explicitly add h3 package so the H3Event type declaration can be updated.
|
|
36
|
+
// Package managers other than pnpm will hoist the dependency, as will pnpm with `--shamefully-hoist`
|
|
37
|
+
if (pm === "pnpm") {
|
|
38
|
+
packages.push("h3");
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
await installPackages(packages, {
|
|
42
|
+
dev: true,
|
|
43
|
+
startText: "Installing nitro module `nitro-cloudflare-dev`",
|
|
44
|
+
doneText: `${brandColor("installed")} ${dim(`via \`${npm} install\``)}`,
|
|
45
|
+
});
|
|
46
|
+
updateNuxtConfig();
|
|
47
|
+
|
|
48
|
+
updateEnvTypes(ctx);
|
|
49
|
+
};
|
|
50
|
+
|
|
51
|
+
const updateEnvTypes = (ctx: C3Context) => {
|
|
52
|
+
const filepath = "env.d.ts";
|
|
53
|
+
|
|
54
|
+
const s = spinner();
|
|
55
|
+
s.start(`Updating ${filepath}`);
|
|
56
|
+
|
|
57
|
+
let file = readFile(filepath);
|
|
58
|
+
|
|
59
|
+
let typesEntrypoint = `@cloudflare/workers-types`;
|
|
60
|
+
const latestEntrypoint = getLatestTypesEntrypoint(ctx);
|
|
61
|
+
if (latestEntrypoint) {
|
|
62
|
+
typesEntrypoint += `/${latestEntrypoint}`;
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
// Replace placeholder with actual types entrypoint
|
|
66
|
+
file = file.replace("WORKERS_TYPES_ENTRYPOINT", typesEntrypoint);
|
|
67
|
+
writeFile("env.d.ts", file);
|
|
68
|
+
|
|
69
|
+
s.stop(`${brandColor(`updated`)} ${dim(`\`${filepath}\``)}`);
|
|
70
|
+
};
|
|
71
|
+
|
|
72
|
+
const updateNuxtConfig = () => {
|
|
33
73
|
const s = spinner();
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
74
|
+
|
|
75
|
+
const configFile = "nuxt.config.ts";
|
|
76
|
+
s.start(`Updating \`${configFile}\``);
|
|
77
|
+
|
|
78
|
+
const b = recast.types.builders;
|
|
79
|
+
|
|
80
|
+
const presetDef = b.objectProperty(
|
|
81
|
+
b.identifier("nitro"),
|
|
82
|
+
b.objectExpression([
|
|
83
|
+
b.objectProperty(
|
|
84
|
+
b.identifier("preset"),
|
|
85
|
+
b.stringLiteral("cloudflare-pages"),
|
|
86
|
+
),
|
|
87
|
+
]),
|
|
40
88
|
);
|
|
41
|
-
|
|
42
|
-
|
|
89
|
+
|
|
90
|
+
const moduleDef = b.objectProperty(
|
|
91
|
+
b.identifier("modules"),
|
|
92
|
+
b.arrayExpression([b.stringLiteral("nitro-cloudflare-dev")]),
|
|
93
|
+
);
|
|
94
|
+
|
|
95
|
+
transformFile(configFile, {
|
|
96
|
+
visitCallExpression: function (n) {
|
|
97
|
+
const callee = n.node.callee as recast.types.namedTypes.Identifier;
|
|
98
|
+
if (callee.name === "defineNuxtConfig") {
|
|
99
|
+
mergeObjectProperties(
|
|
100
|
+
n.node.arguments[0] as recast.types.namedTypes.ObjectExpression,
|
|
101
|
+
[presetDef, moduleDef],
|
|
102
|
+
);
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
return this.traverse(n);
|
|
106
|
+
},
|
|
107
|
+
});
|
|
108
|
+
|
|
109
|
+
s.stop(`${brandColor(`updated`)} ${dim(`\`${configFile}\``)}`);
|
|
43
110
|
};
|
|
44
111
|
|
|
45
112
|
const config: TemplateConfig = {
|
|
46
113
|
configVersion: 1,
|
|
47
114
|
id: "nuxt",
|
|
115
|
+
frameworkCli: "nuxi",
|
|
48
116
|
platform: "pages",
|
|
49
117
|
displayName: "Nuxt",
|
|
118
|
+
copyFiles: {
|
|
119
|
+
path: "./templates",
|
|
120
|
+
},
|
|
50
121
|
generate,
|
|
51
122
|
configure,
|
|
52
123
|
transformPackageJson: async () => ({
|
|
53
124
|
scripts: {
|
|
54
|
-
|
|
55
|
-
|
|
125
|
+
deploy: `${npm} run build && wrangler pages deploy`,
|
|
126
|
+
preview: `${npm} run build && wrangler pages dev`,
|
|
127
|
+
"cf-typegen": `wrangler types`,
|
|
56
128
|
},
|
|
57
129
|
}),
|
|
130
|
+
devScript: "dev",
|
|
131
|
+
deployScript: "deploy",
|
|
132
|
+
previewScript: "preview",
|
|
58
133
|
};
|
|
59
134
|
export default config;
|
package/templates/openapi/c3.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
# Cloudflare Workers OpenAPI 3.1
|
|
2
2
|
|
|
3
|
-
This is a Cloudflare Worker with OpenAPI 3.1 using [
|
|
3
|
+
This is a Cloudflare Worker with OpenAPI 3.1 using [chanfana](https://github.com/cloudflare/chanfana) and [Hono](https://github.com/honojs/hono).
|
|
4
4
|
|
|
5
5
|
This is an example project made to be used as a quick start into building OpenAPI compliant Workers that generates the
|
|
6
6
|
`openapi.json` schema automatically from code and validates the incoming request to the defined parameters or request body.
|
|
@@ -16,10 +16,10 @@ This is an example project made to be used as a quick start into building OpenAP
|
|
|
16
16
|
|
|
17
17
|
1. Your main router is defined in `src/index.ts`.
|
|
18
18
|
2. Each endpoint has its own file in `src/endpoints/`.
|
|
19
|
-
3. For more information read the [
|
|
19
|
+
3. For more information read the [chanfana documentation](https://chanfana.pages.dev/) and [Hono documentation](https://hono.dev/docs).
|
|
20
20
|
|
|
21
21
|
## Development
|
|
22
22
|
|
|
23
23
|
1. Run `wrangler dev` to start a local instance of the API.
|
|
24
|
-
2. Open `http://localhost:
|
|
24
|
+
2. Open `http://localhost:8787/` in your browser to see the Swagger interface where you can try the endpoints.
|
|
25
25
|
3. Changes made in the `src/` folder will automatically trigger the server to reload, you only need to refresh the Swagger interface.
|