create-cloudflare 0.0.0-e7ccc859 → 0.0.0-e7ea6005c

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 (221) hide show
  1. package/README.md +1 -1
  2. package/dist/cli.js +59166 -56638
  3. package/dist/tsconfig.tsbuildinfo +1 -0
  4. package/package.json +29 -24
  5. package/templates/analog/c3.ts +135 -0
  6. package/templates/analog/snippets/devBindingsModule.ts +7 -0
  7. package/templates/analog/templates/env.d.ts +13 -0
  8. package/templates/analog/templates/src/dev-bindings.ts +18 -0
  9. package/templates/analog/templates/worker-configuration.d.ts +4 -0
  10. package/templates/analog/templates/wrangler.toml +85 -0
  11. package/templates/angular/c3.ts +14 -11
  12. package/templates/astro/c3.ts +83 -20
  13. package/templates/astro/snippets/runtimeDeclaration.ts +5 -0
  14. package/templates/astro/templates/wrangler.toml +85 -0
  15. package/templates/common/c3.ts +10 -5
  16. package/templates/common/js/.editorconfig +0 -1
  17. package/templates/common/js/package.json +1 -1
  18. package/templates/common/js/wrangler.toml +84 -22
  19. package/templates/common/ts/.editorconfig +0 -1
  20. package/templates/common/ts/package.json +4 -3
  21. package/templates/common/ts/src/ab-test.ts +2 -2
  22. package/templates/common/ts/src/index.ts +5 -2
  23. package/templates/common/ts/src/proxy.ts +2 -2
  24. package/templates/common/ts/src/redirect.ts +2 -2
  25. package/templates/common/ts/tsconfig.json +37 -95
  26. package/templates/common/ts/worker-configuration.d.ts +2 -14
  27. package/templates/common/ts/wrangler.toml +84 -22
  28. package/templates/docusaurus/c3.ts +7 -6
  29. package/templates/gatsby/c3.ts +8 -5
  30. package/templates/hello-world/c3.ts +12 -6
  31. package/templates/hello-world/js/.editorconfig +0 -1
  32. package/templates/hello-world/js/package.json +5 -2
  33. package/templates/hello-world/js/test/index.spec.js +20 -0
  34. package/templates/hello-world/js/vitest.config.js +11 -0
  35. package/templates/hello-world/js/wrangler.toml +85 -22
  36. package/templates/hello-world/py/__dot__gitignore +68 -0
  37. package/templates/hello-world/py/package.json +13 -0
  38. package/templates/hello-world/py/src/entry.py +4 -0
  39. package/templates/hello-world/py/wrangler.toml +114 -0
  40. package/templates/hello-world/ts/.editorconfig +0 -1
  41. package/templates/hello-world/ts/package.json +7 -3
  42. package/templates/hello-world/ts/src/index.ts +5 -19
  43. package/templates/hello-world/ts/test/index.spec.ts +25 -0
  44. package/templates/hello-world/ts/test/tsconfig.json +8 -0
  45. package/templates/hello-world/ts/tsconfig.json +39 -96
  46. package/templates/hello-world/ts/vitest.config.mts +11 -0
  47. package/templates/hello-world/ts/worker-configuration.d.ts +4 -0
  48. package/templates/hello-world/ts/wrangler.toml +85 -22
  49. package/templates/hello-world-durable-object/c3.ts +10 -6
  50. package/templates/hello-world-durable-object/js/.editorconfig +0 -1
  51. package/templates/hello-world-durable-object/js/package.json +1 -1
  52. package/templates/hello-world-durable-object/js/src/index.js +18 -14
  53. package/templates/hello-world-durable-object/js/wrangler.toml +84 -22
  54. package/templates/hello-world-durable-object/ts/.editorconfig +0 -1
  55. package/templates/hello-world-durable-object/ts/package.json +4 -4
  56. package/templates/hello-world-durable-object/ts/src/index.ts +24 -37
  57. package/templates/hello-world-durable-object/ts/tsconfig.json +36 -95
  58. package/templates/hello-world-durable-object/ts/worker-configuration.d.ts +5 -0
  59. package/templates/hello-world-durable-object/ts/wrangler.toml +84 -22
  60. package/templates/hono/c3.ts +45 -1
  61. package/templates/hono/snippets/appDeclaration.ts +1 -0
  62. package/templates/hono/templates/worker-configuration.d.ts +4 -0
  63. package/templates/hono/templates/wrangler.toml +113 -0
  64. package/templates/next/README.md +68 -0
  65. package/templates/next/app/js/app/api/hello/route.js +21 -0
  66. package/templates/next/app/js/app/not-found.js +58 -0
  67. package/templates/next/app/ts/app/api/hello/route.ts +22 -0
  68. package/templates/next/app/ts/app/not-found.tsx +58 -0
  69. package/templates/next/c3.ts +109 -84
  70. package/templates/next/env.d.ts +5 -0
  71. package/templates/next/pages/js/pages/api/hello.js +23 -0
  72. package/templates/next/pages/ts/pages/api/hello.ts +24 -0
  73. package/templates/next/wrangler.toml +86 -0
  74. package/templates/nuxt/c3.ts +94 -19
  75. package/templates/nuxt/templates/env.d.ts +14 -0
  76. package/templates/nuxt/templates/worker-configuration.d.ts +4 -0
  77. package/templates/nuxt/templates/wrangler.toml +86 -0
  78. package/templates/openapi/c3.ts +1 -0
  79. package/templates/openapi/ts/README.md +3 -3
  80. package/templates/openapi/ts/package.json +7 -4
  81. package/templates/openapi/ts/src/endpoints/taskCreate.ts +26 -16
  82. package/templates/openapi/ts/src/endpoints/taskDelete.ts +20 -19
  83. package/templates/openapi/ts/src/endpoints/taskFetch.ts +30 -23
  84. package/templates/openapi/ts/src/endpoints/taskList.ts +27 -24
  85. package/templates/openapi/ts/src/index.ts +14 -20
  86. package/templates/openapi/ts/src/types.ts +9 -8
  87. package/templates/openapi/ts/worker-configuration.d.ts +4 -0
  88. package/templates/openapi/ts/wrangler.toml +110 -0
  89. package/templates/pre-existing/c3.ts +34 -15
  90. package/templates/pre-existing/js/.editorconfig +0 -1
  91. package/templates/pre-existing/js/package.json +1 -1
  92. package/templates/pre-existing/js/wrangler.toml +1 -0
  93. package/templates/queues/c3.ts +9 -5
  94. package/templates/queues/js/.editorconfig +0 -1
  95. package/templates/queues/js/package.json +1 -1
  96. package/templates/queues/js/wrangler.toml +101 -2
  97. package/templates/queues/ts/.editorconfig +0 -1
  98. package/templates/queues/ts/package.json +4 -3
  99. package/templates/queues/ts/src/index.ts +6 -8
  100. package/templates/queues/ts/tsconfig.json +36 -95
  101. package/templates/queues/ts/worker-configuration.d.ts +5 -0
  102. package/templates/queues/ts/wrangler.toml +101 -2
  103. package/templates/qwik/c3.ts +85 -30
  104. package/templates/qwik/snippets/getPlatformProxy.ts +6 -0
  105. package/templates/qwik/templates/worker-configuration.d.ts +4 -0
  106. package/templates/qwik/templates/wrangler.toml +86 -0
  107. package/templates/react/c3.ts +38 -6
  108. package/templates/remix/c3.ts +40 -6
  109. package/templates/remix/templates/worker-configuration.d.ts +4 -0
  110. package/templates/remix/templates/wrangler.toml +85 -0
  111. package/templates/scheduled/c3.ts +9 -5
  112. package/templates/scheduled/js/.editorconfig +0 -1
  113. package/templates/scheduled/js/package.json +3 -3
  114. package/templates/scheduled/js/src/index.js +8 -1
  115. package/templates/scheduled/js/wrangler.toml +110 -0
  116. package/templates/scheduled/ts/.editorconfig +0 -1
  117. package/templates/scheduled/ts/package.json +5 -4
  118. package/templates/scheduled/ts/src/index.ts +6 -23
  119. package/templates/scheduled/ts/tsconfig.json +36 -95
  120. package/templates/scheduled/ts/worker-configuration.d.ts +4 -0
  121. package/templates/scheduled/ts/wrangler.toml +110 -0
  122. package/templates/solid/c3.ts +61 -11
  123. package/templates/solid/templates/wrangler.toml +84 -0
  124. package/templates/svelte/c3.ts +84 -30
  125. package/templates/svelte/js/wrangler.toml +85 -0
  126. package/templates/svelte/ts/wrangler.toml +85 -0
  127. package/templates/vue/c3.ts +8 -6
  128. package/templates-experimental/angular/c3.ts +98 -0
  129. package/templates-experimental/angular/templates/server.ts +34 -0
  130. package/templates-experimental/angular/templates/tools/alter-polyfills.mjs +32 -0
  131. package/templates-experimental/angular/templates/wrangler.toml +11 -0
  132. package/templates-experimental/astro/c3.ts +114 -0
  133. package/templates-experimental/astro/snippets/runtimeDeclaration.ts +5 -0
  134. package/templates-experimental/astro/templates/public/.assetsignore +4 -0
  135. package/templates-experimental/astro/templates/wrangler.toml +12 -0
  136. package/templates-experimental/docusaurus/c3.ts +32 -0
  137. package/templates-experimental/docusaurus/templates/wrangler.toml +10 -0
  138. package/templates-experimental/gatsby/c3.ts +53 -0
  139. package/templates-experimental/gatsby/templates/wrangler.toml +10 -0
  140. package/templates-experimental/hello-world-assets-only/c3.ts +15 -0
  141. package/templates-experimental/hello-world-assets-only/templates/package.json +13 -0
  142. package/templates-experimental/hello-world-assets-only/templates/public/index.html +11 -0
  143. package/templates-experimental/hello-world-assets-only/templates/wrangler.toml +10 -0
  144. package/templates-experimental/hello-world-durable-object-with-assets/c3.ts +23 -0
  145. package/templates-experimental/hello-world-durable-object-with-assets/js/.editorconfig +12 -0
  146. package/templates-experimental/hello-world-durable-object-with-assets/js/.prettierrc +6 -0
  147. package/templates-experimental/hello-world-durable-object-with-assets/js/__dot__gitignore +172 -0
  148. package/templates-experimental/hello-world-durable-object-with-assets/js/package.json +13 -0
  149. package/templates-experimental/hello-world-durable-object-with-assets/js/public/index.html +19 -0
  150. package/templates-experimental/hello-world-durable-object-with-assets/js/src/index.js +69 -0
  151. package/templates-experimental/hello-world-durable-object-with-assets/js/wrangler.toml +24 -0
  152. package/templates-experimental/hello-world-durable-object-with-assets/ts/.editorconfig +12 -0
  153. package/templates-experimental/hello-world-durable-object-with-assets/ts/.prettierrc +6 -0
  154. package/templates-experimental/hello-world-durable-object-with-assets/ts/__dot__gitignore +172 -0
  155. package/templates-experimental/hello-world-durable-object-with-assets/ts/package.json +15 -0
  156. package/templates-experimental/hello-world-durable-object-with-assets/ts/public/index.html +19 -0
  157. package/templates-experimental/hello-world-durable-object-with-assets/ts/src/index.ts +66 -0
  158. package/templates-experimental/hello-world-durable-object-with-assets/ts/tsconfig.json +42 -0
  159. package/templates-experimental/hello-world-durable-object-with-assets/ts/worker-configuration.d.ts +5 -0
  160. package/templates-experimental/hello-world-durable-object-with-assets/ts/wrangler.toml +24 -0
  161. package/templates-experimental/hello-world-with-assets/c3.ts +22 -0
  162. package/templates-experimental/hello-world-with-assets/js/.editorconfig +12 -0
  163. package/templates-experimental/hello-world-with-assets/js/.prettierrc +6 -0
  164. package/templates-experimental/hello-world-with-assets/js/__dot__gitignore +172 -0
  165. package/templates-experimental/hello-world-with-assets/js/package.json +16 -0
  166. package/templates-experimental/hello-world-with-assets/js/public/index.html +31 -0
  167. package/templates-experimental/hello-world-with-assets/js/src/index.js +23 -0
  168. package/templates-experimental/hello-world-with-assets/js/test/index.spec.js +41 -0
  169. package/templates-experimental/hello-world-with-assets/js/vitest.config.js +11 -0
  170. package/templates-experimental/hello-world-with-assets/js/wrangler.toml +12 -0
  171. package/templates-experimental/hello-world-with-assets/py/__dot__gitignore +68 -0
  172. package/templates-experimental/hello-world-with-assets/py/package.json +13 -0
  173. package/templates-experimental/hello-world-with-assets/py/public/index.html +31 -0
  174. package/templates-experimental/hello-world-with-assets/py/src/entry.py +9 -0
  175. package/templates-experimental/hello-world-with-assets/py/wrangler.toml +12 -0
  176. package/templates-experimental/hello-world-with-assets/ts/.editorconfig +12 -0
  177. package/templates-experimental/hello-world-with-assets/ts/.prettierrc +6 -0
  178. package/templates-experimental/hello-world-with-assets/ts/__dot__gitignore +172 -0
  179. package/templates-experimental/hello-world-with-assets/ts/package.json +18 -0
  180. package/templates-experimental/hello-world-with-assets/ts/public/index.html +31 -0
  181. package/templates-experimental/hello-world-with-assets/ts/src/index.ts +26 -0
  182. package/templates-experimental/hello-world-with-assets/ts/test/index.spec.ts +41 -0
  183. package/templates-experimental/hello-world-with-assets/ts/test/tsconfig.json +8 -0
  184. package/templates-experimental/hello-world-with-assets/ts/tsconfig.json +44 -0
  185. package/templates-experimental/hello-world-with-assets/ts/vitest.config.mts +11 -0
  186. package/templates-experimental/hello-world-with-assets/ts/worker-configuration.d.ts +4 -0
  187. package/templates-experimental/hello-world-with-assets/ts/wrangler.toml +12 -0
  188. package/templates-experimental/hono/c3.ts +43 -0
  189. package/templates-experimental/hono/templates/public/index.html +19 -0
  190. package/templates-experimental/hono/templates/src/index.ts +9 -0
  191. package/templates-experimental/hono/templates/worker-configuration.d.ts +4 -0
  192. package/templates-experimental/hono/templates/wrangler.toml +5 -0
  193. package/templates-experimental/next/c3.ts +52 -0
  194. package/templates-experimental/next/templates/__dot__gitignore +42 -0
  195. package/templates-experimental/next/templates/env.d.ts +5 -0
  196. package/templates-experimental/next/templates/wrangler.toml +12 -0
  197. package/templates-experimental/nuxt/c3.ts +135 -0
  198. package/templates-experimental/nuxt/templates/cloudflare-preset/nitro.config.ts +27 -0
  199. package/templates-experimental/nuxt/templates/env.d.ts +14 -0
  200. package/templates-experimental/nuxt/templates/worker-configuration.d.ts +4 -0
  201. package/templates-experimental/nuxt/templates/wrangler.toml +11 -0
  202. package/templates-experimental/qwik/c3.ts +153 -0
  203. package/templates-experimental/qwik/snippets/getPlatformProxy.ts +6 -0
  204. package/templates-experimental/qwik/templates/public/.assetsignore +4 -0
  205. package/templates-experimental/qwik/templates/worker-configuration.d.ts +4 -0
  206. package/templates-experimental/qwik/templates/wrangler.toml +12 -0
  207. package/templates-experimental/remix/c3.ts +77 -0
  208. package/templates-experimental/remix/templates/public/.assetsignore +4 -0
  209. package/templates-experimental/remix/templates/worker-configuration.d.ts +4 -0
  210. package/templates-experimental/remix/templates/wrangler.toml +11 -0
  211. package/templates-experimental/solid/c3.ts +137 -0
  212. package/templates-experimental/solid/templates/wrangler.toml +12 -0
  213. package/templates-experimental/svelte/c3.ts +132 -0
  214. package/templates-experimental/svelte/js/static/.assetsignore +4 -0
  215. package/templates-experimental/svelte/js/wrangler.toml +11 -0
  216. package/templates-experimental/svelte/ts/static/.assetsignore +4 -0
  217. package/templates-experimental/svelte/ts/wrangler.toml +11 -0
  218. package/templates/next/templates.ts +0 -281
  219. package/templates/solid/js/vite.config.js +0 -12
  220. package/templates/solid/ts/vite.config.ts +0 -12
  221. package/templates/svelte/templates.ts +0 -13
