create-cloudflare 0.0.0-e6ada079 → 0.0.0-e6fea1318

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 (269) hide show
  1. package/README.md +1 -1
  2. package/dist/cli.js +42462 -40996
  3. package/dist/tsconfig.tsbuildinfo +1 -1
  4. package/package.json +21 -12
  5. package/templates/analog/c3.ts +1 -0
  6. package/templates/analog/templates/worker-configuration.d.ts +1 -1
  7. package/templates/analog/templates/wrangler.jsonc +5 -0
  8. package/templates/angular/c3.ts +5 -97
  9. package/templates/angular/pages/c3.ts +134 -0
  10. package/templates/angular/pages/templates/src/server.ts +15 -0
  11. package/templates/angular/pages/templates/tools/copy-files.mjs +15 -0
  12. package/templates/angular/workers/c3.ts +130 -0
  13. package/templates/angular/workers/templates/src/server.ts +15 -0
  14. package/templates/angular/workers/templates/wrangler.jsonc +12 -0
  15. package/templates/astro/c3.ts +5 -108
  16. package/templates/astro/pages/c3.ts +98 -0
  17. package/templates/astro/pages/templates/js/wrangler.jsonc +8 -0
  18. package/templates/astro/pages/templates/ts/worker-configuration.d.ts +4 -0
  19. package/templates/astro/pages/templates/ts/wrangler.jsonc +8 -0
  20. package/templates/astro/workers/c3.ts +98 -0
  21. package/templates/astro/workers/templates/js/public/.assetsignore +2 -0
  22. package/templates/astro/workers/templates/js/wrangler.jsonc +15 -0
  23. package/templates/astro/workers/templates/ts/public/.assetsignore +2 -0
  24. package/templates/astro/workers/templates/ts/src/env.d.ts +5 -0
  25. package/templates/astro/workers/templates/ts/worker-configuration.d.ts +4 -0
  26. package/templates/astro/workers/templates/ts/wrangler.jsonc +15 -0
  27. package/templates/common/c3.ts +8 -1
  28. package/templates/common/js/package.json +1 -1
  29. package/templates/common/js/wrangler.jsonc +8 -0
  30. package/templates/common/ts/package.json +1 -1
  31. package/templates/common/ts/src/index.ts +1 -1
  32. package/templates/common/ts/tsconfig.json +37 -95
  33. package/templates/common/ts/worker-configuration.d.ts +1 -1
  34. package/templates/common/ts/wrangler.jsonc +8 -0
  35. package/templates/docusaurus/c3.ts +5 -22
  36. package/templates/docusaurus/pages/c3.ts +30 -0
  37. package/templates/docusaurus/workers/c3.ts +33 -0
  38. package/templates/docusaurus/workers/templates/wrangler.jsonc +10 -0
  39. package/templates/gatsby/c3.ts +5 -44
  40. package/templates/gatsby/pages/c3.ts +50 -0
  41. package/templates/gatsby/workers/c3.ts +53 -0
  42. package/templates/gatsby/workers/templates/wrangler.jsonc +10 -0
  43. package/templates/hello-world/c3.ts +23 -2
  44. package/templates/hello-world/js/package.json +3 -3
  45. package/templates/hello-world/js/test/index.spec.js +1 -1
  46. package/templates/hello-world/js/vitest.config.js +1 -1
  47. package/templates/hello-world/js/wrangler.jsonc +8 -0
  48. package/templates/hello-world/py/.python-version +1 -0
  49. package/templates/hello-world/py/README.md +23 -0
  50. package/templates/hello-world/py/__dot__gitignore +68 -0
  51. package/templates/hello-world/py/package.json +13 -0
  52. package/templates/hello-world/py/pyproject.toml +9 -0
  53. package/templates/hello-world/py/uv.lock +22 -0
  54. package/templates/hello-world/py/wrangler.jsonc +9 -0
  55. package/templates/hello-world/ts/package.json +3 -3
  56. package/templates/hello-world/ts/src/index.ts +1 -1
  57. package/templates/hello-world/ts/test/env.d.ts +3 -0
  58. package/templates/hello-world/ts/test/tsconfig.json +1 -1
  59. package/templates/hello-world/ts/tsconfig.json +36 -95
  60. package/templates/hello-world/ts/vitest.config.mts +1 -1
  61. package/templates/hello-world/ts/worker-configuration.d.ts +7 -3
  62. package/templates/hello-world/ts/wrangler.jsonc +8 -0
  63. package/templates/hello-world-assets-only/c3.ts +16 -0
  64. package/templates/{hello-world-python/py → hello-world-assets-only/templates}/package.json +1 -1
  65. package/templates/hello-world-assets-only/templates/public/index.html +11 -0
  66. package/templates/hello-world-assets-only/templates/wrangler.jsonc +10 -0
  67. package/templates/hello-world-durable-object/c3.ts +7 -2
  68. package/templates/hello-world-durable-object/js/package.json +1 -1
  69. package/templates/hello-world-durable-object/js/src/index.js +13 -12
  70. package/templates/hello-world-durable-object/js/wrangler.jsonc +24 -0
  71. package/templates/hello-world-durable-object/ts/package.json +1 -1
  72. package/templates/hello-world-durable-object/ts/src/index.ts +14 -34
  73. package/templates/hello-world-durable-object/ts/tsconfig.json +36 -95
  74. package/templates/hello-world-durable-object/ts/worker-configuration.d.ts +6 -5
  75. package/templates/hello-world-durable-object/ts/wrangler.jsonc +24 -0
  76. package/templates/hello-world-durable-object-with-assets/c3.ts +23 -0
  77. package/templates/hello-world-durable-object-with-assets/js/.editorconfig +12 -0
  78. package/templates/hello-world-durable-object-with-assets/js/.prettierrc +6 -0
  79. package/templates/hello-world-durable-object-with-assets/js/__dot__gitignore +172 -0
  80. package/templates/hello-world-durable-object-with-assets/js/package.json +13 -0
  81. package/templates/hello-world-durable-object-with-assets/js/public/index.html +19 -0
  82. package/templates/hello-world-durable-object-with-assets/js/src/index.js +70 -0
  83. package/templates/hello-world-durable-object-with-assets/js/wrangler.jsonc +28 -0
  84. package/templates/hello-world-durable-object-with-assets/ts/.editorconfig +12 -0
  85. package/templates/hello-world-durable-object-with-assets/ts/.prettierrc +6 -0
  86. package/templates/hello-world-durable-object-with-assets/ts/__dot__gitignore +172 -0
  87. package/templates/hello-world-durable-object-with-assets/ts/package.json +15 -0
  88. package/templates/hello-world-durable-object-with-assets/ts/public/index.html +19 -0
  89. package/templates/hello-world-durable-object-with-assets/ts/src/index.ts +67 -0
  90. package/templates/hello-world-durable-object-with-assets/ts/tsconfig.json +42 -0
  91. package/templates/hello-world-durable-object-with-assets/ts/worker-configuration.d.ts +8 -0
  92. package/templates/hello-world-durable-object-with-assets/ts/wrangler.jsonc +28 -0
  93. package/templates/hello-world-with-assets/c3.ts +24 -0
  94. package/templates/hello-world-with-assets/js/.editorconfig +12 -0
  95. package/templates/hello-world-with-assets/js/.prettierrc +6 -0
  96. package/templates/hello-world-with-assets/js/__dot__gitignore +172 -0
  97. package/templates/hello-world-with-assets/js/package.json +16 -0
  98. package/templates/hello-world-with-assets/js/public/index.html +31 -0
  99. package/templates/hello-world-with-assets/js/src/index.js +23 -0
  100. package/templates/hello-world-with-assets/js/test/index.spec.js +41 -0
  101. package/templates/hello-world-with-assets/js/vitest.config.js +11 -0
  102. package/templates/hello-world-with-assets/js/wrangler.jsonc +15 -0
  103. package/templates/hello-world-with-assets/py/package.json +13 -0
  104. package/templates/hello-world-with-assets/py/public/index.html +31 -0
  105. package/templates/hello-world-with-assets/py/src/entry.py +9 -0
  106. package/templates/hello-world-with-assets/py/wrangler.jsonc +15 -0
  107. package/templates/hello-world-with-assets/ts/.editorconfig +12 -0
  108. package/templates/hello-world-with-assets/ts/.prettierrc +6 -0
  109. package/templates/hello-world-with-assets/ts/__dot__gitignore +172 -0
  110. package/templates/hello-world-with-assets/ts/package.json +18 -0
  111. package/templates/hello-world-with-assets/ts/public/index.html +31 -0
  112. package/templates/hello-world-with-assets/ts/src/index.ts +26 -0
  113. package/templates/hello-world-with-assets/ts/test/env.d.ts +3 -0
  114. package/templates/hello-world-with-assets/ts/test/index.spec.ts +41 -0
  115. package/templates/hello-world-with-assets/ts/test/tsconfig.json +8 -0
  116. package/templates/hello-world-with-assets/ts/tsconfig.json +44 -0
  117. package/templates/hello-world-with-assets/ts/vitest.config.mts +11 -0
  118. package/templates/hello-world-with-assets/ts/worker-configuration.d.ts +7 -0
  119. package/templates/hello-world-with-assets/ts/wrangler.jsonc +15 -0
  120. package/templates/hono/c3.ts +5 -74
  121. package/templates/hono/pages/c3.ts +42 -0
  122. package/templates/hono/pages/templates/src/index.tsx +12 -0
  123. package/templates/hono/pages/templates/worker-configuration.d.ts +4 -0
  124. package/templates/hono/pages/templates/wrangler.jsonc +9 -0
  125. package/templates/hono/workers/c3.ts +42 -0
  126. package/templates/hono/workers/templates/public/index.html +19 -0
  127. package/templates/hono/workers/templates/src/index.ts +9 -0
  128. package/templates/hono/workers/templates/worker-configuration.d.ts +4 -0
  129. package/templates/hono/workers/templates/wrangler.jsonc +9 -0
  130. package/templates/next/README.md +3 -4
  131. package/templates/next/app/js/app/api/hello/route.js +4 -4
  132. package/templates/next/app/ts/app/api/hello/route.ts +4 -5
  133. package/templates/next/c3.ts +22 -37
  134. package/templates/next/wrangler.jsonc +8 -0
  135. package/templates/nuxt/c3.ts +5 -129
  136. package/templates/nuxt/pages/c3.ts +146 -0
  137. package/templates/nuxt/pages/templates/worker-configuration.d.ts +4 -0
  138. package/templates/nuxt/pages/templates/wrangler.jsonc +5 -0
  139. package/templates/nuxt/workers/c3.ts +146 -0
  140. package/templates/nuxt/workers/templates/env.d.ts +14 -0
  141. package/templates/nuxt/workers/templates/worker-configuration.d.ts +4 -0
  142. package/templates/nuxt/workers/templates/wrangler.jsonc +12 -0
  143. package/templates/openapi/c3.ts +6 -1
  144. package/templates/openapi/ts/package.json +1 -1
  145. package/templates/openapi/ts/worker-configuration.d.ts +1 -1
  146. package/templates/openapi/ts/wrangler.jsonc +8 -0
  147. package/templates/pre-existing/c3.ts +36 -13
  148. package/templates/pre-existing/js/package.json +1 -1
  149. package/templates/queues/c3.ts +7 -1
  150. package/templates/queues/js/package.json +1 -1
  151. package/templates/queues/js/wrangler.jsonc +21 -0
  152. package/templates/queues/ts/package.json +1 -1
  153. package/templates/queues/ts/src/index.ts +1 -1
  154. package/templates/queues/ts/tsconfig.json +36 -95
  155. package/templates/queues/ts/worker-configuration.d.ts +1 -1
  156. package/templates/queues/ts/wrangler.jsonc +21 -0
  157. package/templates/qwik/c3.ts +5 -142
  158. package/templates/qwik/pages/c3.ts +149 -0
  159. package/templates/qwik/pages/templates/worker-configuration.d.ts +4 -0
  160. package/templates/qwik/pages/templates/wrangler.jsonc +8 -0
  161. package/templates/qwik/workers/c3.ts +154 -0
  162. package/templates/qwik/workers/snippets/getPlatformProxy.ts +6 -0
  163. package/templates/qwik/workers/templates/public/.assetsignore +4 -0
  164. package/templates/qwik/workers/templates/worker-configuration.d.ts +4 -0
  165. package/templates/qwik/workers/templates/wrangler.jsonc +15 -0
  166. package/templates/react/c3.ts +5 -27
  167. package/templates/react/pages/c3.ts +62 -0
  168. package/templates/react/workers/c3.ts +183 -0
  169. package/templates/react/workers/js/api/index.js +13 -0
  170. package/templates/react/workers/js/src/App.css +45 -0
  171. package/templates/react/workers/js/src/App.jsx +58 -0
  172. package/templates/react/workers/js/src/assets/Cloudflare_Logo.svg +53 -0
  173. package/templates/react/workers/js/wrangler.jsonc +9 -0
  174. package/templates/react/workers/ts/api/index.ts +13 -0
  175. package/templates/react/workers/ts/src/App.css +45 -0
  176. package/templates/react/workers/ts/src/App.tsx +58 -0
  177. package/templates/react/workers/ts/src/assets/Cloudflare_Logo.svg +51 -0
  178. package/templates/react/workers/ts/tsconfig.worker.json +8 -0
  179. package/templates/react/workers/ts/worker-configuration.d.ts +5 -0
  180. package/templates/react/workers/ts/wrangler.jsonc +9 -0
  181. package/templates/react-router/c3.ts +53 -0
  182. package/templates/react-router/templates/worker-configuration.d.ts +8 -0
  183. package/templates/remix/c3.ts +6 -62
  184. package/templates/remix/pages/c3.ts +68 -0
  185. package/templates/remix/pages/templates/worker-configuration.d.ts +4 -0
  186. package/templates/remix/pages/templates/wrangler.jsonc +5 -0
  187. package/templates/remix/workers/c3.ts +52 -0
  188. package/templates/remix/workers/templates/public/.assetsignore +0 -0
  189. package/templates/remix/workers/templates/wrangler.toml +11 -0
  190. package/templates/scheduled/c3.ts +7 -1
  191. package/templates/scheduled/js/package.json +1 -1
  192. package/templates/scheduled/js/src/index.js +1 -1
  193. package/templates/scheduled/js/wrangler.jsonc +13 -0
  194. package/templates/scheduled/ts/package.json +1 -1
  195. package/templates/scheduled/ts/src/index.ts +4 -4
  196. package/templates/scheduled/ts/tsconfig.json +36 -95
  197. package/templates/scheduled/ts/worker-configuration.d.ts +1 -1
  198. package/templates/scheduled/ts/wrangler.jsonc +13 -0
  199. package/templates/solid/c3.ts +2 -1
  200. package/templates/solid/templates/wrangler.jsonc +8 -0
  201. package/templates/svelte/c3.ts +6 -127
  202. package/templates/svelte/pages/c3.ts +159 -0
  203. package/templates/svelte/pages/templates/wrangler.jsonc +5 -0
  204. package/templates/svelte/workers/c3.ts +129 -0
  205. package/templates/svelte/workers/templates/static/.assetsignore +2 -0
  206. package/templates/svelte/workers/templates/wrangler.jsonc +12 -0
  207. package/templates/vue/c3.ts +5 -24
  208. package/templates/vue/pages/c3.ts +30 -0
  209. package/templates/vue/workers/c3.ts +98 -0
  210. package/templates/vue/workers/js/server/index.js +13 -0
  211. package/templates/vue/workers/js/src/App.vue +107 -0
  212. package/templates/vue/workers/js/src/components/HelloWorld.vue +47 -0
  213. package/templates/vue/workers/js/vite.config.js +21 -0
  214. package/templates/vue/workers/js/wrangler.jsonc +12 -0
  215. package/templates/vue/workers/ts/server/index.ts +13 -0
  216. package/templates/vue/workers/ts/src/App.vue +107 -0
  217. package/templates/vue/workers/ts/src/components/HelloWorld.vue +44 -0
  218. package/templates/vue/workers/ts/tsconfig.worker.json +8 -0
  219. package/templates/vue/workers/ts/vite.config.ts +21 -0
  220. package/templates/vue/workers/ts/worker-configuration.d.ts +6 -0
  221. package/templates/vue/workers/ts/wrangler.jsonc +12 -0
  222. package/templates-experimental/next/c3.ts +75 -0
  223. package/templates-experimental/next/templates/.dev.vars +2 -0
  224. package/templates-experimental/next/templates/__dot__gitignore +39 -0
  225. package/templates-experimental/next/templates/cloudflare-env.d.ts +5 -0
  226. package/templates-experimental/next/templates/open-next.config.ts +6 -0
  227. package/templates-experimental/next/templates/wrangler.jsonc +12 -0
  228. package/templates-experimental/solid/c3.ts +94 -0
  229. package/templates-experimental/solid/templates/wrangler.jsonc +15 -0
  230. package/templates/analog/templates/wrangler.toml +0 -85
  231. package/templates/angular/templates/server.ts +0 -34
  232. package/templates/angular/templates/tools/alter-polyfills.mjs +0 -27
  233. package/templates/angular/templates/tools/copy-files.mjs +0 -9
  234. package/templates/angular/templates/tools/paths.mjs +0 -9
  235. package/templates/astro/templates/wrangler.toml +0 -85
  236. package/templates/common/js/wrangler.toml +0 -107
  237. package/templates/common/ts/wrangler.toml +0 -107
  238. package/templates/hello-world/js/wrangler.toml +0 -108
  239. package/templates/hello-world/ts/wrangler.toml +0 -108
  240. package/templates/hello-world-durable-object/js/wrangler.toml +0 -107
  241. package/templates/hello-world-durable-object/ts/wrangler.toml +0 -107
  242. package/templates/hello-world-python/c3.ts +0 -9
  243. package/templates/hello-world-python/py/wrangler.toml +0 -108
  244. package/templates/hono/snippets/appDeclaration.ts +0 -1
  245. package/templates/hono/snippets/bindingsType.ts +0 -3
  246. package/templates/hono/templates/worker-configuration.d.ts +0 -4
  247. package/templates/hono/templates/wrangler.toml +0 -107
  248. package/templates/next/wrangler.toml +0 -86
  249. package/templates/nuxt/templates/wrangler.toml +0 -85
  250. package/templates/openapi/ts/wrangler.toml +0 -107
  251. package/templates/pre-existing/js/wrangler.toml +0 -4
  252. package/templates/queues/js/wrangler.toml +0 -112
  253. package/templates/queues/ts/wrangler.toml +0 -112
  254. package/templates/qwik/templates/worker-configuration.d.ts +0 -4
  255. package/templates/qwik/templates/wrangler.toml +0 -85
  256. package/templates/remix/templates/worker-configuration.d.ts +0 -4
  257. package/templates/remix/templates/wrangler.toml +0 -85
  258. package/templates/scheduled/js/wrangler.toml +0 -113
  259. package/templates/scheduled/ts/wrangler.toml +0 -113
  260. package/templates/solid/templates/wrangler.toml +0 -84
  261. package/templates/svelte/js/wrangler.toml +0 -85
  262. package/templates/svelte/ts/wrangler.toml +0 -85
  263. /package/templates/angular/{templates → pages/templates}/src/_routes.json +0 -0
  264. /package/templates/astro/{snippets/runtimeDeclaration.ts → pages/templates/ts/src/env.d.ts} +0 -0
  265. /package/templates/{hello-world-python → hello-world}/py/src/entry.py +0 -0
  266. /package/templates/{hello-world-python → hello-world-with-assets}/py/__dot__gitignore +0 -0
  267. /package/templates/nuxt/{templates → pages/templates}/env.d.ts +0 -0
  268. /package/templates/qwik/{snippets → pages/snippets}/getPlatformProxy.ts +0 -0
  269. /package/templates/{nuxt → remix/workers}/templates/worker-configuration.d.ts +0 -0
