create-cloudflare 0.0.0-ee305dd67 → 0.0.0-ee4873c96

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 (170) hide show
  1. package/dist/cli.js +6623 -7974
  2. package/dist/tsconfig.tsbuildinfo +1 -1
  3. package/package.json +12 -7
  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 +25 -13
  7. package/templates/angular/templates/src/server.ts +15 -0
  8. package/templates/angular/templates/tools/copy-files.mjs +8 -2
  9. package/templates/astro/c3.ts +17 -33
  10. package/templates/astro/templates/js/wrangler.jsonc +8 -0
  11. package/templates/astro/templates/ts/worker-configuration.d.ts +4 -0
  12. package/templates/astro/templates/ts/wrangler.jsonc +8 -0
  13. package/templates/common/js/package.json +1 -1
  14. package/templates/common/js/wrangler.jsonc +8 -0
  15. package/templates/common/ts/package.json +1 -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/common/ts/wrangler.jsonc +8 -0
  19. package/templates/hello-world/js/package.json +3 -3
  20. package/templates/hello-world/js/test/index.spec.js +1 -1
  21. package/templates/hello-world/js/vitest.config.js +1 -1
  22. package/templates/hello-world/js/wrangler.jsonc +8 -0
  23. package/templates/hello-world/py/package.json +1 -1
  24. package/templates/hello-world/py/wrangler.jsonc +9 -0
  25. package/templates/hello-world/ts/package.json +3 -3
  26. package/templates/hello-world/ts/src/index.ts +1 -1
  27. package/templates/hello-world/ts/test/tsconfig.json +1 -1
  28. package/templates/hello-world/ts/vitest.config.mts +1 -1
  29. package/templates/hello-world/ts/worker-configuration.d.ts +1 -1
  30. package/templates/hello-world/ts/wrangler.jsonc +8 -0
  31. package/templates/hello-world-durable-object/js/package.json +1 -1
  32. package/templates/hello-world-durable-object/js/src/index.js +3 -3
  33. package/templates/hello-world-durable-object/js/wrangler.jsonc +24 -0
  34. package/templates/hello-world-durable-object/ts/package.json +1 -1
  35. package/templates/hello-world-durable-object/ts/src/index.ts +4 -4
  36. package/templates/hello-world-durable-object/ts/wrangler.jsonc +24 -0
  37. package/templates/hono/templates/worker-configuration.d.ts +1 -1
  38. package/templates/hono/templates/wrangler.jsonc +8 -0
  39. package/templates/next/README.md +3 -4
  40. package/templates/next/app/js/app/api/hello/route.js +4 -4
  41. package/templates/next/app/ts/app/api/hello/route.ts +4 -5
  42. package/templates/next/c3.ts +12 -30
  43. package/templates/next/wrangler.jsonc +8 -0
  44. package/templates/nuxt/c3.ts +1 -1
  45. package/templates/nuxt/templates/worker-configuration.d.ts +1 -1
  46. package/templates/nuxt/templates/wrangler.jsonc +8 -0
  47. package/templates/openapi/ts/package.json +1 -1
  48. package/templates/openapi/ts/worker-configuration.d.ts +1 -1
  49. package/templates/openapi/ts/wrangler.jsonc +8 -0
  50. package/templates/pre-existing/c3.ts +3 -3
  51. package/templates/pre-existing/js/package.json +1 -1
  52. package/templates/pre-existing/js/wrangler.jsonc +5 -0
  53. package/templates/queues/js/package.json +1 -1
  54. package/templates/queues/js/wrangler.jsonc +21 -0
  55. package/templates/queues/ts/package.json +1 -1
  56. package/templates/queues/ts/src/index.ts +1 -1
  57. package/templates/queues/ts/worker-configuration.d.ts +1 -1
  58. package/templates/queues/ts/wrangler.jsonc +21 -0
  59. package/templates/qwik/templates/worker-configuration.d.ts +1 -1
  60. package/templates/qwik/templates/wrangler.jsonc +8 -0
  61. package/templates/remix/templates/worker-configuration.d.ts +1 -1
  62. package/templates/remix/templates/wrangler.jsonc +5 -0
  63. package/templates/scheduled/js/package.json +1 -1
  64. package/templates/scheduled/js/src/index.js +1 -1
  65. package/templates/scheduled/js/wrangler.jsonc +13 -0
  66. package/templates/scheduled/ts/package.json +1 -1
  67. package/templates/scheduled/ts/src/index.ts +4 -4
  68. package/templates/scheduled/ts/worker-configuration.d.ts +1 -1
  69. package/templates/scheduled/ts/wrangler.jsonc +13 -0
  70. package/templates/solid/c3.ts +1 -1
  71. package/templates/solid/templates/wrangler.jsonc +8 -0
  72. package/templates/svelte/c3.ts +31 -4
  73. package/templates/svelte/templates/wrangler.jsonc +5 -0
  74. package/templates-experimental/angular/c3.ts +21 -7
  75. package/templates-experimental/angular/templates/src/server.ts +15 -0
  76. package/templates-experimental/angular/templates/wrangler.jsonc +12 -0
  77. package/templates-experimental/astro/c3.ts +17 -33
  78. package/templates-experimental/astro/templates/js/wrangler.jsonc +15 -0
  79. package/templates-experimental/astro/templates/ts/worker-configuration.d.ts +4 -0
  80. package/templates-experimental/astro/templates/ts/wrangler.jsonc +15 -0
  81. package/templates-experimental/docusaurus/templates/wrangler.jsonc +10 -0
  82. package/templates-experimental/gatsby/templates/wrangler.jsonc +10 -0
  83. package/templates-experimental/hello-world-assets-only/templates/wrangler.jsonc +10 -0
  84. package/templates-experimental/hello-world-durable-object-with-assets/js/package.json +1 -1
  85. package/templates-experimental/hello-world-durable-object-with-assets/js/src/index.js +3 -3
  86. package/templates-experimental/hello-world-durable-object-with-assets/js/wrangler.jsonc +28 -0
  87. package/templates-experimental/hello-world-durable-object-with-assets/ts/package.json +1 -1
  88. package/templates-experimental/hello-world-durable-object-with-assets/ts/src/index.ts +3 -3
  89. package/templates-experimental/hello-world-durable-object-with-assets/ts/wrangler.jsonc +28 -0
  90. package/templates-experimental/hello-world-with-assets/js/package.json +3 -3
  91. package/templates-experimental/hello-world-with-assets/js/vitest.config.js +1 -1
  92. package/templates-experimental/hello-world-with-assets/js/wrangler.jsonc +15 -0
  93. package/templates-experimental/hello-world-with-assets/py/package.json +1 -1
  94. package/templates-experimental/hello-world-with-assets/py/wrangler.jsonc +15 -0
  95. package/templates-experimental/hello-world-with-assets/ts/package.json +3 -3
  96. package/templates-experimental/hello-world-with-assets/ts/src/index.ts +1 -1
  97. package/templates-experimental/hello-world-with-assets/ts/vitest.config.mts +1 -1
  98. package/templates-experimental/hello-world-with-assets/ts/worker-configuration.d.ts +1 -1
  99. package/templates-experimental/hello-world-with-assets/ts/wrangler.jsonc +15 -0
  100. package/templates-experimental/hono/templates/worker-configuration.d.ts +1 -1
  101. package/templates-experimental/hono/templates/wrangler.jsonc +9 -0
  102. package/templates-experimental/next/c3.ts +37 -5
  103. package/templates-experimental/next/templates/.dev.vars +2 -0
  104. package/templates-experimental/next/templates/__dot__gitignore +2 -5
  105. package/templates-experimental/next/templates/cloudflare-env.d.ts +5 -0
  106. package/templates-experimental/next/templates/open-next.config.ts +28 -0
  107. package/templates-experimental/next/templates/wrangler.jsonc +13 -0
  108. package/templates-experimental/nuxt/c3.ts +2 -2
  109. package/templates-experimental/nuxt/templates/worker-configuration.d.ts +1 -1
  110. package/templates-experimental/nuxt/templates/wrangler.jsonc +12 -0
  111. package/templates-experimental/qwik/templates/worker-configuration.d.ts +1 -1
  112. package/templates-experimental/qwik/templates/wrangler.jsonc +15 -0
  113. package/templates-experimental/solid/c3.ts +8 -51
  114. package/templates-experimental/solid/templates/wrangler.jsonc +15 -0
  115. package/templates-experimental/svelte/c3.ts +1 -4
  116. package/templates-experimental/svelte/templates/wrangler.jsonc +12 -0
  117. package/templates-experimental/vue/c3.ts +33 -0
  118. package/templates-experimental/vue/templates/wrangler.jsonc +10 -0
  119. package/templates/analog/templates/wrangler.toml +0 -85
  120. package/templates/angular/templates/server.ts +0 -34
  121. package/templates/angular/templates/tools/alter-polyfills.mjs +0 -27
  122. package/templates/angular/templates/tools/paths.mjs +0 -9
  123. package/templates/astro/templates/wrangler.toml +0 -86
  124. package/templates/common/js/wrangler.toml +0 -113
  125. package/templates/common/ts/wrangler.toml +0 -113
  126. package/templates/hello-world/js/wrangler.toml +0 -114
  127. package/templates/hello-world/py/wrangler.toml +0 -114
  128. package/templates/hello-world/ts/wrangler.toml +0 -114
  129. package/templates/hello-world-durable-object/js/wrangler.toml +0 -113
  130. package/templates/hello-world-durable-object/ts/wrangler.toml +0 -113
  131. package/templates/hono/templates/wrangler.toml +0 -113
  132. package/templates/next/wrangler.toml +0 -86
  133. package/templates/nuxt/templates/wrangler.toml +0 -86
  134. package/templates/openapi/ts/wrangler.toml +0 -113
  135. package/templates/pre-existing/js/wrangler.toml +0 -4
  136. package/templates/queues/js/wrangler.toml +0 -118
  137. package/templates/queues/ts/wrangler.toml +0 -118
  138. package/templates/qwik/templates/wrangler.toml +0 -86
  139. package/templates/remix/templates/wrangler.toml +0 -85
  140. package/templates/scheduled/js/wrangler.toml +0 -119
  141. package/templates/scheduled/ts/wrangler.toml +0 -119
  142. package/templates/solid/templates/wrangler.toml +0 -84
  143. package/templates/svelte/js/wrangler.toml +0 -85
  144. package/templates/svelte/ts/wrangler.toml +0 -85
  145. package/templates-experimental/angular/templates/server.ts +0 -34
  146. package/templates-experimental/angular/templates/tools/alter-polyfills.mjs +0 -32
  147. package/templates-experimental/angular/templates/wrangler.toml +0 -11
  148. package/templates-experimental/astro/templates/wrangler.toml +0 -12
  149. package/templates-experimental/docusaurus/templates/wrangler.toml +0 -10
  150. package/templates-experimental/gatsby/templates/wrangler.toml +0 -10
  151. package/templates-experimental/hello-world-assets-only/templates/wrangler.toml +0 -10
  152. package/templates-experimental/hello-world-durable-object-with-assets/js/wrangler.toml +0 -24
  153. package/templates-experimental/hello-world-durable-object-with-assets/ts/wrangler.toml +0 -24
  154. package/templates-experimental/hello-world-with-assets/js/wrangler.toml +0 -12
  155. package/templates-experimental/hello-world-with-assets/py/wrangler.toml +0 -12
  156. package/templates-experimental/hello-world-with-assets/ts/wrangler.toml +0 -12
  157. package/templates-experimental/hono/templates/wrangler.toml +0 -5
  158. package/templates-experimental/next/templates/env.d.ts +0 -5
  159. package/templates-experimental/next/templates/wrangler.toml +0 -12
  160. package/templates-experimental/nuxt/templates/cloudflare-preset/nitro.config.ts +0 -27
  161. package/templates-experimental/nuxt/templates/wrangler.toml +0 -11
  162. package/templates-experimental/qwik/templates/wrangler.toml +0 -12
  163. package/templates-experimental/solid/templates/wrangler.toml +0 -12
  164. package/templates-experimental/svelte/js/wrangler.toml +0 -11
  165. package/templates-experimental/svelte/ts/wrangler.toml +0 -11
  166. /package/templates/astro/{snippets/runtimeDeclaration.ts → templates/ts/src/env.d.ts} +0 -0
  167. /package/templates-experimental/astro/templates/{public → js/public}/.assetsignore +0 -0
  168. /package/templates-experimental/{svelte/js/static → astro/templates/ts/public}/.assetsignore +0 -0
  169. /package/templates-experimental/astro/{snippets/runtimeDeclaration.ts → templates/ts/src/env.d.ts} +0 -0
  170. /package/templates-experimental/svelte/{ts → templates}/static/.assetsignore +0 -0
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "create-cloudflare",
3
- "version": "0.0.0-ee305dd67",
3
+ "version": "0.0.0-ee4873c96",
4
4
  "description": "A CLI for creating and deploying new applications to Cloudflare.",
