wrangler 2.20.0 ā 3.0.0
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 +4 -4
- package/bin/wrangler.js +9 -75
- package/package.json +5 -13
- package/templates/__tests__/tsconfig.tsbuildinfo +1 -1
- package/templates/checked-fetch.js +1 -1
- package/templates/first-party-worker-module-facade.ts +2 -2
- package/templates/middleware/common.ts +9 -4
- package/templates/middleware/loader-sw.ts +2 -7
- package/templates/new-worker-scheduled.ts +1 -1
- package/templates/new-worker.ts +1 -1
- package/templates/pages-dev-util.ts +4 -1
- package/templates/pages-shim.ts +0 -3
- package/templates/tsconfig.tsbuildinfo +1 -1
- package/wrangler-dist/cli.d.ts +149 -75
- package/wrangler-dist/cli.js +60062 -64338
- package/import_meta_url.js +0 -3
- package/miniflare-config-stubs/.env.empty +0 -0
- package/miniflare-config-stubs/package.empty.json +0 -1
- package/miniflare-config-stubs/wrangler.empty.toml +0 -0
- package/miniflare-dist/index.mjs +0 -6442
- package/src/__tests__/access.test.ts +0 -25
- package/src/__tests__/api-dev.test.ts +0 -238
- package/src/__tests__/api-devregistry.test.ts +0 -121
- package/src/__tests__/api.test.ts +0 -102
- package/src/__tests__/config-cache-without-cache-dir.test.ts +0 -38
- package/src/__tests__/config-cache.test.ts +0 -42
- package/src/__tests__/configuration.test.ts +0 -4517
- package/src/__tests__/constellation.test.ts +0 -371
- package/src/__tests__/d1/d1.test.ts +0 -82
- package/src/__tests__/d1/execute.test.ts +0 -66
- package/src/__tests__/d1/migrate.test.ts +0 -257
- package/src/__tests__/d1/splitter.test.ts +0 -255
- package/src/__tests__/delete.test.ts +0 -272
- package/src/__tests__/deployments.test.ts +0 -369
- package/src/__tests__/dev.test.tsx +0 -1617
- package/src/__tests__/generate.test.ts +0 -237
- package/src/__tests__/get-host-from-url.test.ts +0 -16
- package/src/__tests__/guess-worker-format.test.ts +0 -120
- package/src/__tests__/helpers/clipboardy-mock.js +0 -4
- package/src/__tests__/helpers/cmd-shim.d.ts +0 -11
- package/src/__tests__/helpers/end-event-loop.ts +0 -6
- package/src/__tests__/helpers/mock-account-id.ts +0 -48
- package/src/__tests__/helpers/mock-auth-domain.ts +0 -20
- package/src/__tests__/helpers/mock-bin.ts +0 -36
- package/src/__tests__/helpers/mock-console.ts +0 -112
- package/src/__tests__/helpers/mock-dialogs.ts +0 -139
- package/src/__tests__/helpers/mock-get-pages-upload-token.ts +0 -25
- package/src/__tests__/helpers/mock-get-zone-from-host.ts +0 -11
- package/src/__tests__/helpers/mock-http-server.ts +0 -46
- package/src/__tests__/helpers/mock-istty.ts +0 -74
- package/src/__tests__/helpers/mock-known-routes.ts +0 -12
- package/src/__tests__/helpers/mock-kv.ts +0 -46
- package/src/__tests__/helpers/mock-oauth-flow.ts +0 -263
- package/src/__tests__/helpers/mock-process.ts +0 -34
- package/src/__tests__/helpers/mock-set-timeout.ts +0 -16
- package/src/__tests__/helpers/mock-stdin.ts +0 -108
- package/src/__tests__/helpers/mock-web-socket.ts +0 -29
- package/src/__tests__/helpers/msw/blob-worker.cjs +0 -19
- package/src/__tests__/helpers/msw/handlers/access.ts +0 -13
- package/src/__tests__/helpers/msw/handlers/deployments.ts +0 -160
- package/src/__tests__/helpers/msw/handlers/namespaces.ts +0 -81
- package/src/__tests__/helpers/msw/handlers/oauth.ts +0 -31
- package/src/__tests__/helpers/msw/handlers/r2.ts +0 -60
- package/src/__tests__/helpers/msw/handlers/script.ts +0 -56
- package/src/__tests__/helpers/msw/handlers/user.ts +0 -52
- package/src/__tests__/helpers/msw/handlers/zones.ts +0 -20
- package/src/__tests__/helpers/msw/index.ts +0 -52
- package/src/__tests__/helpers/msw/read-file-sync.js +0 -61
- package/src/__tests__/helpers/run-in-tmp.ts +0 -38
- package/src/__tests__/helpers/run-wrangler.ts +0 -16
- package/src/__tests__/helpers/string-dynamic-values-matcher.ts +0 -28
- package/src/__tests__/helpers/worker-scripts/child-wrangler.toml +0 -1
- package/src/__tests__/helpers/worker-scripts/hello-world-worker.js +0 -5
- package/src/__tests__/helpers/worker-scripts/hello-world-wrangler.toml +0 -1
- package/src/__tests__/helpers/worker-scripts/parent-worker.js +0 -11
- package/src/__tests__/helpers/worker-scripts/parent-wrangler.toml +0 -5
- package/src/__tests__/helpers/write-worker-source.ts +0 -31
- package/src/__tests__/helpers/write-wrangler-toml.ts +0 -17
- package/src/__tests__/https-options.test.ts +0 -163
- package/src/__tests__/index.test.ts +0 -282
- package/src/__tests__/init.test.ts +0 -3196
- package/src/__tests__/jest.setup.ts +0 -179
- package/src/__tests__/kv.test.ts +0 -1799
- package/src/__tests__/logger.test.ts +0 -207
- package/src/__tests__/logout.test.ts +0 -47
- package/src/__tests__/metrics.test.ts +0 -493
- package/src/__tests__/middleware.scheduled.test.ts +0 -145
- package/src/__tests__/middleware.test.ts +0 -816
- package/src/__tests__/mtls-certificates.test.ts +0 -589
- package/src/__tests__/package-manager.test.ts +0 -353
- package/src/__tests__/pages/deployment-list.test.ts +0 -80
- package/src/__tests__/pages/functions-build.test.ts +0 -528
- package/src/__tests__/pages/pages.test.ts +0 -81
- package/src/__tests__/pages/project-create.test.ts +0 -63
- package/src/__tests__/pages/project-list.test.ts +0 -110
- package/src/__tests__/pages/project-upload.test.ts +0 -500
- package/src/__tests__/pages/publish.test.ts +0 -2864
- package/src/__tests__/pages-deployment-tail.test.ts +0 -957
- package/src/__tests__/parse.test.ts +0 -436
- package/src/__tests__/paths.test.ts +0 -39
- package/src/__tests__/publish.test.ts +0 -8849
- package/src/__tests__/pubsub.test.ts +0 -496
- package/src/__tests__/queues.test.ts +0 -532
- package/src/__tests__/r2.test.ts +0 -374
- package/src/__tests__/route.test.ts +0 -45
- package/src/__tests__/secret.test.ts +0 -693
- package/src/__tests__/tail.test.ts +0 -989
- package/src/__tests__/test-old-node-version.js +0 -31
- package/src/__tests__/traverse-module-graph.test.ts +0 -220
- package/src/__tests__/tsconfig-sanity.ts +0 -12
- package/src/__tests__/tsconfig.json +0 -8
- package/src/__tests__/tsconfig.tsbuildinfo +0 -1
- package/src/__tests__/type-generation.test.ts +0 -234
- package/src/__tests__/user.test.ts +0 -118
- package/src/__tests__/utils-collectKeyValues.test.ts +0 -47
- package/src/__tests__/validate-dev-props.test.ts +0 -56
- package/src/__tests__/version.test.ts +0 -35
- package/src/__tests__/whoami.test.tsx +0 -172
- package/src/__tests__/worker-namespace.test.ts +0 -340
- package/src/abort.d.ts +0 -3
- package/src/api/dev.ts +0 -321
- package/src/api/index.ts +0 -11
- package/src/api/mtls-certificate.ts +0 -148
- package/src/api/pages/create-worker-bundle-contents.ts +0 -77
- package/src/api/pages/index.ts +0 -5
- package/src/api/pages/publish.tsx +0 -371
- package/src/bundle-reporter.ts +0 -68
- package/src/bundle.ts +0 -929
- package/src/cfetch/index.ts +0 -158
- package/src/cfetch/internal.ts +0 -258
- package/src/cli.ts +0 -28
- package/src/config/README.md +0 -107
- package/src/config/config.ts +0 -282
- package/src/config/diagnostics.ts +0 -80
- package/src/config/environment.ts +0 -625
- package/src/config/index.ts +0 -403
- package/src/config/validation-helpers.ts +0 -597
- package/src/config/validation.ts +0 -2369
- package/src/config-cache.ts +0 -85
- package/src/constellation/createProject.tsx +0 -51
- package/src/constellation/deleteProject.ts +0 -51
- package/src/constellation/deleteProjectModel.ts +0 -68
- package/src/constellation/index.ts +0 -75
- package/src/constellation/listCatalog.tsx +0 -35
- package/src/constellation/listModel.tsx +0 -41
- package/src/constellation/listProject.tsx +0 -28
- package/src/constellation/listRuntime.tsx +0 -28
- package/src/constellation/options.ts +0 -17
- package/src/constellation/types.ts +0 -17
- package/src/constellation/uploadModel.tsx +0 -64
- package/src/constellation/utils.ts +0 -90
- package/src/create-worker-preview.ts +0 -293
- package/src/create-worker-upload-form.ts +0 -363
- package/src/d1/backups.tsx +0 -219
- package/src/d1/constants.ts +0 -2
- package/src/d1/create.tsx +0 -70
- package/src/d1/delete.ts +0 -53
- package/src/d1/execute.tsx +0 -357
- package/src/d1/formatTimeAgo.ts +0 -14
- package/src/d1/index.ts +0 -100
- package/src/d1/list.tsx +0 -62
- package/src/d1/migrations/apply.tsx +0 -212
- package/src/d1/migrations/create.tsx +0 -79
- package/src/d1/migrations/helpers.ts +0 -169
- package/src/d1/migrations/index.ts +0 -3
- package/src/d1/migrations/list.tsx +0 -95
- package/src/d1/migrations/options.ts +0 -23
- package/src/d1/options.ts +0 -22
- package/src/d1/splitter.ts +0 -161
- package/src/d1/types.ts +0 -25
- package/src/d1/utils.ts +0 -49
- package/src/delete.ts +0 -100
- package/src/deployments.ts +0 -368
- package/src/deprecated/index.ts +0 -144
- package/src/dev/dev-vars.ts +0 -39
- package/src/dev/dev.tsx +0 -605
- package/src/dev/get-local-persistence-path.ts +0 -31
- package/src/dev/local.tsx +0 -952
- package/src/dev/remote.tsx +0 -635
- package/src/dev/start-server.ts +0 -545
- package/src/dev/use-esbuild.ts +0 -215
- package/src/dev/validate-dev-props.ts +0 -40
- package/src/dev-registry.ts +0 -202
- package/src/dev.tsx +0 -934
- package/src/dialogs.ts +0 -136
- package/src/dispatch-namespace.ts +0 -211
- package/src/docs/helpers.ts +0 -50
- package/src/docs/index.ts +0 -54
- package/src/durable.ts +0 -102
- package/src/entry.ts +0 -344
- package/src/environment-variables/factory.ts +0 -89
- package/src/environment-variables/misc-variables.ts +0 -30
- package/src/errors.ts +0 -11
- package/src/generate/index.ts +0 -298
- package/src/git-client.ts +0 -135
- package/src/global-wrangler-config-path.ts +0 -26
- package/src/https-options.ts +0 -127
- package/src/index.ts +0 -768
- package/src/init.ts +0 -1037
- package/src/inspect.ts +0 -883
- package/src/intl-polyfill.d.ts +0 -139
- package/src/is-ci.ts +0 -14
- package/src/is-interactive.ts +0 -16
- package/src/jest.d.ts +0 -4
- package/src/kv/helpers.ts +0 -433
- package/src/kv/index.ts +0 -594
- package/src/logger.ts +0 -123
- package/src/metrics/index.ts +0 -5
- package/src/metrics/metrics-config.ts +0 -239
- package/src/metrics/metrics-dispatcher.ts +0 -96
- package/src/metrics/metrics-usage-headers.ts +0 -24
- package/src/metrics/send-event.ts +0 -99
- package/src/miniflare-cli/README.md +0 -30
- package/src/miniflare-cli/assets.ts +0 -251
- package/src/miniflare-cli/index.ts +0 -210
- package/src/miniflare-cli/request-context.ts +0 -40
- package/src/miniflare-cli/tsconfig.json +0 -9
- package/src/miniflare-cli/tsconfig.tsbuildinfo +0 -1
- package/src/miniflare-cli/types.ts +0 -11
- package/src/module-collection.ts +0 -333
- package/src/mtls-certificate/cli.ts +0 -155
- package/src/open-in-browser.ts +0 -17
- package/src/package-manager.ts +0 -219
- package/src/pages/build.ts +0 -423
- package/src/pages/buildFunctions.ts +0 -140
- package/src/pages/constants.ts +0 -18
- package/src/pages/deployment-tails.ts +0 -281
- package/src/pages/deployments.tsx +0 -84
- package/src/pages/dev.ts +0 -734
- package/src/pages/errors.ts +0 -67
- package/src/pages/functions/buildPlugin.ts +0 -114
- package/src/pages/functions/buildWorker.ts +0 -350
- package/src/pages/functions/filepath-routing.test.ts +0 -234
- package/src/pages/functions/filepath-routing.ts +0 -189
- package/src/pages/functions/identifiers.ts +0 -78
- package/src/pages/functions/routes-consolidation.test.ts +0 -250
- package/src/pages/functions/routes-consolidation.ts +0 -73
- package/src/pages/functions/routes-transformation.test.ts +0 -282
- package/src/pages/functions/routes-transformation.ts +0 -115
- package/src/pages/functions/routes-validation.test.ts +0 -403
- package/src/pages/functions/routes-validation.ts +0 -202
- package/src/pages/functions/routes.ts +0 -151
- package/src/pages/functions/tsconfig.json +0 -8
- package/src/pages/functions/tsconfig.tsbuildinfo +0 -1
- package/src/pages/functions.ts +0 -86
- package/src/pages/hash.ts +0 -13
- package/src/pages/index.ts +0 -102
- package/src/pages/projects.tsx +0 -159
- package/src/pages/prompt-select-project.tsx +0 -31
- package/src/pages/publish.tsx +0 -267
- package/src/pages/types.ts +0 -46
- package/src/pages/upload.tsx +0 -469
- package/src/pages/utils.ts +0 -23
- package/src/parse.ts +0 -308
- package/src/paths.ts +0 -71
- package/src/proxy.ts +0 -694
- package/src/publish/index.ts +0 -274
- package/src/publish/publish.ts +0 -1065
- package/src/pubsub/index.ts +0 -286
- package/src/pubsub/pubsub-commands.ts +0 -623
- package/src/queues/cli/commands/consumer/add.ts +0 -71
- package/src/queues/cli/commands/consumer/index.ts +0 -19
- package/src/queues/cli/commands/consumer/remove.ts +0 -31
- package/src/queues/cli/commands/create.ts +0 -25
- package/src/queues/cli/commands/delete.ts +0 -26
- package/src/queues/cli/commands/index.ts +0 -35
- package/src/queues/cli/commands/list.ts +0 -25
- package/src/queues/client.ts +0 -136
- package/src/queues/utils.ts +0 -18
- package/src/r2/constants.ts +0 -4
- package/src/r2/helpers.ts +0 -132
- package/src/r2/index.ts +0 -289
- package/src/routes.ts +0 -140
- package/src/secret/index.ts +0 -377
- package/src/selfsigned.d.ts +0 -29
- package/src/sites.ts +0 -484
- package/src/tail/createTail.ts +0 -415
- package/src/tail/filters.ts +0 -277
- package/src/tail/index.ts +0 -211
- package/src/tail/printing.ts +0 -132
- package/src/traverse-module-graph.ts +0 -54
- package/src/tsconfig-sanity.ts +0 -16
- package/src/type-generation.ts +0 -181
- package/src/update-check.ts +0 -19
- package/src/user/access.ts +0 -68
- package/src/user/auth-variables.ts +0 -113
- package/src/user/choose-account.tsx +0 -39
- package/src/user/generate-auth-url.ts +0 -33
- package/src/user/generate-random-state.ts +0 -16
- package/src/user/index.ts +0 -2
- package/src/user/user.ts +0 -1234
- package/src/utils/collectKeyValues.ts +0 -14
- package/src/utils/render.ts +0 -93
- package/src/whoami.ts +0 -135
- package/src/worker.ts +0 -279
- package/src/yargs-types.ts +0 -37
- package/src/zones.ts +0 -191
|
@@ -1,95 +0,0 @@
|
|
|
1
|
-
import path from "path";
|
|
2
|
-
import { Box, Text } from "ink";
|
|
3
|
-
import Table from "ink-table";
|
|
4
|
-
import React from "react";
|
|
5
|
-
import { withConfig } from "../../config";
|
|
6
|
-
import { logger } from "../../logger";
|
|
7
|
-
import { requireAuth } from "../../user";
|
|
8
|
-
import { renderToString } from "../../utils/render";
|
|
9
|
-
import { DEFAULT_MIGRATION_PATH, DEFAULT_MIGRATION_TABLE } from "../constants";
|
|
10
|
-
import { d1BetaWarning, getDatabaseInfoFromConfig } from "../utils";
|
|
11
|
-
import {
|
|
12
|
-
getMigrationsPath,
|
|
13
|
-
getUnappliedMigrations,
|
|
14
|
-
initMigrationsTable,
|
|
15
|
-
} from "./helpers";
|
|
16
|
-
import { MigrationOptions } from "./options";
|
|
17
|
-
import type {
|
|
18
|
-
CommonYargsArgv,
|
|
19
|
-
StrictYargsOptionsToInterface,
|
|
20
|
-
} from "../../yargs-types";
|
|
21
|
-
|
|
22
|
-
export function ListOptions(yargs: CommonYargsArgv) {
|
|
23
|
-
return MigrationOptions(yargs);
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
type ListHandlerOptions = StrictYargsOptionsToInterface<typeof ListOptions>;
|
|
27
|
-
|
|
28
|
-
export const ListHandler = withConfig<ListHandlerOptions>(
|
|
29
|
-
async ({ config, database, local, persistTo, preview }): Promise<void> => {
|
|
30
|
-
if (!local) {
|
|
31
|
-
await requireAuth({});
|
|
32
|
-
}
|
|
33
|
-
logger.log(d1BetaWarning);
|
|
34
|
-
|
|
35
|
-
const databaseInfo = getDatabaseInfoFromConfig(config, database);
|
|
36
|
-
if (!databaseInfo && !local) {
|
|
37
|
-
throw new Error(
|
|
38
|
-
`Can't find a DB with name/binding '${database}' in local config. Check info in wrangler.toml...`
|
|
39
|
-
);
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
if (!config.configPath) {
|
|
43
|
-
return;
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
const migrationsPath = await getMigrationsPath({
|
|
47
|
-
projectPath: path.dirname(config.configPath),
|
|
48
|
-
migrationsFolderPath:
|
|
49
|
-
databaseInfo?.migrationsFolderPath ?? DEFAULT_MIGRATION_PATH,
|
|
50
|
-
createIfMissing: false,
|
|
51
|
-
});
|
|
52
|
-
|
|
53
|
-
const migrationsTableName =
|
|
54
|
-
databaseInfo?.migrationsTableName ?? DEFAULT_MIGRATION_TABLE;
|
|
55
|
-
|
|
56
|
-
await initMigrationsTable({
|
|
57
|
-
migrationsTableName,
|
|
58
|
-
local,
|
|
59
|
-
config,
|
|
60
|
-
name: database,
|
|
61
|
-
persistTo,
|
|
62
|
-
preview,
|
|
63
|
-
});
|
|
64
|
-
|
|
65
|
-
const unappliedMigrations = (
|
|
66
|
-
await getUnappliedMigrations({
|
|
67
|
-
migrationsTableName,
|
|
68
|
-
migrationsPath,
|
|
69
|
-
local,
|
|
70
|
-
config,
|
|
71
|
-
name: database,
|
|
72
|
-
persistTo,
|
|
73
|
-
preview,
|
|
74
|
-
})
|
|
75
|
-
).map((migration) => {
|
|
76
|
-
return {
|
|
77
|
-
Name: migration,
|
|
78
|
-
};
|
|
79
|
-
});
|
|
80
|
-
|
|
81
|
-
if (unappliedMigrations.length === 0) {
|
|
82
|
-
logger.log(renderToString(<Text>ā
No migrations to apply!</Text>));
|
|
83
|
-
return;
|
|
84
|
-
}
|
|
85
|
-
|
|
86
|
-
logger.log(
|
|
87
|
-
renderToString(
|
|
88
|
-
<Box flexDirection="column">
|
|
89
|
-
<Text>Migrations to be applied:</Text>
|
|
90
|
-
<Table data={unappliedMigrations} columns={["Name"]}></Table>
|
|
91
|
-
</Box>
|
|
92
|
-
)
|
|
93
|
-
);
|
|
94
|
-
}
|
|
95
|
-
);
|
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
import { Database } from "../options";
|
|
2
|
-
import type { CommonYargsArgv } from "../../yargs-types";
|
|
3
|
-
|
|
4
|
-
export function MigrationOptions(yargs: CommonYargsArgv) {
|
|
5
|
-
return Database(yargs)
|
|
6
|
-
.option("local", {
|
|
7
|
-
describe:
|
|
8
|
-
"Execute commands/files against a local DB for use with wrangler dev --local",
|
|
9
|
-
type: "boolean",
|
|
10
|
-
})
|
|
11
|
-
.option("preview", {
|
|
12
|
-
describe: "Execute commands/files against a preview D1 DB",
|
|
13
|
-
type: "boolean",
|
|
14
|
-
default: false,
|
|
15
|
-
})
|
|
16
|
-
.option("persist-to", {
|
|
17
|
-
describe:
|
|
18
|
-
"Specify directory to use for local persistence (you must use --local with this flag)",
|
|
19
|
-
type: "string",
|
|
20
|
-
requiresArg: true,
|
|
21
|
-
})
|
|
22
|
-
.implies("persist-to", "local");
|
|
23
|
-
}
|
package/src/d1/options.ts
DELETED
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
import { d1BetaWarning } from "./utils";
|
|
2
|
-
import type { CommonYargsArgv } from "../yargs-types";
|
|
3
|
-
|
|
4
|
-
export function Name(yargs: CommonYargsArgv) {
|
|
5
|
-
return yargs
|
|
6
|
-
.positional("name", {
|
|
7
|
-
describe: "The name or binding of the DB",
|
|
8
|
-
type: "string",
|
|
9
|
-
demandOption: true,
|
|
10
|
-
})
|
|
11
|
-
.epilogue(d1BetaWarning);
|
|
12
|
-
}
|
|
13
|
-
|
|
14
|
-
export function Database(yargs: CommonYargsArgv) {
|
|
15
|
-
return yargs
|
|
16
|
-
.positional("database", {
|
|
17
|
-
describe: "The name or binding of the DB",
|
|
18
|
-
type: "string",
|
|
19
|
-
demandOption: true,
|
|
20
|
-
})
|
|
21
|
-
.epilogue(d1BetaWarning);
|
|
22
|
-
}
|
package/src/d1/splitter.ts
DELETED
|
@@ -1,161 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @module
|
|
3
|
-
* This code is inspired by that of https://www.atdatabases.org/docs/split-sql-query, which is published under MIT license,
|
|
4
|
-
* and is Copyright (c) 2019 Forbes Lindesay.
|
|
5
|
-
*
|
|
6
|
-
* See https://github.com/ForbesLindesay/atdatabases/blob/103c1e7/packages/split-sql-query/src/index.ts
|
|
7
|
-
* for the original code.
|
|
8
|
-
*/
|
|
9
|
-
|
|
10
|
-
/**
|
|
11
|
-
* Is the given `sql` string likely to contain multiple statements.
|
|
12
|
-
*
|
|
13
|
-
* If `mayContainMultipleStatements()` returns `false` you can be confident that the sql
|
|
14
|
-
* does not contain multiple statements. Otherwise you have to check further.
|
|
15
|
-
*/
|
|
16
|
-
export function mayContainMultipleStatements(sql: string): boolean {
|
|
17
|
-
const trimmed = sql.trimEnd();
|
|
18
|
-
const semiColonIndex = trimmed.indexOf(";");
|
|
19
|
-
return semiColonIndex !== -1 && semiColonIndex !== trimmed.length - 1;
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
/**
|
|
23
|
-
* Split an SQLQuery into an array of statements
|
|
24
|
-
*/
|
|
25
|
-
export default function splitSqlQuery(sql: string): string[] {
|
|
26
|
-
if (!mayContainMultipleStatements(sql)) return [sql];
|
|
27
|
-
const split = splitSqlIntoStatements(sql);
|
|
28
|
-
if (split.length === 0) {
|
|
29
|
-
return [sql];
|
|
30
|
-
} else {
|
|
31
|
-
return split;
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
function splitSqlIntoStatements(sql: string): string[] {
|
|
36
|
-
const statements: string[] = [];
|
|
37
|
-
let str = "";
|
|
38
|
-
const compoundStatementStack: ((s: string) => boolean)[] = [];
|
|
39
|
-
|
|
40
|
-
const iterator = sql[Symbol.iterator]();
|
|
41
|
-
let next = iterator.next();
|
|
42
|
-
while (!next.done) {
|
|
43
|
-
const char = next.value;
|
|
44
|
-
|
|
45
|
-
if (compoundStatementStack[0]?.(str + char)) {
|
|
46
|
-
compoundStatementStack.shift();
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
switch (char) {
|
|
50
|
-
case `'`:
|
|
51
|
-
case `"`:
|
|
52
|
-
case "`":
|
|
53
|
-
str += char + consumeUntilMarker(iterator, char);
|
|
54
|
-
break;
|
|
55
|
-
case `$`: {
|
|
56
|
-
const dollarQuote =
|
|
57
|
-
"$" + consumeWhile(iterator, isDollarQuoteIdentifier);
|
|
58
|
-
str += dollarQuote;
|
|
59
|
-
if (dollarQuote.endsWith("$")) {
|
|
60
|
-
str += consumeUntilMarker(iterator, dollarQuote);
|
|
61
|
-
}
|
|
62
|
-
break;
|
|
63
|
-
}
|
|
64
|
-
case `-`:
|
|
65
|
-
str += char;
|
|
66
|
-
next = iterator.next();
|
|
67
|
-
if (!next.done && next.value === "-") {
|
|
68
|
-
str += next.value + consumeUntilMarker(iterator, "\n");
|
|
69
|
-
break;
|
|
70
|
-
} else {
|
|
71
|
-
continue;
|
|
72
|
-
}
|
|
73
|
-
case `/`:
|
|
74
|
-
str += char;
|
|
75
|
-
next = iterator.next();
|
|
76
|
-
if (!next.done && next.value === "*") {
|
|
77
|
-
str += next.value + consumeUntilMarker(iterator, "*/");
|
|
78
|
-
break;
|
|
79
|
-
} else {
|
|
80
|
-
continue;
|
|
81
|
-
}
|
|
82
|
-
case `;`:
|
|
83
|
-
if (compoundStatementStack.length === 0) {
|
|
84
|
-
statements.push(str);
|
|
85
|
-
str = "";
|
|
86
|
-
} else {
|
|
87
|
-
str += char;
|
|
88
|
-
}
|
|
89
|
-
break;
|
|
90
|
-
default:
|
|
91
|
-
str += char;
|
|
92
|
-
break;
|
|
93
|
-
}
|
|
94
|
-
|
|
95
|
-
if (isCompoundStatementStart(str)) {
|
|
96
|
-
compoundStatementStack.unshift(isCompoundStatementEnd);
|
|
97
|
-
}
|
|
98
|
-
|
|
99
|
-
next = iterator.next();
|
|
100
|
-
}
|
|
101
|
-
statements.push(str);
|
|
102
|
-
|
|
103
|
-
return statements
|
|
104
|
-
.map((statement) => statement.trim())
|
|
105
|
-
.filter((statement) => statement.length > 0);
|
|
106
|
-
}
|
|
107
|
-
|
|
108
|
-
/**
|
|
109
|
-
* Pulls characters from the string iterator while the predicate remains true.
|
|
110
|
-
*/
|
|
111
|
-
function consumeWhile(
|
|
112
|
-
iterator: Iterator<string>,
|
|
113
|
-
predicate: (str: string) => boolean
|
|
114
|
-
) {
|
|
115
|
-
let next = iterator.next();
|
|
116
|
-
let str = "";
|
|
117
|
-
while (!next.done) {
|
|
118
|
-
str += next.value;
|
|
119
|
-
if (!predicate(str)) {
|
|
120
|
-
break;
|
|
121
|
-
}
|
|
122
|
-
next = iterator.next();
|
|
123
|
-
}
|
|
124
|
-
return str;
|
|
125
|
-
}
|
|
126
|
-
|
|
127
|
-
/**
|
|
128
|
-
* Pulls characters from the string iterator until the `endMarker` is found.
|
|
129
|
-
*/
|
|
130
|
-
function consumeUntilMarker(iterator: Iterator<string>, endMarker: string) {
|
|
131
|
-
return consumeWhile(iterator, (str) => !str.endsWith(endMarker));
|
|
132
|
-
}
|
|
133
|
-
|
|
134
|
-
/**
|
|
135
|
-
* Returns true if the `str` ends with a dollar-quoted string marker.
|
|
136
|
-
* See https://www.postgresql.org/docs/current/sql-syntax-lexical.html#SQL-SYNTAX-DOLLAR-QUOTING.
|
|
137
|
-
*/
|
|
138
|
-
function isDollarQuoteIdentifier(str: string) {
|
|
139
|
-
const lastChar = str.slice(-1);
|
|
140
|
-
return (
|
|
141
|
-
// The $ marks the end of the identifier
|
|
142
|
-
lastChar !== "$" &&
|
|
143
|
-
// we allow numbers, underscore and letters with diacritical marks
|
|
144
|
-
(/[0-9_]/i.test(lastChar) ||
|
|
145
|
-
lastChar.toLowerCase() !== lastChar.toUpperCase())
|
|
146
|
-
);
|
|
147
|
-
}
|
|
148
|
-
|
|
149
|
-
/**
|
|
150
|
-
* Returns true if the `str` ends with a compound statement `BEGIN` marker.
|
|
151
|
-
*/
|
|
152
|
-
function isCompoundStatementStart(str: string) {
|
|
153
|
-
return /\sBEGIN\s$/.test(str);
|
|
154
|
-
}
|
|
155
|
-
|
|
156
|
-
/**
|
|
157
|
-
* Returns true if the `str` ends with a compound statement `END` marker.
|
|
158
|
-
*/
|
|
159
|
-
function isCompoundStatementEnd(str: string) {
|
|
160
|
-
return /\sEND[;\s]$/.test(str);
|
|
161
|
-
}
|
package/src/d1/types.ts
DELETED
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
export type Database = {
|
|
2
|
-
uuid: string;
|
|
3
|
-
previewDatabaseUuid?: string;
|
|
4
|
-
name: string;
|
|
5
|
-
binding: string;
|
|
6
|
-
internal_env?: string;
|
|
7
|
-
migrationsTableName: string;
|
|
8
|
-
migrationsFolderPath: string;
|
|
9
|
-
};
|
|
10
|
-
|
|
11
|
-
export type Backup = {
|
|
12
|
-
id: string;
|
|
13
|
-
database_id: string;
|
|
14
|
-
created_at: string;
|
|
15
|
-
state: "progress" | "done";
|
|
16
|
-
num_tables: number;
|
|
17
|
-
file_size: number;
|
|
18
|
-
size?: string;
|
|
19
|
-
};
|
|
20
|
-
|
|
21
|
-
export type Migration = {
|
|
22
|
-
id: string;
|
|
23
|
-
name: string;
|
|
24
|
-
applied_at: string;
|
|
25
|
-
};
|
package/src/d1/utils.ts
DELETED
|
@@ -1,49 +0,0 @@
|
|
|
1
|
-
import { DEFAULT_MIGRATION_PATH, DEFAULT_MIGRATION_TABLE } from "./constants";
|
|
2
|
-
import { listDatabases } from "./list";
|
|
3
|
-
import type { Config } from "../config";
|
|
4
|
-
import type { Database } from "./types";
|
|
5
|
-
|
|
6
|
-
export function getDatabaseInfoFromConfig(
|
|
7
|
-
config: Config,
|
|
8
|
-
name: string
|
|
9
|
-
): Database | null {
|
|
10
|
-
for (const d1Database of config.d1_databases) {
|
|
11
|
-
if (
|
|
12
|
-
d1Database.database_id &&
|
|
13
|
-
(name === d1Database.database_name || name === d1Database.binding)
|
|
14
|
-
) {
|
|
15
|
-
return {
|
|
16
|
-
uuid: d1Database.database_id,
|
|
17
|
-
previewDatabaseUuid: d1Database.preview_database_id,
|
|
18
|
-
binding: d1Database.binding,
|
|
19
|
-
name: d1Database.database_name,
|
|
20
|
-
migrationsTableName:
|
|
21
|
-
d1Database.migrations_table || DEFAULT_MIGRATION_TABLE,
|
|
22
|
-
migrationsFolderPath:
|
|
23
|
-
d1Database.migrations_dir || DEFAULT_MIGRATION_PATH,
|
|
24
|
-
internal_env: d1Database.database_internal_env,
|
|
25
|
-
};
|
|
26
|
-
}
|
|
27
|
-
}
|
|
28
|
-
return null;
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
export const getDatabaseByNameOrBinding = async (
|
|
32
|
-
config: Config,
|
|
33
|
-
accountId: string,
|
|
34
|
-
name: string
|
|
35
|
-
): Promise<Database> => {
|
|
36
|
-
const dbFromConfig = getDatabaseInfoFromConfig(config, name);
|
|
37
|
-
if (dbFromConfig) return dbFromConfig;
|
|
38
|
-
|
|
39
|
-
const allDBs = await listDatabases(accountId);
|
|
40
|
-
const matchingDB = allDBs.find((db) => db.name === name);
|
|
41
|
-
if (!matchingDB) {
|
|
42
|
-
throw new Error(`Couldn't find DB with name '${name}'`);
|
|
43
|
-
}
|
|
44
|
-
return matchingDB;
|
|
45
|
-
};
|
|
46
|
-
|
|
47
|
-
export const d1BetaWarning = process.env.NO_D1_WARNING
|
|
48
|
-
? ""
|
|
49
|
-
: "--------------------\nš§ D1 is currently in open alpha and is not recommended for production data and traffic\nš§ Please report any bugs to https://github.com/cloudflare/workers-sdk/issues/new/choose\nš§ To request features, visit https://community.cloudflare.com/c/developers/d1\nš§ To give feedback, visit https://discord.gg/cloudflaredev\n--------------------\n";
|
package/src/delete.ts
DELETED
|
@@ -1,100 +0,0 @@
|
|
|
1
|
-
import assert from "assert";
|
|
2
|
-
import path from "path";
|
|
3
|
-
import { fetchResult } from "./cfetch";
|
|
4
|
-
import { findWranglerToml, readConfig } from "./config";
|
|
5
|
-
import { confirm } from "./dialogs";
|
|
6
|
-
import { deleteKVNamespace, listKVNamespaces } from "./kv/helpers";
|
|
7
|
-
import { logger } from "./logger";
|
|
8
|
-
import * as metrics from "./metrics";
|
|
9
|
-
import { requireAuth } from "./user";
|
|
10
|
-
import { getScriptName, printWranglerBanner } from "./index";
|
|
11
|
-
import type {
|
|
12
|
-
CommonYargsArgv,
|
|
13
|
-
StrictYargsOptionsToInterface,
|
|
14
|
-
} from "./yargs-types";
|
|
15
|
-
|
|
16
|
-
export function deleteOptions(yargs: CommonYargsArgv) {
|
|
17
|
-
return yargs
|
|
18
|
-
.positional("script", {
|
|
19
|
-
describe: "The path to an entry point for your worker",
|
|
20
|
-
type: "string",
|
|
21
|
-
requiresArg: true,
|
|
22
|
-
})
|
|
23
|
-
.option("name", {
|
|
24
|
-
describe: "Name of the worker",
|
|
25
|
-
type: "string",
|
|
26
|
-
requiresArg: true,
|
|
27
|
-
})
|
|
28
|
-
.option("dry-run", {
|
|
29
|
-
describe: "Don't actually delete",
|
|
30
|
-
type: "boolean",
|
|
31
|
-
})
|
|
32
|
-
.option("legacy-env", {
|
|
33
|
-
type: "boolean",
|
|
34
|
-
describe: "Use legacy environments",
|
|
35
|
-
hidden: true,
|
|
36
|
-
});
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
type DeleteArgs = StrictYargsOptionsToInterface<typeof deleteOptions>;
|
|
40
|
-
|
|
41
|
-
export async function deleteHandler(args: DeleteArgs) {
|
|
42
|
-
await printWranglerBanner();
|
|
43
|
-
|
|
44
|
-
const configPath =
|
|
45
|
-
args.config || (args.script && findWranglerToml(path.dirname(args.script)));
|
|
46
|
-
const config = readConfig(configPath, args);
|
|
47
|
-
await metrics.sendMetricsEvent(
|
|
48
|
-
"delete worker script",
|
|
49
|
-
{},
|
|
50
|
-
{ sendMetrics: config.send_metrics }
|
|
51
|
-
);
|
|
52
|
-
|
|
53
|
-
const accountId = args.dryRun ? undefined : await requireAuth(config);
|
|
54
|
-
|
|
55
|
-
const scriptName = getScriptName(args, config);
|
|
56
|
-
|
|
57
|
-
assert(
|
|
58
|
-
scriptName,
|
|
59
|
-
"A worker name must be defined, either via --name, or in wrangler.toml"
|
|
60
|
-
);
|
|
61
|
-
|
|
62
|
-
if (args.dryRun) {
|
|
63
|
-
logger.log(`--dry-run: exiting now.`);
|
|
64
|
-
return;
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
assert(accountId, "Missing accountId");
|
|
68
|
-
|
|
69
|
-
const confirmed = await confirm(
|
|
70
|
-
`Are you sure you want to delete ${scriptName}? This action cannot be undone.`
|
|
71
|
-
);
|
|
72
|
-
|
|
73
|
-
if (confirmed) {
|
|
74
|
-
await fetchResult(
|
|
75
|
-
`/accounts/${accountId}/workers/services/${scriptName}`,
|
|
76
|
-
{ method: "DELETE" },
|
|
77
|
-
new URLSearchParams({ force: "true" })
|
|
78
|
-
);
|
|
79
|
-
|
|
80
|
-
await deleteSiteNamespaceIfExisting(scriptName, accountId);
|
|
81
|
-
|
|
82
|
-
logger.log("Successfully deleted", scriptName);
|
|
83
|
-
}
|
|
84
|
-
}
|
|
85
|
-
|
|
86
|
-
async function deleteSiteNamespaceIfExisting(
|
|
87
|
-
scriptName: string,
|
|
88
|
-
accountId: string
|
|
89
|
-
): Promise<void> {
|
|
90
|
-
const title = `__${scriptName}-workers_sites_assets`;
|
|
91
|
-
const previewTitle = `__${scriptName}-workers_sites_assets_preview`;
|
|
92
|
-
const allNamespaces = await listKVNamespaces(accountId);
|
|
93
|
-
const namespacesToDelete = allNamespaces.filter(
|
|
94
|
-
(ns) => ns.title === title || ns.title === previewTitle
|
|
95
|
-
);
|
|
96
|
-
for (const ns of namespacesToDelete) {
|
|
97
|
-
await deleteKVNamespace(accountId, ns.id);
|
|
98
|
-
logger.log(`š Deleted asset namespace for Workers Site "${ns.title}"`);
|
|
99
|
-
}
|
|
100
|
-
}
|