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
package/src/d1/backups.tsx
DELETED
|
@@ -1,219 +0,0 @@
|
|
|
1
|
-
import fs from "node:fs/promises";
|
|
2
|
-
import * as path from "path";
|
|
3
|
-
import Table from "ink-table";
|
|
4
|
-
import React from "react";
|
|
5
|
-
import { fetchResult } from "../cfetch";
|
|
6
|
-
import { performApiFetch } from "../cfetch/internal";
|
|
7
|
-
import { withConfig } from "../config";
|
|
8
|
-
import { logger } from "../logger";
|
|
9
|
-
import { requireAuth } from "../user";
|
|
10
|
-
import { renderToString } from "../utils/render";
|
|
11
|
-
import { formatBytes, formatTimeAgo } from "./formatTimeAgo";
|
|
12
|
-
import { Name } from "./options";
|
|
13
|
-
import { d1BetaWarning, getDatabaseByNameOrBinding } from "./utils";
|
|
14
|
-
import type {
|
|
15
|
-
CommonYargsArgv,
|
|
16
|
-
StrictYargsOptionsToInterface,
|
|
17
|
-
} from "../yargs-types";
|
|
18
|
-
import type { Backup, Database } from "./types";
|
|
19
|
-
import type { Response } from "undici";
|
|
20
|
-
|
|
21
|
-
export function ListOptions(yargs: CommonYargsArgv) {
|
|
22
|
-
return Name(yargs);
|
|
23
|
-
}
|
|
24
|
-
type ListHandlerOptions = StrictYargsOptionsToInterface<typeof ListOptions>;
|
|
25
|
-
export const ListHandler = withConfig<ListHandlerOptions>(
|
|
26
|
-
async ({ config, name }): Promise<void> => {
|
|
27
|
-
const accountId = await requireAuth(config);
|
|
28
|
-
logger.log(d1BetaWarning);
|
|
29
|
-
const db: Database = await getDatabaseByNameOrBinding(
|
|
30
|
-
config,
|
|
31
|
-
accountId,
|
|
32
|
-
name
|
|
33
|
-
);
|
|
34
|
-
|
|
35
|
-
const backups: Backup[] = await listBackups(accountId, db.uuid);
|
|
36
|
-
logger.log(
|
|
37
|
-
renderToString(
|
|
38
|
-
<Table
|
|
39
|
-
data={backups}
|
|
40
|
-
columns={["created_at", "id", "num_tables", "size"]}
|
|
41
|
-
></Table>
|
|
42
|
-
)
|
|
43
|
-
);
|
|
44
|
-
}
|
|
45
|
-
);
|
|
46
|
-
|
|
47
|
-
export const listBackups = async (
|
|
48
|
-
accountId: string,
|
|
49
|
-
uuid: string
|
|
50
|
-
): Promise<Array<Backup>> => {
|
|
51
|
-
const json: Backup[] = await fetchResult(
|
|
52
|
-
`/accounts/${accountId}/d1/database/${uuid}/backup`,
|
|
53
|
-
{}
|
|
54
|
-
);
|
|
55
|
-
const results: Record<string, Backup> = {};
|
|
56
|
-
|
|
57
|
-
json
|
|
58
|
-
// First, convert created_at to a Date
|
|
59
|
-
.map((backup) => ({
|
|
60
|
-
...backup,
|
|
61
|
-
created_at: new Date(backup.created_at),
|
|
62
|
-
}))
|
|
63
|
-
// Then, sort descending based on created_at
|
|
64
|
-
.sort((a, b) => +b.created_at - +a.created_at)
|
|
65
|
-
// then group_by their human-readable timestamp i.e. "2 days ago"
|
|
66
|
-
// (storing only the first of each group)
|
|
67
|
-
// and replace the Date version with this new human-readable one
|
|
68
|
-
.forEach((backup) => {
|
|
69
|
-
const timeAgo = formatTimeAgo(backup.created_at);
|
|
70
|
-
if (!results[timeAgo]) {
|
|
71
|
-
results[timeAgo] = {
|
|
72
|
-
...backup,
|
|
73
|
-
created_at: timeAgo,
|
|
74
|
-
size: formatBytes(backup.file_size),
|
|
75
|
-
};
|
|
76
|
-
}
|
|
77
|
-
});
|
|
78
|
-
|
|
79
|
-
// Take advantage of JS objects' sorting to return the newest backup of a certain age
|
|
80
|
-
return Object.values(results);
|
|
81
|
-
};
|
|
82
|
-
|
|
83
|
-
export function CreateOptions(yargs: CommonYargsArgv) {
|
|
84
|
-
return ListOptions(yargs);
|
|
85
|
-
}
|
|
86
|
-
type CreateHandlerOptions = StrictYargsOptionsToInterface<typeof CreateOptions>;
|
|
87
|
-
|
|
88
|
-
export const CreateHandler = withConfig<CreateHandlerOptions>(
|
|
89
|
-
async ({ config, name }): Promise<void> => {
|
|
90
|
-
const accountId = await requireAuth(config);
|
|
91
|
-
logger.log(d1BetaWarning);
|
|
92
|
-
const db: Database = await getDatabaseByNameOrBinding(
|
|
93
|
-
config,
|
|
94
|
-
accountId,
|
|
95
|
-
name
|
|
96
|
-
);
|
|
97
|
-
|
|
98
|
-
const backup: Backup = await createBackup(accountId, db.uuid);
|
|
99
|
-
logger.log(
|
|
100
|
-
renderToString(
|
|
101
|
-
<Table
|
|
102
|
-
data={[backup]}
|
|
103
|
-
columns={["created_at", "id", "num_tables", "size", "state"]}
|
|
104
|
-
></Table>
|
|
105
|
-
)
|
|
106
|
-
);
|
|
107
|
-
}
|
|
108
|
-
);
|
|
109
|
-
|
|
110
|
-
export const createBackup = async (
|
|
111
|
-
accountId: string,
|
|
112
|
-
uuid: string
|
|
113
|
-
): Promise<Backup> => {
|
|
114
|
-
const backup: Backup = await fetchResult(
|
|
115
|
-
`/accounts/${accountId}/d1/database/${uuid}/backup`,
|
|
116
|
-
{
|
|
117
|
-
method: "POST",
|
|
118
|
-
}
|
|
119
|
-
);
|
|
120
|
-
return {
|
|
121
|
-
...backup,
|
|
122
|
-
size: formatBytes(backup.file_size),
|
|
123
|
-
};
|
|
124
|
-
};
|
|
125
|
-
|
|
126
|
-
export function RestoreOptions(yargs: CommonYargsArgv) {
|
|
127
|
-
return ListOptions(yargs).positional("backup-id", {
|
|
128
|
-
describe: "The Backup ID to restore",
|
|
129
|
-
type: "string",
|
|
130
|
-
demandOption: true,
|
|
131
|
-
});
|
|
132
|
-
}
|
|
133
|
-
type RestoreHandlerOptions = StrictYargsOptionsToInterface<
|
|
134
|
-
typeof RestoreOptions
|
|
135
|
-
>;
|
|
136
|
-
export const RestoreHandler = withConfig<RestoreHandlerOptions>(
|
|
137
|
-
async ({ config, name, backupId }): Promise<void> => {
|
|
138
|
-
const accountId = await requireAuth(config);
|
|
139
|
-
logger.log(d1BetaWarning);
|
|
140
|
-
const db: Database = await getDatabaseByNameOrBinding(
|
|
141
|
-
config,
|
|
142
|
-
accountId,
|
|
143
|
-
name
|
|
144
|
-
);
|
|
145
|
-
|
|
146
|
-
logger.log(`Restoring ${name} from backup ${backupId}....`);
|
|
147
|
-
await restoreBackup(accountId, db.uuid, backupId);
|
|
148
|
-
logger.log(`Done!`);
|
|
149
|
-
}
|
|
150
|
-
);
|
|
151
|
-
|
|
152
|
-
export const restoreBackup = async (
|
|
153
|
-
accountId: string,
|
|
154
|
-
uuid: string,
|
|
155
|
-
backupId: string
|
|
156
|
-
): Promise<void> => {
|
|
157
|
-
await fetchResult(
|
|
158
|
-
`/accounts/${accountId}/d1/database/${uuid}/backup/${backupId}/restore`,
|
|
159
|
-
{
|
|
160
|
-
method: "POST",
|
|
161
|
-
headers: {
|
|
162
|
-
"Content-Type": "application/json",
|
|
163
|
-
},
|
|
164
|
-
}
|
|
165
|
-
);
|
|
166
|
-
};
|
|
167
|
-
|
|
168
|
-
export function DownloadOptions(yargs: CommonYargsArgv) {
|
|
169
|
-
return ListOptions(yargs)
|
|
170
|
-
.positional("backup-id", {
|
|
171
|
-
describe: "The Backup ID to download",
|
|
172
|
-
type: "string",
|
|
173
|
-
demandOption: true,
|
|
174
|
-
})
|
|
175
|
-
.option("output", {
|
|
176
|
-
describe:
|
|
177
|
-
"The .sqlite3 file to write to (defaults to '<db-name>.<short-backup-id>.sqlite3'",
|
|
178
|
-
type: "string",
|
|
179
|
-
});
|
|
180
|
-
}
|
|
181
|
-
type DownloadHandlerOptions = StrictYargsOptionsToInterface<
|
|
182
|
-
typeof DownloadOptions
|
|
183
|
-
>;
|
|
184
|
-
export const DownloadHandler = withConfig<DownloadHandlerOptions>(
|
|
185
|
-
async ({ name, backupId, output, config }): Promise<void> => {
|
|
186
|
-
const accountId = await requireAuth(config);
|
|
187
|
-
logger.log(d1BetaWarning);
|
|
188
|
-
const db: Database = await getDatabaseByNameOrBinding(
|
|
189
|
-
config,
|
|
190
|
-
accountId,
|
|
191
|
-
name
|
|
192
|
-
);
|
|
193
|
-
const filename =
|
|
194
|
-
output || path.resolve(`${name}.${backupId.slice(0, 8)}.sqlite3`);
|
|
195
|
-
|
|
196
|
-
logger.log(`š Downloading backup ${backupId} from '${name}'`);
|
|
197
|
-
const response = await getBackupResponse(accountId, db.uuid, backupId);
|
|
198
|
-
if (!response.ok) {
|
|
199
|
-
throw new Error(
|
|
200
|
-
`Failed to download backup ${backupId} from '${name}' - got ${response.status} from the API`
|
|
201
|
-
);
|
|
202
|
-
}
|
|
203
|
-
logger.log(`š Saving to ${filename}`);
|
|
204
|
-
// TODO: stream this once we upgrade to Node18 and can use Writable.fromWeb
|
|
205
|
-
const buffer = await response.arrayBuffer();
|
|
206
|
-
await fs.writeFile(filename, new Buffer(buffer));
|
|
207
|
-
logger.log(`š Done!`);
|
|
208
|
-
}
|
|
209
|
-
);
|
|
210
|
-
|
|
211
|
-
export const getBackupResponse = async (
|
|
212
|
-
accountId: string,
|
|
213
|
-
uuid: string,
|
|
214
|
-
backupId: string
|
|
215
|
-
): Promise<Response> => {
|
|
216
|
-
return await performApiFetch(
|
|
217
|
-
`/accounts/${accountId}/d1/database/${uuid}/backup/${backupId}/download`
|
|
218
|
-
);
|
|
219
|
-
};
|
package/src/d1/constants.ts
DELETED
package/src/d1/create.tsx
DELETED
|
@@ -1,70 +0,0 @@
|
|
|
1
|
-
import { Text, Box } from "ink";
|
|
2
|
-
import React from "react";
|
|
3
|
-
import { fetchResult } from "../cfetch";
|
|
4
|
-
import { withConfig } from "../config";
|
|
5
|
-
import { logger } from "../logger";
|
|
6
|
-
import { requireAuth } from "../user";
|
|
7
|
-
import { renderToString } from "../utils/render";
|
|
8
|
-
import { d1BetaWarning } from "./utils";
|
|
9
|
-
import type {
|
|
10
|
-
CommonYargsArgv,
|
|
11
|
-
StrictYargsOptionsToInterface,
|
|
12
|
-
} from "../yargs-types";
|
|
13
|
-
import type { Database } from "./types";
|
|
14
|
-
|
|
15
|
-
export function Options(yargs: CommonYargsArgv) {
|
|
16
|
-
return yargs
|
|
17
|
-
.positional("name", {
|
|
18
|
-
describe: "The name of the new DB",
|
|
19
|
-
type: "string",
|
|
20
|
-
demandOption: true,
|
|
21
|
-
})
|
|
22
|
-
.epilogue(d1BetaWarning);
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
type HandlerOptions = StrictYargsOptionsToInterface<typeof Options>;
|
|
26
|
-
export const Handler = withConfig<HandlerOptions>(
|
|
27
|
-
async ({ name, config }): Promise<void> => {
|
|
28
|
-
const accountId = await requireAuth(config);
|
|
29
|
-
|
|
30
|
-
logger.log(d1BetaWarning);
|
|
31
|
-
|
|
32
|
-
let db: Database;
|
|
33
|
-
try {
|
|
34
|
-
db = await fetchResult(`/accounts/${accountId}/d1/database`, {
|
|
35
|
-
method: "POST",
|
|
36
|
-
headers: {
|
|
37
|
-
"Content-Type": "application/json",
|
|
38
|
-
},
|
|
39
|
-
body: JSON.stringify({
|
|
40
|
-
name,
|
|
41
|
-
}),
|
|
42
|
-
});
|
|
43
|
-
} catch (e) {
|
|
44
|
-
if ((e as { code: number }).code === 7502) {
|
|
45
|
-
throw new Error("A database with that name already exists");
|
|
46
|
-
}
|
|
47
|
-
throw e;
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
logger.log(
|
|
51
|
-
renderToString(
|
|
52
|
-
<Box flexDirection="column">
|
|
53
|
-
<Text>ā
Successfully created DB '{db.name}'!</Text>
|
|
54
|
-
<Text> </Text>
|
|
55
|
-
<Text>
|
|
56
|
-
Add the following to your wrangler.toml to connect to it from a
|
|
57
|
-
Worker:
|
|
58
|
-
</Text>
|
|
59
|
-
<Text> </Text>
|
|
60
|
-
<Text>[[ d1_databases ]]</Text>
|
|
61
|
-
<Text>
|
|
62
|
-
binding = "DB" # i.e. available in your Worker on env.DB
|
|
63
|
-
</Text>
|
|
64
|
-
<Text>database_name = "{db.name}"</Text>
|
|
65
|
-
<Text>database_id = "{db.uuid}"</Text>
|
|
66
|
-
</Box>
|
|
67
|
-
)
|
|
68
|
-
);
|
|
69
|
-
}
|
|
70
|
-
);
|
package/src/d1/delete.ts
DELETED
|
@@ -1,53 +0,0 @@
|
|
|
1
|
-
import { fetchResult } from "../cfetch";
|
|
2
|
-
import { withConfig } from "../config";
|
|
3
|
-
import { confirm } from "../dialogs";
|
|
4
|
-
import { logger } from "../logger";
|
|
5
|
-
import { requireAuth } from "../user";
|
|
6
|
-
import { Name } from "./options";
|
|
7
|
-
import { d1BetaWarning, getDatabaseByNameOrBinding } from "./utils";
|
|
8
|
-
import type {
|
|
9
|
-
CommonYargsArgv,
|
|
10
|
-
StrictYargsOptionsToInterface,
|
|
11
|
-
} from "../yargs-types";
|
|
12
|
-
import type { Database } from "./types";
|
|
13
|
-
|
|
14
|
-
export function Options(d1ListYargs: CommonYargsArgv) {
|
|
15
|
-
return Name(d1ListYargs)
|
|
16
|
-
.option("skip-confirmation", {
|
|
17
|
-
describe: "Skip confirmation",
|
|
18
|
-
type: "boolean",
|
|
19
|
-
alias: "y",
|
|
20
|
-
default: false,
|
|
21
|
-
})
|
|
22
|
-
.epilogue(d1BetaWarning);
|
|
23
|
-
}
|
|
24
|
-
type HandlerOptions = StrictYargsOptionsToInterface<typeof Options>;
|
|
25
|
-
export const Handler = withConfig<HandlerOptions>(
|
|
26
|
-
async ({ name, skipConfirmation, config }): Promise<void> => {
|
|
27
|
-
const accountId = await requireAuth(config);
|
|
28
|
-
logger.log(d1BetaWarning);
|
|
29
|
-
|
|
30
|
-
const db: Database = await getDatabaseByNameOrBinding(
|
|
31
|
-
config,
|
|
32
|
-
accountId,
|
|
33
|
-
name
|
|
34
|
-
);
|
|
35
|
-
|
|
36
|
-
logger.log(`About to delete DB '${name}' (${db.uuid}).`);
|
|
37
|
-
if (!skipConfirmation) {
|
|
38
|
-
const response = await confirm(`Ok to proceed?`);
|
|
39
|
-
if (!response) {
|
|
40
|
-
logger.log(`Not deleting.`);
|
|
41
|
-
return;
|
|
42
|
-
}
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
logger.log("Deleting...");
|
|
46
|
-
|
|
47
|
-
await fetchResult(`/accounts/${accountId}/d1/database/${db.uuid}`, {
|
|
48
|
-
method: "DELETE",
|
|
49
|
-
});
|
|
50
|
-
|
|
51
|
-
logger.log(`Deleted '${name}' successfully.`);
|
|
52
|
-
}
|
|
53
|
-
);
|
package/src/d1/execute.tsx
DELETED
|
@@ -1,357 +0,0 @@
|
|
|
1
|
-
import { existsSync } from "node:fs";
|
|
2
|
-
import { mkdir } from "node:fs/promises";
|
|
3
|
-
import path from "node:path";
|
|
4
|
-
import chalk from "chalk";
|
|
5
|
-
import { Static, Text } from "ink";
|
|
6
|
-
import Table from "ink-table";
|
|
7
|
-
import { npxImport } from "npx-import";
|
|
8
|
-
import React from "react";
|
|
9
|
-
import { fetchResult } from "../cfetch";
|
|
10
|
-
import { readConfig } from "../config";
|
|
11
|
-
import { getLocalPersistencePath } from "../dev/get-local-persistence-path";
|
|
12
|
-
import { confirm } from "../dialogs";
|
|
13
|
-
import { logger } from "../logger";
|
|
14
|
-
import { readFileSync } from "../parse";
|
|
15
|
-
import { readableRelative } from "../paths";
|
|
16
|
-
import { requireAuth } from "../user";
|
|
17
|
-
import { renderToString } from "../utils/render";
|
|
18
|
-
import * as options from "./options";
|
|
19
|
-
import splitSqlQuery from "./splitter";
|
|
20
|
-
import {
|
|
21
|
-
d1BetaWarning,
|
|
22
|
-
getDatabaseByNameOrBinding,
|
|
23
|
-
getDatabaseInfoFromConfig,
|
|
24
|
-
} from "./utils";
|
|
25
|
-
import type { Config, ConfigFields, DevConfig, Environment } from "../config";
|
|
26
|
-
import type {
|
|
27
|
-
CommonYargsArgv,
|
|
28
|
-
StrictYargsOptionsToInterface,
|
|
29
|
-
} from "../yargs-types";
|
|
30
|
-
import type { Database } from "./types";
|
|
31
|
-
|
|
32
|
-
export type QueryResult = {
|
|
33
|
-
results: Record<string, string | number | boolean>[];
|
|
34
|
-
success: boolean;
|
|
35
|
-
meta?: {
|
|
36
|
-
duration?: number;
|
|
37
|
-
};
|
|
38
|
-
query?: string;
|
|
39
|
-
};
|
|
40
|
-
// Max number of statements to send in a single /execute call
|
|
41
|
-
const QUERY_LIMIT = 10_000;
|
|
42
|
-
|
|
43
|
-
export function Options(yargs: CommonYargsArgv) {
|
|
44
|
-
return options
|
|
45
|
-
.Database(yargs)
|
|
46
|
-
.option("yes", {
|
|
47
|
-
describe: 'Answer "yes" to any prompts',
|
|
48
|
-
type: "boolean",
|
|
49
|
-
alias: "y",
|
|
50
|
-
})
|
|
51
|
-
.option("local", {
|
|
52
|
-
describe:
|
|
53
|
-
"Execute commands/files against a local DB for use with wrangler dev",
|
|
54
|
-
type: "boolean",
|
|
55
|
-
})
|
|
56
|
-
.option("file", {
|
|
57
|
-
describe: "A .sql file to ingest",
|
|
58
|
-
type: "string",
|
|
59
|
-
})
|
|
60
|
-
.option("command", {
|
|
61
|
-
describe: "A single SQL statement to execute",
|
|
62
|
-
type: "string",
|
|
63
|
-
})
|
|
64
|
-
.option("persist-to", {
|
|
65
|
-
describe: "Specify directory to use for local persistence (for --local)",
|
|
66
|
-
type: "string",
|
|
67
|
-
requiresArg: true,
|
|
68
|
-
})
|
|
69
|
-
.option("json", {
|
|
70
|
-
describe: "Return output as clean JSON",
|
|
71
|
-
type: "boolean",
|
|
72
|
-
default: false,
|
|
73
|
-
})
|
|
74
|
-
.option("preview", {
|
|
75
|
-
describe: "Execute commands/files against a preview D1 DB",
|
|
76
|
-
type: "boolean",
|
|
77
|
-
default: false,
|
|
78
|
-
});
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
type HandlerOptions = StrictYargsOptionsToInterface<typeof Options>;
|
|
82
|
-
|
|
83
|
-
export const Handler = async (args: HandlerOptions): Promise<void> => {
|
|
84
|
-
const { local, database, yes, persistTo, file, command, json, preview } =
|
|
85
|
-
args;
|
|
86
|
-
const existingLogLevel = logger.loggerLevel;
|
|
87
|
-
if (json) {
|
|
88
|
-
// set loggerLevel to error to avoid readConfig warnings appearing in JSON output
|
|
89
|
-
logger.loggerLevel = "error";
|
|
90
|
-
}
|
|
91
|
-
const config = readConfig(args.config, args);
|
|
92
|
-
logger.log(d1BetaWarning);
|
|
93
|
-
if (file && command)
|
|
94
|
-
return logger.error(`Error: can't provide both --command and --file.`);
|
|
95
|
-
|
|
96
|
-
const isInteractive = process.stdout.isTTY;
|
|
97
|
-
const response: QueryResult[] | null = await executeSql({
|
|
98
|
-
local,
|
|
99
|
-
config,
|
|
100
|
-
name: database,
|
|
101
|
-
shouldPrompt: isInteractive && !yes,
|
|
102
|
-
persistTo,
|
|
103
|
-
file,
|
|
104
|
-
command,
|
|
105
|
-
json,
|
|
106
|
-
preview,
|
|
107
|
-
});
|
|
108
|
-
|
|
109
|
-
// Early exit if prompt rejected
|
|
110
|
-
if (!response) return;
|
|
111
|
-
|
|
112
|
-
if (isInteractive && !json) {
|
|
113
|
-
// Render table if single result
|
|
114
|
-
logger.log(
|
|
115
|
-
renderToString(
|
|
116
|
-
<Static items={response}>
|
|
117
|
-
{(result) => {
|
|
118
|
-
// batch results
|
|
119
|
-
if (!Array.isArray(result)) {
|
|
120
|
-
const { results, query } = result;
|
|
121
|
-
|
|
122
|
-
if (Array.isArray(results) && results.length > 0) {
|
|
123
|
-
const shortQuery = shorten(query, 48);
|
|
124
|
-
return (
|
|
125
|
-
<>
|
|
126
|
-
{shortQuery ? <Text dimColor>{shortQuery}</Text> : null}
|
|
127
|
-
<Table data={results}></Table>
|
|
128
|
-
</>
|
|
129
|
-
);
|
|
130
|
-
}
|
|
131
|
-
}
|
|
132
|
-
}}
|
|
133
|
-
</Static>
|
|
134
|
-
)
|
|
135
|
-
);
|
|
136
|
-
} else {
|
|
137
|
-
// set loggerLevel back to what it was before to actually output the JSON in stdout
|
|
138
|
-
logger.loggerLevel = existingLogLevel;
|
|
139
|
-
logger.log(JSON.stringify(response, null, 2));
|
|
140
|
-
}
|
|
141
|
-
};
|
|
142
|
-
|
|
143
|
-
export async function executeSql({
|
|
144
|
-
local,
|
|
145
|
-
config,
|
|
146
|
-
name,
|
|
147
|
-
shouldPrompt,
|
|
148
|
-
persistTo,
|
|
149
|
-
file,
|
|
150
|
-
command,
|
|
151
|
-
json,
|
|
152
|
-
preview,
|
|
153
|
-
}: {
|
|
154
|
-
local: boolean | undefined;
|
|
155
|
-
config: ConfigFields<DevConfig> & Environment;
|
|
156
|
-
name: string;
|
|
157
|
-
shouldPrompt: boolean | undefined;
|
|
158
|
-
persistTo: string | undefined;
|
|
159
|
-
file: string | undefined;
|
|
160
|
-
command: string | undefined;
|
|
161
|
-
json: boolean | undefined;
|
|
162
|
-
preview: boolean | undefined;
|
|
163
|
-
}) {
|
|
164
|
-
const sql = file ? readFileSync(file) : command;
|
|
165
|
-
if (!sql) throw new Error(`Error: must provide --command or --file.`);
|
|
166
|
-
if (preview && local)
|
|
167
|
-
throw new Error(`Error: can't use --preview with --local`);
|
|
168
|
-
if (persistTo && !local)
|
|
169
|
-
throw new Error(`Error: can't use --persist-to without --local`);
|
|
170
|
-
logger.log(`š Mapping SQL input into an array of statements`);
|
|
171
|
-
const queries = splitSqlQuery(sql);
|
|
172
|
-
|
|
173
|
-
if (file && sql) {
|
|
174
|
-
if (queries[0].startsWith("SQLite format 3")) {
|
|
175
|
-
//TODO: update this error to recommend using `wrangler d1 restore` when it exists
|
|
176
|
-
throw new Error(
|
|
177
|
-
"Provided file is a binary SQLite database file instead of an SQL text file.\nThe execute command can only process SQL text files.\nPlease export an SQL file from your SQLite database and try again."
|
|
178
|
-
);
|
|
179
|
-
}
|
|
180
|
-
}
|
|
181
|
-
|
|
182
|
-
return local
|
|
183
|
-
? await executeLocally({
|
|
184
|
-
config,
|
|
185
|
-
name,
|
|
186
|
-
shouldPrompt,
|
|
187
|
-
queries,
|
|
188
|
-
persistTo,
|
|
189
|
-
json,
|
|
190
|
-
})
|
|
191
|
-
: await executeRemotely({
|
|
192
|
-
config,
|
|
193
|
-
name,
|
|
194
|
-
shouldPrompt,
|
|
195
|
-
batches: batchSplit(queries),
|
|
196
|
-
json,
|
|
197
|
-
preview,
|
|
198
|
-
});
|
|
199
|
-
}
|
|
200
|
-
|
|
201
|
-
async function executeLocally({
|
|
202
|
-
config,
|
|
203
|
-
name,
|
|
204
|
-
shouldPrompt,
|
|
205
|
-
queries,
|
|
206
|
-
persistTo,
|
|
207
|
-
json,
|
|
208
|
-
}: {
|
|
209
|
-
config: Config;
|
|
210
|
-
name: string;
|
|
211
|
-
shouldPrompt: boolean | undefined;
|
|
212
|
-
queries: string[];
|
|
213
|
-
persistTo: string | undefined;
|
|
214
|
-
json: boolean | undefined;
|
|
215
|
-
}) {
|
|
216
|
-
const localDB = getDatabaseInfoFromConfig(config, name);
|
|
217
|
-
if (!localDB) {
|
|
218
|
-
throw new Error(
|
|
219
|
-
`Can't find a DB with name/binding '${name}' in local config. Check info in wrangler.toml...`
|
|
220
|
-
);
|
|
221
|
-
}
|
|
222
|
-
|
|
223
|
-
const persistencePath = getLocalPersistencePath(
|
|
224
|
-
persistTo,
|
|
225
|
-
true,
|
|
226
|
-
config.configPath
|
|
227
|
-
);
|
|
228
|
-
|
|
229
|
-
const dbDir = path.join(persistencePath, "d1");
|
|
230
|
-
const dbPath = path.join(dbDir, `${localDB.binding}.sqlite3`);
|
|
231
|
-
const [{ D1Database, D1DatabaseAPI }, { createSQLiteDB }] = await npxImport<
|
|
232
|
-
// eslint-disable-next-line @typescript-eslint/consistent-type-imports
|
|
233
|
-
[typeof import("@miniflare/d1"), typeof import("@miniflare/shared")]
|
|
234
|
-
>(["@miniflare/d1", "@miniflare/shared"], logger.log);
|
|
235
|
-
|
|
236
|
-
if (!existsSync(dbDir)) {
|
|
237
|
-
const ok =
|
|
238
|
-
json ||
|
|
239
|
-
!shouldPrompt ||
|
|
240
|
-
(await confirm(`About to create ${readableRelative(dbPath)}, ok?`));
|
|
241
|
-
if (!ok) return null;
|
|
242
|
-
await mkdir(dbDir, { recursive: true });
|
|
243
|
-
}
|
|
244
|
-
|
|
245
|
-
logger.log(`š Loading DB at ${readableRelative(dbPath)}`);
|
|
246
|
-
|
|
247
|
-
const sqliteDb = await createSQLiteDB(dbPath);
|
|
248
|
-
const db = new D1Database(new D1DatabaseAPI(sqliteDb));
|
|
249
|
-
const stmts = queries.map((query) => db.prepare(query));
|
|
250
|
-
return (await db.batch(stmts)) as QueryResult[];
|
|
251
|
-
}
|
|
252
|
-
|
|
253
|
-
async function executeRemotely({
|
|
254
|
-
config,
|
|
255
|
-
name,
|
|
256
|
-
shouldPrompt,
|
|
257
|
-
batches,
|
|
258
|
-
json,
|
|
259
|
-
preview,
|
|
260
|
-
}: {
|
|
261
|
-
config: Config;
|
|
262
|
-
name: string;
|
|
263
|
-
shouldPrompt: boolean | undefined;
|
|
264
|
-
batches: string[];
|
|
265
|
-
json: boolean | undefined;
|
|
266
|
-
preview: boolean | undefined;
|
|
267
|
-
}) {
|
|
268
|
-
const multiple_batches = batches.length > 1;
|
|
269
|
-
// in JSON mode, we don't want a prompt here
|
|
270
|
-
if (multiple_batches && !json) {
|
|
271
|
-
const warning = `ā ļø Too much SQL to send at once, this execution will be sent as ${batches.length} batches.`;
|
|
272
|
-
|
|
273
|
-
if (shouldPrompt) {
|
|
274
|
-
const ok = await confirm(
|
|
275
|
-
`${warning}\nā¹ļø Each batch is sent individually and may leave your DB in an unexpected state if a later batch fails.\nā ļø Make sure you have a recent backup. Ok to proceed?`
|
|
276
|
-
);
|
|
277
|
-
if (!ok) return null;
|
|
278
|
-
logger.log(`š Let's go`);
|
|
279
|
-
} else {
|
|
280
|
-
logger.error(warning);
|
|
281
|
-
}
|
|
282
|
-
}
|
|
283
|
-
|
|
284
|
-
const accountId = await requireAuth(config);
|
|
285
|
-
const db: Database = await getDatabaseByNameOrBinding(
|
|
286
|
-
config,
|
|
287
|
-
accountId,
|
|
288
|
-
name
|
|
289
|
-
);
|
|
290
|
-
if (preview && !db.previewDatabaseUuid) {
|
|
291
|
-
throw logger.error(
|
|
292
|
-
"Please define a `preview_database_id` in your wrangler.toml to execute your queries against a preview database"
|
|
293
|
-
);
|
|
294
|
-
}
|
|
295
|
-
const dbUuid = preview ? db.previewDatabaseUuid : db.uuid;
|
|
296
|
-
logger.log(`š Executing on ${name} (${dbUuid}):`);
|
|
297
|
-
|
|
298
|
-
const results: QueryResult[] = [];
|
|
299
|
-
for (const sql of batches) {
|
|
300
|
-
if (multiple_batches)
|
|
301
|
-
logger.log(
|
|
302
|
-
chalk.gray(` ${sql.slice(0, 70)}${sql.length > 70 ? "..." : ""}`)
|
|
303
|
-
);
|
|
304
|
-
|
|
305
|
-
const result = await fetchResult<QueryResult[]>(
|
|
306
|
-
`/accounts/${accountId}/d1/database/${dbUuid}/query`,
|
|
307
|
-
{
|
|
308
|
-
method: "POST",
|
|
309
|
-
headers: {
|
|
310
|
-
"Content-Type": "application/json",
|
|
311
|
-
...(db.internal_env ? { "x-d1-internal-env": db.internal_env } : {}),
|
|
312
|
-
},
|
|
313
|
-
body: JSON.stringify({ sql }),
|
|
314
|
-
}
|
|
315
|
-
);
|
|
316
|
-
result.map(logResult);
|
|
317
|
-
results.push(...result);
|
|
318
|
-
}
|
|
319
|
-
return results;
|
|
320
|
-
}
|
|
321
|
-
|
|
322
|
-
function logResult(r: QueryResult | QueryResult[]) {
|
|
323
|
-
logger.log(
|
|
324
|
-
`š£ Executed ${
|
|
325
|
-
Array.isArray(r) ? `${r.length} commands` : "1 command"
|
|
326
|
-
} in ${
|
|
327
|
-
Array.isArray(r)
|
|
328
|
-
? r
|
|
329
|
-
.map((d: QueryResult) => d.meta?.duration || 0)
|
|
330
|
-
.reduce((a: number, b: number) => a + b, 0)
|
|
331
|
-
: r.meta?.duration
|
|
332
|
-
}ms`
|
|
333
|
-
);
|
|
334
|
-
}
|
|
335
|
-
|
|
336
|
-
function batchSplit(queries: string[]) {
|
|
337
|
-
logger.log(`š Parsing ${queries.length} statements`);
|
|
338
|
-
const num_batches = Math.ceil(queries.length / QUERY_LIMIT);
|
|
339
|
-
const batches: string[] = [];
|
|
340
|
-
for (let i = 0; i < num_batches; i++) {
|
|
341
|
-
batches.push(
|
|
342
|
-
queries.slice(i * QUERY_LIMIT, (i + 1) * QUERY_LIMIT).join("; ")
|
|
343
|
-
);
|
|
344
|
-
}
|
|
345
|
-
if (num_batches > 1) {
|
|
346
|
-
logger.log(
|
|
347
|
-
`š We are sending ${num_batches} batch(es) to D1 (limited to ${QUERY_LIMIT} statements per batch)`
|
|
348
|
-
);
|
|
349
|
-
}
|
|
350
|
-
return batches;
|
|
351
|
-
}
|
|
352
|
-
|
|
353
|
-
function shorten(query: string | undefined, length: number) {
|
|
354
|
-
return query && query.length > length
|
|
355
|
-
? query.slice(0, length) + "..."
|
|
356
|
-
: query;
|
|
357
|
-
}
|