create-cloudflare 0.0.0-e2214012f → 0.0.0-e2472f152

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 (220) hide show
  1. package/dist/cli.js +14914 -14658
  2. package/dist/tsconfig.tsbuildinfo +1 -1
  3. package/package.json +17 -10
  4. package/templates/analog/templates/worker-configuration.d.ts +1 -1
  5. package/templates/analog/templates/wrangler.jsonc +5 -0
  6. package/templates/angular/c3.ts +5 -98
  7. package/templates/angular/pages/c3.ts +134 -0
  8. package/templates/angular/pages/templates/src/server.ts +15 -0
  9. package/templates/angular/pages/templates/tools/copy-files.mjs +15 -0
  10. package/{templates-experimental/angular → templates/angular/workers}/c3.ts +46 -14
  11. package/templates/angular/workers/templates/src/server.ts +15 -0
  12. package/templates/angular/workers/templates/wrangler.jsonc +12 -0
  13. package/templates/astro/c3.ts +17 -33
  14. package/templates/astro/templates/js/wrangler.jsonc +8 -0
  15. package/templates/astro/templates/ts/worker-configuration.d.ts +4 -0
  16. package/templates/astro/templates/ts/wrangler.jsonc +8 -0
  17. package/templates/common/js/package.json +1 -1
  18. package/templates/common/js/wrangler.jsonc +8 -0
  19. package/templates/common/ts/package.json +1 -1
  20. package/templates/common/ts/src/index.ts +1 -1
  21. package/templates/common/ts/worker-configuration.d.ts +1 -1
  22. package/templates/common/ts/wrangler.jsonc +8 -0
  23. package/templates/docusaurus/c3.ts +5 -24
  24. package/templates/docusaurus/pages/c3.ts +30 -0
  25. package/{templates-experimental/docusaurus → templates/docusaurus/workers}/c3.ts +3 -2
  26. package/templates/docusaurus/workers/templates/wrangler.jsonc +10 -0
  27. package/templates/gatsby/c3.ts +5 -45
  28. package/templates/gatsby/pages/c3.ts +50 -0
  29. package/{templates-experimental/gatsby → templates/gatsby/workers}/c3.ts +2 -2
  30. package/templates/gatsby/workers/templates/wrangler.jsonc +10 -0
  31. package/templates/hello-world/c3.ts +17 -1
  32. package/templates/hello-world/js/package.json +3 -3
  33. package/templates/hello-world/js/test/index.spec.js +1 -1
  34. package/templates/hello-world/js/vitest.config.js +1 -1
  35. package/templates/hello-world/js/wrangler.jsonc +8 -0
  36. package/templates/hello-world/py/.python-version +1 -0
  37. package/templates/hello-world/py/README.md +23 -0
  38. package/templates/hello-world/py/package.json +1 -1
  39. package/templates/hello-world/py/pyproject.toml +9 -0
  40. package/templates/hello-world/py/uv.lock +22 -0
  41. package/templates/hello-world/py/wrangler.jsonc +9 -0
  42. package/templates/hello-world/ts/package.json +3 -3
  43. package/templates/hello-world/ts/src/index.ts +1 -1
  44. package/templates/hello-world/ts/test/tsconfig.json +1 -1
  45. package/templates/hello-world/ts/vitest.config.mts +1 -1
  46. package/templates/hello-world/ts/worker-configuration.d.ts +1 -1
  47. package/templates/hello-world/ts/wrangler.jsonc +8 -0
  48. package/templates/hello-world-durable-object/js/package.json +1 -1
  49. package/templates/hello-world-durable-object/js/src/index.js +3 -3
  50. package/templates/hello-world-durable-object/js/wrangler.jsonc +24 -0
  51. package/templates/hello-world-durable-object/ts/package.json +1 -1
  52. package/templates/hello-world-durable-object/ts/src/index.ts +4 -4
  53. package/templates/hello-world-durable-object/ts/wrangler.jsonc +24 -0
  54. package/templates/hono/c3.ts +1 -0
  55. package/templates/hono/templates/worker-configuration.d.ts +1 -1
  56. package/templates/hono/templates/wrangler.jsonc +8 -0
  57. package/templates/next/README.md +3 -4
  58. package/templates/next/app/js/app/api/hello/route.js +4 -4
  59. package/templates/next/app/ts/app/api/hello/route.ts +4 -5
  60. package/templates/next/c3.ts +16 -31
  61. package/templates/next/wrangler.jsonc +8 -0
  62. package/templates/nuxt/c3.ts +5 -130
  63. package/templates/nuxt/pages/c3.ts +145 -0
  64. package/templates/nuxt/pages/templates/worker-configuration.d.ts +4 -0
  65. package/templates/nuxt/pages/templates/wrangler.jsonc +5 -0
  66. package/{templates-experimental/nuxt → templates/nuxt/workers}/c3.ts +14 -4
  67. package/templates/nuxt/workers/templates/worker-configuration.d.ts +4 -0
  68. package/templates/nuxt/workers/templates/wrangler.jsonc +12 -0
  69. package/templates/openapi/ts/package.json +1 -1
  70. package/templates/openapi/ts/worker-configuration.d.ts +1 -1
  71. package/templates/openapi/ts/wrangler.jsonc +8 -0
  72. package/templates/pre-existing/c3.ts +3 -3
  73. package/templates/pre-existing/js/package.json +1 -1
  74. package/templates/queues/js/package.json +1 -1
  75. package/templates/queues/js/wrangler.jsonc +21 -0
  76. package/templates/queues/ts/package.json +1 -1
  77. package/templates/queues/ts/src/index.ts +1 -1
  78. package/templates/queues/ts/worker-configuration.d.ts +1 -1
  79. package/templates/queues/ts/wrangler.jsonc +21 -0
  80. package/templates/qwik/c3.ts +3 -2
  81. package/templates/qwik/templates/worker-configuration.d.ts +1 -1
  82. package/templates/qwik/templates/wrangler.jsonc +8 -0
  83. package/templates/react/c3.ts +5 -57
  84. package/templates/react/pages/c3.ts +62 -0
  85. package/templates/react/workers/c3.ts +183 -0
  86. package/templates/react/workers/js/api/index.js +13 -0
  87. package/templates/react/workers/js/src/App.css +45 -0
  88. package/templates/react/workers/js/src/App.jsx +58 -0
  89. package/templates/react/workers/js/src/assets/Cloudflare_Logo.svg +51 -0
  90. package/templates/react/workers/js/wrangler.jsonc +9 -0
  91. package/templates/react/workers/ts/api/index.ts +13 -0
  92. package/templates/react/workers/ts/src/App.css +45 -0
  93. package/templates/react/workers/ts/src/App.tsx +58 -0
  94. package/templates/react/workers/ts/src/assets/Cloudflare_Logo.svg +51 -0
  95. package/templates/react/workers/ts/tsconfig.worker.json +8 -0
  96. package/templates/react/workers/ts/worker-configuration.d.ts +5 -0
  97. package/templates/react/workers/ts/wrangler.jsonc +9 -0
  98. package/templates/remix/templates/worker-configuration.d.ts +1 -1
  99. package/templates/remix/templates/wrangler.jsonc +5 -0
  100. package/templates/scheduled/js/package.json +1 -1
  101. package/templates/scheduled/js/src/index.js +1 -1
  102. package/templates/scheduled/js/wrangler.jsonc +13 -0
  103. package/templates/scheduled/ts/package.json +1 -1
  104. package/templates/scheduled/ts/src/index.ts +4 -4
  105. package/templates/scheduled/ts/worker-configuration.d.ts +1 -1
  106. package/templates/scheduled/ts/wrangler.jsonc +13 -0
  107. package/templates/solid/c3.ts +1 -1
  108. package/templates/solid/templates/wrangler.jsonc +8 -0
  109. package/templates/svelte/c3.ts +31 -4
  110. package/templates/svelte/templates/wrangler.jsonc +5 -0
  111. package/templates/vue/c3.ts +5 -25
  112. package/templates/vue/pages/c3.ts +30 -0
  113. package/templates/vue/workers/c3.ts +98 -0
  114. package/templates/vue/workers/js/server/index.js +13 -0
  115. package/templates/vue/workers/js/src/App.vue +107 -0
  116. package/templates/vue/workers/js/src/components/HelloWorld.vue +47 -0
  117. package/templates/vue/workers/js/vite.config.js +21 -0
  118. package/templates/vue/workers/js/wrangler.jsonc +12 -0
  119. package/templates/vue/workers/ts/server/index.ts +13 -0
  120. package/templates/vue/workers/ts/src/App.vue +107 -0
  121. package/templates/vue/workers/ts/src/components/HelloWorld.vue +44 -0
  122. package/templates/vue/workers/ts/tsconfig.worker.json +8 -0
  123. package/templates/vue/workers/ts/vite.config.ts +21 -0
  124. package/templates/vue/workers/ts/worker-configuration.d.ts +6 -0
  125. package/templates/vue/workers/ts/wrangler.jsonc +12 -0
  126. package/templates-experimental/astro/c3.ts +17 -33
  127. package/templates-experimental/astro/templates/js/wrangler.jsonc +15 -0
  128. package/templates-experimental/astro/templates/ts/worker-configuration.d.ts +4 -0
  129. package/templates-experimental/astro/templates/ts/wrangler.jsonc +15 -0
  130. package/templates-experimental/hello-world-assets-only/templates/wrangler.jsonc +10 -0
  131. package/templates-experimental/hello-world-durable-object-with-assets/js/package.json +1 -1
  132. package/templates-experimental/hello-world-durable-object-with-assets/js/src/index.js +3 -3
  133. package/templates-experimental/hello-world-durable-object-with-assets/js/wrangler.jsonc +28 -0
  134. package/templates-experimental/hello-world-durable-object-with-assets/ts/package.json +1 -1
  135. package/templates-experimental/hello-world-durable-object-with-assets/ts/src/index.ts +3 -3
  136. package/templates-experimental/hello-world-durable-object-with-assets/ts/wrangler.jsonc +28 -0
  137. package/templates-experimental/hello-world-with-assets/js/package.json +3 -3
  138. package/templates-experimental/hello-world-with-assets/js/vitest.config.js +1 -1
  139. package/templates-experimental/hello-world-with-assets/js/wrangler.jsonc +15 -0
  140. package/templates-experimental/hello-world-with-assets/py/package.json +1 -1
  141. package/templates-experimental/hello-world-with-assets/py/wrangler.jsonc +15 -0
  142. package/templates-experimental/hello-world-with-assets/ts/package.json +3 -3
  143. package/templates-experimental/hello-world-with-assets/ts/src/index.ts +1 -1
  144. package/templates-experimental/hello-world-with-assets/ts/vitest.config.mts +1 -1
  145. package/templates-experimental/hello-world-with-assets/ts/worker-configuration.d.ts +1 -1
  146. package/templates-experimental/hello-world-with-assets/ts/wrangler.jsonc +15 -0
  147. package/templates-experimental/hono/c3.ts +1 -0
  148. package/templates-experimental/hono/templates/worker-configuration.d.ts +1 -1
  149. package/templates-experimental/hono/templates/wrangler.jsonc +9 -0
  150. package/templates-experimental/next/c3.ts +38 -15
  151. package/templates-experimental/next/templates/.dev.vars +2 -0
  152. package/templates-experimental/next/templates/__dot__gitignore +2 -5
  153. package/templates-experimental/next/templates/cloudflare-env.d.ts +5 -0
  154. package/templates-experimental/next/templates/open-next.config.ts +28 -0
  155. package/templates-experimental/next/templates/wrangler.jsonc +13 -0
  156. package/templates-experimental/qwik/c3.ts +3 -2
  157. package/templates-experimental/qwik/templates/worker-configuration.d.ts +1 -1
  158. package/templates-experimental/qwik/templates/wrangler.jsonc +15 -0
  159. package/templates-experimental/solid/c3.ts +8 -51
  160. package/templates-experimental/solid/templates/wrangler.jsonc +15 -0
  161. package/templates-experimental/svelte/c3.ts +1 -4
  162. package/templates-experimental/svelte/templates/wrangler.jsonc +12 -0
  163. package/templates/analog/templates/wrangler.toml +0 -85
  164. package/templates/angular/templates/server.ts +0 -34
  165. package/templates/angular/templates/tools/alter-polyfills.mjs +0 -27
  166. package/templates/angular/templates/tools/copy-files.mjs +0 -9
  167. package/templates/angular/templates/tools/paths.mjs +0 -9
  168. package/templates/astro/templates/wrangler.toml +0 -86
  169. package/templates/common/js/wrangler.toml +0 -113
  170. package/templates/common/ts/wrangler.toml +0 -113
  171. package/templates/hello-world/js/wrangler.toml +0 -114
  172. package/templates/hello-world/py/wrangler.toml +0 -114
  173. package/templates/hello-world/ts/wrangler.toml +0 -114
  174. package/templates/hello-world-durable-object/js/wrangler.toml +0 -113
  175. package/templates/hello-world-durable-object/ts/wrangler.toml +0 -113
  176. package/templates/hono/templates/wrangler.toml +0 -113
  177. package/templates/next/wrangler.toml +0 -86
  178. package/templates/nuxt/templates/worker-configuration.d.ts +0 -4
  179. package/templates/nuxt/templates/wrangler.toml +0 -86
  180. package/templates/openapi/ts/wrangler.toml +0 -113
  181. package/templates/pre-existing/js/wrangler.toml +0 -4
  182. package/templates/queues/js/wrangler.toml +0 -118
  183. package/templates/queues/ts/wrangler.toml +0 -118
  184. package/templates/qwik/templates/wrangler.toml +0 -86
  185. package/templates/remix/templates/wrangler.toml +0 -85
  186. package/templates/scheduled/js/wrangler.toml +0 -119
  187. package/templates/scheduled/ts/wrangler.toml +0 -119
  188. package/templates/solid/templates/wrangler.toml +0 -84
  189. package/templates/svelte/js/wrangler.toml +0 -85
  190. package/templates/svelte/ts/wrangler.toml +0 -85
  191. package/templates-experimental/angular/templates/server.ts +0 -34
  192. package/templates-experimental/angular/templates/tools/alter-polyfills.mjs +0 -32
  193. package/templates-experimental/angular/templates/wrangler.toml +0 -11
  194. package/templates-experimental/astro/templates/wrangler.toml +0 -12
  195. package/templates-experimental/docusaurus/templates/wrangler.toml +0 -10
  196. package/templates-experimental/gatsby/templates/wrangler.toml +0 -10
  197. package/templates-experimental/hello-world-assets-only/templates/wrangler.toml +0 -10
  198. package/templates-experimental/hello-world-durable-object-with-assets/js/wrangler.toml +0 -24
  199. package/templates-experimental/hello-world-durable-object-with-assets/ts/wrangler.toml +0 -24
  200. package/templates-experimental/hello-world-with-assets/js/wrangler.toml +0 -12
  201. package/templates-experimental/hello-world-with-assets/py/wrangler.toml +0 -12
  202. package/templates-experimental/hello-world-with-assets/ts/wrangler.toml +0 -12
  203. package/templates-experimental/hono/templates/wrangler.toml +0 -5
  204. package/templates-experimental/next/templates/env.d.ts +0 -5
  205. package/templates-experimental/next/templates/wrangler.toml +0 -12
  206. package/templates-experimental/nuxt/templates/cloudflare-preset/nitro.config.ts +0 -27
  207. package/templates-experimental/nuxt/templates/worker-configuration.d.ts +0 -4
  208. package/templates-experimental/nuxt/templates/wrangler.toml +0 -11
  209. package/templates-experimental/qwik/templates/wrangler.toml +0 -12
  210. package/templates-experimental/solid/templates/wrangler.toml +0 -12
  211. package/templates-experimental/svelte/js/wrangler.toml +0 -11
  212. package/templates-experimental/svelte/ts/wrangler.toml +0 -11
  213. /package/templates/angular/{templates → pages/templates}/src/_routes.json +0 -0
  214. /package/templates/astro/{snippets/runtimeDeclaration.ts → templates/ts/src/env.d.ts} +0 -0
  215. /package/{templates-experimental/nuxt → templates/nuxt/pages}/templates/env.d.ts +0 -0
  216. /package/templates/nuxt/{templates → workers/templates}/env.d.ts +0 -0
  217. /package/templates-experimental/astro/templates/{public → js/public}/.assetsignore +0 -0
  218. /package/templates-experimental/{svelte/js/static → astro/templates/ts/public}/.assetsignore +0 -0
  219. /package/templates-experimental/astro/{snippets/runtimeDeclaration.ts → templates/ts/src/env.d.ts} +0 -0
  220. /package/templates-experimental/svelte/{ts → templates}/static/.assetsignore +0 -0
