create-cloudflare 0.0.0-e8aaa3930 → 0.0.0-e9106dfa5

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 (227) hide show
  1. package/dist/cli.js +24336 -22644
  2. package/dist/tsconfig.tsbuildinfo +1 -1
  3. package/package.json +15 -9
  4. package/templates/analog/templates/worker-configuration.d.ts +1 -1
  5. package/templates/angular/c3.ts +5 -110
  6. package/templates/angular/pages/c3.ts +134 -0
  7. package/{templates-experimental/angular → templates/angular/workers}/c3.ts +25 -7
  8. package/templates/astro/c3.ts +5 -93
  9. package/templates/astro/pages/c3.ts +98 -0
  10. package/templates/astro/pages/templates/ts/worker-configuration.d.ts +4 -0
  11. package/{templates-experimental/astro → templates/astro/workers}/c3.ts +2 -2
  12. package/templates/astro/workers/templates/js/public/.assetsignore +2 -0
  13. package/templates/astro/workers/templates/ts/public/.assetsignore +2 -0
  14. package/templates/astro/workers/templates/ts/worker-configuration.d.ts +4 -0
  15. package/templates/common/c3.ts +5 -1
  16. package/templates/common/ts/src/index.ts +1 -1
  17. package/templates/common/ts/worker-configuration.d.ts +1 -1
  18. package/templates/docusaurus/c3.ts +5 -24
  19. package/templates/docusaurus/pages/c3.ts +30 -0
  20. package/{templates-experimental/docusaurus → templates/docusaurus/workers}/c3.ts +3 -2
  21. package/templates/gatsby/c3.ts +5 -45
  22. package/templates/gatsby/pages/c3.ts +50 -0
  23. package/{templates-experimental/gatsby → templates/gatsby/workers}/c3.ts +2 -2
  24. package/templates/hello-world/c3.ts +20 -3
  25. package/templates/hello-world/js/package.json +2 -2
  26. package/templates/hello-world/js/test/index.spec.js +1 -1
  27. package/templates/hello-world/js/vitest.config.js +1 -1
  28. package/templates/hello-world/js/{wrangler.json → wrangler.jsonc} +2 -2
  29. package/templates/hello-world/py/.python-version +1 -0
  30. package/templates/hello-world/py/README.md +23 -0
  31. package/templates/hello-world/py/pyproject.toml +9 -0
  32. package/templates/hello-world/py/uv.lock +22 -0
  33. package/templates/hello-world/py/{wrangler.json → wrangler.jsonc} +2 -2
  34. package/templates/hello-world/ts/package.json +2 -2
  35. package/templates/hello-world/ts/src/index.ts +1 -1
  36. package/templates/hello-world/ts/test/env.d.ts +3 -0
  37. package/templates/hello-world/ts/vitest.config.mts +1 -1
  38. package/templates/hello-world/ts/worker-configuration.d.ts +7 -3
  39. package/templates/hello-world/ts/{wrangler.json → wrangler.jsonc} +2 -2
  40. package/{templates-experimental → templates}/hello-world-assets-only/c3.ts +4 -3
  41. package/templates/hello-world-durable-object/c3.ts +6 -3
  42. package/templates/hello-world-durable-object/js/src/index.js +13 -12
  43. package/templates/hello-world-durable-object/js/{wrangler.json → wrangler.jsonc} +1 -1
  44. package/templates/hello-world-durable-object/ts/src/index.ts +13 -12
  45. package/templates/hello-world-durable-object/ts/worker-configuration.d.ts +6 -4
  46. package/templates/hello-world-durable-object/ts/{wrangler.json → wrangler.jsonc} +1 -1
  47. package/{templates-experimental → templates}/hello-world-durable-object-with-assets/c3.ts +3 -3
  48. package/{templates-experimental → templates}/hello-world-durable-object-with-assets/js/src/index.js +14 -13
  49. package/{templates-experimental/hello-world-durable-object-with-assets/js/wrangler.json → templates/hello-world-durable-object-with-assets/js/wrangler.jsonc} +2 -2
  50. package/{templates-experimental → templates}/hello-world-durable-object-with-assets/ts/src/index.ts +13 -12
  51. package/templates/hello-world-durable-object-with-assets/ts/worker-configuration.d.ts +8 -0
  52. package/{templates-experimental/hello-world-durable-object-with-assets/ts/wrangler.json → templates/hello-world-durable-object-with-assets/ts/wrangler.jsonc} +1 -1
  53. package/templates/hello-world-with-assets/c3.ts +24 -0
  54. package/{templates-experimental → templates}/hello-world-with-assets/js/package.json +2 -2
  55. package/{templates-experimental/hello-world-with-assets/ts → templates/hello-world-with-assets/js}/public/index.html +2 -2
  56. package/{templates-experimental → templates}/hello-world-with-assets/js/vitest.config.js +1 -1
  57. package/{templates-experimental/hello-world-with-assets/js → templates/hello-world-with-assets/py}/public/index.html +2 -2
  58. package/{templates-experimental → templates}/hello-world-with-assets/ts/package.json +2 -2
  59. package/{templates-experimental/hello-world-with-assets/py → templates/hello-world-with-assets/ts}/public/index.html +2 -2
  60. package/{templates-experimental → templates}/hello-world-with-assets/ts/src/index.ts +1 -1
  61. package/templates/hello-world-with-assets/ts/test/env.d.ts +3 -0
  62. package/{templates-experimental → templates}/hello-world-with-assets/ts/test/tsconfig.json +1 -1
  63. package/{templates-experimental → templates}/hello-world-with-assets/ts/vitest.config.mts +1 -1
  64. package/templates/hello-world-with-assets/ts/worker-configuration.d.ts +7 -0
  65. package/templates/hono/c3.ts +5 -65
  66. package/templates/hono/pages/c3.ts +42 -0
  67. package/templates/hono/pages/templates/src/index.tsx +12 -0
  68. package/templates/hono/pages/templates/worker-configuration.d.ts +4 -0
  69. package/templates/{openapi/ts/wrangler.json → hono/pages/templates/wrangler.jsonc} +2 -1
  70. package/{templates-experimental/hono → templates/hono/workers}/c3.ts +3 -4
  71. package/templates/hono/workers/templates/worker-configuration.d.ts +4 -0
  72. package/templates/next/README.md +2 -3
  73. package/templates/next/c3.ts +12 -27
  74. package/templates/nuxt/c3.ts +5 -130
  75. package/templates/nuxt/pages/c3.ts +146 -0
  76. package/templates/nuxt/pages/templates/worker-configuration.d.ts +4 -0
  77. package/templates/nuxt/pages/templates/wrangler.jsonc +5 -0
  78. package/{templates-experimental/nuxt → templates/nuxt/workers}/c3.ts +13 -2
  79. package/templates/nuxt/workers/templates/worker-configuration.d.ts +4 -0
  80. package/templates/openapi/c3.ts +5 -1
  81. package/templates/openapi/ts/worker-configuration.d.ts +1 -1
  82. package/templates/pre-existing/c3.ts +8 -4
  83. package/templates/queues/c3.ts +5 -1
  84. package/templates/queues/ts/src/index.ts +1 -1
  85. package/templates/queues/ts/worker-configuration.d.ts +1 -1
  86. package/templates/qwik/c3.ts +5 -143
  87. package/templates/qwik/pages/c3.ts +149 -0
  88. package/templates/qwik/pages/templates/worker-configuration.d.ts +4 -0
  89. package/{templates-experimental/qwik → templates/qwik/workers}/c3.ts +5 -4
  90. package/templates/qwik/workers/templates/worker-configuration.d.ts +4 -0
  91. package/templates/react/c3.ts +5 -57
  92. package/templates/react/pages/c3.ts +62 -0
  93. package/templates/react/workers/c3.ts +183 -0
  94. package/templates/react/workers/js/api/index.js +13 -0
  95. package/templates/react/workers/js/src/App.css +45 -0
  96. package/templates/react/workers/js/src/App.jsx +58 -0
  97. package/templates/react/workers/js/src/assets/Cloudflare_Logo.svg +53 -0
  98. package/templates/react/workers/js/wrangler.jsonc +9 -0
  99. package/templates/react/workers/ts/api/index.ts +13 -0
  100. package/templates/react/workers/ts/src/App.css +45 -0
  101. package/templates/react/workers/ts/src/App.tsx +58 -0
  102. package/templates/react/workers/ts/src/assets/Cloudflare_Logo.svg +51 -0
  103. package/templates/react/workers/ts/tsconfig.worker.json +8 -0
  104. package/templates/react/workers/ts/worker-configuration.d.ts +5 -0
  105. package/templates/react/workers/ts/wrangler.jsonc +9 -0
  106. package/templates/react-router/c3.ts +53 -0
  107. package/templates/react-router/templates/worker-configuration.d.ts +8 -0
  108. package/templates/remix/c3.ts +6 -63
  109. package/templates/remix/pages/c3.ts +68 -0
  110. package/templates/remix/pages/templates/worker-configuration.d.ts +4 -0
  111. package/{templates-experimental/remix → templates/remix/workers}/c3.ts +2 -2
  112. package/templates/scheduled/c3.ts +5 -1
  113. package/templates/scheduled/js/src/index.js +1 -1
  114. package/templates/scheduled/ts/src/index.ts +4 -4
  115. package/templates/scheduled/ts/worker-configuration.d.ts +1 -1
  116. package/templates/svelte/c3.ts +5 -154
  117. package/templates/svelte/pages/c3.ts +159 -0
  118. package/{templates-experimental/svelte → templates/svelte/workers}/c3.ts +3 -3
  119. package/templates/svelte/workers/templates/static/.assetsignore +2 -0
  120. package/templates/vue/c3.ts +5 -25
  121. package/{templates-experimental/vue → templates/vue/pages}/c3.ts +5 -8
  122. package/templates/vue/workers/c3.ts +98 -0
  123. package/templates/vue/workers/js/server/index.js +13 -0
  124. package/templates/vue/workers/js/src/App.vue +107 -0
  125. package/templates/vue/workers/js/src/components/HelloWorld.vue +47 -0
  126. package/templates/vue/workers/js/vite.config.js +21 -0
  127. package/templates/vue/workers/js/wrangler.jsonc +12 -0
  128. package/templates/vue/workers/ts/server/index.ts +13 -0
  129. package/templates/vue/workers/ts/src/App.vue +107 -0
  130. package/templates/vue/workers/ts/src/components/HelloWorld.vue +44 -0
  131. package/templates/vue/workers/ts/tsconfig.worker.json +8 -0
  132. package/templates/vue/workers/ts/vite.config.ts +21 -0
  133. package/templates/vue/workers/ts/worker-configuration.d.ts +6 -0
  134. package/templates/vue/workers/ts/wrangler.jsonc +12 -0
  135. package/templates-experimental/next/c3.ts +32 -16
  136. package/templates-experimental/next/templates/open-next.config.ts +5 -27
  137. package/templates-experimental/next/templates/{wrangler.json → wrangler.jsonc} +0 -1
  138. package/templates/astro/templates/ts/worker-configuration.d.ts +0 -4
  139. package/templates/hono/snippets/appDeclaration.ts +0 -1
  140. package/templates/hono/templates/worker-configuration.d.ts +0 -4
  141. package/templates/nuxt/templates/worker-configuration.d.ts +0 -4
  142. package/templates/pre-existing/js/wrangler.json +0 -5
  143. package/templates/qwik/templates/worker-configuration.d.ts +0 -4
  144. package/templates/remix/templates/worker-configuration.d.ts +0 -4
  145. package/templates/solid/templates/wrangler.json +0 -8
  146. package/templates-experimental/astro/templates/ts/public/.assetsignore +0 -4
  147. package/templates-experimental/hello-world-durable-object-with-assets/ts/worker-configuration.d.ts +0 -5
  148. package/templates-experimental/hello-world-with-assets/c3.ts +0 -22
  149. package/templates-experimental/hello-world-with-assets/ts/worker-configuration.d.ts +0 -4
  150. package/templates-experimental/hono/templates/worker-configuration.d.ts +0 -4
  151. package/templates-experimental/nuxt/templates/worker-configuration.d.ts +0 -4
  152. package/templates-experimental/qwik/templates/public/.assetsignore +0 -4
  153. package/templates-experimental/qwik/templates/worker-configuration.d.ts +0 -4
  154. package/templates-experimental/remix/templates/worker-configuration.d.ts +0 -4
  155. package/templates-experimental/svelte/templates/static/.assetsignore +0 -4
  156. package/templates-experimental/vue/templates/wrangler.json +0 -10
  157. /package/templates/analog/templates/{wrangler.json → wrangler.jsonc} +0 -0
  158. /package/templates/angular/{templates → pages/templates}/src/_routes.json +0 -0
  159. /package/{templates-experimental/angular → templates/angular/pages}/templates/src/server.ts +0 -0
  160. /package/templates/angular/{templates → pages/templates}/tools/copy-files.mjs +0 -0
  161. /package/templates/angular/{templates → workers/templates}/src/server.ts +0 -0
  162. /package/{templates-experimental/angular/templates/wrangler.json → templates/angular/workers/templates/wrangler.jsonc} +0 -0
  163. /package/templates/astro/{templates/js/wrangler.json → pages/templates/js/wrangler.jsonc} +0 -0
  164. /package/{templates-experimental/astro → templates/astro/pages}/templates/ts/src/env.d.ts +0 -0
  165. /package/templates/astro/{templates/ts/wrangler.json → pages/templates/ts/wrangler.jsonc} +0 -0
  166. /package/{templates-experimental/astro/templates/js/wrangler.json → templates/astro/workers/templates/js/wrangler.jsonc} +0 -0
  167. /package/templates/astro/{templates → workers/templates}/ts/src/env.d.ts +0 -0
  168. /package/{templates-experimental/astro/templates/ts/wrangler.json → templates/astro/workers/templates/ts/wrangler.jsonc} +0 -0
  169. /package/templates/common/js/{wrangler.json → wrangler.jsonc} +0 -0
  170. /package/templates/common/ts/{wrangler.json → wrangler.jsonc} +0 -0
  171. /package/{templates-experimental/docusaurus/templates/wrangler.json → templates/docusaurus/workers/templates/wrangler.jsonc} +0 -0
  172. /package/{templates-experimental/gatsby/templates/wrangler.json → templates/gatsby/workers/templates/wrangler.jsonc} +0 -0
  173. /package/{templates-experimental → templates}/hello-world-assets-only/templates/package.json +0 -0
  174. /package/{templates-experimental → templates}/hello-world-assets-only/templates/public/index.html +0 -0
  175. /package/{templates-experimental/hello-world-assets-only/templates/wrangler.json → templates/hello-world-assets-only/templates/wrangler.jsonc} +0 -0
  176. /package/{templates-experimental → templates}/hello-world-durable-object-with-assets/js/.editorconfig +0 -0
  177. /package/{templates-experimental → templates}/hello-world-durable-object-with-assets/js/.prettierrc +0 -0
  178. /package/{templates-experimental → templates}/hello-world-durable-object-with-assets/js/__dot__gitignore +0 -0
  179. /package/{templates-experimental → templates}/hello-world-durable-object-with-assets/js/package.json +0 -0
  180. /package/{templates-experimental → templates}/hello-world-durable-object-with-assets/js/public/index.html +0 -0
  181. /package/{templates-experimental → templates}/hello-world-durable-object-with-assets/ts/.editorconfig +0 -0
  182. /package/{templates-experimental → templates}/hello-world-durable-object-with-assets/ts/.prettierrc +0 -0
  183. /package/{templates-experimental → templates}/hello-world-durable-object-with-assets/ts/__dot__gitignore +0 -0
  184. /package/{templates-experimental → templates}/hello-world-durable-object-with-assets/ts/package.json +0 -0
  185. /package/{templates-experimental → templates}/hello-world-durable-object-with-assets/ts/public/index.html +0 -0
  186. /package/{templates-experimental → templates}/hello-world-durable-object-with-assets/ts/tsconfig.json +0 -0
  187. /package/{templates-experimental → templates}/hello-world-with-assets/js/.editorconfig +0 -0
  188. /package/{templates-experimental → templates}/hello-world-with-assets/js/.prettierrc +0 -0
  189. /package/{templates-experimental → templates}/hello-world-with-assets/js/__dot__gitignore +0 -0
  190. /package/{templates-experimental → templates}/hello-world-with-assets/js/src/index.js +0 -0
  191. /package/{templates-experimental → templates}/hello-world-with-assets/js/test/index.spec.js +0 -0
  192. /package/{templates-experimental/hello-world-with-assets/js/wrangler.json → templates/hello-world-with-assets/js/wrangler.jsonc} +0 -0
  193. /package/{templates-experimental → templates}/hello-world-with-assets/py/__dot__gitignore +0 -0
  194. /package/{templates-experimental → templates}/hello-world-with-assets/py/package.json +0 -0
  195. /package/{templates-experimental → templates}/hello-world-with-assets/py/src/entry.py +0 -0
  196. /package/{templates-experimental/hello-world-with-assets/py/wrangler.json → templates/hello-world-with-assets/py/wrangler.jsonc} +0 -0
  197. /package/{templates-experimental → templates}/hello-world-with-assets/ts/.editorconfig +0 -0
  198. /package/{templates-experimental → templates}/hello-world-with-assets/ts/.prettierrc +0 -0
  199. /package/{templates-experimental → templates}/hello-world-with-assets/ts/__dot__gitignore +0 -0
  200. /package/{templates-experimental → templates}/hello-world-with-assets/ts/test/index.spec.ts +0 -0
  201. /package/{templates-experimental → templates}/hello-world-with-assets/ts/tsconfig.json +0 -0
  202. /package/{templates-experimental/hello-world-with-assets/ts/wrangler.json → templates/hello-world-with-assets/ts/wrangler.jsonc} +0 -0
  203. /package/{templates-experimental/hono → templates/hono/workers}/templates/public/index.html +0 -0
  204. /package/{templates-experimental/hono → templates/hono/workers}/templates/src/index.ts +0 -0
  205. /package/{templates-experimental/hono/templates/wrangler.json → templates/hono/workers/templates/wrangler.jsonc} +0 -0
  206. /package/templates/next/{wrangler.json → wrangler.jsonc} +0 -0
  207. /package/{templates-experimental/nuxt → templates/nuxt/pages}/templates/env.d.ts +0 -0
  208. /package/templates/nuxt/{templates → workers/templates}/env.d.ts +0 -0
  209. /package/{templates-experimental/nuxt/templates/wrangler.json → templates/nuxt/workers/templates/wrangler.jsonc} +0 -0
  210. /package/templates/{hono/templates/wrangler.json → openapi/ts/wrangler.jsonc} +0 -0
  211. /package/templates/queues/js/{wrangler.json → wrangler.jsonc} +0 -0
  212. /package/templates/queues/ts/{wrangler.json → wrangler.jsonc} +0 -0
  213. /package/{templates-experimental/qwik → templates/qwik/pages}/snippets/getPlatformProxy.ts +0 -0
  214. /package/templates/{nuxt/templates/wrangler.json → qwik/pages/templates/wrangler.jsonc} +0 -0
  215. /package/templates/qwik/{snippets → workers/snippets}/getPlatformProxy.ts +0 -0
  216. /package/{templates-experimental/astro/templates/js → templates/qwik/workers/templates}/public/.assetsignore +0 -0
  217. /package/{templates-experimental/qwik/templates/wrangler.json → templates/qwik/workers/templates/wrangler.jsonc} +0 -0
  218. /package/templates/remix/{templates/wrangler.json → pages/templates/wrangler.jsonc} +0 -0
  219. /package/{templates-experimental/remix → templates/remix/workers}/templates/public/.assetsignore +0 -0
  220. /package/{templates-experimental/astro/templates/ts → templates/remix/workers/templates}/worker-configuration.d.ts +0 -0
  221. /package/{templates-experimental/remix → templates/remix/workers}/templates/wrangler.toml +0 -0
  222. /package/templates/scheduled/js/{wrangler.json → wrangler.jsonc} +0 -0
  223. /package/templates/scheduled/ts/{wrangler.json → wrangler.jsonc} +0 -0
  224. /package/templates/{qwik/templates/wrangler.json → solid/templates/wrangler.jsonc} +0 -0
  225. /package/templates/svelte/{templates/wrangler.json → pages/templates/wrangler.jsonc} +0 -0
  226. /package/{templates-experimental/svelte/templates/wrangler.json → templates/svelte/workers/templates/wrangler.jsonc} +0 -0
  227. /package/templates-experimental/solid/templates/{wrangler.json → wrangler.jsonc} +0 -0
