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.
Files changed (242) hide show
  1. package/README.md +1 -1
  2. package/dist/cli.js +61432 -60289
  3. package/dist/tsconfig.tsbuildinfo +1 -0
  4. package/package.json +34 -25
  5. package/templates/analog/c3.ts +135 -0
  6. package/templates/analog/snippets/devBindingsModule.ts +7 -0
  7. package/templates/analog/templates/env.d.ts +13 -0
  8. package/templates/analog/templates/src/dev-bindings.ts +18 -0
  9. package/templates/analog/templates/worker-configuration.d.ts +4 -0
  10. package/templates/analog/templates/wrangler.json +5 -0
  11. package/templates/angular/c3.ts +37 -22
  12. package/templates/angular/templates/src/server.ts +15 -0
  13. package/templates/angular/templates/tools/copy-files.mjs +8 -2
  14. package/templates/astro/c3.ts +66 -19
  15. package/templates/astro/templates/js/wrangler.json +8 -0
  16. package/templates/astro/templates/ts/src/env.d.ts +5 -0
  17. package/templates/astro/templates/ts/worker-configuration.d.ts +4 -0
  18. package/templates/astro/templates/ts/wrangler.json +8 -0
  19. package/templates/common/c3.ts +10 -5
  20. package/templates/common/js/.editorconfig +0 -1
  21. package/templates/common/js/package.json +1 -1
  22. package/templates/common/js/wrangler.json +8 -0
  23. package/templates/common/ts/.editorconfig +0 -1
  24. package/templates/common/ts/package.json +4 -3
  25. package/templates/common/ts/src/ab-test.ts +2 -2
  26. package/templates/common/ts/src/index.ts +5 -2
  27. package/templates/common/ts/src/proxy.ts +2 -2
  28. package/templates/common/ts/src/redirect.ts +2 -2
  29. package/templates/common/ts/tsconfig.json +37 -95
  30. package/templates/common/ts/worker-configuration.d.ts +2 -14
  31. package/templates/common/ts/wrangler.json +8 -0
  32. package/templates/docusaurus/c3.ts +7 -6
  33. package/templates/gatsby/c3.ts +8 -5
  34. package/templates/hello-world/c3.ts +12 -6
  35. package/templates/hello-world/js/.editorconfig +0 -1
  36. package/templates/hello-world/js/package.json +5 -2
  37. package/templates/hello-world/js/test/index.spec.js +20 -0
  38. package/templates/hello-world/js/vitest.config.js +11 -0
  39. package/templates/hello-world/js/wrangler.json +8 -0
  40. package/templates/hello-world/py/__dot__gitignore +68 -0
  41. package/templates/hello-world/py/package.json +13 -0
  42. package/templates/hello-world/py/src/entry.py +4 -0
  43. package/templates/hello-world/py/wrangler.json +9 -0
  44. package/templates/hello-world/ts/.editorconfig +0 -1
  45. package/templates/hello-world/ts/package.json +7 -3
  46. package/templates/hello-world/ts/src/index.ts +5 -19
  47. package/templates/hello-world/ts/test/index.spec.ts +25 -0
  48. package/templates/hello-world/ts/test/tsconfig.json +8 -0
  49. package/templates/hello-world/ts/tsconfig.json +39 -96
  50. package/templates/hello-world/ts/vitest.config.mts +11 -0
  51. package/templates/hello-world/ts/worker-configuration.d.ts +4 -0
  52. package/templates/hello-world/ts/wrangler.json +8 -0
  53. package/templates/hello-world-durable-object/c3.ts +10 -6
  54. package/templates/hello-world-durable-object/js/.editorconfig +0 -1
  55. package/templates/hello-world-durable-object/js/package.json +1 -1
  56. package/templates/hello-world-durable-object/js/src/index.js +21 -17
  57. package/templates/hello-world-durable-object/js/wrangler.json +24 -0
  58. package/templates/hello-world-durable-object/ts/.editorconfig +0 -1
  59. package/templates/hello-world-durable-object/ts/package.json +4 -4
  60. package/templates/hello-world-durable-object/ts/src/index.ts +26 -39
  61. package/templates/hello-world-durable-object/ts/tsconfig.json +36 -95
  62. package/templates/hello-world-durable-object/ts/worker-configuration.d.ts +5 -0
  63. package/templates/hello-world-durable-object/ts/wrangler.json +24 -0
  64. package/templates/hono/c3.ts +45 -1
  65. package/templates/hono/snippets/appDeclaration.ts +1 -0
  66. package/templates/hono/templates/worker-configuration.d.ts +4 -0
  67. package/templates/hono/templates/wrangler.json +8 -0
  68. package/templates/next/README.md +67 -0
  69. package/templates/next/app/js/app/api/hello/route.js +21 -0
  70. package/templates/next/app/js/app/not-found.js +58 -0
  71. package/templates/next/app/ts/app/api/hello/route.ts +21 -0
  72. package/templates/next/app/ts/app/not-found.tsx +58 -0
  73. package/templates/next/c3.ts +92 -85
  74. package/templates/next/env.d.ts +5 -0
  75. package/templates/next/pages/js/pages/api/hello.js +23 -0
  76. package/templates/next/pages/ts/pages/api/hello.ts +24 -0
  77. package/templates/next/wrangler.json +8 -0
  78. package/templates/nuxt/c3.ts +95 -20
  79. package/templates/nuxt/templates/env.d.ts +14 -0
  80. package/templates/nuxt/templates/worker-configuration.d.ts +4 -0
  81. package/templates/nuxt/templates/wrangler.json +8 -0
  82. package/templates/openapi/c3.ts +1 -0
  83. package/templates/openapi/ts/README.md +3 -3
  84. package/templates/openapi/ts/package.json +7 -4
  85. package/templates/openapi/ts/src/endpoints/taskCreate.ts +26 -16
  86. package/templates/openapi/ts/src/endpoints/taskDelete.ts +20 -19
  87. package/templates/openapi/ts/src/endpoints/taskFetch.ts +30 -23
  88. package/templates/openapi/ts/src/endpoints/taskList.ts +27 -24
  89. package/templates/openapi/ts/src/index.ts +14 -20
  90. package/templates/openapi/ts/src/types.ts +9 -8
  91. package/templates/openapi/ts/worker-configuration.d.ts +4 -0
  92. package/templates/openapi/ts/wrangler.json +8 -0
  93. package/templates/pre-existing/c3.ts +37 -18
  94. package/templates/pre-existing/js/.editorconfig +0 -1
  95. package/templates/pre-existing/js/package.json +1 -1
  96. package/templates/pre-existing/js/wrangler.json +5 -0
  97. package/templates/queues/c3.ts +9 -5
  98. package/templates/queues/js/.editorconfig +0 -1
  99. package/templates/queues/js/package.json +1 -1
  100. package/templates/queues/js/wrangler.json +21 -0
  101. package/templates/queues/ts/.editorconfig +0 -1
  102. package/templates/queues/ts/package.json +4 -3
  103. package/templates/queues/ts/src/index.ts +6 -8
  104. package/templates/queues/ts/tsconfig.json +36 -95
  105. package/templates/queues/ts/worker-configuration.d.ts +5 -0
  106. package/templates/queues/ts/wrangler.json +21 -0
  107. package/templates/qwik/c3.ts +85 -30
  108. package/templates/qwik/snippets/getPlatformProxy.ts +6 -0
  109. package/templates/qwik/templates/worker-configuration.d.ts +4 -0
  110. package/templates/qwik/templates/wrangler.json +8 -0
  111. package/templates/react/c3.ts +38 -6
  112. package/templates/remix/c3.ts +40 -6
  113. package/templates/remix/templates/worker-configuration.d.ts +4 -0
  114. package/templates/remix/templates/wrangler.json +5 -0
  115. package/templates/scheduled/c3.ts +9 -5
  116. package/templates/scheduled/js/.editorconfig +0 -1
  117. package/templates/scheduled/js/package.json +3 -3
  118. package/templates/scheduled/js/src/index.js +9 -2
  119. package/templates/scheduled/js/wrangler.json +13 -0
  120. package/templates/scheduled/ts/.editorconfig +0 -1
  121. package/templates/scheduled/ts/package.json +5 -4
  122. package/templates/scheduled/ts/src/index.ts +8 -25
  123. package/templates/scheduled/ts/tsconfig.json +36 -95
  124. package/templates/scheduled/ts/worker-configuration.d.ts +4 -0
  125. package/templates/scheduled/ts/wrangler.json +13 -0
  126. package/templates/solid/c3.ts +62 -12
  127. package/templates/solid/templates/wrangler.json +8 -0
  128. package/templates/svelte/c3.ts +111 -30
  129. package/templates/svelte/templates/wrangler.json +5 -0
  130. package/templates/vue/c3.ts +8 -6
  131. package/templates-experimental/angular/c3.ts +112 -0
  132. package/templates-experimental/angular/templates/src/server.ts +15 -0
  133. package/templates-experimental/angular/templates/wrangler.json +12 -0
  134. package/templates-experimental/astro/c3.ts +98 -0
  135. package/templates-experimental/astro/templates/js/public/.assetsignore +4 -0
  136. package/templates-experimental/astro/templates/js/wrangler.json +15 -0
  137. package/templates-experimental/astro/templates/ts/public/.assetsignore +4 -0
  138. package/templates-experimental/astro/templates/ts/src/env.d.ts +5 -0
  139. package/templates-experimental/astro/templates/ts/worker-configuration.d.ts +4 -0
  140. package/templates-experimental/astro/templates/ts/wrangler.json +15 -0
  141. package/templates-experimental/docusaurus/c3.ts +32 -0
  142. package/templates-experimental/docusaurus/templates/wrangler.json +10 -0
  143. package/templates-experimental/gatsby/c3.ts +53 -0
  144. package/templates-experimental/gatsby/templates/wrangler.json +10 -0
  145. package/templates-experimental/hello-world-assets-only/c3.ts +15 -0
  146. package/templates-experimental/hello-world-assets-only/templates/package.json +13 -0
  147. package/templates-experimental/hello-world-assets-only/templates/public/index.html +11 -0
  148. package/templates-experimental/hello-world-assets-only/templates/wrangler.json +10 -0
  149. package/templates-experimental/hello-world-durable-object-with-assets/c3.ts +23 -0
  150. package/templates-experimental/hello-world-durable-object-with-assets/js/.editorconfig +12 -0
  151. package/templates-experimental/hello-world-durable-object-with-assets/js/.prettierrc +6 -0
  152. package/templates-experimental/hello-world-durable-object-with-assets/js/__dot__gitignore +172 -0
  153. package/templates-experimental/hello-world-durable-object-with-assets/js/package.json +13 -0
  154. package/templates-experimental/hello-world-durable-object-with-assets/js/public/index.html +19 -0
  155. package/templates-experimental/hello-world-durable-object-with-assets/js/src/index.js +69 -0
  156. package/templates-experimental/hello-world-durable-object-with-assets/js/wrangler.json +28 -0
  157. package/templates-experimental/hello-world-durable-object-with-assets/ts/.editorconfig +12 -0
  158. package/templates-experimental/hello-world-durable-object-with-assets/ts/.prettierrc +6 -0
  159. package/templates-experimental/hello-world-durable-object-with-assets/ts/__dot__gitignore +172 -0
  160. package/templates-experimental/hello-world-durable-object-with-assets/ts/package.json +15 -0
  161. package/templates-experimental/hello-world-durable-object-with-assets/ts/public/index.html +19 -0
  162. package/templates-experimental/hello-world-durable-object-with-assets/ts/src/index.ts +66 -0
  163. package/templates-experimental/hello-world-durable-object-with-assets/ts/tsconfig.json +42 -0
  164. package/templates-experimental/hello-world-durable-object-with-assets/ts/worker-configuration.d.ts +5 -0
  165. package/templates-experimental/hello-world-durable-object-with-assets/ts/wrangler.json +28 -0
  166. package/templates-experimental/hello-world-with-assets/c3.ts +22 -0
  167. package/templates-experimental/hello-world-with-assets/js/.editorconfig +12 -0
  168. package/templates-experimental/hello-world-with-assets/js/.prettierrc +6 -0
  169. package/templates-experimental/hello-world-with-assets/js/__dot__gitignore +172 -0
  170. package/templates-experimental/hello-world-with-assets/js/package.json +16 -0
  171. package/templates-experimental/hello-world-with-assets/js/public/index.html +31 -0
  172. package/templates-experimental/hello-world-with-assets/js/src/index.js +23 -0
  173. package/templates-experimental/hello-world-with-assets/js/test/index.spec.js +41 -0
  174. package/templates-experimental/hello-world-with-assets/js/vitest.config.js +11 -0
  175. package/templates-experimental/hello-world-with-assets/js/wrangler.json +15 -0
  176. package/templates-experimental/hello-world-with-assets/py/__dot__gitignore +68 -0
  177. package/templates-experimental/hello-world-with-assets/py/package.json +13 -0
  178. package/templates-experimental/hello-world-with-assets/py/public/index.html +31 -0
  179. package/templates-experimental/hello-world-with-assets/py/src/entry.py +9 -0
  180. package/templates-experimental/hello-world-with-assets/py/wrangler.json +15 -0
  181. package/templates-experimental/hello-world-with-assets/ts/.editorconfig +12 -0
  182. package/templates-experimental/hello-world-with-assets/ts/.prettierrc +6 -0
  183. package/templates-experimental/hello-world-with-assets/ts/__dot__gitignore +172 -0
  184. package/templates-experimental/hello-world-with-assets/ts/package.json +18 -0
  185. package/templates-experimental/hello-world-with-assets/ts/public/index.html +31 -0
  186. package/templates-experimental/hello-world-with-assets/ts/src/index.ts +26 -0
  187. package/templates-experimental/hello-world-with-assets/ts/test/index.spec.ts +41 -0
  188. package/templates-experimental/hello-world-with-assets/ts/test/tsconfig.json +8 -0
  189. package/templates-experimental/hello-world-with-assets/ts/tsconfig.json +44 -0
  190. package/templates-experimental/hello-world-with-assets/ts/vitest.config.mts +11 -0
  191. package/templates-experimental/hello-world-with-assets/ts/worker-configuration.d.ts +4 -0
  192. package/templates-experimental/hello-world-with-assets/ts/wrangler.json +15 -0
  193. package/templates-experimental/hono/c3.ts +43 -0
  194. package/templates-experimental/hono/templates/public/index.html +19 -0
  195. package/templates-experimental/hono/templates/src/index.ts +9 -0
  196. package/templates-experimental/hono/templates/worker-configuration.d.ts +4 -0
  197. package/templates-experimental/hono/templates/wrangler.json +9 -0
  198. package/templates-experimental/next/c3.ts +59 -0
  199. package/templates-experimental/next/templates/.dev.vars +2 -0
  200. package/templates-experimental/next/templates/__dot__gitignore +39 -0
  201. package/templates-experimental/next/templates/cloudflare-env.d.ts +5 -0
  202. package/templates-experimental/next/templates/open-next.config.ts +28 -0
  203. package/templates-experimental/next/templates/wrangler.json +13 -0
  204. package/templates-experimental/nuxt/c3.ts +135 -0
  205. package/templates-experimental/nuxt/templates/env.d.ts +14 -0
  206. package/templates-experimental/nuxt/templates/worker-configuration.d.ts +4 -0
  207. package/templates-experimental/nuxt/templates/wrangler.json +12 -0
  208. package/templates-experimental/qwik/c3.ts +153 -0
  209. package/templates-experimental/qwik/snippets/getPlatformProxy.ts +6 -0
  210. package/templates-experimental/qwik/templates/public/.assetsignore +4 -0
  211. package/templates-experimental/qwik/templates/worker-configuration.d.ts +4 -0
  212. package/templates-experimental/qwik/templates/wrangler.json +15 -0
  213. package/templates-experimental/remix/c3.ts +52 -0
  214. package/templates-experimental/remix/templates/public/.assetsignore +0 -0
  215. package/templates-experimental/remix/templates/worker-configuration.d.ts +4 -0
  216. package/templates-experimental/remix/templates/wrangler.toml +11 -0
  217. package/templates-experimental/solid/c3.ts +94 -0
  218. package/templates-experimental/solid/templates/wrangler.json +15 -0
  219. package/templates-experimental/svelte/c3.ts +129 -0
  220. package/templates-experimental/svelte/templates/static/.assetsignore +4 -0
  221. package/templates-experimental/svelte/templates/wrangler.json +12 -0
  222. package/templates-experimental/vue/c3.ts +33 -0
  223. package/templates-experimental/vue/templates/wrangler.json +10 -0
  224. package/templates/angular/templates/server.ts +0 -34
  225. package/templates/angular/templates/tools/alter-polyfills.mjs +0 -27
  226. package/templates/angular/templates/tools/paths.mjs +0 -9
  227. package/templates/common/js/wrangler.toml +0 -51
  228. package/templates/common/ts/wrangler.toml +0 -51
  229. package/templates/hello-world/js/wrangler.toml +0 -51
  230. package/templates/hello-world/ts/wrangler.toml +0 -51
  231. package/templates/hello-world-durable-object/js/wrangler.toml +0 -51
  232. package/templates/hello-world-durable-object/ts/wrangler.toml +0 -51
  233. package/templates/next/templates.ts +0 -281
  234. package/templates/openapi/ts/wrangler.toml +0 -3
  235. package/templates/pre-existing/js/wrangler.toml +0 -3
  236. package/templates/queues/js/wrangler.toml +0 -19
  237. package/templates/queues/ts/wrangler.toml +0 -19
  238. package/templates/scheduled/js/wrangler.toml +0 -9
  239. package/templates/scheduled/ts/wrangler.toml +0 -9
  240. package/templates/solid/js/vite.config.js +0 -12
  241. package/templates/solid/ts/vite.config.ts +0 -12
  242. 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;