@@ -0,0 +1,135 @@
1
+ import { logRaw } from "@cloudflare/cli";
2
+ import { brandColor, dim } from "@cloudflare/cli/colors";
3
+ import { spinner } from "@cloudflare/cli/interactive";
4
+ import { runFrameworkGenerator } from "frameworks/index";
5
+ import { mergeObjectProperties, transformFile } from "helpers/codemod";
6
+ import { getLatestTypesEntrypoint } from "helpers/compatDate";
7
+ import { readFile, writeFile } from "helpers/files";
8
+ import { detectPackageManager } from "helpers/packageManagers";
9
+ import { installPackages } from "helpers/packages";
10
+ import * as recast from "recast";
11
+ import type { TemplateConfig } from "../../src/templates";
12
+ import type { C3Context } from "types";
13
+
14
+ const { npm, name: pm } = detectPackageManager();
15
+
16
+ const generate = async (ctx: C3Context) => {
17
+ const gitFlag = ctx.args.git ? `--gitInit` : `--no-gitInit`;
18
+
19
+ await runFrameworkGenerator(ctx, [
20
+ "init",
21
+ ctx.project.name,
22
+ "--packageManager",
23
+ npm,
24
+ gitFlag,
25
+ ]);
26
+
27
+ writeFile("./.node-version", "17");
28
+
29
+ logRaw(""); // newline
30
+ };
31
+
32
+ const configure = async (ctx: C3Context) => {
33
+ const packages = ["nitro-cloudflare-dev", "nitropack"];
34
+
35
+ // When using pnpm, explicitly add h3 package so the H3Event type declaration can be updated.
36
+ // Package managers other than pnpm will hoist the dependency, as will pnpm with `--shamefully-hoist`
37
+ if (pm === "pnpm") {
38
+ packages.push("h3");
39
+ }
40
+
41
+ await installPackages(packages, {
42
+ dev: true,
43
+ startText: "Installing nitro module `nitro-cloudflare-dev`",
44
+ doneText: `${brandColor("installed")} ${dim(`via \`${npm} install\``)}`,
45
+ });
46
+ updateNuxtConfig();
47
+
48
+ updateEnvTypes(ctx);
49
+ };
50
+
51
+ const updateEnvTypes = (ctx: C3Context) => {
52
+ const filepath = "env.d.ts";
53
+
54
+ const s = spinner();
55
+ s.start(`Updating ${filepath}`);
56
+
57
+ let file = readFile(filepath);
58
+
59
+ let typesEntrypoint = `@cloudflare/workers-types`;
60
+ const latestEntrypoint = getLatestTypesEntrypoint(ctx);
61
+ if (latestEntrypoint) {
62
+ typesEntrypoint += `/${latestEntrypoint}`;
63
+ }
64
+
65
+ // Replace placeholder with actual types entrypoint
66
+ file = file.replace("WORKERS_TYPES_ENTRYPOINT", typesEntrypoint);
67
+ writeFile("env.d.ts", file);
68
+
69
+ s.stop(`${brandColor(`updated`)} ${dim(`\`${filepath}\``)}`);
70
+ };
71
+
72
+ const updateNuxtConfig = () => {
73
+ const s = spinner();
74
+
75
+ const configFile = "nuxt.config.ts";
76
+ s.start(`Updating \`${configFile}\``);
77
+
78
+ const b = recast.types.builders;
79
+
80
+ const presetDef = b.objectProperty(
81
+ b.identifier("nitro"),
82
+ b.objectExpression([
83
+ b.objectProperty(
84
+ b.identifier("preset"),
85
+ b.stringLiteral("./cloudflare-preset"),
86
+ ),
87
+ ]),
88
+ );
89
+
90
+ const moduleDef = b.objectProperty(
91
+ b.identifier("modules"),
92
+ b.arrayExpression([b.stringLiteral("nitro-cloudflare-dev")]),
93
+ );
94
+
95
+ transformFile(configFile, {
96
+ visitCallExpression: function (n) {
97
+ const callee = n.node.callee as recast.types.namedTypes.Identifier;
98
+ if (callee.name === "defineNuxtConfig") {
99
+ mergeObjectProperties(
100
+ n.node.arguments[0] as recast.types.namedTypes.ObjectExpression,
101
+ [presetDef, moduleDef],
102
+ );
103
+ }
104
+
105
+ return this.traverse(n);
106
+ },
107
+ });
108
+
109
+ s.stop(`${brandColor(`updated`)} ${dim(`\`${configFile}\``)}`);
110
+ };
111
+
112
+ const config: TemplateConfig = {
113
+ configVersion: 1,
114
+ id: "nuxt",
115
+ frameworkCli: "nuxi",
116
+ platform: "workers",
117
+ displayName: "Nuxt",
118
+ copyFiles: {
119
+ path: "./templates",
120
+ },
121
+ path: "templates-experimental/nuxt",
122
+ generate,
123
+ configure,
124
+ transformPackageJson: async () => ({
125
+ scripts: {
126
+ deploy: `${npm} run build && wrangler deploy`,
127
+ preview: `${npm} run build && wrangler dev`,
128
+ "cf-typegen": `wrangler types`,
129
+ },
130
+ }),
131
+ devScript: "dev",
132
+ deployScript: "deploy",
133
+ previewScript: "preview",
134
+ };
135
+ export default config;
@@ -0,0 +1,27 @@
1
+ import { type NitroPreset } from "nitropack";
2
+
3
+ export default <NitroPreset>{
4
+ extends: "cloudflare",
5
+ exportConditions: ["workerd"],
6
+ output: {
7
+ dir: "{{ rootDir }}/dist",
8
+ publicDir: "{{ output.dir }}/public",
9
+ serverDir: "{{ output.dir }}/worker",
10
+ },
11
+ commands: {
12
+ preview: "npx wrangler dev",
13
+ deploy: "npx wrangler deploy",
14
+ },
15
+ wasm: {
16
+ lazy: false,
17
+ esmImport: true,
18
+ },
19
+ rollupConfig: {
20
+ output: {
21
+ entryFileNames: "index.js",
22
+ format: "esm",
23
+ exports: "named",
24
+ inlineDynamicImports: false,
25
+ },
26
+ },
27
+ };
@@ -0,0 +1,14 @@
1
+ /// <reference types="WORKERS_TYPES_ENTRYPOINT" />
2
+
3
+ declare module "h3" {
4
+ interface H3EventContext {
5
+ cf: CfProperties;
6
+ cloudflare: {
7
+ request: Request;
8
+ env: Env;
9
+ context: ExecutionContext;
10
+ };
11
+ }
12
+ }
13
+
14
+ export {};
@@ -0,0 +1,4 @@
1
+ // Generated by Wrangler
2
+ // After adding bindings to `wrangler.toml`, regenerate this interface via `npm run cf-typegen`
3
+ interface Env {
4
+ }
@@ -0,0 +1,11 @@
1
+ #:schema node_modules/wrangler/config-schema.json
2
+ name = "<TBD>"
3
+ compatibility_date = "<TBD>"
4
+ main = "./dist/worker/index.js"
5
+ assets = { directory = "./dist/public", binding = "ASSETS" }
6
+
7
+ # Workers Logs
8
+ # Docs: https://developers.cloudflare.com/workers/observability/logs/workers-logs/
9
+ # Configuration: https://developers.cloudflare.com/workers/observability/logs/workers-logs/#enable-workers-logs
10
+ [observability]
11
+ enabled = true
@@ -0,0 +1,153 @@
1
+ import { crash, endSection } from "@cloudflare/cli";
2
+ import { brandColor } from "@cloudflare/cli/colors";
3
+ import { spinner } from "@cloudflare/cli/interactive";
4
+ import { runFrameworkGenerator } from "frameworks/index";
5
+ import { loadTemplateSnippets, transformFile } from "helpers/codemod";
6
+ import { quoteShellArgs, runCommand } from "helpers/command";
7
+ import { removeFile, usesTypescript } from "helpers/files";
8
+ import { detectPackageManager } from "helpers/packageManagers";
9
+ import * as recast from "recast";
10
+ import type { TemplateConfig } from "../../src/templates";
11
+ import type { C3Context } from "types";
12
+
13
+ const { npm, npx } = detectPackageManager();
14
+
15
+ const generate = async (ctx: C3Context) => {
16
+ await runFrameworkGenerator(ctx, ["playground", ctx.project.name]);
17
+ };
18
+
19
+ const configure = async (ctx: C3Context) => {
20
+ // Add the pages integration
21
+ const cmd = [npx, "qwik", "add", "cloudflare-pages"];
22
+ endSection(`Running ${quoteShellArgs(cmd)}`);
23
+ await runCommand(cmd);
24
+
25
+ // Remove the extraneous Pages files
26
+ removeFile("./public/_headers");
27
+ removeFile("./public/_redirects");
28
+ removeFile("./public/_routes.json");
29
+
30
+ addBindingsProxy(ctx);
31
+ populateCloudflareEnv();
32
+ };
33
+
34
+ const addBindingsProxy = (ctx: C3Context) => {
35
+ // Qwik only has a typescript template atm.
36
+ // This check is an extra precaution
37
+ if (!usesTypescript(ctx)) {
38
+ return;
39
+ }
40
+
41
+ const s = spinner();
42
+ s.start("Updating `vite.config.ts`");
43
+
44
+ const snippets = loadTemplateSnippets(ctx);
45
+ const b = recast.types.builders;
46
+
47
+ transformFile("vite.config.ts", {
48
+ // Insert the env declaration after the last import (but before the rest of the body)
49
+ visitProgram: function (n) {
50
+ const lastImportIndex = n.node.body.findLastIndex(
51
+ (t) => t.type === "ImportDeclaration",
52
+ );
53
+ const lastImport = n.get("body", lastImportIndex);
54
+ lastImport.insertAfter(...snippets.getPlatformProxyTs);
55
+
56
+ return this.traverse(n);
57
+ },
58
+ // Pass the `platform` object from the declaration to the `qwikCity` plugin
59
+ visitCallExpression: function (n) {
60
+ const callee = n.node.callee as recast.types.namedTypes.Identifier;
61
+ if (callee.name !== "qwikCity") {
62
+ return this.traverse(n);
63
+ }
64
+
65
+ // The config object passed to `qwikCity`
66
+ const configArgument = n.node.arguments[0] as
67
+ | recast.types.namedTypes.ObjectExpression
68
+ | undefined;
69
+
70
+ const platformPropery = b.objectProperty.from({
71
+ key: b.identifier("platform"),
72
+ value: b.identifier("platform"),
73
+ shorthand: true,
74
+ });
75
+
76
+ if (!configArgument) {
77
+ n.node.arguments = [b.objectExpression([platformPropery])];
78
+
79
+ return false;
80
+ }
81
+
82
+ if (configArgument.type !== "ObjectExpression") {
83
+ crash("Failed to update `vite.config.ts`");
84
+ }
85
+
86
+ // Add the `platform` object to the object
87
+ configArgument.properties.push(platformPropery);
88
+
89
+ return false;
90
+ },
91
+ });
92
+
93
+ s.stop(`${brandColor("updated")} \`vite.config.ts\``);
94
+ };
95
+
96
+ const populateCloudflareEnv = () => {
97
+ const entrypointPath = "src/entry.cloudflare-pages.tsx";
98
+
99
+ const s = spinner();
100
+ s.start(`Updating \`${entrypointPath}\``);
101
+
102
+ transformFile(entrypointPath, {
103
+ visitTSInterfaceDeclaration: function (n) {
104
+ const b = recast.types.builders;
105
+ const id = n.node.id as recast.types.namedTypes.Identifier;
106
+ if (id.name !== "QwikCityPlatform") {
107
+ this.traverse(n);
108
+ }
109
+
110
+ const newBody = [
111
+ ["env", "Env"],
112
+ // Qwik doesn't supply `cf` to the platform object. Should they do so, uncomment this
113
+ // ["cf", "CfProperties"],
114
+ ].map(([varName, type]) =>
115
+ b.tsPropertySignature(
116
+ b.identifier(varName),
117
+ b.tsTypeAnnotation(b.tsTypeReference(b.identifier(type))),
118
+ ),
119
+ );
120
+
121
+ n.node.body.body = newBody;
122
+
123
+ return false;
124
+ },
125
+ });
126
+
127
+ s.stop(`${brandColor("updated")} \`${entrypointPath}\``);
128
+ };
129
+
130
+ const config: TemplateConfig = {
131
+ configVersion: 1,
132
+ id: "qwik",
133
+ frameworkCli: "create-qwik",
134
+ displayName: "Qwik",
135
+ platform: "workers",
136
+ copyFiles: {
137
+ path: "./templates",
138
+ },
139
+ path: "templates-experimental/qwik",
140
+ generate,
141
+ configure,
142
+ transformPackageJson: async () => ({
143
+ scripts: {
144
+ deploy: `${npm} run build && wrangler deploy`,
145
+ preview: `${npm} run build && wrangler dev`,
146
+ "cf-typegen": `wrangler types`,
147
+ },
148
+ }),
149
+ devScript: "dev",
150
+ deployScript: "deploy",
151
+ previewScript: "preview",
152
+ };
153
+ export default config;
@@ -0,0 +1,6 @@
1
+ let platform = {};
2
+
3
+ if(process.env.NODE_ENV === 'development') {
4
+ const { getPlatformProxy } = await import('wrangler');
5
+ platform = await getPlatformProxy();
6
+ }
@@ -0,0 +1,4 @@
1
+ _worker.js
2
+ _routes.json
3
+ _headers
4
+ _redirects
@@ -0,0 +1,4 @@
1
+ // Generated by Wrangler
2
+ // After adding bindings to `wrangler.toml`, regenerate this interface via `npm run cf-typegen`
3
+ interface Env {
4
+ }
@@ -0,0 +1,12 @@
1
+ #:schema node_modules/wrangler/config-schema.json
2
+ name = "<TBD>"
3
+ compatibility_date = "<TBD>"
4
+ compatibility_flags = ["nodejs_compat"]
5
+ main = "./dist/_worker.js"
6
+ assets = { directory = "./dist", binding = "ASSET" }
7
+
8
+ # Workers Logs
9
+ # Docs: https://developers.cloudflare.com/workers/observability/logs/workers-logs/
10
+ # Configuration: https://developers.cloudflare.com/workers/observability/logs/workers-logs/#enable-workers-logs
11
+ [observability]
12
+ enabled = true
@@ -0,0 +1,77 @@
1
+ import { logRaw } from "@cloudflare/cli";
2
+ import { brandColor, dim } from "@cloudflare/cli/colors";
3
+ import { spinner } from "@cloudflare/cli/interactive";
4
+ import { runFrameworkGenerator } from "frameworks/index";
5
+ import { transformFile } from "helpers/codemod";
6
+ import { detectPackageManager } from "helpers/packageManagers";
7
+ import { installPackages } from "helpers/packages";
8
+ import type { TemplateConfig } from "../../src/templates";
9
+ import type { C3Context } from "types";
10
+
11
+ const { npm } = detectPackageManager();
12
+
13
+ const generate = async (ctx: C3Context) => {
14
+ await runFrameworkGenerator(ctx, [
15
+ ctx.project.name,
16
+ "--template",
17
+ "https://github.com/remix-run/remix/tree/main/templates/cloudflare",
18
+ ]);
19
+
20
+ logRaw(""); // newline
21
+ };
22
+
23
+ const configure = async () => {
24
+ await installPackages(["wrangler@latest"], {
25
+ dev: true,
26
+ startText: "Updating the Wrangler version",
27
+ doneText: `${brandColor(`updated`)} ${dim("wrangler@latest")}`,
28
+ });
29
+
30
+ const typeDefsPath = "load-context.ts";
31
+
32
+ const s = spinner();
33
+ s.start(`Updating \`${typeDefsPath}\``);
34
+
35
+ // Remove the empty Env declaration from the template to allow the type from
36
+ // worker-configuration.d.ts to take over
37
+ transformFile(typeDefsPath, {
38
+ visitTSInterfaceDeclaration(n) {
39
+ if (n.node.id.type === "Identifier" && n.node.id.name !== "Env") {
40
+ return this.traverse(n);
41
+ }
42
+
43
+ // Removes the node
44
+ n.replace();
45
+ return false;
46
+ },
47
+ });
48
+
49
+ s.stop(`${brandColor("updated")} \`${dim(typeDefsPath)}\``);
50
+ };
51
+
52
+ const config: TemplateConfig = {
53
+ configVersion: 1,
54
+ id: "remix",
55
+ frameworkCli: "create-remix",
56
+ platform: "workers",
57
+ displayName: "Remix",
58
+ copyFiles: {
59
+ path: "./templates",
60
+ },
61
+ path: "templates-experimental/remix",
62
+ generate,
63
+ configure,
64
+ transformPackageJson: async () => ({
65
+ scripts: {
66
+ build:
67
+ "remix vite:build && wrangler pages functions build --outdir build/worker",
68
+ deploy: `${npm} run build && wrangler deploy`,
69
+ preview: `${npm} run build && wrangler dev`,
70
+ "cf-typegen": `wrangler types`,
71
+ },
72
+ }),
73
+ devScript: "dev",
74
+ deployScript: "deploy",
75
+ previewScript: "preview",
76
+ };
77
+ export default config;
@@ -0,0 +1,4 @@
1
+ _worker.js
2
+ _routes.json
3
+ _headers
4
+ _redirects
@@ -0,0 +1,4 @@
1
+ // Generated by Wrangler
2
+ // After adding bindings to `wrangler.toml`, regenerate this interface via `npm run cf-typegen`
3
+ interface Env {
4
+ }
@@ -0,0 +1,11 @@
1
+ #:schema node_modules/wrangler/config-schema.json
2
+ name = "<TBD>"
3
+ compatibility_date = "<TBD>"
4
+ main = "./build/worker/index.js"
5
+ assets = { directory = "./build/client" }
6
+
7
+ # Workers Logs
8
+ # Docs: https://developers.cloudflare.com/workers/observability/logs/workers-logs/
9
+ # Configuration: https://developers.cloudflare.com/workers/observability/logs/workers-logs/#enable-workers-logs
10
+ [observability]
11
+ enabled = true
@@ -0,0 +1,137 @@
1
+ import { logRaw, updateStatus } from "@cloudflare/cli";
2
+ import { blue, brandColor, dim } from "@cloudflare/cli/colors";
3
+ import { runFrameworkGenerator } from "frameworks/index";
4
+ import { mergeObjectProperties, transformFile } from "helpers/codemod";
5
+ import { usesTypescript } from "helpers/files";
6
+ import { detectPackageManager } from "helpers/packageManagers";
7
+ import { installPackages } from "helpers/packages";
8
+ import * as recast from "recast";
9
+ import type { TemplateConfig } from "../../src/templates";
10
+ import type { C3Context } from "types";
11
+
12
+ const { npm } = detectPackageManager();
13
+
14
+ const generate = async (ctx: C3Context) => {
15
+ // Run the create-solid command
16
+ // -s flag forces solid-start
17
+ await runFrameworkGenerator(ctx, ["-p", ctx.project.name, "-s"]);
18
+
19
+ logRaw("");
20
+ };
21
+
22
+ const configure = async (ctx: C3Context) => {
23
+ const packages = ["nitropack"];
24
+ await installPackages(packages, {
25
+ dev: true,
26
+ startText: "Installing nitro module `nitropack`",
27
+ doneText: `${brandColor("installed")} ${dim(`via \`${npm} install\``)}`,
28
+ });
29
+
30
+ usesTypescript(ctx);
31
+ const filePath = `app.config.${usesTypescript(ctx) ? "ts" : "js"}`;
32
+
33
+ updateStatus(`Updating configuration in ${blue(filePath)}`);
34
+
35
+ transformFile(filePath, {
36
+ visitCallExpression: function (n) {
37
+ const callee = n.node.callee as recast.types.namedTypes.Identifier;
38
+ if (callee.name !== "defineConfig") {
39
+ return this.traverse(n);
40
+ }
41
+
42
+ const b = recast.types.builders;
43
+ mergeObjectProperties(
44
+ n.node.arguments[0] as recast.types.namedTypes.ObjectExpression,
45
+ [
46
+ b.objectProperty(
47
+ b.identifier("server"),
48
+ b.objectExpression([
49
+ // preset: "cloudflare-pages"
50
+ b.objectProperty(
51
+ b.identifier("preset"),
52
+ b.stringLiteral("./cloudflare-pages"),
53
+ ),
54
+ // output: {
55
+ // dir: "{{ rootDir }}/dist",
56
+ // publicDir: "{{ output.dir }}/public",
57
+ // serverDir: "{{ output.dir }}/worker",
58
+ // },
59
+ b.objectProperty(
60
+ b.identifier("output"),
61
+ b.objectExpression([
62
+ b.objectProperty(
63
+ b.identifier("dir"),
64
+ b.stringLiteral("{{ rootDir }}/dist"),
65
+ ),
66
+ b.objectProperty(
67
+ b.identifier("publicDir"),
68
+ b.stringLiteral("{{ output.dir }}/public"),
69
+ ),
70
+ b.objectProperty(
71
+ b.identifier("serverDir"),
72
+ b.stringLiteral("{{ output.dir }}/worker"),
73
+ ),
74
+ ]),
75
+ ),
76
+ // rollupConfig: {
77
+ // external: ["node:async_hooks"],
78
+ // },
79
+ b.objectProperty(
80
+ b.identifier("rollupConfig"),
81
+ b.objectExpression([
82
+ b.objectProperty(
83
+ b.identifier("external"),
84
+ b.arrayExpression([b.stringLiteral("node:async_hooks")]),
85
+ ),
86
+ ]),
87
+ ),
88
+ // hooks: {
89
+ // // Prevent the Pages preset from writing the _routes.json etc.
90
+ // compiled() {},
91
+ // },
92
+ b.objectProperty(
93
+ b.identifier("hooks"),
94
+ b.objectExpression([
95
+ b.objectMethod(
96
+ "method",
97
+ b.identifier("compiled"),
98
+ [],
99
+ b.blockStatement([]),
100
+ false,
101
+ ),
102
+ ]),
103
+ ),
104
+ ]),
105
+ ),
106
+ ],
107
+ );
108
+
109
+ return false;
110
+ },
111
+ });
112
+ };
113
+
114
+ const config: TemplateConfig = {
115
+ configVersion: 1,
116
+ id: "solid",
117
+ frameworkCli: "create-solid",
118
+ displayName: "Solid",
119
+ platform: "workers",
120
+ copyFiles: {
121
+ path: "./templates",
122
+ },
123
+ path: "templates-experimental/solid",
124
+ generate,
125
+ configure,
126
+ transformPackageJson: async () => ({
127
+ scripts: {
128
+ preview: `${npm} run build && npx wrangler dev`,
129
+ deploy: `${npm} run build && wrangler deploy`,
130
+ },
131
+ }),
132
+ compatibilityFlags: ["nodejs_compat"],
133
+ devScript: "dev",
134
+ deployScript: "deploy",
135
+ previewScript: "preview",
136
+ };
137
+ export default config;
@@ -0,0 +1,12 @@
1
+ #:schema node_modules/wrangler/config-schema.json
2
+ name = "<TBD>"
3
+ compatibility_date = "<TBD>"
4
+ compatibility_flags = ["nodejs_compat"]
5
+ main = "./dist/worker/index.js"
6
+ assets = { directory = "./dist/public", binding = "ASSETS" }
7
+
8
+ # Workers Logs
9
+ # Docs: https://developers.cloudflare.com/workers/observability/logs/workers-logs/
10
+ # Configuration: https://developers.cloudflare.com/workers/observability/logs/workers-logs/#enable-workers-logs
11
+ [observability]
12
+ enabled = true