@@ -0,0 +1,8 @@
1
+ {
2
+ "name": "<TBD>",
3
+ "main": "src/index.ts",
4
+ "compatibility_date": "<TBD>",
5
+ "observability": {
6
+ "enabled": true
7
+ }
8
+ }
@@ -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;
@@ -0,0 +1,10 @@
1
+ {
2
+ "name": "<TBD>",
3
+ "compatibility_date": "<TBD>",
4
+ "assets": {
5
+ "directory": "./build"
6
+ },
7
+ "observability": {
8
+ "enabled": true
9
+ }
10
+ }
@@ -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: {
@@ -0,0 +1,10 @@
1
+ {
2
+ "name": "<TBD>",
3
+ "compatibility_date": "<TBD>",
4
+ "assets": {
5
+ "directory": "./public"
6
+ },
7
+ "observability": {
8
+ "enabled": true
9
+ }
10
+ }
@@ -1,9 +1,25 @@
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
8
  displayName: "Hello World Worker",
5
9
  description: "Get started with a basic Worker in the language of your choice",
6
10
  platform: "workers",
11
+ async configure(ctx) {
12
+ if (ctx.args.lang === "python") {
13
+ for (const file of ["pyproject.toml", "uv.lock"]) {
14
+ const contents = await readFile(
15
+ resolve(ctx.project.path, file),
16
+ "utf8",
17
+ );
18
+ const updated = contents.replaceAll(/<TBD>/g, ctx.project.name);
19
+ await writeFile(resolve(ctx.project.path, file), updated);
20
+ }
21
+ }
22
+ },
7
23
  copyFiles: {
8
24
  variants: {
9
25
  js: {
@@ -17,4 +33,4 @@ export default {
17
33
  },
18
34
  },
19
35
  },
20
- };
36
+ } satisfies TemplateConfig;
@@ -9,8 +9,8 @@
9
9
  "test": "vitest"
