create-cloudflare 0.0.0-e5b8cb40 → 0.0.0-e5dbedd78

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 (272) hide show
  1. package/README.md +1 -1
  2. package/dist/cli.js +65987 -65595
  3. package/dist/tsconfig.tsbuildinfo +1 -1
  4. package/package.json +32 -24
  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 -96
  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 +3 -0
  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 +2 -2
  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 +4 -4
  56. package/templates/hello-world/ts/src/index.ts +1 -1
  57. package/templates/hello-world/ts/test/tsconfig.json +1 -1
  58. package/templates/hello-world/ts/tsconfig.json +38 -96
  59. package/templates/hello-world/ts/vitest.config.mts +11 -0
  60. package/templates/hello-world/ts/worker-configuration.d.ts +1 -1
  61. package/templates/hello-world/ts/wrangler.jsonc +8 -0
  62. package/templates/hello-world-assets-only/c3.ts +16 -0
  63. package/templates/{hello-world-python/py → hello-world-assets-only/templates}/package.json +1 -1
  64. package/templates/hello-world-assets-only/templates/public/index.html +11 -0
  65. package/templates/hello-world-assets-only/templates/wrangler.jsonc +10 -0
  66. package/templates/hello-world-durable-object/c3.ts +3 -1
  67. package/templates/hello-world-durable-object/js/package.json +1 -1
  68. package/templates/hello-world-durable-object/js/src/index.js +13 -12
  69. package/templates/hello-world-durable-object/js/wrangler.jsonc +24 -0
  70. package/templates/hello-world-durable-object/ts/package.json +2 -2
  71. package/templates/hello-world-durable-object/ts/src/index.ts +14 -34
  72. package/templates/hello-world-durable-object/ts/tsconfig.json +36 -95
  73. package/templates/hello-world-durable-object/ts/worker-configuration.d.ts +3 -4
  74. package/templates/hello-world-durable-object/ts/wrangler.jsonc +24 -0
  75. package/templates/hello-world-durable-object-with-assets/c3.ts +23 -0
  76. package/templates/hello-world-durable-object-with-assets/js/.editorconfig +12 -0
  77. package/templates/hello-world-durable-object-with-assets/js/.prettierrc +6 -0
  78. package/templates/hello-world-durable-object-with-assets/js/__dot__gitignore +172 -0
  79. package/templates/hello-world-durable-object-with-assets/js/package.json +13 -0
  80. package/templates/hello-world-durable-object-with-assets/js/public/index.html +19 -0
  81. package/templates/hello-world-durable-object-with-assets/js/src/index.js +69 -0
  82. package/templates/hello-world-durable-object-with-assets/js/wrangler.jsonc +28 -0
  83. package/templates/hello-world-durable-object-with-assets/ts/.editorconfig +12 -0
  84. package/templates/hello-world-durable-object-with-assets/ts/.prettierrc +6 -0
  85. package/templates/hello-world-durable-object-with-assets/ts/__dot__gitignore +172 -0
  86. package/templates/hello-world-durable-object-with-assets/ts/package.json +15 -0
  87. package/templates/hello-world-durable-object-with-assets/ts/public/index.html +19 -0
  88. package/templates/hello-world-durable-object-with-assets/ts/src/index.ts +66 -0
  89. package/templates/hello-world-durable-object-with-assets/ts/tsconfig.json +42 -0
  90. package/templates/hello-world-durable-object-with-assets/ts/worker-configuration.d.ts +5 -0
  91. package/templates/hello-world-durable-object-with-assets/ts/wrangler.jsonc +28 -0
  92. package/templates/hello-world-with-assets/c3.ts +21 -0
  93. package/templates/hello-world-with-assets/js/.editorconfig +12 -0
  94. package/templates/hello-world-with-assets/js/.prettierrc +6 -0
  95. package/templates/hello-world-with-assets/js/__dot__gitignore +172 -0
  96. package/templates/hello-world-with-assets/js/package.json +16 -0
  97. package/templates/hello-world-with-assets/js/public/index.html +31 -0
  98. package/templates/hello-world-with-assets/js/src/index.js +23 -0
  99. package/templates/hello-world-with-assets/js/test/index.spec.js +41 -0
  100. package/templates/{hello-world/ts/vitest.config.ts → hello-world-with-assets/js/vitest.config.js} +1 -1
  101. package/templates/hello-world-with-assets/js/wrangler.jsonc +15 -0
  102. package/templates/hello-world-with-assets/py/package.json +13 -0
  103. package/templates/hello-world-with-assets/py/public/index.html +31 -0
  104. package/templates/hello-world-with-assets/py/src/entry.py +9 -0
  105. package/templates/hello-world-with-assets/py/wrangler.jsonc +15 -0
  106. package/templates/hello-world-with-assets/ts/.editorconfig +12 -0
  107. package/templates/hello-world-with-assets/ts/.prettierrc +6 -0
  108. package/templates/hello-world-with-assets/ts/__dot__gitignore +172 -0
  109. package/templates/hello-world-with-assets/ts/package.json +18 -0
  110. package/templates/hello-world-with-assets/ts/public/index.html +31 -0
  111. package/templates/hello-world-with-assets/ts/src/index.ts +26 -0
  112. package/templates/hello-world-with-assets/ts/test/index.spec.ts +41 -0
  113. package/templates/hello-world-with-assets/ts/test/tsconfig.json +8 -0
  114. package/templates/hello-world-with-assets/ts/tsconfig.json +44 -0
  115. package/templates/hello-world-with-assets/ts/vitest.config.mts +11 -0
  116. package/templates/hello-world-with-assets/ts/worker-configuration.d.ts +4 -0
  117. package/templates/hello-world-with-assets/ts/wrangler.jsonc +15 -0
  118. package/templates/hono/c3.ts +5 -74
  119. package/templates/hono/pages/c3.ts +42 -0
  120. package/templates/hono/pages/templates/src/index.tsx +12 -0
  121. package/templates/hono/pages/templates/worker-configuration.d.ts +4 -0
  122. package/templates/hono/pages/templates/wrangler.jsonc +9 -0
  123. package/templates/hono/workers/c3.ts +42 -0
  124. package/templates/hono/workers/templates/public/index.html +19 -0
  125. package/templates/hono/workers/templates/src/index.ts +9 -0
  126. package/templates/hono/workers/templates/worker-configuration.d.ts +4 -0
  127. package/templates/hono/workers/templates/wrangler.jsonc +9 -0
  128. package/templates/next/README.md +4 -5
  129. package/templates/next/app/js/app/api/hello/route.js +4 -4
  130. package/templates/next/app/ts/app/api/hello/route.ts +4 -5
  131. package/templates/next/c3.ts +23 -38
  132. package/templates/next/wrangler.jsonc +8 -0
  133. package/templates/nuxt/c3.ts +5 -129
  134. package/templates/nuxt/pages/c3.ts +145 -0
  135. package/templates/nuxt/pages/templates/worker-configuration.d.ts +4 -0
  136. package/templates/nuxt/pages/templates/wrangler.jsonc +5 -0
  137. package/templates/nuxt/workers/c3.ts +145 -0
  138. package/templates/nuxt/workers/templates/env.d.ts +14 -0
  139. package/templates/nuxt/workers/templates/worker-configuration.d.ts +4 -0
  140. package/templates/nuxt/workers/templates/wrangler.jsonc +12 -0
  141. package/templates/openapi/c3.ts +1 -0
  142. package/templates/openapi/ts/README.md +3 -3
  143. package/templates/openapi/ts/package.json +5 -3
  144. package/templates/openapi/ts/src/endpoints/taskCreate.ts +26 -16
  145. package/templates/openapi/ts/src/endpoints/taskDelete.ts +20 -19
  146. package/templates/openapi/ts/src/endpoints/taskFetch.ts +30 -23
  147. package/templates/openapi/ts/src/endpoints/taskList.ts +27 -24
  148. package/templates/openapi/ts/src/index.ts +14 -20
  149. package/templates/openapi/ts/src/types.ts +9 -8
  150. package/templates/openapi/ts/worker-configuration.d.ts +1 -1
  151. package/templates/openapi/ts/wrangler.jsonc +8 -0
  152. package/templates/pre-existing/c3.ts +31 -12
  153. package/templates/pre-existing/js/package.json +1 -1
  154. package/templates/queues/c3.ts +2 -0
  155. package/templates/queues/js/package.json +1 -1
  156. package/templates/queues/js/wrangler.jsonc +21 -0
  157. package/templates/queues/ts/package.json +2 -2
  158. package/templates/queues/ts/src/index.ts +1 -1
  159. package/templates/queues/ts/tsconfig.json +36 -95
  160. package/templates/queues/ts/worker-configuration.d.ts +1 -1
  161. package/templates/queues/ts/wrangler.jsonc +21 -0
  162. package/templates/qwik/c3.ts +5 -142
  163. package/templates/qwik/pages/c3.ts +149 -0
  164. package/templates/qwik/pages/templates/worker-configuration.d.ts +4 -0
  165. package/templates/qwik/pages/templates/wrangler.jsonc +8 -0
  166. package/templates/qwik/workers/c3.ts +154 -0
  167. package/templates/qwik/workers/snippets/getPlatformProxy.ts +6 -0
  168. package/templates/qwik/workers/templates/public/.assetsignore +4 -0
  169. package/templates/qwik/workers/templates/worker-configuration.d.ts +4 -0
  170. package/templates/qwik/workers/templates/wrangler.jsonc +15 -0
  171. package/templates/react/c3.ts +5 -27
  172. package/templates/react/pages/c3.ts +62 -0
  173. package/templates/react/workers/c3.ts +183 -0
  174. package/templates/react/workers/js/api/index.js +13 -0
  175. package/templates/react/workers/js/src/App.css +45 -0
  176. package/templates/react/workers/js/src/App.jsx +58 -0
  177. package/templates/react/workers/js/src/assets/Cloudflare_Logo.svg +53 -0
  178. package/templates/react/workers/js/wrangler.jsonc +9 -0
  179. package/templates/react/workers/ts/api/index.ts +13 -0
  180. package/templates/react/workers/ts/src/App.css +45 -0
  181. package/templates/react/workers/ts/src/App.tsx +58 -0
  182. package/templates/react/workers/ts/src/assets/Cloudflare_Logo.svg +51 -0
  183. package/templates/react/workers/ts/tsconfig.worker.json +8 -0
  184. package/templates/react/workers/ts/worker-configuration.d.ts +5 -0
  185. package/templates/react/workers/ts/wrangler.jsonc +9 -0
  186. package/templates/remix/c3.ts +5 -62
  187. package/templates/remix/pages/c3.ts +68 -0
  188. package/templates/remix/pages/templates/worker-configuration.d.ts +4 -0
  189. package/templates/remix/pages/templates/wrangler.jsonc +5 -0
  190. package/templates/remix/workers/c3.ts +52 -0
  191. package/templates/remix/workers/templates/public/.assetsignore +0 -0
  192. package/templates/remix/workers/templates/wrangler.toml +11 -0
  193. package/templates/scheduled/c3.ts +2 -0
  194. package/templates/scheduled/js/package.json +1 -1
  195. package/templates/scheduled/js/src/index.js +1 -1
  196. package/templates/scheduled/js/wrangler.jsonc +13 -0
  197. package/templates/scheduled/ts/package.json +2 -2
  198. package/templates/scheduled/ts/src/index.ts +4 -4
  199. package/templates/scheduled/ts/tsconfig.json +36 -95
  200. package/templates/scheduled/ts/worker-configuration.d.ts +1 -1
  201. package/templates/scheduled/ts/wrangler.jsonc +13 -0
  202. package/templates/solid/c3.ts +2 -1
  203. package/templates/solid/templates/wrangler.jsonc +8 -0
  204. package/templates/svelte/c3.ts +6 -127
  205. package/templates/svelte/pages/c3.ts +159 -0
  206. package/templates/svelte/pages/templates/wrangler.jsonc +5 -0
  207. package/templates/svelte/workers/c3.ts +129 -0
  208. package/templates/svelte/workers/templates/static/.assetsignore +2 -0
  209. package/templates/svelte/workers/templates/wrangler.jsonc +12 -0
  210. package/templates/vue/c3.ts +5 -24
  211. package/templates/vue/pages/c3.ts +30 -0
  212. package/templates/vue/workers/c3.ts +98 -0
  213. package/templates/vue/workers/js/server/index.js +13 -0
  214. package/templates/vue/workers/js/src/App.vue +107 -0
  215. package/templates/vue/workers/js/src/components/HelloWorld.vue +47 -0
  216. package/templates/vue/workers/js/vite.config.js +21 -0
  217. package/templates/vue/workers/js/wrangler.jsonc +12 -0
  218. package/templates/vue/workers/ts/server/index.ts +13 -0
  219. package/templates/vue/workers/ts/src/App.vue +107 -0
  220. package/templates/vue/workers/ts/src/components/HelloWorld.vue +44 -0
  221. package/templates/vue/workers/ts/tsconfig.worker.json +8 -0
  222. package/templates/vue/workers/ts/vite.config.ts +21 -0
  223. package/templates/vue/workers/ts/worker-configuration.d.ts +6 -0
  224. package/templates/vue/workers/ts/wrangler.jsonc +12 -0
  225. package/templates-experimental/next/c3.ts +75 -0
  226. package/templates-experimental/next/templates/.dev.vars +2 -0
  227. package/templates-experimental/next/templates/__dot__gitignore +39 -0
  228. package/templates-experimental/next/templates/cloudflare-env.d.ts +5 -0
  229. package/templates-experimental/next/templates/open-next.config.ts +6 -0
  230. package/templates-experimental/next/templates/wrangler.jsonc +12 -0
  231. package/templates-experimental/solid/c3.ts +94 -0
  232. package/templates-experimental/solid/templates/wrangler.jsonc +15 -0
  233. package/templates/analog/templates/wrangler.toml +0 -85
  234. package/templates/angular/templates/server.ts +0 -34
  235. package/templates/angular/templates/tools/alter-polyfills.mjs +0 -27
  236. package/templates/angular/templates/tools/copy-files.mjs +0 -9
  237. package/templates/angular/templates/tools/paths.mjs +0 -9
  238. package/templates/astro/templates/wrangler.toml +0 -85
  239. package/templates/common/js/wrangler.toml +0 -107
  240. package/templates/common/ts/wrangler.toml +0 -107
  241. package/templates/hello-world/js/wrangler.toml +0 -108
  242. package/templates/hello-world/ts/wrangler.toml +0 -108
  243. package/templates/hello-world-durable-object/js/wrangler.toml +0 -107
  244. package/templates/hello-world-durable-object/ts/wrangler.toml +0 -107
  245. package/templates/hello-world-python/c3.ts +0 -9
  246. package/templates/hello-world-python/py/wrangler.toml +0 -108
  247. package/templates/hono/snippets/appDeclaration.ts +0 -1
  248. package/templates/hono/snippets/bindingsType.ts +0 -3
  249. package/templates/hono/templates/worker-configuration.d.ts +0 -4
  250. package/templates/hono/templates/wrangler.toml +0 -107
  251. package/templates/next/wrangler.toml +0 -86
  252. package/templates/nuxt/templates/wrangler.toml +0 -85
  253. package/templates/openapi/ts/wrangler.toml +0 -107
  254. package/templates/pre-existing/js/wrangler.toml +0 -4
  255. package/templates/queues/js/wrangler.toml +0 -112
  256. package/templates/queues/ts/wrangler.toml +0 -112
  257. package/templates/qwik/templates/worker-configuration.d.ts +0 -4
  258. package/templates/qwik/templates/wrangler.toml +0 -85
  259. package/templates/remix/templates/worker-configuration.d.ts +0 -4
  260. package/templates/remix/templates/wrangler.toml +0 -85
  261. package/templates/scheduled/js/wrangler.toml +0 -113
  262. package/templates/scheduled/ts/wrangler.toml +0 -113
  263. package/templates/solid/templates/wrangler.toml +0 -84
  264. package/templates/svelte/js/wrangler.toml +0 -85
  265. package/templates/svelte/ts/wrangler.toml +0 -85
  266. /package/templates/angular/{templates → pages/templates}/src/_routes.json +0 -0
  267. /package/templates/astro/{snippets/runtimeDeclaration.ts → pages/templates/ts/src/env.d.ts} +0 -0
  268. /package/templates/{hello-world-python → hello-world}/py/src/entry.py +0 -0
  269. /package/templates/{hello-world-python → hello-world-with-assets}/py/__dot__gitignore +0 -0
  270. /package/templates/nuxt/{templates → pages/templates}/env.d.ts +0 -0
  271. /package/templates/qwik/{snippets → pages/snippets}/getPlatformProxy.ts +0 -0
  272. /package/templates/{nuxt → remix/workers}/templates/worker-configuration.d.ts +0 -0
