create-cloudflare 2.45.3 → 2.46.1
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 +15 -32
- package/package.json +7 -7
- package/templates/hello-world/py/README.md +2 -2
- package/templates/hello-world/py/src/entry.py +3 -2
- package/templates/hello-world-durable-object/c3.ts +3 -0
- package/templates/hello-world-durable-object/py/.python-version +1 -0
- package/templates/hello-world-durable-object/py/README.md +23 -0
- package/templates/hello-world-durable-object/py/__dot__gitignore +68 -0
- package/templates/hello-world-durable-object/py/package.json +13 -0
- package/templates/hello-world-durable-object/py/pyproject.toml +9 -0
- package/templates/hello-world-durable-object/py/src/entry.py +66 -0
- package/templates/hello-world-durable-object/py/uv.lock +22 -0
- package/templates/hello-world-durable-object/py/wrangler.jsonc +27 -0
- package/templates/hello-world-durable-object-with-assets/c3.ts +3 -0
- package/templates/hello-world-durable-object-with-assets/py/.python-version +1 -0
- package/templates/hello-world-durable-object-with-assets/py/README.md +23 -0
- package/templates/hello-world-durable-object-with-assets/py/__dot__gitignore +68 -0
- package/templates/hello-world-durable-object-with-assets/py/package.json +13 -0
- package/templates/hello-world-durable-object-with-assets/py/public/index.html +19 -0
- package/templates/hello-world-durable-object-with-assets/py/pyproject.toml +9 -0
- package/templates/hello-world-durable-object-with-assets/py/src/entry.py +66 -0
- package/templates/hello-world-durable-object-with-assets/py/uv.lock +22 -0
- package/templates/hello-world-durable-object-with-assets/py/wrangler.jsonc +31 -0
- package/templates/hello-world-with-assets/py/.python-version +1 -0
- package/templates/hello-world-with-assets/py/README.md +23 -0
- package/templates/hello-world-with-assets/py/pyproject.toml +9 -0
- package/templates/hello-world-with-assets/py/src/entry.py +9 -7
- package/templates/hello-world-with-assets/py/uv.lock +22 -0
- package/templates/next/workers/c3.ts +2 -7
- package/templates/next/workers/templates/wrangler.jsonc +2 -1
package/dist/cli.js
CHANGED
|
@@ -74560,7 +74560,7 @@ var Yargs = YargsFactory(esm_default);
|
|
|
74560
74560
|
var yargs_default = Yargs;
|
|
74561
74561
|
|
|
74562
74562
|
// package.json
|
|
74563
|
-
var version = "2.
|
|
74563
|
+
var version = "2.46.1";
|
|
74564
74564
|
|
|
74565
74565
|
// src/metrics.ts
|
|
74566
74566
|
var import_node_async_hooks = require("node:async_hooks");
|
|
@@ -75335,20 +75335,20 @@ var package_default = {
|
|
|
75335
75335
|
"so that we can use dependabot to update these dependencies automatically."
|
|
75336
75336
|
],
|
|
75337
75337
|
dependencies: {
|
|
75338
|
-
"create-astro": "4.11.
|
|
75338
|
+
"create-astro": "4.11.3",
|
|
75339
75339
|
"create-analog": "1.8.1",
|
|
75340
|
-
"@angular/create": "19.2.
|
|
75340
|
+
"@angular/create": "19.2.9",
|
|
75341
75341
|
"create-docusaurus": "3.7.0",
|
|
75342
|
-
"create-hono": "0.
|
|
75342
|
+
"create-hono": "0.18.0",
|
|
75343
75343
|
"create-next-app": "15.3.1",
|
|
75344
75344
|
"create-qwik": "1.13.0",
|
|
75345
75345
|
"create-vite": "6.4.1",
|
|
75346
75346
|
"create-remix": "2.16.5",
|
|
75347
|
-
"create-react-router": "7.5.
|
|
75347
|
+
"create-react-router": "7.5.2",
|
|
75348
75348
|
"create-solid": "0.6.2",
|
|
75349
75349
|
"create-vue": "3.16.4",
|
|
75350
75350
|
gatsby: "5.14.3",
|
|
75351
|
-
sv: "0.8.
|
|
75351
|
+
sv: "0.8.3",
|
|
75352
75352
|
nuxi: "3.25.0"
|
|
75353
75353
|
}
|
|
75354
75354
|
};
|
|
@@ -76228,6 +76228,9 @@ var config17 = {
|
|
|
76228
76228
|
},
|
|
76229
76229
|
ts: {
|
|
76230
76230
|
path: "./ts"
|
|
76231
|
+
},
|
|
76232
|
+
python: {
|
|
76233
|
+
path: "./py"
|
|
76231
76234
|
}
|
|
76232
76235
|
}
|
|
76233
76236
|
}
|
|
@@ -76248,6 +76251,9 @@ var config18 = {
|
|
|
76248
76251
|
},
|
|
76249
76252
|
ts: {
|
|
76250
76253
|
path: "./ts"
|
|
76254
|
+
},
|
|
76255
|
+
python: {
|
|
76256
|
+
path: "./py"
|
|
76251
76257
|
}
|
|
76252
76258
|
}
|
|
76253
76259
|
}
|
|
@@ -76565,14 +76571,9 @@ var generate14 = async (ctx) => {
|
|
|
76565
76571
|
await runFrameworkGenerator(ctx, [ctx.project.name]);
|
|
76566
76572
|
};
|
|
76567
76573
|
var configure8 = async (ctx) => {
|
|
76568
|
-
|
|
76569
|
-
"@opennextjs/cloudflare@~1.0.0-beta.0 || ^1.0.0",
|
|
76570
|
-
"@cloudflare/workers-types"
|
|
76571
|
-
];
|
|
76572
|
-
await installPackages(packages, {
|
|
76573
|
-
dev: true,
|
|
76574
|
+
await installPackages(["@opennextjs/cloudflare@~1.0.0-beta.0 || ^1.0.0"], {
|
|
76574
76575
|
startText: "Adding the Cloudflare adapter",
|
|
76575
|
-
doneText: `${brandColor(`installed`)}
|
|
76576
|
+
doneText: `${brandColor(`installed`)} @opennextjs/cloudflare)}`
|
|
76576
76577
|
});
|
|
76577
76578
|
const usesTs = usesTypescript(ctx);
|
|
76578
76579
|
updateNextConfig2(usesTs);
|
|
@@ -78063,7 +78064,7 @@ var c3_default50 = config47;
|
|
|
78063
78064
|
var import_node_assert = __toESM(require("node:assert"));
|
|
78064
78065
|
|
|
78065
78066
|
// ../wrangler/package.json
|
|
78066
|
-
var version2 = "4.
|
|
78067
|
+
var version2 = "4.14.3";
|
|
78067
78068
|
|
|
78068
78069
|
// src/git.ts
|
|
78069
78070
|
var offerGit = async (ctx) => {
|
|
@@ -81663,26 +81664,8 @@ repeat-string/index.js:
|
|
|
81663
81664
|
*)
|
|
81664
81665
|
|
|
81665
81666
|
yargs-parser/build/lib/string-utils.js:
|
|
81666
|
-
(**
|
|
81667
|
-
* @license
|
|
81668
|
-
* Copyright (c) 2016, Contributors
|
|
81669
|
-
* SPDX-License-Identifier: ISC
|
|
81670
|
-
*)
|
|
81671
|
-
|
|
81672
81667
|
yargs-parser/build/lib/tokenize-arg-string.js:
|
|
81673
|
-
(**
|
|
81674
|
-
* @license
|
|
81675
|
-
* Copyright (c) 2016, Contributors
|
|
81676
|
-
* SPDX-License-Identifier: ISC
|
|
81677
|
-
*)
|
|
81678
|
-
|
|
81679
81668
|
yargs-parser/build/lib/yargs-parser-types.js:
|
|
81680
|
-
(**
|
|
81681
|
-
* @license
|
|
81682
|
-
* Copyright (c) 2016, Contributors
|
|
81683
|
-
* SPDX-License-Identifier: ISC
|
|
81684
|
-
*)
|
|
81685
|
-
|
|
81686
81669
|
yargs-parser/build/lib/yargs-parser.js:
|
|
81687
81670
|
(**
|
|
81688
81671
|
* @license
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "create-cloudflare",
|
|
3
|
-
"version": "2.
|
|
3
|
+
"version": "2.46.1",
|
|
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.20250507.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": "^
|
|
41
|
+
"@types/node": "^20.17.32",
|
|
42
42
|
"@types/semver": "^7.5.1",
|
|
43
43
|
"@types/which-pm-runs": "^1.0.0",
|
|
44
44
|
"@types/yargs": "^17.0.22",
|
|
@@ -52,7 +52,7 @@
|
|
|
52
52
|
"degit": "^2.8.4",
|
|
53
53
|
"dns2": "^2.1.0",
|
|
54
54
|
"dotenv": "^16.0.0",
|
|
55
|
-
"esbuild": "0.25.
|
|
55
|
+
"esbuild": "0.25.4",
|
|
56
56
|
"execa": "^7.1.1",
|
|
57
57
|
"glob": "^10.3.3",
|
|
58
58
|
"haikunator": "^2.1.2",
|
|
@@ -71,11 +71,11 @@
|
|
|
71
71
|
"xdg-app-paths": "^8.3.0",
|
|
72
72
|
"yargs": "^17.7.2",
|
|
73
73
|
"@cloudflare/cli": "1.1.1",
|
|
74
|
+
"@cloudflare/eslint-config-worker": "1.1.0",
|
|
74
75
|
"@cloudflare/mock-npm-registry": "0.0.0",
|
|
75
|
-
"@cloudflare/vite-plugin": "1.
|
|
76
|
+
"@cloudflare/vite-plugin": "1.1.1",
|
|
76
77
|
"@cloudflare/workers-tsconfig": "0.0.0",
|
|
77
|
-
"wrangler": "4.
|
|
78
|
-
"@cloudflare/eslint-config-worker": "1.1.0"
|
|
78
|
+
"wrangler": "4.14.3"
|
|
79
79
|
},
|
|
80
80
|
"engines": {
|
|
81
81
|
"node": ">=18.14.1"
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
## Usage
|
|
2
2
|
|
|
3
|
-
You can run the
|
|
3
|
+
You can run the Worker defined by your new project by executing `wrangler dev` in this
|
|
4
4
|
directory. This will start up an HTTP server and will allow you to iterate on your
|
|
5
|
-
|
|
5
|
+
Worker without having to restart `wrangler`.
|
|
6
6
|
|
|
7
7
|
### Types and autocomplete
|
|
8
8
|
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
3.12
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
## Usage
|
|
2
|
+
|
|
3
|
+
You can run the Worker defined by your new project by executing `wrangler dev` in this
|
|
4
|
+
directory. This will start up an HTTP server and will allow you to iterate on your
|
|
5
|
+
Worker without having to restart `wrangler`.
|
|
6
|
+
|
|
7
|
+
### Types and autocomplete
|
|
8
|
+
|
|
9
|
+
This project also includes a pyproject.toml and uv.lock file with some requirements which
|
|
10
|
+
set up autocomplete and type hints for this Python Workers project.
|
|
11
|
+
|
|
12
|
+
To get these installed you'll need `uv`, which you can install by following
|
|
13
|
+
https://docs.astral.sh/uv/getting-started/installation/.
|
|
14
|
+
|
|
15
|
+
Once `uv` is installed, you can run the following:
|
|
16
|
+
|
|
17
|
+
```
|
|
18
|
+
uv venv
|
|
19
|
+
uv sync
|
|
20
|
+
```
|
|
21
|
+
|
|
22
|
+
Then point your editor's Python plugin at the `.venv` directory. You should then have working
|
|
23
|
+
autocomplete and type information in your editor.
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
# Logs
|
|
2
|
+
|
|
3
|
+
logs
|
|
4
|
+
_.log
|
|
5
|
+
npm-debug.log_
|
|
6
|
+
yarn-debug.log*
|
|
7
|
+
yarn-error.log*
|
|
8
|
+
lerna-debug.log*
|
|
9
|
+
.pnpm-debug.log*
|
|
10
|
+
|
|
11
|
+
# Diagnostic reports (https://nodejs.org/api/report.html)
|
|
12
|
+
|
|
13
|
+
report.[0-9]_.[0-9]_.[0-9]_.[0-9]_.json
|
|
14
|
+
|
|
15
|
+
# Runtime data
|
|
16
|
+
|
|
17
|
+
pids
|
|
18
|
+
_.pid
|
|
19
|
+
_.seed
|
|
20
|
+
\*.pid.lock
|
|
21
|
+
|
|
22
|
+
# Dependency directories
|
|
23
|
+
|
|
24
|
+
node_modules/
|
|
25
|
+
jspm_packages/
|
|
26
|
+
|
|
27
|
+
# TypeScript cache
|
|
28
|
+
|
|
29
|
+
\*.tsbuildinfo
|
|
30
|
+
|
|
31
|
+
# Optional npm cache directory
|
|
32
|
+
|
|
33
|
+
.npm
|
|
34
|
+
|
|
35
|
+
# Optional eslint cache
|
|
36
|
+
|
|
37
|
+
.eslintcache
|
|
38
|
+
|
|
39
|
+
# Optional stylelint cache
|
|
40
|
+
|
|
41
|
+
.stylelintcache
|
|
42
|
+
|
|
43
|
+
# Optional REPL history
|
|
44
|
+
|
|
45
|
+
.node_repl_history
|
|
46
|
+
|
|
47
|
+
# Output of 'npm pack'
|
|
48
|
+
|
|
49
|
+
\*.tgz
|
|
50
|
+
|
|
51
|
+
# dotenv environment variable files
|
|
52
|
+
|
|
53
|
+
.env
|
|
54
|
+
.env.development.local
|
|
55
|
+
.env.test.local
|
|
56
|
+
.env.production.local
|
|
57
|
+
.env.local
|
|
58
|
+
|
|
59
|
+
# public
|
|
60
|
+
|
|
61
|
+
# Stores VSCode versions used for testing VSCode extensions
|
|
62
|
+
|
|
63
|
+
.vscode-test
|
|
64
|
+
|
|
65
|
+
# wrangler project
|
|
66
|
+
|
|
67
|
+
.dev.vars
|
|
68
|
+
.wrangler/
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
from workers import DurableObject, Response
|
|
2
|
+
|
|
3
|
+
"""
|
|
4
|
+
* Welcome to Cloudflare Workers! This is your first Durable Objects application.
|
|
5
|
+
*
|
|
6
|
+
* - Run `npm run dev` in your terminal to start a development server
|
|
7
|
+
* - Open a browser tab at http://localhost:8787/ to see your Durable Object in action
|
|
8
|
+
* - Run `npm run deploy` to publish your application
|
|
9
|
+
*
|
|
10
|
+
* Learn more at https://developers.cloudflare.com/durable-objects
|
|
11
|
+
"""
|
|
12
|
+
|
|
13
|
+
"""
|
|
14
|
+
* Env provides a mechanism to reference bindings declared in wrangler.jsonc within Python
|
|
15
|
+
*
|
|
16
|
+
* @typedef {Object} Env
|
|
17
|
+
* @property {DurableObjectNamespace} MY_DURABLE_OBJECT - The Durable Object namespace binding
|
|
18
|
+
"""
|
|
19
|
+
|
|
20
|
+
# A Durable Object's behavior is defined in an exported Python class
|
|
21
|
+
class MyDurableObject(DurableObject):
|
|
22
|
+
"""
|
|
23
|
+
* The constructor is invoked once upon creation of the Durable Object, i.e. the first call to
|
|
24
|
+
* `DurableObjectStub::get` for a given identifier (no-op constructors can be omitted)
|
|
25
|
+
*
|
|
26
|
+
* @param {DurableObjectState} ctx - The interface for interacting with Durable Object state
|
|
27
|
+
* @param {Env} env - The interface to reference bindings declared in wrangler.jsonc
|
|
28
|
+
"""
|
|
29
|
+
def __init__(self, ctx, env):
|
|
30
|
+
super().__init__(ctx, env)
|
|
31
|
+
|
|
32
|
+
"""
|
|
33
|
+
* The Durable Object exposes an RPC method `say_hello` which will be invoked when when a Durable
|
|
34
|
+
* Object instance receives a request from a Worker via the same method invocation on the stub
|
|
35
|
+
*
|
|
36
|
+
* @param {string} name - The name provided to a Durable Object instance from a Worker
|
|
37
|
+
* @returns {Promise<string>} The greeting to be sent back to the Worker
|
|
38
|
+
"""
|
|
39
|
+
async def say_hello(self, name):
|
|
40
|
+
return f"Hello, {name}!"
|
|
41
|
+
|
|
42
|
+
|
|
43
|
+
"""
|
|
44
|
+
* This is the standard fetch handler for a Cloudflare Worker
|
|
45
|
+
*
|
|
46
|
+
* @param {Request} request - The request submitted to the Worker from the client
|
|
47
|
+
* @param {Env} env - The interface to reference bindings declared in wrangler.jsonc
|
|
48
|
+
* @param {ExecutionContext} ctx - The execution context of the Worker
|
|
49
|
+
* @returns {Promise<Response>} The response to be sent back to the client
|
|
50
|
+
"""
|
|
51
|
+
async def on_fetch(request, env, ctx):
|
|
52
|
+
# Create a `DurableObjectId` for an instance of the `MyDurableObject`
|
|
53
|
+
# class named "foo". Requests from all Workers to the instance named
|
|
54
|
+
# "foo" will go to a single globally unique Durable Object instance.
|
|
55
|
+
id = env.MY_DURABLE_OBJECT.idFromName("foo")
|
|
56
|
+
|
|
57
|
+
# Create a stub to open a communication channel with the Durable
|
|
58
|
+
# Object instance.
|
|
59
|
+
stub = env.MY_DURABLE_OBJECT.get(id)
|
|
60
|
+
|
|
61
|
+
# Call the `say_hello()` RPC method on the stub to invoke the method on
|
|
62
|
+
# the remote Durable Object instance
|
|
63
|
+
greeting = await stub.say_hello("world")
|
|
64
|
+
|
|
65
|
+
return Response(greeting)
|
|
66
|
+
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
version = 1
|
|
2
|
+
requires-python = ">=3.12"
|
|
3
|
+
|
|
4
|
+
[[package]]
|
|
5
|
+
name = "<TBD>"
|
|
6
|
+
version = "0.1.0"
|
|
7
|
+
source = { virtual = "." }
|
|
8
|
+
dependencies = [
|
|
9
|
+
{ name = "webtypy" },
|
|
10
|
+
]
|
|
11
|
+
|
|
12
|
+
[package.metadata]
|
|
13
|
+
requires-dist = [{ name = "webtypy", specifier = ">=0.1.7" }]
|
|
14
|
+
|
|
15
|
+
[[package]]
|
|
16
|
+
name = "webtypy"
|
|
17
|
+
version = "0.1.7"
|
|
18
|
+
source = { registry = "https://pypi.org/simple" }
|
|
19
|
+
sdist = { url = "https://files.pythonhosted.org/packages/5e/89/c7a0311fdc73809fc2415be97767f085ff3e00c86546430034dc8465fee7/webtypy-0.1.7.tar.gz", hash = "sha256:1b7212719a949c802f3d60fac5f0d952eb503a92121409cf1ad9847d7c76a336", size = 104505 }
|
|
20
|
+
wheels = [
|
|
21
|
+
{ url = "https://files.pythonhosted.org/packages/61/91/c731bdaa605279e00b28bfd2bf0ae67f48061d16890fb1c026924bfbd242/webtypy-0.1.7-py3-none-any.whl", hash = "sha256:f35e6d73a4e08783e23adfac271a11cda3a2bd1105499db70e4819244efed0ae", size = 103519 },
|
|
22
|
+
]
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "<TBD>",
|
|
3
|
+
"main": "src/entry.py",
|
|
4
|
+
"compatibility_date": "<TBD>",
|
|
5
|
+
"compatibility_flags": [
|
|
6
|
+
"python_workers"
|
|
7
|
+
],
|
|
8
|
+
"migrations": [
|
|
9
|
+
{
|
|
10
|
+
"new_sqlite_classes": [
|
|
11
|
+
"MyDurableObject"
|
|
12
|
+
],
|
|
13
|
+
"tag": "v1"
|
|
14
|
+
}
|
|
15
|
+
],
|
|
16
|
+
"durable_objects": {
|
|
17
|
+
"bindings": [
|
|
18
|
+
{
|
|
19
|
+
"class_name": "MyDurableObject",
|
|
20
|
+
"name": "MY_DURABLE_OBJECT"
|
|
21
|
+
}
|
|
22
|
+
]
|
|
23
|
+
},
|
|
24
|
+
"observability": {
|
|
25
|
+
"enabled": true
|
|
26
|
+
}
|
|
27
|
+
}
|
|
@@ -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,68 @@
|
|
|
1
|
+
# Logs
|
|
2
|
+
|
|
3
|
+
logs
|
|
4
|
+
_.log
|
|
5
|
+
npm-debug.log_
|
|
6
|
+
yarn-debug.log*
|
|
7
|
+
yarn-error.log*
|
|
8
|
+
lerna-debug.log*
|
|
9
|
+
.pnpm-debug.log*
|
|
10
|
+
|
|
11
|
+
# Diagnostic reports (https://nodejs.org/api/report.html)
|
|
12
|
+
|
|
13
|
+
report.[0-9]_.[0-9]_.[0-9]_.[0-9]_.json
|
|
14
|
+
|
|
15
|
+
# Runtime data
|
|
16
|
+
|
|
17
|
+
pids
|
|
18
|
+
_.pid
|
|
19
|
+
_.seed
|
|
20
|
+
\*.pid.lock
|
|
21
|
+
|
|
22
|
+
# Dependency directories
|
|
23
|
+
|
|
24
|
+
node_modules/
|
|
25
|
+
jspm_packages/
|
|
26
|
+
|
|
27
|
+
# TypeScript cache
|
|
28
|
+
|
|
29
|
+
\*.tsbuildinfo
|
|
30
|
+
|
|
31
|
+
# Optional npm cache directory
|
|
32
|
+
|
|
33
|
+
.npm
|
|
34
|
+
|
|
35
|
+
# Optional eslint cache
|
|
36
|
+
|
|
37
|
+
.eslintcache
|
|
38
|
+
|
|
39
|
+
# Optional stylelint cache
|
|
40
|
+
|
|
41
|
+
.stylelintcache
|
|
42
|
+
|
|
43
|
+
# Optional REPL history
|
|
44
|
+
|
|
45
|
+
.node_repl_history
|
|
46
|
+
|
|
47
|
+
# Output of 'npm pack'
|
|
48
|
+
|
|
49
|
+
\*.tgz
|
|
50
|
+
|
|
51
|
+
# dotenv environment variable files
|
|
52
|
+
|
|
53
|
+
.env
|
|
54
|
+
.env.development.local
|
|
55
|
+
.env.test.local
|
|
56
|
+
.env.production.local
|
|
57
|
+
.env.local
|
|
58
|
+
|
|
59
|
+
# public
|
|
60
|
+
|
|
61
|
+
# Stores VSCode versions used for testing VSCode extensions
|
|
62
|
+
|
|
63
|
+
.vscode-test
|
|
64
|
+
|
|
65
|
+
# wrangler project
|
|
66
|
+
|
|
67
|
+
.dev.vars
|
|
68
|
+
.wrangler/
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
<!DOCTYPE html>
|
|
2
|
+
<html lang="en">
|
|
3
|
+
<head>
|
|
4
|
+
<meta charset="UTF-8" />
|
|
5
|
+
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
|
6
|
+
<title>Hello, World!</title>
|
|
7
|
+
</head>
|
|
8
|
+
<body>
|
|
9
|
+
<h1 id="heading"></h1>
|
|
10
|
+
<script>
|
|
11
|
+
fetch('/message')
|
|
12
|
+
.then((resp) => resp.text())
|
|
13
|
+
.then((text) => {
|
|
14
|
+
const h1 = document.getElementById('heading');
|
|
15
|
+
h1.textContent = text;
|
|
16
|
+
});
|
|
17
|
+
</script>
|
|
18
|
+
</body>
|
|
19
|
+
</html>
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
from workers import DurableObject, Response
|
|
2
|
+
|
|
3
|
+
"""
|
|
4
|
+
* Welcome to Cloudflare Workers! This is your first Durable Objects application.
|
|
5
|
+
*
|
|
6
|
+
* - Run `npm run dev` in your terminal to start a development server
|
|
7
|
+
* - Open a browser tab at http://localhost:8787/ to see your Durable Object in action
|
|
8
|
+
* - Run `npm run deploy` to publish your application
|
|
9
|
+
*
|
|
10
|
+
* Learn more at https://developers.cloudflare.com/durable-objects
|
|
11
|
+
"""
|
|
12
|
+
|
|
13
|
+
"""
|
|
14
|
+
* Env provides a mechanism to reference bindings declared in wrangler.jsonc within Python
|
|
15
|
+
*
|
|
16
|
+
* @typedef {Object} Env
|
|
17
|
+
* @property {DurableObjectNamespace} MY_DURABLE_OBJECT - The Durable Object namespace binding
|
|
18
|
+
"""
|
|
19
|
+
|
|
20
|
+
# A Durable Object's behavior is defined in an exported Python class
|
|
21
|
+
class MyDurableObject(DurableObject):
|
|
22
|
+
"""
|
|
23
|
+
* The constructor is invoked once upon creation of the Durable Object, i.e. the first call to
|
|
24
|
+
* `DurableObjectStub::get` for a given identifier (no-op constructors can be omitted)
|
|
25
|
+
*
|
|
26
|
+
* @param {DurableObjectState} ctx - The interface for interacting with Durable Object state
|
|
27
|
+
* @param {Env} env - The interface to reference bindings declared in wrangler.jsonc
|
|
28
|
+
"""
|
|
29
|
+
def __init__(self, ctx, env):
|
|
30
|
+
super().__init__(ctx, env)
|
|
31
|
+
|
|
32
|
+
"""
|
|
33
|
+
* The Durable Object exposes an RPC method `say_hello` which will be invoked when when a Durable
|
|
34
|
+
* Object instance receives a request from a Worker via the same method invocation on the stub
|
|
35
|
+
*
|
|
36
|
+
* @param {string} name - The name provided to a Durable Object instance from a Worker
|
|
37
|
+
* @returns {Promise<string>} The greeting to be sent back to the Worker
|
|
38
|
+
"""
|
|
39
|
+
async def say_hello(self, name):
|
|
40
|
+
return f"Hello, {name}!"
|
|
41
|
+
|
|
42
|
+
|
|
43
|
+
"""
|
|
44
|
+
* This is the standard fetch handler for a Cloudflare Worker
|
|
45
|
+
*
|
|
46
|
+
* @param {Request} request - The request submitted to the Worker from the client
|
|
47
|
+
* @param {Env} env - The interface to reference bindings declared in wrangler.jsonc
|
|
48
|
+
* @param {ExecutionContext} ctx - The execution context of the Worker
|
|
49
|
+
* @returns {Promise<Response>} The response to be sent back to the client
|
|
50
|
+
"""
|
|
51
|
+
async def on_fetch(request, env, ctx):
|
|
52
|
+
# Create a `DurableObjectId` for an instance of the `MyDurableObject`
|
|
53
|
+
# class named "foo". Requests from all Workers to the instance named
|
|
54
|
+
# "foo" will go to a single globally unique Durable Object instance.
|
|
55
|
+
id = env.MY_DURABLE_OBJECT.idFromName("foo")
|
|
56
|
+
|
|
57
|
+
# Create a stub to open a communication channel with the Durable
|
|
58
|
+
# Object instance.
|
|
59
|
+
stub = env.MY_DURABLE_OBJECT.get(id)
|
|
60
|
+
|
|
61
|
+
# Call the `say_hello()` RPC method on the stub to invoke the method on
|
|
62
|
+
# the remote Durable Object instance
|
|
63
|
+
greeting = await stub.say_hello("world")
|
|
64
|
+
|
|
65
|
+
return Response(greeting)
|
|
66
|
+
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
version = 1
|
|
2
|
+
requires-python = ">=3.12"
|
|
3
|
+
|
|
4
|
+
[[package]]
|
|
5
|
+
name = "<TBD>"
|
|
6
|
+
version = "0.1.0"
|
|
7
|
+
source = { virtual = "." }
|
|
8
|
+
dependencies = [
|
|
9
|
+
{ name = "webtypy" },
|
|
10
|
+
]
|
|
11
|
+
|
|
12
|
+
[package.metadata]
|
|
13
|
+
requires-dist = [{ name = "webtypy", specifier = ">=0.1.7" }]
|
|
14
|
+
|
|
15
|
+
[[package]]
|
|
16
|
+
name = "webtypy"
|
|
17
|
+
version = "0.1.7"
|
|
18
|
+
source = { registry = "https://pypi.org/simple" }
|
|
19
|
+
sdist = { url = "https://files.pythonhosted.org/packages/5e/89/c7a0311fdc73809fc2415be97767f085ff3e00c86546430034dc8465fee7/webtypy-0.1.7.tar.gz", hash = "sha256:1b7212719a949c802f3d60fac5f0d952eb503a92121409cf1ad9847d7c76a336", size = 104505 }
|
|
20
|
+
wheels = [
|
|
21
|
+
{ url = "https://files.pythonhosted.org/packages/61/91/c731bdaa605279e00b28bfd2bf0ae67f48061d16890fb1c026924bfbd242/webtypy-0.1.7-py3-none-any.whl", hash = "sha256:f35e6d73a4e08783e23adfac271a11cda3a2bd1105499db70e4819244efed0ae", size = 103519 },
|
|
22
|
+
]
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "<TBD>",
|
|
3
|
+
"main": "src/entry.py",
|
|
4
|
+
"compatibility_date": "<TBD>",
|
|
5
|
+
"compatibility_flags": [
|
|
6
|
+
"python_workers"
|
|
7
|
+
],
|
|
8
|
+
"assets": {
|
|
9
|
+
"binding": "ASSETS",
|
|
10
|
+
"directory": "./public"
|
|
11
|
+
},
|
|
12
|
+
"migrations": [
|
|
13
|
+
{
|
|
14
|
+
"new_sqlite_classes": [
|
|
15
|
+
"MyDurableObject"
|
|
16
|
+
],
|
|
17
|
+
"tag": "v1"
|
|
18
|
+
}
|
|
19
|
+
],
|
|
20
|
+
"durable_objects": {
|
|
21
|
+
"bindings": [
|
|
22
|
+
{
|
|
23
|
+
"class_name": "MyDurableObject",
|
|
24
|
+
"name": "MY_DURABLE_OBJECT"
|
|
25
|
+
}
|
|
26
|
+
]
|
|
27
|
+
},
|
|
28
|
+
"observability": {
|
|
29
|
+
"enabled": true
|
|
30
|
+
}
|
|
31
|
+
}
|
|
@@ -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.
|
|
@@ -1,9 +1,11 @@
|
|
|
1
|
-
from
|
|
1
|
+
from workers import Response
|
|
2
|
+
from uuid import uuid4
|
|
3
|
+
from urllib.parse import urlparse
|
|
2
4
|
|
|
3
5
|
async def on_fetch(request, env):
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
6
|
+
url = urlparse(request.url)
|
|
7
|
+
if url.path == '/message':
|
|
8
|
+
return Response('Hello, World!')
|
|
9
|
+
if url.path == '/random':
|
|
10
|
+
return Response(uuid4())
|
|
11
|
+
return Response('Not Found', status=404)
|
|
@@ -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
|
+
]
|
|
@@ -11,14 +11,9 @@ const generate = async (ctx: C3Context) => {
|
|
|
11
11
|
};
|
|
12
12
|
|
|
13
13
|
const configure = async (ctx: C3Context) => {
|
|
14
|
-
|
|
15
|
-
"@opennextjs/cloudflare@~1.0.0-beta.0 || ^1.0.0",
|
|
16
|
-
"@cloudflare/workers-types",
|
|
17
|
-
];
|
|
18
|
-
await installPackages(packages, {
|
|
19
|
-
dev: true,
|
|
14
|
+
await installPackages(["@opennextjs/cloudflare@~1.0.0-beta.0 || ^1.0.0"], {
|
|
20
15
|
startText: "Adding the Cloudflare adapter",
|
|
21
|
-
doneText: `${brandColor(`installed`)}
|
|
16
|
+
doneText: `${brandColor(`installed`)} @opennextjs/cloudflare)}`,
|
|
22
17
|
});
|
|
23
18
|
|
|
24
19
|
const usesTs = usesTypescript(ctx);
|