@@ -1,28 +1,9 @@
1
- import { runFrameworkGenerator } from "frameworks/index";
2
- import { detectPackageManager } from "helpers/packageManagers";
3
- import type { TemplateConfig } from "../../src/templates";
4
- import type { C3Context } from "types";
1
+ import pages from "./pages/c3";
2
+ import workers from "./workers/c3";
3
+ import type { MultiPlatformTemplateConfig } from "../../src/templates";
5
4
 
6
- const { npm } = detectPackageManager();
7
-
8
- const generate = async (ctx: C3Context) => {
9
- await runFrameworkGenerator(ctx, [ctx.project.name, "classic"]);
10
- };
11
-
12
- const config: TemplateConfig = {
13
- configVersion: 1,
14
- id: "docusaurus",
15
- frameworkCli: "create-docusaurus",
16
- platform: "pages",
5
+ const config: MultiPlatformTemplateConfig = {
17
6
  displayName: "Docusaurus",
18
- generate,
19
- transformPackageJson: async () => ({
20
- scripts: {
21
- preview: `${npm} run build && wrangler pages dev ./build`,
22
- deploy: `${npm} run build && wrangler pages deploy ./build`,
23
- },
24
- }),
25
- devScript: "preview",
26
- deployScript: "deploy",
7
+ platformVariants: { pages, workers },
27
8
  };
28
9
  export default config;
@@ -0,0 +1,30 @@
1
+ import { runFrameworkGenerator } from "frameworks/index";
2
+ import { detectPackageManager } from "helpers/packageManagers";
3
+ import type { TemplateConfig } from "../../../src/templates";
4
+ import type { C3Context } from "types";
5
+
6
+ const { npm } = detectPackageManager();
7
+
8
+ const generate = async (ctx: C3Context) => {
9
+ await runFrameworkGenerator(ctx, [ctx.project.name, "classic"]);
10
+ };
11
+
12
+ const config: TemplateConfig = {
13
+ configVersion: 1,
14
+ id: "docusaurus",
15
+ frameworkCli: "create-docusaurus",
16
+ platform: "pages",
17
+ displayName: "Docusaurus",
18
+ path: "templates/docusaurus/pages",
19
+ generate,
20
+ transformPackageJson: async () => ({
21
+ scripts: {
22
+ preview: `${npm} run build && wrangler pages dev ./build`,
23
+ deploy: `${npm} run build && wrangler pages deploy ./build`,
24
+ },
25
+ }),
26
+ devScript: "preview",
27
+ deployScript: "deploy",
28
+ previewScript: "preview",
29
+ };
30
+ export default config;
@@ -1,6 +1,6 @@
1
1
  import { runFrameworkGenerator } from "frameworks/index";
2
2
  import { detectPackageManager } from "helpers/packageManagers";
3
- import type { TemplateConfig } from "../../src/templates";
3
+ import type { TemplateConfig } from "../../../src/templates";
4
4
  import type { C3Context } from "types";
5
5
 
6
6
  const { npm } = detectPackageManager();
@@ -18,7 +18,7 @@ const config: TemplateConfig = {
18
18
  copyFiles: {
19
19
  path: "./templates",
20
20
  },
21
- path: "templates-experimental/docusaurus",
21
+ path: "templates/docusaurus/workers",
22
22
  generate,
23
23
  transformPackageJson: async () => ({
24
24
  scripts: {
@@ -28,5 +28,6 @@ const config: TemplateConfig = {
28
28
  }),
29
29
  devScript: "start",
30
30
  deployScript: "deploy",
31
+ previewScript: "preview",
31
32
  };
32
33
  export default config;
@@ -1,49 +1,9 @@
1
- import { inputPrompt } from "@cloudflare/cli/interactive";
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";
1
+ import pages from "./pages/c3";
2
+ import workers from "./workers/c3";
3
+ import type { MultiPlatformTemplateConfig } from "../../src/templates";
6
4
 
7
- const { npm } = detectPackageManager();
8
-
9
- const generate = async (ctx: C3Context) => {
10
- const defaultTemplate = "https://github.com/gatsbyjs/gatsby-starter-blog";
11
-
12
- const useTemplate = await inputPrompt({
13
- type: "confirm",
14
- question: "Would you like to use a template?",
15
- label: "template",
16
- defaultValue: true,
17
- });
18
-
19
- let templateUrl = "";
20
- if (useTemplate) {
21
- templateUrl = await inputPrompt({
22
- type: "text",
23
- question: `Please specify the url of the template you'd like to use`,
24
- label: "template",
25
- defaultValue: defaultTemplate,
26
- });
27
- }
28
-
29
- await runFrameworkGenerator(ctx, ["new", ctx.project.name, templateUrl]);
30
- };
31
-
32
- const config: TemplateConfig = {
33
- configVersion: 1,
34
- id: "gatsby",
35
- frameworkCli: "gatsby",
36
- platform: "pages",
5
+ const config: MultiPlatformTemplateConfig = {
37
6
  displayName: "Gatsby",
38
- generate,
39
- transformPackageJson: async () => ({
40
- scripts: {
41
- deploy: `${npm} run build && wrangler pages deploy ./public`,
42
- preview: `${npm} run build && wrangler pages dev ./public`,
43
- },
44
- }),
45
- devScript: "develop",
46
- deployScript: "deploy",
47
- previewScript: "preview",
7
+ platformVariants: { pages, workers },
48
8
  };
49
9
  export default config;
@@ -0,0 +1,50 @@
1
+ import { inputPrompt } from "@cloudflare/cli/interactive";
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 { npm } = detectPackageManager();
8
+
9
+ const generate = async (ctx: C3Context) => {
10
+ const defaultTemplate = "https://github.com/gatsbyjs/gatsby-starter-blog";
11
+
12
+ const useTemplate = await inputPrompt({
13
+ type: "confirm",
14
+ question: "Would you like to use a template?",
15
+ label: "template",
16
+ defaultValue: true,
17
+ });
18
+
19
+ let templateUrl = "";
20
+ if (useTemplate) {
21
+ templateUrl = await inputPrompt({
22
+ type: "text",
23
+ question: `Please specify the url of the template you'd like to use`,
24
+ label: "template",
25
+ defaultValue: defaultTemplate,
26
+ });
27
+ }
28
+
29
+ await runFrameworkGenerator(ctx, ["new", ctx.project.name, templateUrl]);
30
+ };
31
+
32
+ const config: TemplateConfig = {
33
+ configVersion: 1,
34
+ id: "gatsby",
35
+ frameworkCli: "gatsby",
36
+ platform: "pages",
37
+ displayName: "Gatsby",
38
+ path: "templates/gatsby/pages",
39
+ generate,
40
+ transformPackageJson: async () => ({
41
+ scripts: {
42
+ deploy: `${npm} run build && wrangler pages deploy ./public`,
43
+ preview: `${npm} run build && wrangler pages dev ./public`,
44
+ },
45
+ }),
46
+ devScript: "develop",
47
+ deployScript: "deploy",
48
+ previewScript: "preview",
49
+ };
50
+ export default config;
@@ -1,7 +1,7 @@
1
1
  import { inputPrompt } from "@cloudflare/cli/interactive";
2
2
  import { runFrameworkGenerator } from "frameworks/index";
3
3
  import { detectPackageManager } from "helpers/packageManagers";
4
- import type { TemplateConfig } from "../../src/templates";
4
+ import type { TemplateConfig } from "../../../src/templates";
5
5
  import type { C3Context } from "types";
6
6
 
7
7
  const { npm } = detectPackageManager();
@@ -38,7 +38,7 @@ const config: TemplateConfig = {
38
38
  copyFiles: {
39
39
  path: "./templates",
40
40
  },
41
- path: "templates-experimental/gatsby",
41
+ path: "templates/gatsby/workers",
42
42
  generate,
43
43
  transformPackageJson: async () => ({
44
44
  scripts: {
@@ -1,9 +1,26 @@
1
+ import { readFile, writeFile } from "node:fs/promises";
2
+ import { resolve } from "node:path";
3
+ import type { TemplateConfig } from "../../src/templates";
4
+
1
5
  export default {
2
6
  configVersion: 1,
3
7
  id: "hello-world",
4
- displayName: "Hello World Worker",
5
- description: "Get started with a basic Worker in the language of your choice",
8
+ displayName: "Worker only",
9
+ description:
10
+ "For processing requests, transforming responses, or API endpoints",
6
11
  platform: "workers",
12
+ async configure(ctx) {
13
+ if (ctx.args.lang === "python") {
14
+ for (const file of ["pyproject.toml", "uv.lock"]) {
15
+ const contents = await readFile(
16
+ resolve(ctx.project.path, file),
17
+ "utf8",
18
+ );
19
+ const updated = contents.replaceAll(/<TBD>/g, ctx.project.name);
20
+ await writeFile(resolve(ctx.project.path, file), updated);
21
+ }
22
+ }
23
+ },
7
24
  copyFiles: {
8
25
  variants: {
9
26
  js: {
@@ -17,4 +34,4 @@ export default {
17
34
  },
18
35
  },
19
36
  },
20
- };
37
+ } satisfies TemplateConfig;
@@ -9,8 +9,8 @@
9
9
  "test": "vitest"
10
10
  },
11
11
  "devDependencies": {
12
- "@cloudflare/vitest-pool-workers": "^0.5.2",
12
+ "@cloudflare/vitest-pool-workers": "^0.7.5",
13
13
  "wrangler": "^3.101.0",
14
- "vitest": "2.1.8"
14
+ "vitest": "~3.0.7"
15
15
  }
16
16
  }
@@ -14,7 +14,7 @@ describe('Hello World worker', () => {
14
14
  });
15
15
 
16
16
  it('responds with Hello World! (integration style)', async () => {
17
- const response = await SELF.fetch(request, env, ctx);
17
+ const response = await SELF.fetch('http://example.com');
18
18
  expect(await response.text()).toMatchInlineSnapshot(`"Hello World!"`);
19
19
  });
20
20
  });
@@ -4,7 +4,7 @@ export default defineWorkersConfig({
4
4
  test: {
5
5
  poolOptions: {
6
6
  workers: {
7
- wrangler: { configPath: './wrangler.toml' },
7
+ wrangler: { configPath: './wrangler.jsonc' },
8
8
  },
9
9
  },
10
10
  },
@@ -3,6 +3,6 @@
3
3
  "main": "src/index.js",
4
4
  "compatibility_date": "<TBD>",
5
5
  "observability": {
6
- "enabled": true
7
- }
6
+ "enabled": true,
7
+ },
8
8
  }
@@ -0,0 +1 @@
1
+ 3.12
@@ -0,0 +1,23 @@
1
+ ## Usage
2
+
3
+ You can run the worker defined by your new project by executing `wrangler dev` in this
4
+ directory. This will start up an HTTP server and will allow you to iterate on your
5
+ worker without having to restart `wrangler`.
6
+
7
+ ### Types and autocomplete
8
+
9
+ This project also includes a pyproject.toml and uv.lock file with some requirements which
10
+ set up autocomplete and type hints for this Python Workers project.
11
+
12
+ To get these installed you'll need `uv`, which you can install by following
13
+ https://docs.astral.sh/uv/getting-started/installation/.
14
+
15
+ Once `uv` is installed, you can run the following:
16
+
17
+ ```
18
+ uv venv
19
+ uv sync
20
+ ```
21
+
22
+ Then point your editor's Python plugin at the `.venv` directory. You should then have working
23
+ autocomplete and type information in your editor.
@@ -0,0 +1,9 @@
1
+ [project]
2
+ name = "<TBD>"
3
+ version = "0.1.0"
4
+ description = "Add your description here"
5
+ readme = "README.md"
6
+ requires-python = ">=3.12"
7
+ dependencies = [
8
+ "webtypy>=0.1.7",
9
+ ]
@@ -0,0 +1,22 @@
1
+ version = 1
2
+ requires-python = ">=3.12"
3
+
4
+ [[package]]
5
+ name = "<TBD>"
6
+ version = "0.1.0"
7
+ source = { virtual = "." }
8
+ dependencies = [
9
+ { name = "webtypy" },
10
+ ]
11
+
12
+ [package.metadata]
13
+ requires-dist = [{ name = "webtypy", specifier = ">=0.1.7" }]
14
+
15
+ [[package]]
16
+ name = "webtypy"
17
+ version = "0.1.7"
18
+ source = { registry = "https://pypi.org/simple" }
19
+ sdist = { url = "https://files.pythonhosted.org/packages/5e/89/c7a0311fdc73809fc2415be97767f085ff3e00c86546430034dc8465fee7/webtypy-0.1.7.tar.gz", hash = "sha256:1b7212719a949c802f3d60fac5f0d952eb503a92121409cf1ad9847d7c76a336", size = 104505 }
20
+ wheels = [
21
+ { url = "https://files.pythonhosted.org/packages/61/91/c731bdaa605279e00b28bfd2bf0ae67f48061d16890fb1c026924bfbd242/webtypy-0.1.7-py3-none-any.whl", hash = "sha256:f35e6d73a4e08783e23adfac271a11cda3a2bd1105499db70e4819244efed0ae", size = 103519 },
22
+ ]
@@ -4,6 +4,6 @@
4
4
  "compatibility_date": "<TBD>",
5
5
  "compatibility_flags": ["python_workers"],
6
6
  "observability": {
7
- "enabled": true
8
- }
7
+ "enabled": true,
8
+ },
9
9
  }
@@ -10,9 +10,9 @@
10
10
  "cf-typegen": "wrangler types"
11
11
  },
12
12
  "devDependencies": {
13
- "@cloudflare/vitest-pool-workers": "^0.5.2",
13
+ "@cloudflare/vitest-pool-workers": "^0.7.5",
14
14
  "typescript": "^5.5.2",
15
- "vitest": "2.1.8",
15
+ "vitest": "~3.0.7",
16
16
  "wrangler": "^3.101.0"
17
17
  }
18
18
  }