10
10
  },
11
11
  "devDependencies": {
12
- "@cloudflare/vitest-pool-workers": "^0.5.2",
13
- "wrangler": "^3.60.3",
14
- "vitest": "2.0.5"
12
+ "@cloudflare/vitest-pool-workers": "^0.7.5",
13
+ "wrangler": "^3.101.0",
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
  },
@@ -0,0 +1,8 @@
1
+ {
2
+ "name": "<TBD>",
3
+ "main": "src/index.js",
4
+ "compatibility_date": "<TBD>",
5
+ "observability": {
6
+ "enabled": true,
7
+ },
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.
@@ -8,6 +8,6 @@
8
8
  "start": "wrangler dev"
9
9
  },
10
10
  "devDependencies": {
11
- "wrangler": "^3.60.3"
11
+ "wrangler": "^3.101.0"
12
12
  }
13
13
  }
@@ -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
+ ]
@@ -0,0 +1,9 @@
1
+ {
2
+ "name": "<TBD>",
3
+ "main": "src/entry.py",
4
+ "compatibility_date": "<TBD>",
5
+ "compatibility_flags": ["python_workers"],
6
+ "observability": {
7
+ "enabled": true,
8
+ },
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.0.5",
16
- "wrangler": "^3.60.3"
15
+ "vitest": "~3.0.7",
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/
@@ -3,6 +3,6 @@
3
3
  "compilerOptions": {
4
4
  "types": ["@cloudflare/workers-types/experimental", "@cloudflare/vitest-pool-workers"]
5
5
  },
6
- "include": ["./**/*.ts", "../src/env.d.ts"],
6
+ "include": ["./**/*.ts", "../worker-configuration.d.ts"],
7
7
  "exclude": []
8
8
  }