@@ -0,0 +1,26 @@
1
+ /**
2
+ * Welcome to Cloudflare Workers! This is your first worker.
3
+ *
4
+ * - Run `npm run dev` in your terminal to start a development server
5
+ * - Open a browser tab at http://localhost:8787/ to see your worker in action
6
+ * - Run `npm run deploy` to publish your worker
7
+ *
8
+ * Bind resources to your worker in `wrangler.jsonc`. After adding bindings, a type definition for the
9
+ * `Env` object can be regenerated with `npm run cf-typegen`.
10
+ *
11
+ * Learn more at https://developers.cloudflare.com/workers/
12
+ */
13
+
14
+ export default {
15
+ async fetch(request, env, ctx): Promise<Response> {
16
+ const url = new URL(request.url);
17
+ switch (url.pathname) {
18
+ case '/message':
19
+ return new Response('Hello, World!');
20
+ case '/random':
21
+ return new Response(crypto.randomUUID());
22
+ default:
23
+ return new Response('Not Found', { status: 404 });
24
+ }
25
+ },
26
+ } satisfies ExportedHandler<Env>;
@@ -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", "../src/env.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,4 @@
1
+ // Generated by Wrangler
2
+ // After adding bindings to `wrangler.jsonc`, regenerate this interface via `npm run cf-typegen`
3
+ interface Env {
4
+ }
@@ -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
+ }
@@ -23,7 +23,7 @@ Besides the `dev` script mentioned above `c3` has added a few extra scripts that
23
23
  - `preview` to locally preview your Pages application using the [Wrangler](https://developers.cloudflare.com/workers/wrangler/) CLI
24
24
  - `deploy` to deploy your Pages application using the [Wrangler](https://developers.cloudflare.com/workers/wrangler/) CLI
25
25
 
26
- > __Note:__ while the `dev` script is optimal for local development you should preview your Pages application as well (periodically or before deployments) in order to make sure that it can properly work in the Pages environment (for more details see the [`@cloudflare/next-on-pages` recommended workflow](https://github.com/cloudflare/next-on-pages/blob/05b6256/internal-packages/next-dev/README.md#recommended-workflow))
26
+ > __Note:__ while the `dev` script is optimal for local development you should preview your Pages application as well (periodically or before deployments) in order to make sure that it can properly work in the Pages environment (for more details see the [`@cloudflare/next-on-pages` recommended workflow](https://github.com/cloudflare/next-on-pages/blob/main/internal-packages/next-dev/README.md#recommended-development-workflow))
27
27
 
28
28
  ### Bindings
29
29
 
@@ -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:
66
- // https://github.com/cloudflare/next-on-pages/blob/5712c57ea7/internal-packages/next-dev/README.md
67
- if (process.env.NODE_ENV === 'development') {
68
- await setupDevPlatform();
69
- }
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:
49
+ // https://github.com/cloudflare/next-on-pages/blob/main/internal-packages/next-dev/README.md
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
+ }