5
5
  "keywords": [
6
6
  "cloudflare",
@@ -30,7 +30,7 @@
30
30
  "@babel/parser": "^7.21.3",
31
31
  "@babel/types": "^7.21.4",
32
32
  "@clack/prompts": "^0.6.3",
33
- "@cloudflare/workers-types": "^4.20241106.0",
33
+ "@cloudflare/workers-types": "^4.20250204.0",
34
34
  "@iarna/toml": "^3.0.0",
35
35
  "@types/command-exists": "^1.2.0",
36
36
  "@types/cross-spawn": "^6.0.2",
@@ -38,7 +38,7 @@
38
38
  "@types/degit": "^2.8.6",
39
39
  "@types/dns2": "^2.0.3",
40
40
  "@types/esprima": "^4.0.3",
41
- "@types/node": "^18.19.59",
41
+ "@types/node": "^18.19.71",
42
42
  "@types/semver": "^7.5.1",
43
43
  "@types/which-pm-runs": "^1.0.0",
44
44
  "@types/yargs": "^17.0.22",
@@ -60,22 +60,27 @@
60
60
  "open": "^8.4.0",
61
61
  "recast": "^0.22.0",
62
62
  "semver": "^7.5.1",
63
+ "typescript": "^5.7.2",
63
64
  "undici": "^5.28.4",
65
+ "vite": "^5.4.14",
64
66
  "vite-tsconfig-paths": "^4.0.8",
67
+ "vitest": "~2.1.9",
65
68
  "which-pm-runs": "^1.1.0",
66
69
  "wrap-ansi": "^9.0.0",
67
70
  "xdg-app-paths": "^8.3.0",
68
71
  "yargs": "^17.7.2",
69
72
  "@cloudflare/eslint-config-worker": "1.1.0",
73
+ "@cloudflare/mock-npm-registry": "0.0.0",
74
+ "wrangler": "0.0.0-ee4873c96",
70
75
  "@cloudflare/workers-tsconfig": "0.0.0",
71
- "@cloudflare/cli": "1.1.1",
72
- "wrangler": "0.0.0-ee305dd67"
76
+ "@cloudflare/cli": "1.1.1"
73
77
  },
