create-cloudflare 0.0.0-facb3ffc9 → 0.0.0-fbba583df
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.
- package/dist/cli.js +28282 -26413
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +13 -8
- package/templates/analog/templates/worker-configuration.d.ts +1 -1
- package/templates/angular/c3.ts +24 -5
- package/templates/astro/templates/ts/worker-configuration.d.ts +1 -1
- package/templates/common/ts/src/index.ts +1 -1
- package/templates/common/ts/worker-configuration.d.ts +1 -1
- package/templates/docusaurus/c3.ts +1 -0
- package/templates/hello-world/c3.ts +17 -1
- package/templates/hello-world/js/package.json +2 -2
- package/templates/hello-world/js/test/index.spec.js +1 -1
- package/templates/hello-world/js/vitest.config.js +1 -1
- package/templates/hello-world/js/{wrangler.json → wrangler.jsonc} +2 -2
- package/templates/hello-world/py/.python-version +1 -0
- package/templates/hello-world/py/README.md +23 -0
- package/templates/hello-world/py/pyproject.toml +9 -0
- package/templates/hello-world/py/uv.lock +22 -0
- package/templates/hello-world/py/{wrangler.json → wrangler.jsonc} +2 -2
- package/templates/hello-world/ts/package.json +2 -2
- package/templates/hello-world/ts/src/index.ts +1 -1
- package/templates/hello-world/ts/vitest.config.mts +1 -1
- package/templates/hello-world/ts/worker-configuration.d.ts +1 -1
- package/templates/hello-world/ts/{wrangler.json → wrangler.jsonc} +2 -2
- package/templates/hello-world-durable-object/js/src/index.js +3 -3
- package/templates/hello-world-durable-object/ts/src/index.ts +3 -3
- package/templates/hono/c3.ts +1 -0
- package/templates/hono/templates/worker-configuration.d.ts +1 -1
- package/templates/next/README.md +1 -1
- package/templates/next/c3.ts +12 -9
- package/templates/nuxt/templates/worker-configuration.d.ts +1 -1
- package/templates/openapi/ts/worker-configuration.d.ts +1 -1
- package/templates/pre-existing/c3.ts +1 -1
- package/templates/queues/ts/src/index.ts +1 -1
- package/templates/queues/ts/worker-configuration.d.ts +1 -1
- package/templates/qwik/c3.ts +3 -2
- package/templates/qwik/templates/worker-configuration.d.ts +1 -1
- package/templates/remix/templates/worker-configuration.d.ts +1 -1
- package/templates/scheduled/js/src/index.js +1 -1
- package/templates/scheduled/ts/src/index.ts +2 -2
- package/templates/scheduled/ts/worker-configuration.d.ts +1 -1
- package/templates-experimental/angular/c3.ts +23 -5
- package/templates-experimental/astro/templates/ts/worker-configuration.d.ts +1 -1
- package/templates-experimental/docusaurus/c3.ts +1 -0
- package/templates-experimental/hello-world-durable-object-with-assets/js/src/index.js +3 -3
- package/templates-experimental/hello-world-durable-object-with-assets/ts/src/index.ts +3 -3
- package/templates-experimental/hello-world-with-assets/js/package.json +2 -2
- package/templates-experimental/hello-world-with-assets/js/vitest.config.js +1 -1
- package/templates-experimental/hello-world-with-assets/ts/package.json +2 -2
- package/templates-experimental/hello-world-with-assets/ts/src/index.ts +1 -1
- package/templates-experimental/hello-world-with-assets/ts/vitest.config.mts +1 -1
- package/templates-experimental/hello-world-with-assets/ts/worker-configuration.d.ts +1 -1
- package/templates-experimental/hono/c3.ts +1 -0
- package/templates-experimental/hono/templates/worker-configuration.d.ts +1 -1
- package/templates-experimental/next/c3.ts +27 -11
- package/templates-experimental/nuxt/templates/worker-configuration.d.ts +1 -1
- package/templates-experimental/qwik/c3.ts +3 -2
- package/templates-experimental/qwik/templates/worker-configuration.d.ts +1 -1
- package/templates-experimental/react/c3.ts +182 -0
- package/templates-experimental/react/js/api/index.js +13 -0
- package/templates-experimental/react/js/src/App.jsx +58 -0
- package/templates-experimental/react/js/src/assets/Cloudflare_Logo.svg +26 -0
- package/templates-experimental/react/js/wrangler.json +9 -0
- package/templates-experimental/react/ts/api/index.ts +17 -0
- package/templates-experimental/react/ts/src/App.tsx +58 -0
- package/templates-experimental/react/ts/src/assets/Cloudflare_Logo.svg +26 -0
- package/templates-experimental/react/ts/tsconfig.worker.json +8 -0
- package/templates-experimental/react/ts/wrangler.json +9 -0
- package/templates/pre-existing/js/wrangler.json +0 -5
- /package/templates/analog/templates/{wrangler.json → wrangler.jsonc} +0 -0
- /package/templates/astro/templates/js/{wrangler.json → wrangler.jsonc} +0 -0
- /package/templates/astro/templates/ts/{wrangler.json → wrangler.jsonc} +0 -0
- /package/templates/common/js/{wrangler.json → wrangler.jsonc} +0 -0
- /package/templates/common/ts/{wrangler.json → wrangler.jsonc} +0 -0
- /package/templates/hello-world-durable-object/js/{wrangler.json → wrangler.jsonc} +0 -0
- /package/templates/hello-world-durable-object/ts/{wrangler.json → wrangler.jsonc} +0 -0
- /package/templates/hono/templates/{wrangler.json → wrangler.jsonc} +0 -0
- /package/templates/next/{wrangler.json → wrangler.jsonc} +0 -0
- /package/templates/nuxt/templates/{wrangler.json → wrangler.jsonc} +0 -0
- /package/templates/openapi/ts/{wrangler.json → wrangler.jsonc} +0 -0
- /package/templates/queues/js/{wrangler.json → wrangler.jsonc} +0 -0
- /package/templates/queues/ts/{wrangler.json → wrangler.jsonc} +0 -0
- /package/templates/qwik/templates/{wrangler.json → wrangler.jsonc} +0 -0
- /package/templates/remix/templates/{wrangler.json → wrangler.jsonc} +0 -0
- /package/templates/scheduled/js/{wrangler.json → wrangler.jsonc} +0 -0
- /package/templates/scheduled/ts/{wrangler.json → wrangler.jsonc} +0 -0
- /package/templates/solid/templates/{wrangler.json → wrangler.jsonc} +0 -0
- /package/templates/svelte/templates/{wrangler.json → wrangler.jsonc} +0 -0
- /package/templates-experimental/angular/templates/{wrangler.json → wrangler.jsonc} +0 -0
- /package/templates-experimental/astro/templates/js/{wrangler.json → wrangler.jsonc} +0 -0
- /package/templates-experimental/astro/templates/ts/{wrangler.json → wrangler.jsonc} +0 -0
- /package/templates-experimental/docusaurus/templates/{wrangler.json → wrangler.jsonc} +0 -0
- /package/templates-experimental/gatsby/templates/{wrangler.json → wrangler.jsonc} +0 -0
- /package/templates-experimental/hello-world-assets-only/templates/{wrangler.json → wrangler.jsonc} +0 -0
- /package/templates-experimental/hello-world-durable-object-with-assets/js/{wrangler.json → wrangler.jsonc} +0 -0
- /package/templates-experimental/hello-world-durable-object-with-assets/ts/{wrangler.json → wrangler.jsonc} +0 -0
- /package/templates-experimental/hello-world-with-assets/js/{wrangler.json → wrangler.jsonc} +0 -0
- /package/templates-experimental/hello-world-with-assets/py/{wrangler.json → wrangler.jsonc} +0 -0
- /package/templates-experimental/hello-world-with-assets/ts/{wrangler.json → wrangler.jsonc} +0 -0
- /package/templates-experimental/hono/templates/{wrangler.json → wrangler.jsonc} +0 -0
- /package/templates-experimental/next/templates/{wrangler.json → wrangler.jsonc} +0 -0
- /package/templates-experimental/nuxt/templates/{wrangler.json → wrangler.jsonc} +0 -0
- /package/templates-experimental/qwik/templates/{wrangler.json → wrangler.jsonc} +0 -0
- /package/templates-experimental/solid/templates/{wrangler.json → wrangler.jsonc} +0 -0
- /package/templates-experimental/svelte/templates/{wrangler.json → wrangler.jsonc} +0 -0
- /package/templates-experimental/vue/templates/{wrangler.json → wrangler.jsonc} +0 -0
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "create-cloudflare",
|
|
3
|
-
"version": "0.0.0-
|
|
3
|
+
"version": "0.0.0-fbba583df",
|
|
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.
|
|
33
|
+
"@cloudflare/workers-types": "^4.20250224.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.
|
|
41
|
+
"@types/node": "^18.19.75",
|
|
42
42
|
"@types/semver": "^7.5.1",
|
|
43
43
|
"@types/which-pm-runs": "^1.0.0",
|
|
44
44
|
"@types/yargs": "^17.0.22",
|
|
@@ -46,6 +46,7 @@
|
|
|
46
46
|
"@typescript-eslint/parser": "^6.9.0",
|
|
47
47
|
"chalk": "^5.2.0",
|
|
48
48
|
"command-exists": "^1.2.9",
|
|
49
|
+
"comment-json": "^4.2.5",
|
|
49
50
|
"cross-spawn": "^7.0.3",
|
|
50
51
|
"deepmerge": "^4.3.1",
|
|
51
52
|
"degit": "^2.8.4",
|
|
@@ -59,17 +60,21 @@
|
|
|
59
60
|
"magic-string": "^0.30.5",
|
|
60
61
|
"open": "^8.4.0",
|
|
61
62
|
"recast": "^0.22.0",
|
|
62
|
-
"semver": "^7.
|
|
63
|
-
"
|
|
63
|
+
"semver": "^7.7.1",
|
|
64
|
+
"typescript": "^5.7.2",
|
|
65
|
+
"undici": "^5.28.5",
|
|
66
|
+
"vite": "^5.4.14",
|
|
64
67
|
"vite-tsconfig-paths": "^4.0.8",
|
|
68
|
+
"vitest": "~3.0.5",
|
|
65
69
|
"which-pm-runs": "^1.1.0",
|
|
66
70
|
"wrap-ansi": "^9.0.0",
|
|
67
71
|
"xdg-app-paths": "^8.3.0",
|
|
68
72
|
"yargs": "^17.7.2",
|
|
69
73
|
"@cloudflare/cli": "1.1.1",
|
|
74
|
+
"@cloudflare/eslint-config-worker": "1.1.0",
|
|
70
75
|
"@cloudflare/workers-tsconfig": "0.0.0",
|
|
71
|
-
"wrangler": "0.0.0-
|
|
72
|
-
"@cloudflare/
|
|
76
|
+
"wrangler": "0.0.0-fbba583df",
|
|
77
|
+
"@cloudflare/mock-npm-registry": "0.0.0"
|
|
73
78
|
},
|
|
74
79
|
"engines": {
|
|
75
80
|
"node": ">=18.14.1"
|
|
@@ -93,7 +98,7 @@
|
|
|
93
98
|
"test:e2e:yarn": "pnpm run build && cross-env TEST_PM=yarn vitest run --config ./vitest-e2e.config.mts",
|
|
94
99
|
"test:unit": "vitest run --config ./vitest.config.mts",
|
|
95
100
|
"test:unit:watch": "vitest --config ./vitest.config.mts",
|
|
96
|
-
"
|
|
101
|
+
"dev": "node -r esbuild-register scripts/build.ts --watch",
|
|
97
102
|
"test:ci": "vitest run --config ./vitest.config.mts"
|
|
98
103
|
}
|
|
99
104
|
}
|
package/templates/angular/c3.ts
CHANGED
|
@@ -8,7 +8,7 @@ import { readFile, readJSON, writeFile } from "helpers/files";
|
|
|
8
8
|
import { detectPackageManager } from "helpers/packageManagers";
|
|
9
9
|
import { installPackages } from "helpers/packages";
|
|
10
10
|
import type { TemplateConfig } from "../../src/templates";
|
|
11
|
-
import type { C3Context } from "types";
|
|
11
|
+
import type { C3Context, PackageJson } from "types";
|
|
12
12
|
|
|
13
13
|
const { npm } = detectPackageManager();
|
|
14
14
|
|
|
@@ -64,10 +64,10 @@ async function updateAppCode() {
|
|
|
64
64
|
// Remove unwanted dependencies
|
|
65
65
|
s.start(`Updating package.json`);
|
|
66
66
|
const packageJsonPath = resolve("package.json");
|
|
67
|
-
const packageManifest = readJSON(packageJsonPath);
|
|
67
|
+
const packageManifest = readJSON(packageJsonPath) as PackageJson;
|
|
68
68
|
|
|
69
|
-
delete packageManifest["dependencies"]["express"];
|
|
70
|
-
delete packageManifest["devDependencies"]["@types/express"];
|
|
69
|
+
delete packageManifest["dependencies"]?.["express"];
|
|
70
|
+
delete packageManifest["devDependencies"]?.["@types/express"];
|
|
71
71
|
|
|
72
72
|
writeFile(packageJsonPath, JSON.stringify(packageManifest, null, 2));
|
|
73
73
|
s.stop(`${brandColor(`updated`)} ${dim(`\`package.json\``)}`);
|
|
@@ -76,7 +76,8 @@ async function updateAppCode() {
|
|
|
76
76
|
function updateAngularJson(ctx: C3Context) {
|
|
77
77
|
const s = spinner();
|
|
78
78
|
s.start(`Updating angular.json config`);
|
|
79
|
-
const angularJson = readJSON(
|
|
79
|
+
const angularJson = readJSON("angular.json") as AngularJson;
|
|
80
|
+
|
|
80
81
|
// Update builder
|
|
81
82
|
const architectSection = angularJson.projects[ctx.project.name].architect;
|
|
82
83
|
architectSection.build.options.outputPath = "dist";
|
|
@@ -112,3 +113,21 @@ const config: TemplateConfig = {
|
|
|
112
113
|
}),
|
|
113
114
|
};
|
|
114
115
|
export default config;
|
|
116
|
+
|
|
117
|
+
type AngularJson = {
|
|
118
|
+
projects: Record<
|
|
119
|
+
string,
|
|
120
|
+
{
|
|
121
|
+
architect: {
|
|
122
|
+
build: {
|
|
123
|
+
options: {
|
|
124
|
+
outputPath: string;
|
|
125
|
+
outputMode: string;
|
|
126
|
+
ssr: Record<string, unknown>;
|
|
127
|
+
assets: string[];
|
|
128
|
+
};
|
|
129
|
+
};
|
|
130
|
+
};
|
|
131
|
+
}
|
|
132
|
+
>;
|
|
133
|
+
};
|
|
@@ -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.
|
|
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,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;
|
|
@@ -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(
|
|
17
|
+
const response = await SELF.fetch('http://example.com');
|
|
18
18
|
expect(await response.text()).toMatchInlineSnapshot(`"Hello World!"`);
|
|
19
19
|
});
|
|
20
20
|
});
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
3.12
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
## Usage
|
|
2
|
+
|
|
3
|
+
You can run the worker defined by your new project by executing `wrangler dev` in this
|
|
4
|
+
directory. This will start up an HTTP server and will allow you to iterate on your
|
|
5
|
+
worker without having to restart `wrangler`.
|
|
6
|
+
|
|
7
|
+
### Types and autocomplete
|
|
8
|
+
|
|
9
|
+
This project also includes a pyproject.toml and uv.lock file with some requirements which
|
|
10
|
+
set up autocomplete and type hints for this Python Workers project.
|
|
11
|
+
|
|
12
|
+
To get these installed you'll need `uv`, which you can install by following
|
|
13
|
+
https://docs.astral.sh/uv/getting-started/installation/.
|
|
14
|
+
|
|
15
|
+
Once `uv` is installed, you can run the following:
|
|
16
|
+
|
|
17
|
+
```
|
|
18
|
+
uv venv
|
|
19
|
+
uv sync
|
|
20
|
+
```
|
|
21
|
+
|
|
22
|
+
Then point your editor's Python plugin at the `.venv` directory. You should then have working
|
|
23
|
+
autocomplete and type information in your editor.
|
|
@@ -0,0 +1,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
|
+
]
|
|
@@ -10,9 +10,9 @@
|
|
|
10
10
|
"cf-typegen": "wrangler types"
|
|
11
11
|
},
|
|
12
12
|
"devDependencies": {
|
|
13
|
-
"@cloudflare/vitest-pool-workers": "^0.
|
|
13
|
+
"@cloudflare/vitest-pool-workers": "^0.6.4",
|
|
14
14
|
"typescript": "^5.5.2",
|
|
15
|
-
"vitest": "2.1.
|
|
15
|
+
"vitest": "~2.1.9",
|
|
16
16
|
"wrangler": "^3.101.0"
|
|
17
17
|
}
|
|
18
18
|
}
|
|
@@ -5,7 +5,7 @@
|
|
|
5
5
|
* - Open a browser tab at http://localhost:8787/ to see your worker in action
|
|
6
6
|
* - Run `npm run deploy` to publish your worker
|
|
7
7
|
*
|
|
8
|
-
* Bind resources to your worker in `wrangler.
|
|
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/
|
|
@@ -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.
|
|
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.
|
|
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.
|
|
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
|
*/
|
|
@@ -7,7 +7,7 @@ import { DurableObject } from "cloudflare:workers";
|
|
|
7
7
|
* - Open a browser tab at http://localhost:8787/ to see your Durable Object in action
|
|
8
8
|
* - Run `npm run deploy` to publish your application
|
|
9
9
|
*
|
|
10
|
-
* Bind resources to your worker in `wrangler.
|
|
10
|
+
* Bind resources to your worker in `wrangler.jsonc`. After adding bindings, a type definition for the
|
|
11
11
|
* `Env` object can be regenerated with `npm run cf-typegen`.
|
|
12
12
|
*
|
|
13
13
|
* Learn more at https://developers.cloudflare.com/durable-objects
|
|
@@ -20,7 +20,7 @@ export class MyDurableObject extends DurableObject<Env> {
|
|
|
20
20
|
* `DurableObjectStub::get` for a given identifier (no-op constructors can be omitted)
|
|
21
21
|
*
|
|
22
22
|
* @param ctx - The interface for interacting with Durable Object state
|
|
23
|
-
* @param env - The interface to reference bindings declared in wrangler.
|
|
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.
|
|
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
|
*/
|
package/templates/hono/c3.ts
CHANGED
package/templates/next/README.md
CHANGED
|
@@ -47,7 +47,7 @@ In order to enable the example:
|
|
|
47
47
|
// KV Example:
|
|
48
48
|
```
|
|
49
49
|
and uncomment the commented lines below it (also uncomment the relevant imports).
|
|
50
|
-
- In the `wrangler.
|
|
50
|
+
- In the `wrangler.jsonc` file add the following configuration line:
|
|
51
51
|
```
|
|
52
52
|
"kv_namespaces": [{ "binding": "MY_KV_NAMESPACE", "id": "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx" }],
|
|
53
53
|
```
|
package/templates/next/c3.ts
CHANGED
|
@@ -26,9 +26,9 @@ const generate = async (ctx: C3Context) => {
|
|
|
26
26
|
|
|
27
27
|
await runFrameworkGenerator(ctx, [projectName]);
|
|
28
28
|
|
|
29
|
-
const wranglerConfig = readFile(join(getTemplatePath(ctx), "wrangler.
|
|
30
|
-
writeFile(join(ctx.project.path, "wrangler.
|
|
31
|
-
updateStatus("Created wrangler.
|
|
29
|
+
const wranglerConfig = readFile(join(getTemplatePath(ctx), "wrangler.jsonc"));
|
|
30
|
+
writeFile(join(ctx.project.path, "wrangler.jsonc"), wranglerConfig);
|
|
31
|
+
updateStatus("Created wrangler.jsonc file");
|
|
32
32
|
};
|
|
33
33
|
|
|
34
34
|
const updateNextConfig = (usesTs: boolean) => {
|
|
@@ -42,12 +42,12 @@ const updateNextConfig = (usesTs: boolean) => {
|
|
|
42
42
|
const updatedConfigFile =
|
|
43
43
|
`import { setupDevPlatform } from '@cloudflare/next-on-pages/next-dev';
|
|
44
44
|
|
|
45
|
-
// Here we use the @cloudflare/next-on-pages next-dev module to allow us to
|
|
46
|
-
// (when running the application with
|
|
45
|
+
// Here we use the @cloudflare/next-on-pages next-dev module to allow us to
|
|
46
|
+
// use bindings during local development (when running the application with
|
|
47
|
+
// \`next dev\`). This function is only necessary during development and
|
|
48
|
+
// has no impact outside of that. For more information see:
|
|
47
49
|
// https://github.com/cloudflare/next-on-pages/blob/main/internal-packages/next-dev/README.md
|
|
48
|
-
|
|
49
|
-
await setupDevPlatform();
|
|
50
|
-
}
|
|
50
|
+
setupDevPlatform().catch(console.error);
|
|
51
51
|
|
|
52
52
|
`.replace(/\n\t*/g, "\n") + configContent;
|
|
53
53
|
|
|
@@ -125,7 +125,10 @@ export const shouldInstallNextOnPagesEslintPlugin = async (
|
|
|
125
125
|
};
|
|
126
126
|
|
|
127
127
|
export const writeEslintrc = async (ctx: C3Context): Promise<void> => {
|
|
128
|
-
const eslintConfig = readJSON(`${ctx.project.path}/.eslintrc.json`)
|
|
128
|
+
const eslintConfig = readJSON(`${ctx.project.path}/.eslintrc.json`) as {
|
|
129
|
+
plugins: string[];
|
|
130
|
+
extends: string | string[];
|
|
131
|
+
};
|
|
129
132
|
|
|
130
133
|
eslintConfig.plugins ??= [];
|
|
131
134
|
eslintConfig.plugins.push("eslint-plugin-next-on-pages");
|
|
@@ -56,7 +56,7 @@ export async function copyExistingWorkerFiles(ctx: C3Context) {
|
|
|
56
56
|
{ recursive: true },
|
|
57
57
|
);
|
|
58
58
|
|
|
59
|
-
// copy wrangler.toml from the downloaded Worker
|
|
59
|
+
// copy ./wrangler.toml from the downloaded Worker
|
|
60
60
|
await cp(
|
|
61
61
|
join(tempdir, ctx.args.existingScript, "wrangler.toml"),
|
|
62
62
|
join(ctx.project.path, "wrangler.toml"),
|
|
@@ -8,7 +8,7 @@
|
|
|
8
8
|
* - Open a browser tab at http://localhost:8787/ to see your worker in action
|
|
9
9
|
* - Run `npm run deploy` to publish your worker
|
|
10
10
|
*
|
|
11
|
-
* Bind resources to your worker in `wrangler.
|
|
11
|
+
* Bind resources to your worker in `wrangler.jsonc`. After adding bindings, a type definition for the
|
|
12
12
|
* `Env` object can be regenerated with `npm run cf-typegen`.
|
|
13
13
|
*
|
|
14
14
|
* Learn more at https://developers.cloudflare.com/workers/
|
package/templates/qwik/c3.ts
CHANGED
|
@@ -10,7 +10,7 @@ import * as recast from "recast";
|
|
|
10
10
|
import type { TemplateConfig } from "../../src/templates";
|
|
11
11
|
import type { C3Context } from "types";
|
|
12
12
|
|
|
13
|
-
const { npm, npx } = detectPackageManager();
|
|
13
|
+
const { npm, npx, name } = detectPackageManager();
|
|
14
14
|
|
|
15
15
|
const generate = async (ctx: C3Context) => {
|
|
16
16
|
await runFrameworkGenerator(ctx, ["playground", ctx.project.name]);
|
|
@@ -18,7 +18,8 @@ const generate = async (ctx: C3Context) => {
|
|
|
18
18
|
|
|
19
19
|
const configure = async (ctx: C3Context) => {
|
|
20
20
|
// Add the pages integration
|
|
21
|
-
|
|
21
|
+
// For some reason `pnpx qwik add` fails for qwik so we use `pnpm qwik add` instead.
|
|
22
|
+
const cmd = [name === "pnpm" ? npm : npx, "qwik", "add", "cloudflare-pages"];
|
|
22
23
|
endSection(`Running ${quoteShellArgs(cmd)}`);
|
|
23
24
|
await runCommand(cmd);
|
|
24
25
|
|
|
@@ -20,7 +20,7 @@ export default {
|
|
|
20
20
|
return new Response(`To test the scheduled handler, ensure you have used the "--test-scheduled" then try running "curl ${url.href}".`);
|
|
21
21
|
},
|
|
22
22
|
|
|
23
|
-
// The scheduled handler is invoked at the interval set in our wrangler.
|
|
23
|
+
// The scheduled handler is invoked at the interval set in our wrangler.jsonc's
|
|
24
24
|
// [[triggers]] configuration.
|
|
25
25
|
async scheduled(event, env, ctx) {
|
|
26
26
|
// A Cron Trigger can make requests to other endpoints on the Internet,
|
|
@@ -9,14 +9,14 @@
|
|
|
9
9
|
* - Run `curl "http://localhost:8787/__scheduled?cron=*+*+*+*+*"` to see your Worker in action
|
|
10
10
|
* - Run `npm run deploy` to publish your Worker
|
|
11
11
|
*
|
|
12
|
-
* Bind resources to your Worker in `wrangler.
|
|
12
|
+
* Bind resources to your Worker in `wrangler.jsonc`. After adding bindings, a type definition for the
|
|
13
13
|
* `Env` object can be regenerated with `npm run cf-typegen`.
|
|
14
14
|
*
|
|
15
15
|
* Learn more at https://developers.cloudflare.com/workers/
|
|
16
16
|
*/
|
|
17
17
|
|
|
18
18
|
export default {
|
|
19
|
-
// The scheduled handler is invoked at the interval set in our wrangler.
|
|
19
|
+
// The scheduled handler is invoked at the interval set in our wrangler.jsonc's
|
|
20
20
|
// [[triggers]] configuration.
|
|
21
21
|
async scheduled(event, env, ctx): Promise<void> {
|
|
22
22
|
// A Cron Trigger can make requests to other endpoints on the Internet,
|