@@ -5,7 +5,7 @@
5
5
  * - Open a browser tab at http://localhost:8787/ to see your worker in action
6
6
  * - Run `npm run deploy` to publish your worker
7
7
  *
8
- * Bind resources to your worker in `wrangler.toml`. After adding bindings, a type definition for the
8
+ * Bind resources to your worker in `wrangler.jsonc`. After adding bindings, a type definition for the
9
9
  * `Env` object can be regenerated with `npm run cf-typegen`.
10
10
  *
11
11
  * Learn more at https://developers.cloudflare.com/workers/
@@ -0,0 +1,3 @@
1
+ declare module 'cloudflare:test' {
2
+ interface ProvidedEnv extends Env {}
3
+ }
@@ -4,7 +4,7 @@ export default defineWorkersConfig({
4
4
  test: {
5
5
  poolOptions: {
6
6
  workers: {
7
- wrangler: { configPath: './wrangler.toml' },
7
+ wrangler: { configPath: './wrangler.jsonc' },
8
8
  },
9
9
  },
10
10
  },
@@ -1,4 +1,8 @@
1
- // Generated by Wrangler
2
- // After adding bindings to `wrangler.toml`, regenerate this interface via `npm run cf-typegen`
3
- interface Env {
1
+ // Generated by Wrangler by running `wrangler types --include-runtime=false` (hash: 2905fd8e181cd2f4083a615fa51f1913)
2
+ // After adding bindings to `wrangler.jsonc`, regenerate this interface via `npm run cf-typegen`
3
+ declare namespace Cloudflare {
4
+ // eslint-disable-next-line @typescript-eslint/no-empty-interface,@typescript-eslint/no-empty-object-type
5
+ interface Env {
6
+ }
4
7
  }
8
+ interface Env extends Cloudflare.Env {}
@@ -3,6 +3,6 @@
3
3
  "main": "src/index.ts",
4
4
  "compatibility_date": "<TBD>",
5
5
  "observability": {
6
- "enabled": true
7
- }
6
+ "enabled": true,
7
+ },
8
8
  }
@@ -3,9 +3,10 @@ import type { TemplateConfig } from "../../src/templates";
3
3
  const config: TemplateConfig = {
4
4
  configVersion: 1,
5
5
  id: "hello-world-assets-only",
6
- path: "templates-experimental/hello-world-assets-only",
7
- displayName: "Hello World - Assets-only",
8
- description: "Get started with a basic Worker that only serves static assets",
6
+ path: "templates/hello-world-assets-only",
7
+ displayName: "Assets only",
8
+ description:
9
+ "For static sites (including SPAs) or when using your own backend",
9
10
  platform: "workers",
10
11
  copyFiles: {
11
12
  path: "./templates",
@@ -1,9 +1,11 @@
1
- export default {
1
+ import type { TemplateConfig } from "../../src/templates";
2
+
3
+ const config: TemplateConfig = {
2
4
  configVersion: 1,
3
5
  id: "hello-world-durable-object",
4
- displayName: "Hello World Worker Using Durable Objects",
6
+ displayName: "Worker + Durable Objects",
5
7
  description:
6
- "Get started with a basic stateful app to build projects like real-time chats, collaborative apps, and multiplayer games",
8
+ "For multiplayer apps using WebSockets, or when you need synchronization",
7
9
  platform: "workers",
8
10
  copyFiles: {
9
11
  variants: {
@@ -16,3 +18,4 @@ export default {
16
18
  },
17
19
  },
18
20
  };
21
+ export default config;
@@ -11,7 +11,7 @@ import { DurableObject } from "cloudflare:workers";
11
11
  */
12
12
 
13
13
  /**
14
- * Env provides a mechanism to reference bindings declared in wrangler.toml within JavaScript
14
+ * Env provides a mechanism to reference bindings declared in wrangler.jsonc within JavaScript
15
15
  *
16
16
  * @typedef {Object} Env
17
17
  * @property {DurableObjectNamespace} MY_DURABLE_OBJECT - The Durable Object namespace binding
@@ -24,7 +24,7 @@ export class MyDurableObject extends DurableObject {
24
24
  * `DurableObjectStub::get` for a given identifier (no-op constructors can be omitted)
25
25
  *
26
26
  * @param {DurableObjectState} ctx - The interface for interacting with Durable Object state
27
- * @param {Env} env - The interface to reference bindings declared in wrangler.toml
27
+ * @param {Env} env - The interface to reference bindings declared in wrangler.jsonc
28
28
  */
29
29
  constructor(ctx, env) {
30
30
  super(ctx, env);
@@ -47,22 +47,23 @@ export default {
47
47
  * This is the standard fetch handler for a Cloudflare Worker
48
48
  *
49
49
  * @param {Request} request - The request submitted to the Worker from the client
50
- * @param {Env} env - The interface to reference bindings declared in wrangler.toml
50
+ * @param {Env} env - The interface to reference bindings declared in wrangler.jsonc
51
51
  * @param {ExecutionContext} ctx - The execution context of the Worker
52
52
  * @returns {Promise<Response>} The response to be sent back to the client
53
53
  */
54
54
  async fetch(request, env, ctx) {
55
- // We will create a `DurableObjectId` using the pathname from the Worker request
56
- // This id refers to a unique instance of our 'MyDurableObject' class above
57
- let id = env.MY_DURABLE_OBJECT.idFromName(new URL(request.url).pathname);
55
+ // Create a `DurableObjectId` for an instance of the `MyDurableObject`
56
+ // class named "foo". Requests from all Workers to the instance named
57
+ // "foo" will go to a single globally unique Durable Object instance.
58
+ const id = env.MY_DURABLE_OBJECT.idFromName("foo");
58
59
 
59
- // This stub creates a communication channel with the Durable Object instance
60
- // The Durable Object constructor will be invoked upon the first call for a given id
61
- let stub = env.MY_DURABLE_OBJECT.get(id);
60
+ // Create a stub to open a communication channel with the Durable
61
+ // Object instance.
62
+ const stub = env.MY_DURABLE_OBJECT.get(id);
62
63
 
63
- // We call the `sayHello()` RPC method on the stub to invoke the method on the remote
64
- // Durable Object instance
65
- let greeting = await stub.sayHello("world");
64
+ // Call the `sayHello()` RPC method on the stub to invoke the method on
65
+ // the remote Durable Object instance
66
+ const greeting = await stub.sayHello("world");
66
67
 
67
68
  return new Response(greeting);
68
69
  },
@@ -4,7 +4,7 @@
4
4
  "compatibility_date": "<TBD>",
5
5
  "migrations": [
6
6
  {
7
- "new_classes": [
7
+ "new_sqlite_classes": [
8
8
  "MyDurableObject"
9
9
  ],
10
10
  "tag": "v1"
@@ -7,7 +7,7 @@ import { DurableObject } from "cloudflare:workers";
7
7
  * - Open a browser tab at http://localhost:8787/ to see your Durable Object in action
8
8
  * - Run `npm run deploy` to publish your application
9
9
  *
10
- * Bind resources to your worker in `wrangler.toml`. After adding bindings, a type definition for the
10
+ * Bind resources to your worker in `wrangler.jsonc`. After adding bindings, a type definition for the
11
11
  * `Env` object can be regenerated with `npm run cf-typegen`.
12
12
  *
13
13
  * Learn more at https://developers.cloudflare.com/durable-objects
@@ -20,7 +20,7 @@ export class MyDurableObject extends DurableObject<Env> {
20
20
  * `DurableObjectStub::get` for a given identifier (no-op constructors can be omitted)
21
21
  *
22
22
  * @param ctx - The interface for interacting with Durable Object state
23
- * @param env - The interface to reference bindings declared in wrangler.toml
23
+ * @param env - The interface to reference bindings declared in wrangler.jsonc
24
24
  */
25
25
  constructor(ctx: DurableObjectState, env: Env) {
26
26
  super(ctx, env);
@@ -43,22 +43,23 @@ export default {
43
43
  * This is the standard fetch handler for a Cloudflare Worker
44
44
  *
45
45
  * @param request - The request submitted to the Worker from the client
46
- * @param env - The interface to reference bindings declared in wrangler.toml
46
+ * @param env - The interface to reference bindings declared in wrangler.jsonc
47
47
  * @param ctx - The execution context of the Worker
48
48
  * @returns The response to be sent back to the client
49
49
  */
50
50
  async fetch(request, env, ctx): Promise<Response> {
51
- // We will create a `DurableObjectId` using the pathname from the Worker request
52
- // This id refers to a unique instance of our 'MyDurableObject' class above
53
- let id: DurableObjectId = env.MY_DURABLE_OBJECT.idFromName(new URL(request.url).pathname);
51
+ // Create a `DurableObjectId` for an instance of the `MyDurableObject`
52
+ // class named "foo". Requests from all Workers to the instance named
53
+ // "foo" will go to a single globally unique Durable Object instance.
54
+ const id: DurableObjectId = env.MY_DURABLE_OBJECT.idFromName("foo");
54
55
 
55
- // This stub creates a communication channel with the Durable Object instance
56
- // The Durable Object constructor will be invoked upon the first call for a given id
57
- let stub = env.MY_DURABLE_OBJECT.get(id);
56
+ // Create a stub to open a communication channel with the Durable
57
+ // Object instance.
58
+ const stub = env.MY_DURABLE_OBJECT.get(id);
58
59
 
59
- // We call the `sayHello()` RPC method on the stub to invoke the method on the remote
60
- // Durable Object instance
61
- let greeting = await stub.sayHello("world");
60
+ // Call the `sayHello()` RPC method on the stub to invoke the method on
61
+ // the remote Durable Object instance
62
+ const greeting = await stub.sayHello("world");
62
63
 
63
64
  return new Response(greeting);
64
65
  },
@@ -1,5 +1,7 @@
1
- // Generated by Wrangler by running `wrangler types`
2
-
3
- interface Env {
4
- MY_DURABLE_OBJECT: DurableObjectNamespace<import("./src/index").MyDurableObject>;
1
+ // Generated by Wrangler by running `wrangler types --include-runtime=false` (hash: 4c81d17e8de07f650cddf73ce751ba8d)
2
+ declare namespace Cloudflare {
3
+ interface Env {
4
+ MY_DURABLE_OBJECT: DurableObjectNamespace<import("./src/index").MyDurableObject>;
5
+ }
5
6
  }
7
+ interface Env extends Cloudflare.Env {}
@@ -4,7 +4,7 @@
4
4
  "compatibility_date": "<TBD>",
5
5
  "migrations": [
6
6
  {
7
- "new_classes": [
7
+ "new_sqlite_classes": [
8
8
  "MyDurableObject"
9
9
  ],
10
10
  "tag": "v1"
@@ -3,10 +3,10 @@ import type { TemplateConfig } from "../../src/templates";
3
3
  const config: TemplateConfig = {
4
4
  configVersion: 1,
5
5
  id: "hello-world-durable-object-with-assets",
6
- path: "templates-experimental/hello-world-durable-object-with-assets",
7
- displayName: "Hello World - Worker Using Durable Objects with Assets",
6
+ path: "templates/hello-world-durable-object-with-assets",
7
+ displayName: "Worker + Durable Objects + Assets",
8
8
  description:
9
- "Get started with a basic stateful app to build projects like real-time chats, collaborative apps, and multiplayer games, which hosts assets",
9
+ "For full-stack applications requiring static assets, an API, and real-time coordination",
10
10
  platform: "workers",
11
11
  copyFiles: {
12
12
  variants: {