74
78
  "engines": {
75
79
  "node": ">=18.14.1"
76
80
  },
77
81
  "workers-sdk": {
78
- "prerelease": true
82
+ "prerelease": true,
83
+ "type": "cli"
79
84
  },
80
85
  "volta": {
81
86
  "extends": "../../package.json"
@@ -92,7 +97,7 @@
92
97
  "test:e2e:yarn": "pnpm run build && cross-env TEST_PM=yarn vitest run --config ./vitest-e2e.config.mts",
93
98
  "test:unit": "vitest run --config ./vitest.config.mts",
94
99
  "test:unit:watch": "vitest --config ./vitest.config.mts",
95
- "watch": "node -r esbuild-register scripts/build.ts --watch",
100
+ "dev": "node -r esbuild-register scripts/build.ts --watch",
96
101
  "test:ci": "vitest run --config ./vitest.config.mts"
97
102
  }
98
103
  }
@@ -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,5 @@
1
+ {
2
+ "name": "<TBD>",
3
+ "compatibility_date": "<TBD>",
4
+ "pages_build_output_dir": "./dist/analog/public"
5
+ }
@@ -13,7 +13,11 @@ import type { C3Context } from "types";
13
13
  const { npm } = detectPackageManager();
14
14
 
15
15
  const generate = async (ctx: C3Context) => {
16
- await runFrameworkGenerator(ctx, [ctx.project.name, "--ssr"]);
16
+ await runFrameworkGenerator(ctx, [
17
+ ctx.project.name,
18
+ "--ssr",
19
+ "--server-routing" /** Dev Preview API */,
20
+ ]);
17
21
  logRaw("");
18
22
  };