@@ -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,4 @@
1
1
  // Generated by Wrangler
2
- // After adding bindings to `wrangler.toml`, regenerate this interface via `npm run cf-typegen`
2
+ // After adding bindings to `wrangler.jsonc`, regenerate this interface via `npm run cf-typegen`
3
3
  interface Env {
4
4
  }
@@ -0,0 +1,8 @@
1
+ {
2
+ "name": "<TBD>",
3
+ "main": "src/index.ts",
4
+ "compatibility_date": "<TBD>",
5
+ "observability": {
6
+ "enabled": true,
7
+ },
8
+ }
@@ -8,6 +8,6 @@
8
8
  "start": "wrangler dev"
9
9
  },
10
10
  "devDependencies": {
11
- "wrangler": "^3.60.3"
11
+ "wrangler": "^3.101.0"
12
12
  }
13
13
  }
@@ -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,7 +47,7 @@ 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
  */
@@ -0,0 +1,24 @@
1
+ {
2
+ "name": "<TBD>",
3
+ "main": "src/index.js",
4
+ "compatibility_date": "<TBD>",
5
+ "migrations": [
6
+ {
7
+ "new_classes": [
8
+ "MyDurableObject"
9
+ ],
10
+ "tag": "v1"
11
+ }
12
+ ],
13
+ "durable_objects": {
14
+ "bindings": [
15
+ {
16
+ "class_name": "MyDurableObject",
17
+ "name": "MY_DURABLE_OBJECT"
18
+ }
19
+ ]
20
+ },
21
+ "observability": {
22
+ "enabled": true
23
+ }
24
+ }
@@ -10,6 +10,6 @@
10
10
  },
