create-cloudflare 0.0.0-e19903d7 → 0.0.0-e1d2fd668
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/README.md +1 -1
- package/dist/cli.js +39118 -38951
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +22 -21
- package/templates/analog/c3.ts +1 -0
- package/templates/angular/c3.ts +2 -0
- package/templates/astro/c3.ts +1 -0
- package/templates/common/c3.ts +3 -0
- package/templates/common/js/package.json +1 -1
- package/templates/common/js/wrangler.toml +6 -0
- package/templates/common/ts/package.json +2 -2
- package/templates/common/ts/src/ab-test.ts +2 -2
- package/templates/common/ts/src/index.ts +2 -2
- package/templates/common/ts/src/proxy.ts +2 -2
- package/templates/common/ts/src/redirect.ts +2 -2
- package/templates/common/ts/tsconfig.json +37 -95
- package/templates/common/ts/wrangler.toml +6 -0
- package/templates/docusaurus/c3.ts +3 -1
- package/templates/gatsby/c3.ts +1 -0
- package/templates/hello-world/c3.ts +5 -1
- package/templates/hello-world/js/package.json +3 -3
- package/templates/hello-world/js/wrangler.toml +6 -0
- package/templates/hello-world/py/__dot__gitignore +68 -0
- package/templates/hello-world/py/package.json +13 -0
- package/templates/{hello-world-python → hello-world}/py/wrangler.toml +6 -0
- package/templates/hello-world/ts/package.json +4 -4
- package/templates/hello-world/ts/src/index.ts +2 -2
- package/templates/hello-world/ts/tsconfig.json +38 -96
- package/templates/hello-world/ts/vitest.config.mts +11 -0
- package/templates/hello-world/ts/wrangler.toml +6 -0
- package/templates/hello-world-durable-object/c3.ts +3 -1
- package/templates/hello-world-durable-object/js/package.json +1 -1
- package/templates/hello-world-durable-object/js/wrangler.toml +6 -0
- package/templates/hello-world-durable-object/ts/package.json +2 -2
- package/templates/hello-world-durable-object/ts/src/index.ts +2 -23
- package/templates/hello-world-durable-object/ts/tsconfig.json +36 -95
- package/templates/hello-world-durable-object/ts/worker-configuration.d.ts +3 -4
- package/templates/hello-world-durable-object/ts/wrangler.toml +6 -0
- package/templates/hono/c3.ts +1 -10
- package/templates/hono/snippets/appDeclaration.ts +1 -1
- package/templates/hono/templates/wrangler.toml +6 -0
- package/templates/next/README.md +1 -1
- package/templates/next/c3.ts +8 -8
- package/templates/nuxt/c3.ts +6 -6
- package/templates/nuxt/templates/wrangler.toml +1 -0
- package/templates/openapi/c3.ts +1 -0
- package/templates/openapi/ts/README.md +3 -3
- package/templates/openapi/ts/package.json +5 -3
- package/templates/openapi/ts/src/endpoints/taskCreate.ts +26 -16
- package/templates/openapi/ts/src/endpoints/taskDelete.ts +20 -19
- package/templates/openapi/ts/src/endpoints/taskFetch.ts +30 -23
- package/templates/openapi/ts/src/endpoints/taskList.ts +27 -24
- package/templates/openapi/ts/src/index.ts +14 -20
- package/templates/openapi/ts/src/types.ts +9 -8
- package/templates/openapi/ts/wrangler.toml +6 -0
- package/templates/pre-existing/c3.ts +28 -9
- package/templates/pre-existing/js/package.json +1 -1
- package/templates/queues/c3.ts +2 -0
- package/templates/queues/js/package.json +1 -1
- package/templates/queues/js/wrangler.toml +6 -0
- package/templates/queues/ts/package.json +2 -2
- package/templates/queues/ts/src/index.ts +3 -3
- package/templates/queues/ts/tsconfig.json +36 -95
- package/templates/queues/ts/wrangler.toml +6 -0
- package/templates/qwik/c3.ts +4 -3
- package/templates/qwik/templates/wrangler.toml +1 -0
- package/templates/react/c3.ts +33 -3
- package/templates/remix/c3.ts +1 -0
- package/templates/scheduled/c3.ts +2 -0
- package/templates/scheduled/js/package.json +1 -1
- package/templates/scheduled/js/wrangler.toml +6 -0
- package/templates/scheduled/ts/package.json +2 -2
- package/templates/scheduled/ts/src/index.ts +2 -2
- package/templates/scheduled/ts/tsconfig.json +36 -95
- package/templates/scheduled/ts/wrangler.toml +6 -0
- package/templates/solid/c3.ts +8 -5
- package/templates/svelte/c3.ts +2 -1
- package/templates/vue/c3.ts +1 -0
- package/templates-experimental/angular/c3.ts +98 -0
- package/templates-experimental/angular/templates/server.ts +34 -0
- package/templates-experimental/angular/templates/tools/alter-polyfills.mjs +32 -0
- package/templates-experimental/angular/templates/wrangler.toml +11 -0
- package/templates-experimental/astro/c3.ts +114 -0
- package/templates-experimental/astro/snippets/runtimeDeclaration.ts +5 -0
- package/templates-experimental/astro/templates/public/.assetsignore +4 -0
- package/templates-experimental/astro/templates/wrangler.toml +12 -0
- package/templates-experimental/docusaurus/c3.ts +32 -0
- package/templates-experimental/docusaurus/templates/wrangler.toml +10 -0
- package/templates-experimental/gatsby/c3.ts +53 -0
- package/templates-experimental/gatsby/templates/wrangler.toml +10 -0
- package/templates-experimental/hello-world-assets-only/c3.ts +15 -0
- package/{templates/hello-world-python/py → templates-experimental/hello-world-assets-only/templates}/package.json +1 -1
- package/templates-experimental/hello-world-assets-only/templates/public/index.html +11 -0
- package/templates-experimental/hello-world-assets-only/templates/wrangler.toml +10 -0
- package/templates-experimental/hello-world-durable-object-with-assets/c3.ts +23 -0
- package/templates-experimental/hello-world-durable-object-with-assets/js/.editorconfig +12 -0
- package/templates-experimental/hello-world-durable-object-with-assets/js/.prettierrc +6 -0
- package/templates-experimental/hello-world-durable-object-with-assets/js/__dot__gitignore +172 -0
- package/templates-experimental/hello-world-durable-object-with-assets/js/package.json +13 -0
- package/templates-experimental/hello-world-durable-object-with-assets/js/public/index.html +19 -0
- package/templates-experimental/hello-world-durable-object-with-assets/js/src/index.js +69 -0
- package/templates-experimental/hello-world-durable-object-with-assets/js/wrangler.toml +24 -0
- package/templates-experimental/hello-world-durable-object-with-assets/ts/.editorconfig +12 -0
- package/templates-experimental/hello-world-durable-object-with-assets/ts/.prettierrc +6 -0
- package/templates-experimental/hello-world-durable-object-with-assets/ts/__dot__gitignore +172 -0
- package/templates-experimental/hello-world-durable-object-with-assets/ts/package.json +15 -0
- package/templates-experimental/hello-world-durable-object-with-assets/ts/public/index.html +19 -0
- package/templates-experimental/hello-world-durable-object-with-assets/ts/src/index.ts +66 -0
- package/templates-experimental/hello-world-durable-object-with-assets/ts/tsconfig.json +42 -0
- package/templates-experimental/hello-world-durable-object-with-assets/ts/worker-configuration.d.ts +5 -0
- package/templates-experimental/hello-world-durable-object-with-assets/ts/wrangler.toml +24 -0
- package/templates-experimental/hello-world-with-assets/c3.ts +22 -0
- package/templates-experimental/hello-world-with-assets/js/.editorconfig +12 -0
- package/templates-experimental/hello-world-with-assets/js/.prettierrc +6 -0
- package/templates-experimental/hello-world-with-assets/js/__dot__gitignore +172 -0
- package/templates-experimental/hello-world-with-assets/js/package.json +16 -0
- package/templates-experimental/hello-world-with-assets/js/public/index.html +31 -0
- package/templates-experimental/hello-world-with-assets/js/src/index.js +23 -0
- package/templates-experimental/hello-world-with-assets/js/test/index.spec.js +41 -0
- package/templates-experimental/hello-world-with-assets/js/wrangler.toml +12 -0
- package/templates-experimental/hello-world-with-assets/py/package.json +13 -0
- package/templates-experimental/hello-world-with-assets/py/public/index.html +31 -0
- package/templates-experimental/hello-world-with-assets/py/src/entry.py +9 -0
- package/templates-experimental/hello-world-with-assets/py/wrangler.toml +12 -0
- package/templates-experimental/hello-world-with-assets/ts/.editorconfig +12 -0
- package/templates-experimental/hello-world-with-assets/ts/.prettierrc +6 -0
- package/templates-experimental/hello-world-with-assets/ts/__dot__gitignore +172 -0
- package/templates-experimental/hello-world-with-assets/ts/package.json +18 -0
- package/templates-experimental/hello-world-with-assets/ts/public/index.html +31 -0
- package/templates-experimental/hello-world-with-assets/ts/src/index.ts +26 -0
- package/templates-experimental/hello-world-with-assets/ts/test/index.spec.ts +41 -0
- package/templates-experimental/hello-world-with-assets/ts/test/tsconfig.json +8 -0
- package/templates-experimental/hello-world-with-assets/ts/tsconfig.json +44 -0
- package/templates-experimental/hello-world-with-assets/ts/vitest.config.mts +11 -0
- package/templates-experimental/hello-world-with-assets/ts/worker-configuration.d.ts +4 -0
- package/templates-experimental/hello-world-with-assets/ts/wrangler.toml +12 -0
- package/templates-experimental/hono/c3.ts +43 -0
- package/templates-experimental/hono/templates/public/index.html +19 -0
- package/templates-experimental/hono/templates/src/index.ts +9 -0
- package/templates-experimental/hono/templates/worker-configuration.d.ts +4 -0
- package/templates-experimental/hono/templates/wrangler.toml +5 -0
- package/templates-experimental/next/c3.ts +52 -0
- package/templates-experimental/next/templates/__dot__gitignore +42 -0
- package/templates-experimental/next/templates/env.d.ts +5 -0
- package/templates-experimental/next/templates/wrangler.toml +12 -0
- package/templates-experimental/nuxt/c3.ts +135 -0
- package/templates-experimental/nuxt/templates/cloudflare-preset/nitro.config.ts +27 -0
- package/templates-experimental/nuxt/templates/env.d.ts +14 -0
- package/templates-experimental/nuxt/templates/worker-configuration.d.ts +4 -0
- package/templates-experimental/nuxt/templates/wrangler.toml +11 -0
- package/templates-experimental/qwik/c3.ts +153 -0
- package/templates-experimental/qwik/snippets/getPlatformProxy.ts +6 -0
- package/templates-experimental/qwik/templates/public/.assetsignore +4 -0
- package/templates-experimental/qwik/templates/worker-configuration.d.ts +4 -0
- package/templates-experimental/qwik/templates/wrangler.toml +12 -0
- package/templates-experimental/remix/c3.ts +77 -0
- package/templates-experimental/remix/templates/public/.assetsignore +4 -0
- package/templates-experimental/remix/templates/worker-configuration.d.ts +4 -0
- package/templates-experimental/remix/templates/wrangler.toml +11 -0
- package/templates-experimental/solid/c3.ts +137 -0
- package/templates-experimental/solid/templates/wrangler.toml +12 -0
- package/templates-experimental/svelte/c3.ts +132 -0
- package/templates-experimental/svelte/js/static/.assetsignore +4 -0
- package/templates-experimental/svelte/js/wrangler.toml +11 -0
- package/templates-experimental/svelte/ts/static/.assetsignore +4 -0
- package/templates-experimental/svelte/ts/wrangler.toml +11 -0
- package/templates/hello-world-python/c3.ts +0 -9
- package/templates/hono/snippets/bindingsType.ts +0 -3
- /package/templates/{hello-world-python → hello-world}/py/src/entry.py +0 -0
- /package/{templates/hello-world/ts/vitest.config.ts → templates-experimental/hello-world-with-assets/js/vitest.config.js} +0 -0
- /package/{templates/hello-world-python → templates-experimental/hello-world-with-assets}/py/__dot__gitignore +0 -0
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { env, createExecutionContext, waitOnExecutionContext, SELF } from 'cloudflare:test';
|
|
2
|
+
import { describe, it, expect } from 'vitest';
|
|
3
|
+
import worker from '../src';
|
|
4
|
+
|
|
5
|
+
describe('Hello World user worker', () => {
|
|
6
|
+
describe('request for /message', () => {
|
|
7
|
+
it('/ responds with "Hello, World!" (unit style)', async () => {
|
|
8
|
+
const request = new Request<unknown, IncomingRequestCfProperties>('http://example.com/message');
|
|
9
|
+
// Create an empty context to pass to `worker.fetch()`.
|
|
10
|
+
const ctx = createExecutionContext();
|
|
11
|
+
const response = await worker.fetch(request, env, ctx);
|
|
12
|
+
// Wait for all `Promise`s passed to `ctx.waitUntil()` to settle before running test assertions
|
|
13
|
+
await waitOnExecutionContext(ctx);
|
|
14
|
+
expect(await response.text()).toMatchInlineSnapshot(`"Hello, World!"`);
|
|
15
|
+
});
|
|
16
|
+
|
|
17
|
+
it('responds with "Hello, World!" (integration style)', async () => {
|
|
18
|
+
const request = new Request('http://example.com/message');
|
|
19
|
+
const response = await SELF.fetch(request);
|
|
20
|
+
expect(await response.text()).toMatchInlineSnapshot(`"Hello, World!"`);
|
|
21
|
+
});
|
|
22
|
+
});
|
|
23
|
+
|
|
24
|
+
describe('request for /random', () => {
|
|
25
|
+
it('/ responds with a random UUID (unit style)', async () => {
|
|
26
|
+
const request = new Request<unknown, IncomingRequestCfProperties>('http://example.com/random');
|
|
27
|
+
// Create an empty context to pass to `worker.fetch()`.
|
|
28
|
+
const ctx = createExecutionContext();
|
|
29
|
+
const response = await worker.fetch(request, env, ctx);
|
|
30
|
+
// Wait for all `Promise`s passed to `ctx.waitUntil()` to settle before running test assertions
|
|
31
|
+
await waitOnExecutionContext(ctx);
|
|
32
|
+
expect(await response.text()).toMatch(/[a-f0-9]{8}-[a-f0-9]{4}-[a-f0-9]{4}-[a-f0-9]{4}-[a-f0-9]{12}/);
|
|
33
|
+
});
|
|
34
|
+
|
|
35
|
+
it('responds with a random UUID (integration style)', async () => {
|
|
36
|
+
const request = new Request('http://example.com/random');
|
|
37
|
+
const response = await SELF.fetch(request);
|
|
38
|
+
expect(await response.text()).toMatch(/[a-f0-9]{8}-[a-f0-9]{4}-[a-f0-9]{4}-[a-f0-9]{4}-[a-f0-9]{12}/);
|
|
39
|
+
});
|
|
40
|
+
});
|
|
41
|
+
});
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
{
|
|
2
|
+
"compilerOptions": {
|
|
3
|
+
/* Visit https://aka.ms/tsconfig.json to read more about this file */
|
|
4
|
+
|
|
5
|
+
/* Set the JavaScript language version for emitted JavaScript and include compatible library declarations. */
|
|
6
|
+
"target": "es2021",
|
|
7
|
+
/* Specify a set of bundled library declaration files that describe the target runtime environment. */
|
|
8
|
+
"lib": ["es2021"],
|
|
9
|
+
/* Specify what JSX code is generated. */
|
|
10
|
+
"jsx": "react-jsx",
|
|
11
|
+
|
|
12
|
+
/* Specify what module code is generated. */
|
|
13
|
+
"module": "es2022",
|
|
14
|
+
/* Specify how TypeScript looks up a file from a given module specifier. */
|
|
15
|
+
"moduleResolution": "Bundler",
|
|
16
|
+
/* Specify type package names to be included without being referenced in a source file. */
|
|
17
|
+
"types": ["@cloudflare/workers-types"],
|
|
18
|
+
/* Enable importing .json files */
|
|
19
|
+
"resolveJsonModule": true,
|
|
20
|
+
|
|
21
|
+
/* Allow JavaScript files to be a part of your program. Use the `checkJS` option to get errors from these files. */
|
|
22
|
+
"allowJs": true,
|
|
23
|
+
/* Enable error reporting in type-checked JavaScript files. */
|
|
24
|
+
"checkJs": false,
|
|
25
|
+
|
|
26
|
+
/* Disable emitting files from a compilation. */
|
|
27
|
+
"noEmit": true,
|
|
28
|
+
|
|
29
|
+
/* Ensure that each file can be safely transpiled without relying on other imports. */
|
|
30
|
+
"isolatedModules": true,
|
|
31
|
+
/* Allow 'import x from y' when a module doesn't have a default export. */
|
|
32
|
+
"allowSyntheticDefaultImports": true,
|
|
33
|
+
/* Ensure that casing is correct in imports. */
|
|
34
|
+
"forceConsistentCasingInFileNames": true,
|
|
35
|
+
|
|
36
|
+
/* Enable all strict type-checking options. */
|
|
37
|
+
"strict": true,
|
|
38
|
+
|
|
39
|
+
/* Skip type checking all .d.ts files. */
|
|
40
|
+
"skipLibCheck": true
|
|
41
|
+
},
|
|
42
|
+
"exclude": ["test"],
|
|
43
|
+
"include": ["worker-configuration.d.ts", "src/**/*.ts"]
|
|
44
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
#:schema node_modules/wrangler/config-schema.json
|
|
2
|
+
name = "<TBD>"
|
|
3
|
+
main = "src/index.ts"
|
|
4
|
+
compatibility_date = "<TBD>"
|
|
5
|
+
compatibility_flags = ["nodejs_compat"]
|
|
6
|
+
assets = { directory = "./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
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { logRaw } from "@cloudflare/cli";
|
|
2
|
+
import { runFrameworkGenerator } from "frameworks/index";
|
|
3
|
+
import { detectPackageManager } from "helpers/packageManagers";
|
|
4
|
+
import type { TemplateConfig } from "../../src/templates";
|
|
5
|
+
import type { C3Context } from "types";
|
|
6
|
+
|
|
7
|
+
const generate = async (ctx: C3Context) => {
|
|
8
|
+
const { name: pm } = detectPackageManager();
|
|
9
|
+
|
|
10
|
+
await runFrameworkGenerator(ctx, [
|
|
11
|
+
ctx.project.name,
|
|
12
|
+
"--template",
|
|
13
|
+
"cloudflare-workers",
|
|
14
|
+
"--install",
|
|
15
|
+
"--pm",
|
|
16
|
+
pm,
|
|
17
|
+
]);
|
|
18
|
+
|
|
19
|
+
logRaw(""); // newline
|
|
20
|
+
};
|
|
21
|
+
|
|
22
|
+
const config: TemplateConfig = {
|
|
23
|
+
configVersion: 1,
|
|
24
|
+
id: "hono",
|
|
25
|
+
frameworkCli: "create-hono",
|
|
26
|
+
displayName: "Hono",
|
|
27
|
+
copyFiles: {
|
|
28
|
+
path: "./templates",
|
|
29
|
+
},
|
|
30
|
+
platform: "workers",
|
|
31
|
+
path: "templates-experimental/hono",
|
|
32
|
+
generate,
|
|
33
|
+
transformPackageJson: async () => ({
|
|
34
|
+
scripts: {
|
|
35
|
+
dev: "wrangler dev",
|
|
36
|
+
deploy: "wrangler deploy --minify",
|
|
37
|
+
"cf-typegen": "wrangler types --env-interface CloudflareBindings",
|
|
38
|
+
},
|
|
39
|
+
}),
|
|
40
|
+
devScript: "dev",
|
|
41
|
+
deployScript: "deploy",
|
|
42
|
+
};
|
|
43
|
+
export default config;
|
|
@@ -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,52 @@
|
|
|
1
|
+
import { brandColor, dim } from "@cloudflare/cli/colors";
|
|
2
|
+
import { runFrameworkGenerator } from "frameworks/index";
|
|
3
|
+
import { installPackages } from "helpers/packages";
|
|
4
|
+
import type { TemplateConfig } from "../../src/templates";
|
|
5
|
+
import type { C3Context } from "types";
|
|
6
|
+
|
|
7
|
+
const generate = async (ctx: C3Context) => {
|
|
8
|
+
await runFrameworkGenerator(ctx, [
|
|
9
|
+
ctx.project.name,
|
|
10
|
+
"--ts",
|
|
11
|
+
"--tailwind",
|
|
12
|
+
"--eslint",
|
|
13
|
+
"--app",
|
|
14
|
+
"--import-alias",
|
|
15
|
+
"@/*",
|
|
16
|
+
"--src-dir",
|
|
17
|
+
]);
|
|
18
|
+
};
|
|
19
|
+
|
|
20
|
+
const configure = async () => {
|
|
21
|
+
const packages = ["@opennextjs/cloudflare", "@cloudflare/workers-types"];
|
|
22
|
+
await installPackages(packages, {
|
|
23
|
+
dev: true,
|
|
24
|
+
startText: "Adding the Cloudflare adapter",
|
|
25
|
+
doneText: `${brandColor(`installed`)} ${dim(packages.join(", "))}`,
|
|
26
|
+
});
|
|
27
|
+
};
|
|
28
|
+
|
|
29
|
+
export default {
|
|
30
|
+
configVersion: 1,
|
|
31
|
+
id: "next",
|
|
32
|
+
frameworkCli: "create-next-app",
|
|
33
|
+
platform: "workers",
|
|
34
|
+
displayName: "Next (using Node.js compat + Workers Assets)",
|
|
35
|
+
path: "templates-experimental/next",
|
|
36
|
+
copyFiles: {
|
|
37
|
+
path: "./templates",
|
|
38
|
+
},
|
|
39
|
+
generate,
|
|
40
|
+
configure,
|
|
41
|
+
transformPackageJson: async () => ({
|
|
42
|
+
scripts: {
|
|
43
|
+
deploy: `cloudflare && wrangler deploy`,
|
|
44
|
+
preview: `cloudflare && wrangler dev`,
|
|
45
|
+
"cf-typegen": `wrangler types --env-interface CloudflareEnv env.d.ts`,
|
|
46
|
+
},
|
|
47
|
+
}),
|
|
48
|
+
devScript: "dev",
|
|
49
|
+
previewScript: "preview",
|
|
50
|
+
deployScript: "deploy",
|
|
51
|
+
compatibilityFlags: ["nodejs_compat"],
|
|
52
|
+
} as TemplateConfig;
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
# See https://help.github.com/articles/ignoring-files/ for more about ignoring files.
|
|
2
|
+
|
|
3
|
+
# dependencies
|
|
4
|
+
/node_modules
|
|
5
|
+
/.pnp
|
|
6
|
+
.pnp.js
|
|
7
|
+
.yarn/install-state.gz
|
|
8
|
+
|
|
9
|
+
# testing
|
|
10
|
+
/coverage
|
|
11
|
+
|
|
12
|
+
# next.js
|
|
13
|
+
/.next/
|
|
14
|
+
/out/
|
|
15
|
+
|
|
16
|
+
# production
|
|
17
|
+
/build
|
|
18
|
+
|
|
19
|
+
# misc
|
|
20
|
+
.DS_Store
|
|
21
|
+
*.pem
|
|
22
|
+
|
|
23
|
+
# debug
|
|
24
|
+
npm-debug.log*
|
|
25
|
+
yarn-debug.log*
|
|
26
|
+
yarn-error.log*
|
|
27
|
+
|
|
28
|
+
# local env files
|
|
29
|
+
.env*.local
|
|
30
|
+
|
|
31
|
+
# vercel
|
|
32
|
+
.vercel
|
|
33
|
+
|
|
34
|
+
# typescript
|
|
35
|
+
*.tsbuildinfo
|
|
36
|
+
next-env.d.ts
|
|
37
|
+
|
|
38
|
+
|
|
39
|
+
# Cloudflare related
|
|
40
|
+
/.save.next
|
|
41
|
+
/.worker-next
|
|
42
|
+
/.wrangler
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
#:schema node_modules/wrangler/config-schema.json
|
|
2
|
+
name = "<app-name>"
|
|
3
|
+
main = ".worker-next/index.mjs"
|
|
4
|
+
|
|
5
|
+
compatibility_date = "2024-09-26"
|
|
6
|
+
compatibility_flags = ["nodejs_compat"]
|
|
7
|
+
|
|
8
|
+
# Minification helps to keep the Worker bundle size down and improve start up time.
|
|
9
|
+
minify = true
|
|
10
|
+
|
|
11
|
+
# Use the new Workers + Assets to host the static frontend files
|
|
12
|
+
assets = { directory = ".worker-next/assets", binding = "ASSETS" }
|
|
@@ -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,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;
|