@@ -0,0 +1,41 @@
1
+ import { env, createExecutionContext, waitOnExecutionContext, SELF } from 'cloudflare:test';
2
+ import { describe, it, expect } from 'vitest';
3
+ import worker from '../src';
4
+
5
+ describe('Hello World user worker', () => {
6
+ describe('request for /message', () => {
7
+ it('/ responds with "Hello, World!" (unit style)', async () => {
8
+ const request = new Request<unknown, IncomingRequestCfProperties>('http://example.com/message');
9
+ // Create an empty context to pass to `worker.fetch()`.
10
+ const ctx = createExecutionContext();
11
+ const response = await worker.fetch(request, env, ctx);
12
+ // Wait for all `Promise`s passed to `ctx.waitUntil()` to settle before running test assertions
13
+ await waitOnExecutionContext(ctx);
14
+ expect(await response.text()).toMatchInlineSnapshot(`"Hello, World!"`);
15
+ });
16
+
17
+ it('responds with "Hello, World!" (integration style)', async () => {
18
+ const request = new Request('http://example.com/message');
19
+ const response = await SELF.fetch(request);
20
+ expect(await response.text()).toMatchInlineSnapshot(`"Hello, World!"`);
21
+ });
22
+ });
23
+
24
+ describe('request for /random', () => {
25
+ it('/ responds with a random UUID (unit style)', async () => {
26
+ const request = new Request<unknown, IncomingRequestCfProperties>('http://example.com/random');
27
+ // Create an empty context to pass to `worker.fetch()`.
28
+ const ctx = createExecutionContext();
29
+ const response = await worker.fetch(request, env, ctx);
30
+ // Wait for all `Promise`s passed to `ctx.waitUntil()` to settle before running test assertions
31
+ await waitOnExecutionContext(ctx);
32
+ expect(await response.text()).toMatch(/[a-f0-9]{8}-[a-f0-9]{4}-[a-f0-9]{4}-[a-f0-9]{4}-[a-f0-9]{12}/);
33
+ });
34
+
35
+ it('responds with a random UUID (integration style)', async () => {
36
+ const request = new Request('http://example.com/random');
37
+ const response = await SELF.fetch(request);
38
+ expect(await response.text()).toMatch(/[a-f0-9]{8}-[a-f0-9]{4}-[a-f0-9]{4}-[a-f0-9]{4}-[a-f0-9]{12}/);
39
+ });
40
+ });
41
+ });
@@ -0,0 +1,8 @@
1
+ {
2
+ "extends": "../tsconfig.json",
3
+ "compilerOptions": {
4
+ "types": ["@cloudflare/workers-types/experimental", "@cloudflare/vitest-pool-workers"]
5
+ },
6
+ "include": ["./**/*.ts", "../worker-configuration.d.ts"],
7
+ "exclude": []
8
+ }
@@ -0,0 +1,44 @@
1
+ {
2
+ "compilerOptions": {
3
+ /* Visit https://aka.ms/tsconfig.json to read more about this file */
4
+
5
+ /* Set the JavaScript language version for emitted JavaScript and include compatible library declarations. */
6
+ "target": "es2021",
7
+ /* Specify a set of bundled library declaration files that describe the target runtime environment. */
8
+ "lib": ["es2021"],
9
+ /* Specify what JSX code is generated. */
10
+ "jsx": "react-jsx",
11
+
12
+ /* Specify what module code is generated. */
13
+ "module": "es2022",
14
+ /* Specify how TypeScript looks up a file from a given module specifier. */
15
+ "moduleResolution": "Bundler",
16
+ /* Specify type package names to be included without being referenced in a source file. */
17
+ "types": ["@cloudflare/workers-types"],
18
+ /* Enable importing .json files */
19
+ "resolveJsonModule": true,
20
+
21
+ /* Allow JavaScript files to be a part of your program. Use the `checkJS` option to get errors from these files. */
22
+ "allowJs": true,
23
+ /* Enable error reporting in type-checked JavaScript files. */
24
+ "checkJs": false,
25
+
26
+ /* Disable emitting files from a compilation. */
27
+ "noEmit": true,
28
+
29
+ /* Ensure that each file can be safely transpiled without relying on other imports. */
30
+ "isolatedModules": true,
31
+ /* Allow 'import x from y' when a module doesn't have a default export. */
32
+ "allowSyntheticDefaultImports": true,
33
+ /* Ensure that casing is correct in imports. */
34
+ "forceConsistentCasingInFileNames": true,
35
+
36
+ /* Enable all strict type-checking options. */
37
+ "strict": true,
38
+
39
+ /* Skip type checking all .d.ts files. */
40
+ "skipLibCheck": true
41
+ },
42
+ "exclude": ["test"],
43
+ "include": ["worker-configuration.d.ts", "src/**/*.ts"]
44
+ }
@@ -0,0 +1,11 @@
1
+ import { defineWorkersConfig } from '@cloudflare/vitest-pool-workers/config';
2
+
3
+ export default defineWorkersConfig({
4
+ test: {
5
+ poolOptions: {
6
+ workers: {
7
+ wrangler: { configPath: './wrangler.jsonc' },
8
+ },
9
+ },
10
+ },
11
+ });
@@ -0,0 +1,7 @@
1
+ // Generated by Wrangler by running `wrangler types --include-runtime=false` (hash: 187132f48ddf0f604882ba8213fe386f)
2
+ declare namespace Cloudflare {
3
+ interface Env {
4
+ ASSETS: Fetcher;
5
+ }
6
+ }
7
+ interface Env extends Cloudflare.Env {}
@@ -0,0 +1,15 @@
1
+ {
2
+ "name": "<TBD>",
3
+ "main": "src/index.ts",
4
+ "compatibility_date": "<TBD>",
5
+ "compatibility_flags": [
6
+ "nodejs_compat"
7
+ ],
8
+ "assets": {
9
+ "binding": "ASSETS",
10
+ "directory": "./public"
11
+ },
12
+ "observability": {
13
+ "enabled": true
14
+ }
15
+ }
@@ -1,78 +1,9 @@
1
- import { logRaw } from "@cloudflare/cli";
2
- import { brandColor, dim } from "@cloudflare/cli/colors";
3
- import { spinner } from "@cloudflare/cli/interactive";
4
- import { runFrameworkGenerator } from "frameworks/index";
5
- import { loadTemplateSnippets, transformFile } from "helpers/codemod";
6
- import { detectPackageManager } from "helpers/packageManagers";
7
- import type { TemplateConfig } from "../../src/templates";
8
- import type * as recast from "recast";
9
- import type { C3Context } from "types";
1
+ import pages from "./pages/c3";
2
+ import workers from "./workers/c3";
3
+ import type { MultiPlatformTemplateConfig } from "../../src/templates";
10
4
 