11
11
  "devDependencies": {
12
12
  "typescript": "^5.5.2",
13
- "wrangler": "^3.60.3"
13
+ "wrangler": "^3.101.0"
14
14
  }
15
15
  }
@@ -7,20 +7,20 @@ 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
14
14
  */
15
15
 
16
16
  /** A Durable Object's behavior is defined in an exported Javascript class */
17
- export class MyDurableObject extends DurableObject {
17
+ export class MyDurableObject extends DurableObject<Env> {
18
18
  /**
19
19
  * The constructor is invoked once upon creation of the Durable Object, i.e. the first call to
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,7 +43,7 @@ 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
  */
@@ -0,0 +1,24 @@
1
+ {
2
+ "name": "<TBD>",
3
+ "main": "src/index.ts",
4
+ "compatibility_date": "<TBD>",
5
+ "migrations": [
6
+ {
7
+ "new_classes": [
8
+ "MyDurableObject"
9
+ ],
10
+ "tag": "v1"
11
+ }
12
+ ],
13
+ "durable_objects": {
14
+ "bindings": [
15
+ {
16
+ "class_name": "MyDurableObject",
17
+ "name": "MY_DURABLE_OBJECT"
18
+ }
19
+ ]
20
+ },
21
+ "observability": {
22
+ "enabled": true
23
+ }
24
+ }
@@ -65,5 +65,6 @@ const config: TemplateConfig = {
65
65
  }),
66
66
  devScript: "dev",
67
67
  deployScript: "deploy",
68
+ previewScript: "dev",
68
69
  };
69
70
  export default config;
@@ -1,4 +1,4 @@
1
1
  // Generated by Wrangler
2
- // After adding bindings to `wrangler.toml`, regenerate this interface via `npm run cf-typegen`
2
+ // After adding bindings to `wrangler.jsonc`, regenerate this interface via `npm run cf-typegen`
3
3
  interface CloudflareBindings {
4
4
  }
@@ -0,0 +1,8 @@
1
+ {
2
+ "name": "<TBD>",
3
+ "main": "src/index.ts",
4
+ "compatibility_date": "<TBD>",
5
+ "observability": {
6
+ "enabled": true
7
+ }
8
+ }
@@ -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