19
23
 
@@ -24,14 +28,11 @@ const configure = async (ctx: C3Context) => {
24
28
  };
25
29
 
26
30
  async function installCFWorker() {
27
- await installPackages(
28
- ["@cloudflare/workers-types", "@miniflare/tre@next", "wrangler@beta"],
29
- {
30
- dev: true,
31
- startText: "Installing adapter dependencies",
32
- doneText: `${brandColor("installed")} ${dim(`via \`${npm} install\``)}`,
33
- },
34
- );
31
+ await installPackages(["xhr2"], {
32
+ dev: true,
33
+ startText: "Installing additional dependencies",
34
+ doneText: `${brandColor("installed")} ${dim(`via \`${npm} install\``)}`,
35
+ });
35
36
  }
36
37
  async function updateAppCode() {
37
38
  const s = spinner();
@@ -50,12 +51,21 @@ async function updateAppCode() {
50
51
  writeFile(resolve(appConfigPath), newAppConfig);
51
52
  s.stop(`${brandColor(`updated`)} ${dim(appConfigPath)}`);
52
53
 
54
+ // Update an app server routes file to:
55
+ const appServerRoutesPath = "src/app/app.routes.server.ts";
56
+ const appRoutes = readFile(resolve(appServerRoutesPath));
57
+ const newAppRoutes = appRoutes.replace(
58
+ "RenderMode.Prerender",
59
+ "RenderMode.Server",
60
+ );
61
+ writeFile(resolve(appServerRoutesPath), newAppRoutes);
62
+ s.stop(`${brandColor(`updated`)} ${dim(appServerRoutesPath)}`);
63
+
53
64
  // Remove unwanted dependencies
54
65
  s.start(`Updating package.json`);
55
66
  const packageJsonPath = resolve("package.json");
56
67
  const packageManifest = readJSON(packageJsonPath);
57
68
 
58
- delete packageManifest["dependencies"]["@angular/ssr"];
59
69
  delete packageManifest["dependencies"]["express"];
60
70
  delete packageManifest["devDependencies"]["@types/express"];
61
71
 
@@ -70,6 +80,8 @@ function updateAngularJson(ctx: C3Context) {
70
80
  // Update builder
71
81
  const architectSection = angularJson.projects[ctx.project.name].architect;
72
82
  architectSection.build.options.outputPath = "dist";
83
+ architectSection.build.options.outputMode = "server";
84
+ architectSection.build.options.ssr.experimentalPlatform = "neutral";
73
85
  architectSection.build.options.assets.push("src/_routes.json");
74
86
 
75
87
  writeFile(resolve("angular.json"), JSON.stringify(angularJson, null, 2));
@@ -87,14 +99,14 @@ const config: TemplateConfig = {
87
99
  },
88
100
  devScript: "start",
89
101
  deployScript: "deploy",
102
+ previewScript: "start",
90
103
  generate,
91
104
  configure,
92
105
  transformPackageJson: async () => ({
93
106
  scripts: {
94
- start: `${npm} run build && wrangler pages dev dist/cloudflare ${await compatDateFlag()} --experimental-local`,
107
+ start: `${npm} run build && wrangler pages dev dist/cloudflare ${await compatDateFlag()}`,
95
108
  build: `ng build && ${npm} run process`,
96
- process:
97
- "node ./tools/copy-files.mjs && node ./tools/alter-polyfills.mjs",
109
+ process: "node ./tools/copy-files.mjs",
98
110
  deploy: `${npm} run build && wrangler pages deploy dist/cloudflare`,
99
111
  },
100
112
  }),
@@ -0,0 +1,15 @@
1
+ import { AngularAppEngine, createRequestHandler } from '@angular/ssr';
2
+
3
+ const angularApp = new AngularAppEngine();
4
+
5
+ /**
6
+ * This is a request handler used by the Angular CLI (dev-server and during build).
7
+ */
8
+ export const reqHandler = createRequestHandler(async (req) => {
9
+ const res = await angularApp.handle(req);
10
+
11
+ return res ?? new Response('Page not found.', { status: 404 });
12
+ });
13
+
14
+
15
+ export default { fetch: reqHandler };
@@ -1,7 +1,13 @@
1
1
  // Copy the files over so that they can be uploaded by the pages publish command.
2
2
  import fs from "node:fs";
3
- import { join } from "node:path";
4
- import { client, cloudflare, ssr, worker } from "./paths.mjs";
3
+ import { join, resolve } from "node:path";
4
+ import { fileURLToPath } from "node:url";
5
+
6
+ const root = resolve(fileURLToPath(import.meta.url), "../../");
7
+ const client = resolve(root, "dist/browser");
8
+ const ssr = resolve(root, "dist/server");
9
+ const cloudflare = resolve(root, "dist/cloudflare");
10
+ const worker = resolve(cloudflare, "_worker.js");
5
11
 
6
12
  fs.cpSync(client, cloudflare, { recursive: true });
7
13
  fs.cpSync(ssr, worker, { recursive: true });
@@ -1,7 +1,7 @@
1
1
  import { logRaw, updateStatus } from "@cloudflare/cli";
2
2
  import { blue, brandColor, dim } from "@cloudflare/cli/colors";
3
3
  import { runFrameworkGenerator } from "frameworks/index";
4
- import { loadTemplateSnippets, transformFile } from "helpers/codemod";
4
+ import { transformFile } from "helpers/codemod";
5
5
  import { runCommand } from "helpers/command";
6
6
  import { usesTypescript } from "helpers/files";
7
7
  import { detectPackageManager } from "helpers/packageManagers";
@@ -17,7 +17,7 @@ const generate = async (ctx: C3Context) => {
17
17
  logRaw(""); // newline
18
18
  };
19
19
 
20
- const configure = async (ctx: C3Context) => {
20
+ const configure = async () => {
21
21
  await runCommand([npx, "astro", "add", "cloudflare", "-y"], {
22
22
  silent: true,
23
23
  startText: "Installing adapter",
@@ -27,7 +27,6 @@ const configure = async (ctx: C3Context) => {
27
27
  });
28
28
 
29
29
  updateAstroConfig();
30
- updateEnvDeclaration(ctx);
31
30
  };
32
31
 
33
32
  const updateAstroConfig = () => {
@@ -59,35 +58,6 @@ const updateAstroConfig = () => {
59
58
  });
60
59
  };
61
60
 
62
- const updateEnvDeclaration = (ctx: C3Context) => {
63
- if (!usesTypescript(ctx)) {
64
- return;
65
- }
66
-
67
- const filePath = "src/env.d.ts";
68
-
69
- updateStatus(`Adding type declarations in ${blue(filePath)}`);
70
-
71
- transformFile(filePath, {
72
- visitProgram: function (n) {
73
- const snippets = loadTemplateSnippets(ctx);
74
- const patch = snippets.runtimeDeclarationTs;
75
- const b = recast.types.builders;
76
-
77
- // Preserve comments with the new body
78
- const comments = n.get("comments").value;
79
- n.node.comments = comments.map((c: recast.types.namedTypes.CommentLine) =>
80
- b.commentLine(c.value),
81
- );
82
-
83
- // Add the patch
84
- n.get("body").push(...patch);
85
-
86
- return false;
87
- },
88
- });
89
- };
90
-
91
61
  const config: TemplateConfig = {
92
62
  configVersion: 1,
93
63
  id: "astro",
@@ -95,7 +65,21 @@ const config: TemplateConfig = {
95
65
  platform: "pages",
96
66
  displayName: "Astro",
97
67
  copyFiles: {
98
- path: "./templates",
68
+ async selectVariant(ctx) {
69
+ // Note: this `selectVariant` function should not be needed
70
+ // this is just a quick workaround until
71
+ // https://github.com/cloudflare/workers-sdk/issues/7495
72
+ // is resolved
73
+ return usesTypescript(ctx) ? "ts" : "js";
74
+ },
75
+ variants: {
76
+ js: {
77
+ path: "./templates/js",
78
+ },
79
+ ts: {
80
+ path: "./templates/ts",
81
+ },
82
+ },
99
83
  },
100
84
  devScript: "dev",
101
85
  deployScript: "deploy",
@@ -0,0 +1,8 @@
1
+ {
2
+ "name": "<TBD>",
3
+ "compatibility_date": "<TBD>",
4
+ "compatibility_flags": [
5
+ "nodejs_compat"
6
+ ],
7
+ "pages_build_output_dir": "./dist"
8
+ }
@@ -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,8 @@
1
+ {
2
+ "name": "<TBD>",
3
+ "compatibility_date": "<TBD>",
4
+ "compatibility_flags": [
5
+ "nodejs_compat"
6
+ ],
7
+ "pages_build_output_dir": "./dist"
8
+ }
@@ -9,6 +9,6 @@
9
9
  },
10
10
  "devDependencies": {
11
11
  "itty-router": "^3.0.12",
12
- "wrangler": "^3.60.3"
12
+ "wrangler": "^3.101.0"
13
13
  }
14
14
  }
@@ -0,0 +1,8 @@
1
+ {
2
+ "name": "<TBD>",
3
+ "main": "src/index.js",
4
+ "compatibility_date": "<TBD>",
5
+ "observability": {
6
+ "enabled": true
7
+ }
8
+ }
@@ -11,6 +11,6 @@
11
11
  "devDependencies": {
12
12
  "itty-router": "^3.0.12",
13
13
  "typescript": "^5.5.2",
14
- "wrangler": "^3.60.3"
14
+ "wrangler": "^3.101.0"
15
15
  }
16
16
  }
@@ -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/
@@ -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
+ }
@@ -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.6.4",
13
+ "wrangler": "^3.101.0",
14
+ "vitest": "~2.1.9"
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
+ }
@@ -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
+ {
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.6.4",
14
14
  "typescript": "^5.5.2",
15
- "vitest": "2.0.5",
16
- "wrangler": "^3.60.3"
15
+ "vitest": "~2.1.9",
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
+ }
@@ -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