@@ -1,31 +1,23 @@
1
- import { existsSync, mkdirSync } from "fs";
2
- import { crash, updateStatus, warn } from "@cloudflare/cli";
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 { installPackages, runFrameworkGenerator } from "helpers/command";
4
+ import { inputPrompt, spinner } from "@cloudflare/cli/interactive";
5
+ import { runFrameworkGenerator } from "frameworks/index";
6
6
  import {
7
- compatDateFlag,
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/packages";
16
- import {
17
- apiAppDirHelloJs,
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 { C3Args, C3Context } from "types";
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 getApiTemplate = (
39
- apiPath: string,
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
- if (isAppDir) {
45
- // App directory uses route handlers that are defined in a subdirectory (`/api/hello/route.ts`).
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
- return isTypescript
50
- ? [`${routeHandlerPath}/route.ts`, apiAppDirHelloTs]
51
- : [`${routeHandlerPath}/route.js`, apiAppDirHelloJs];
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
- return isTypescript
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
- crash("Could not find the `/api` or `/app` directory");
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
- writeFile(`${projectPath}/env.d.ts`, envDts);
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
- writeFile(`${projectPath}/next.config.mjs`, nextConfig);
116
- updateStatus("Updated the next.config.js file");
92
+ updateNextConfig(usesTs);
117
93
 
118
- writeFile(`${projectPath}/README.md`, readme);
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) return false;
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 processArgument(ctx.args, "eslint-plugin" as keyof C3Args, {
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
- transformPackageJson: async () => {
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
- "pages:preview": `${pagesBuildRunCommand} && wrangler pages dev .vercel/output/static ${await compatDateFlag()} --compatibility-flag=nodejs_compat`,
198
- "pages:deploy": `${pagesBuildRunCommand} && wrangler pages deploy .vercel/output/static`,
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
- testFlags: [
203
- "--typescript",
204
- "--no-install",
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,5 @@
1
+ // Generated by Wrangler
2
+ // by running `wrangler types --env-interface CloudflareEnv env.d.ts`
3
+
4
+ interface CloudflareEnv {
5
+ }
@@ -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
+ }
@@ -0,0 +1,8 @@
1
+ {
2
+ "name": "<TBD>",
3
+ "compatibility_date": "<TBD>",
4
+ "compatibility_flags": [
5
+ "nodejs_compat"
6
+ ],
7
+ "pages_build_output_dir": ".vercel/output/static"
8
+ }
@@ -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 "helpers/command";
7
- import { compatDateFlag, writeFile } from "helpers/files";
8
- import { detectPackageManager } from "helpers/packages";
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", "17");
27
+ writeFile("./.node-version", "18");
26
28
 
27
29
  logRaw(""); // newline
28
30
  };
29
31
 
30
- const configure = async () => {
31
- const configFileName = "nuxt.config.ts";
32
- const configFilePath = resolve(configFileName);
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
- s.start(`Updating \`${configFileName}\``);
35
- // Add the cloudflare preset into the configuration file.
36
- const originalConfigFile = readFileSync(configFilePath, "utf8");
37
- const updatedConfigFile = originalConfigFile.replace(
38
- "defineNuxtConfig({",
39
- "defineNuxtConfig({\n nitro: {\n preset: 'cloudflare-pages'\n },"
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
- writeFile(configFilePath, updatedConfigFile);
42
- s.stop(`${brandColor(`updated`)} ${dim(`\`${configFileName}\``)}`);
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
- "pages:dev": `wrangler pages dev ${await compatDateFlag()} --proxy 3000 -- ${npm} run dev`,
55
- "pages:deploy": `${npm} run build && wrangler pages deploy ./dist`,
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;
@@ -0,0 +1,14 @@
1
+ /// <reference types="WORKERS_TYPES_ENTRYPOINT" />
2
+
3
+ declare module "h3" {
4
+ interface H3EventContext {
5
+ cf: CfProperties;
6
+ cloudflare: {
7
+ request: Request;
8
+ env: Env;
9
+ context: ExecutionContext;
10
+ };
11
+ }
12
+ }
13
+
14
+ export {};
@@ -0,0 +1,4 @@
1
+ // Generated by Wrangler
2
+ // After adding bindings to `wrangler.json`, regenerate this interface via `npm run cf-typegen`
3
+ interface Env {
4
+ }
@@ -0,0 +1,8 @@
1
+ {
2
+ "name": "<TBD>",
3
+ "compatibility_date": "<TBD>",
4
+ "compatibility_flags": [
5
+ "nodejs_compat"
6
+ ],
7
+ "pages_build_output_dir": "./dist"
8
+ }
@@ -2,6 +2,7 @@ export default {
2
2
  configVersion: 1,
3
3
  id: "openapi",
4
4
  displayName: "API starter (OpenAPI compliant)",
5
+ description: "Get started building a basic API on Workers",
5
6
  platform: "workers",
6
7
  copyFiles: {
7
8
  path: "./ts",
@@ -1,6 +1,6 @@
1
1
  # Cloudflare Workers OpenAPI 3.1
2
2
 
3
- This is a Cloudflare Worker with OpenAPI 3.1 using [itty-router-openapi](https://github.com/cloudflare/itty-router-openapi).
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 [itty-router-openapi official documentation](https://cloudflare.github.io/itty-router-openapi/).
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:9000/` in your browser to see the Swagger interface where you can try the endpoints.
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.