11
- const generate = async (ctx: C3Context) => {
12
- const { name: pm } = detectPackageManager();
13
-
14
- await runFrameworkGenerator(ctx, [
15
- ctx.project.name,
16
- "--template",
17
- "cloudflare-workers",
18
- "--install",
19
- "--pm",
20
- pm,
21
- ]);
22
-
23
- logRaw(""); // newline
24
- };
25
-
26
- const configure = async (ctx: C3Context) => {
27
- const indexFile = "src/index.ts";
28
-
29
- const s = spinner();
30
- s.start(`Updating \`${indexFile}\``);
31
-
32
- const snippets = loadTemplateSnippets(ctx);
33
-
34
- transformFile(indexFile, {
35
- // Insert the env declaration after the last import (but before the rest of the body)
36
- visitProgram: function (n) {
37
- const lastImportIndex = n.node.body.findLastIndex(
38
- (t) => t.type === "ImportDeclaration",
39
- );
40
- const lastImport = n.get("body", lastImportIndex);
41
- lastImport.insertAfter(...snippets.bindingsTypeTs);
42
-
43
- return this.traverse(n);
44
- },
45
- visitVariableDeclarator(n) {
46
- if (n.node.id.type === "Identifier" && n.node.id.name === "app") {
47
- n.node.init = snippets
48
- .appDeclarationTs[0] as recast.types.namedTypes.NewExpression;
49
-
50
- return false;
51
- }
52
- },
53
- });
54
-
55
- s.stop(`${brandColor("updated")} \`${dim(indexFile)}\``);
56
- };
57
-
58
- const config: TemplateConfig = {
59
- configVersion: 1,
60
- id: "hono",
5
+ const config: MultiPlatformTemplateConfig = {
61
6
  displayName: "Hono",
62
- copyFiles: {
63
- path: "./templates",
64
- },
65
- platform: "workers",
66
- generate,
67
- configure,
68
- transformPackageJson: async () => ({
69
- scripts: {
70
- dev: "wrangler dev",
71
- deploy: "wrangler deploy --minify",
72
- "cf-typegen": "wrangler types --env-interface CloudflareBindings",
73
- },
74
- }),
75
- devScript: "dev",
76
- deployScript: "deploy",
7
+ platformVariants: { pages, workers },
77
8
  };
78
9
  export default config;
@@ -0,0 +1,42 @@
1
+ import { logRaw } from "@cloudflare/cli";
2
+ import { runFrameworkGenerator } from "frameworks/index";
3
+ import { detectPackageManager } from "helpers/packageManagers";
4
+ import type { TemplateConfig } from "../../../src/templates";
5
+ import type { C3Context } from "types";
6
+
7
+ const generate = async (ctx: C3Context) => {
8
+ const { name: pm } = detectPackageManager();
9
+
10
+ await runFrameworkGenerator(ctx, [
11
+ ctx.project.name,
12
+ "--template",
13
+ "cloudflare-pages",
14
+ "--install",
15
+ "--pm",
16
+ pm,
17
+ ]);
18
+
19
+ logRaw(""); // newline
20
+ };
21
+
22
+ const config: TemplateConfig = {
23
+ configVersion: 1,
24
+ id: "hono",
25
+ frameworkCli: "create-hono",
26
+ displayName: "Hono",
27
+ copyFiles: {
28
+ path: "./templates",
29
+ },
30
+ path: "templates/hono/pages",
31
+ platform: "pages",
32
+ generate,
33
+ transformPackageJson: async () => ({
34
+ scripts: {
35
+ "cf-typegen": "wrangler types --env-interface CloudflareBindings",
36
+ },
37
+ }),
38
+ devScript: "dev",
39
+ deployScript: "deploy",
40
+ previewScript: "dev",
41
+ };
42
+ export default config;
@@ -0,0 +1,12 @@
1
+ import { Hono } from 'hono'
2
+ import { renderer } from './renderer'
3
+
4
+ const app = new Hono<{ Bindings: CloudflareBindings }>();
5
+
6
+ app.use(renderer)
7
+
8
+ app.get('/', (c) => {
9
+ return c.render(<h1>Hello!</h1>)
10
+ })
11
+
12
+ export default app
@@ -0,0 +1,4 @@
1
+ // Generated by Wrangler
2
+ // After adding bindings to `wrangler.jsonc`, regenerate this interface via `npm run cf-typegen`
3
+ interface CloudflareBindings {
4
+ }
@@ -0,0 +1,9 @@
1
+ {
2
+ "name": "<TBD>",
3
+ "main": "src/index.ts",
4
+ "compatibility_date": "<TBD>",
5
+ "pages_build_output_dir": "./dist",
6
+ "observability": {
7
+ "enabled": true
8
+ }
9
+ }
@@ -0,0 +1,42 @@
1
+ import { logRaw } from "@cloudflare/cli";
2
+ import { runFrameworkGenerator } from "frameworks/index";
3
+ import { detectPackageManager } from "helpers/packageManagers";
4
+ import type { TemplateConfig } from "../../../src/templates";
5
+ import type { C3Context } from "types";
6
+
7
+ const generate = async (ctx: C3Context) => {
8
+ const { name: pm } = detectPackageManager();
9
+
10
+ await runFrameworkGenerator(ctx, [
11
+ ctx.project.name,
12
+ "--template",
13
+ "cloudflare-workers",
14
+ "--install",
15
+ "--pm",
16
+ pm,
17
+ ]);
18
+
19
+ logRaw(""); // newline
20
+ };
21
+
22
+ const config: TemplateConfig = {
23
+ configVersion: 1,
24
+ id: "hono",
25
+ frameworkCli: "create-hono",
26
+ displayName: "Hono",
27
+ copyFiles: {
28
+ path: "./templates",
29
+ },
30
+ platform: "workers",
31
+ path: "templates/hono/workers",
32
+ generate,
33
+ transformPackageJson: async () => ({
34
+ scripts: {
35
+ "cf-typegen": "wrangler types --env-interface CloudflareBindings",
36
+ },
37
+ }),
38
+ devScript: "dev",
39
+ deployScript: "deploy",
40
+ previewScript: "dev",
41
+ };
42
+ export default config;
@@ -0,0 +1,19 @@
1
+ <!doctype html>
2
+ <html lang="en">
3
+ <head>
4
+ <meta charset="UTF-8" />
5
+ <meta name="viewport" content="width=device-width, initial-scale=1.0" />
6
+ <title>Hello, World!</title>
7
+ </head>
8
+ <body>
9
+ <h1 id="heading"></h1>
10
+ <script>
11
+ fetch('/message')
12
+ .then((resp) => resp.text())
13
+ .then((text) => {
14
+ const h1 = document.getElementById('heading');
15
+ h1.textContent = text;
16
+ });
17
+ </script>
18
+ </body>
19
+ </html>
@@ -0,0 +1,9 @@
1
+ import { Hono } from "hono";
2
+
3
+ const app = new Hono<{ Bindings: CloudflareBindings }>();
4
+
5
+ app.get("/message", (c) => {
6
+ return c.text("Hello Hono!");
7
+ });
8
+
9
+ export default app;
@@ -0,0 +1,4 @@
1
+ // Generated by Wrangler
2
+ // After adding bindings to `wrangler.jsonc`, regenerate this interface via `npm run cf-typegen`
3
+ interface CloudflareBindings {
4
+ }
@@ -0,0 +1,9 @@
1
+ {
2
+ "name": "<TBD>",
3
+ "main": "src/index.ts",
4
+ "compatibility_date": "<TBD>",
5
+ "assets": {
6
+ "binding": "ASSETS",
7
+ "directory": "./public"
8
+ }
9
+ }
@@ -46,11 +46,10 @@ In order to enable the example:
46
46
  ```ts
47
47
  // KV Example:
48
48
  ```
49
- and uncomment the commented lines below it.
50
- - Do the same in the `wrangler.toml` file, where
51
- the comment is:
49
+ and uncomment the commented lines below it (also uncomment the relevant imports).
50
+ - In the `wrangler.jsonc` file add the following configuration line:
52
51
  ```
53
- # KV Example:
52
+ "kv_namespaces": [{ "binding": "MY_KV_NAMESPACE", "id": "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx" }],
54
53
  ```
55
54
  - If you're using TypeScript run the `cf-typegen` script to update the `env.d.ts` file:
56
55
  ```bash
@@ -1,9 +1,9 @@
1
- import { getRequestContext } from '@cloudflare/next-on-pages'
1
+ // import { getRequestContext } from '@cloudflare/next-on-pages'
2
2
 
3
3
  export const runtime = 'edge'
4
4
 
5
- export async function GET(request) {
6
- let responseText = 'Hello World'
5
+ export async function GET() {
6
+ const responseText = 'Hello World'
7
7
 
8
8
  // In the edge runtime you can use Bindings that are available in your application
9
9
  // (for more details see:
@@ -15,7 +15,7 @@ export async function GET(request) {
15
15
  // const myKv = getRequestContext().env.MY_KV_NAMESPACE
16
16
  // await myKv.put('suffix', ' from a KV store!')
17
17
  // const suffix = await myKv.get('suffix')
18
- // responseText += suffix
18
+ // return new Response(responseText + suffix)
19
19
 
20
20
  return new Response(responseText)
21
21
  }
@@ -1,10 +1,9 @@
1
- import type { NextRequest } from 'next/server'
2
- import { getRequestContext } from '@cloudflare/next-on-pages'
1
+ // import { getRequestContext } from '@cloudflare/next-on-pages'
3
2
 
4
3
  export const runtime = 'edge'
5
4
 
6
- export async function GET(request: NextRequest) {
7
- let responseText = 'Hello World'
5
+ export async function GET() {
6
+ const responseText = 'Hello World'
8
7
 
9
8
  // In the edge runtime you can use Bindings that are available in your application
10
9
  // (for more details see:
@@ -16,7 +15,7 @@ export async function GET(request: NextRequest) {
16
15
  // const myKv = getRequestContext().env.MY_KV_NAMESPACE
17
16
  // await myKv.put('suffix', ' from a KV store!')
18
17
  // const suffix = await myKv.get('suffix')
19
- // responseText += suffix
18
+ // return new Response(responseText + suffix)
20
19
 
21
20
  return new Response(responseText)
22
21
  }
@@ -1,8 +1,7 @@
1
1
  import { join } from "path";
2
- import { crash, updateStatus, warn } from "@cloudflare/cli";
3
- import { processArgument } from "@cloudflare/cli/args";
2
+ import { updateStatus, warn } from "@cloudflare/cli";
4
3
  import { brandColor, dim } from "@cloudflare/cli/colors";
5
- import { spinner } from "@cloudflare/cli/interactive";
4
+ import { inputPrompt, spinner } from "@cloudflare/cli/interactive";
6
5
  import { runFrameworkGenerator } from "frameworks/index";
7
6
  import {
8
7
  copyFile,
@@ -18,7 +17,7 @@ import { detectPackageManager } from "helpers/packageManagers";
18
17
  import { installPackages } from "helpers/packages";
19
18
  import { getTemplatePath } from "../../src/templates";
20
19
  import type { TemplateConfig } from "../../src/templates";
21
- import type { C3Args, C3Context } from "types";
20
+ import type { C3Context } from "types";
22
21
 
23
22
  const { npm, npx } = detectPackageManager();
24
23
 
@@ -27,33 +26,15 @@ const generate = async (ctx: C3Context) => {
27
26
 
28
27
  await runFrameworkGenerator(ctx, [projectName]);
29
28
 
30
- const wranglerToml = readFile(join(getTemplatePath(ctx), "wrangler.toml"));
31
-
32
- // Note: here we add `# KV Example:` to the toml file for the KV example, we don't actually
33
- // include the comment in the template wrangler.toml file just so to keep it identical
34
- // and consistent with that of all the other frameworks
35
- // (instead of making it a special case which needs extra care)
36
- const newTomlContent = wranglerToml.replace(
37
- /#\s+\[\[kv_namespaces\]\]\n#\s+binding\s+=\s+"MY_KV_NAMESPACE"\n#\s+id\s+=\s+"[a-zA-Z0-9]+?"/,
38
- ($1) => `# KV Example:\n${$1}`,
39
- );
40
-
41
- if (!/# KV Example/.test(newTomlContent)) {
42
- // This should never happen to users, it is a check mostly so that
43
- // if the toml file is changed in a way that breaks the "KV Example" addition
44
- // the C3 Next.js e2e runs will fail with this
45
- crash("Failed to properly generate the wrangler.toml file");
46
- }
47
-
48
- writeFile(join(ctx.project.path, "wrangler.toml"), newTomlContent);
49
-
50
- updateStatus("Created wrangler.toml file");
29
+ const wranglerConfig = readFile(join(getTemplatePath(ctx), "wrangler.jsonc"));
30
+ writeFile(join(ctx.project.path, "wrangler.jsonc"), wranglerConfig);
31
+ updateStatus("Created wrangler.jsonc file");
51
32
  };
52
33
 
53
- const updateNextConfig = () => {
34
+ const updateNextConfig = (usesTs: boolean) => {
54
35
  const s = spinner();
55
36
 
56
- const configFile = "next.config.mjs";
37
+ const configFile = `next.config.${usesTs ? "ts" : "mjs"}`;
57
38
  s.start(`Updating \`${configFile}\``);
58
39
 
59
40
  const configContent = readFile(configFile);
@@ -61,12 +42,12 @@ const updateNextConfig = () => {
61
42
  const updatedConfigFile =
62
43
  `import { setupDevPlatform } from '@cloudflare/next-on-pages/next-dev';
63
44
 
64
- // Here we use the @cloudflare/next-on-pages next-dev module to allow us to use bindings during local development
65
- // (when running the application with \`next dev\`), for more information see:
45
+ // Here we use the @cloudflare/next-on-pages next-dev module to allow us to
46
+ // use bindings during local development (when running the application with
47
+ // \`next dev\`). This function is only necessary during development and
48
+ // has no impact outside of that. For more information see:
66
49
  // https://github.com/cloudflare/next-on-pages/blob/main/internal-packages/next-dev/README.md
67
- if (process.env.NODE_ENV === 'development') {
68
- await setupDevPlatform();
69
- }
50
+ setupDevPlatform().catch(console.error);
70
51
 
71
52
  `.replace(/\n\t*/g, "\n") + configContent;
72
53
 
@@ -89,7 +70,7 @@ const configure = async (ctx: C3Context) => {
89
70
  ]);
90
71
 
91
72
  if (!path) {
92
- crash("Could not find the `/api` or `/app` directory");
73
+ throw new Error("Could not find the `/api` or `/app` directory");
93
74
  }
94
75
 
95
76
  const usesTs = usesTypescript(ctx);
@@ -108,7 +89,7 @@ const configure = async (ctx: C3Context) => {
108
89
  await writeEslintrc(ctx);
109
90
  }
110
91
 
111
- updateNextConfig();
92
+ updateNextConfig(usesTs);
112
93
 
113
94
  copyFile(
114
95
  join(getTemplatePath(ctx), "README.md"),
@@ -135,7 +116,7 @@ export const shouldInstallNextOnPagesEslintPlugin = async (
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",
@@ -144,7 +125,10 @@ export const shouldInstallNextOnPagesEslintPlugin = async (
144
125
  };
145
126
 
146
127
  export const writeEslintrc = async (ctx: C3Context): Promise<void> => {
147
- const eslintConfig = readJSON(`${ctx.project.path}/.eslintrc.json`);
128
+ const eslintConfig = readJSON(`${ctx.project.path}/.eslintrc.json`) as {
129
+ plugins: string[];
130
+ extends: string | string[];
131
+ };
148
132
 
149
133
  eslintConfig.plugins ??= [];
150
134
  eslintConfig.plugins.push("eslint-plugin-next-on-pages");
@@ -175,8 +159,9 @@ const addDevDependencies = async (installEslintPlugin: boolean) => {
175
159
  export default {
176
160
  configVersion: 1,
177
161
  id: "next",
162
+ frameworkCli: "create-next-app",
178
163
  platform: "pages",
179
- displayName: "Next",
164
+ displayName: "Next.js",
180
165
  generate,
181
166
  configure,
182
167
  copyFiles: {
@@ -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
+ }