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/metrics/index.ts
DELETED
|
@@ -1,5 +0,0 @@
|
|
|
1
|
-
export { getMetricsDispatcher } from "./metrics-dispatcher";
|
|
2
|
-
export type { Properties } from "./metrics-dispatcher";
|
|
3
|
-
export { getMetricsConfig } from "./metrics-config";
|
|
4
|
-
export * from "./send-event";
|
|
5
|
-
export { getMetricsUsageHeaders } from "./metrics-usage-headers";
|
|
@@ -1,239 +0,0 @@
|
|
|
1
|
-
import { randomUUID } from "node:crypto";
|
|
2
|
-
import { readFileSync, mkdirSync, writeFileSync } from "node:fs";
|
|
3
|
-
import path from "node:path";
|
|
4
|
-
import { fetchResult } from "../cfetch";
|
|
5
|
-
import { getConfigCache, saveToConfigCache } from "../config-cache";
|
|
6
|
-
import { confirm } from "../dialogs";
|
|
7
|
-
import { getEnvironmentVariableFactory } from "../environment-variables/factory";
|
|
8
|
-
import { getGlobalWranglerConfigPath } from "../global-wrangler-config-path";
|
|
9
|
-
import { CI } from "../is-ci";
|
|
10
|
-
import isInteractive from "../is-interactive";
|
|
11
|
-
import { logger } from "../logger";
|
|
12
|
-
import { getAPIToken } from "../user";
|
|
13
|
-
|
|
14
|
-
/**
|
|
15
|
-
* The date that the metrics being gathered was last updated in a way that would require
|
|
16
|
-
* the user to give their permission again.
|
|
17
|
-
*
|
|
18
|
-
* When reading from a config file, we check the recorded date in the config file against
|
|
19
|
-
* this one here. We ignore the permissions set in the the file if the recorded date is older.
|
|
20
|
-
* This allows us to prompt the user to re-opt-in when we make substantive changes to our metrics
|
|
21
|
-
* gathering.
|
|
22
|
-
*/
|
|
23
|
-
export const CURRENT_METRICS_DATE = new Date(2022, 6, 4);
|
|
24
|
-
export const USER_ID_CACHE_PATH = "user-id.json";
|
|
25
|
-
|
|
26
|
-
export const getWranglerSendMetricsFromEnv = getEnvironmentVariableFactory({
|
|
27
|
-
variableName: "WRANGLER_SEND_METRICS",
|
|
28
|
-
});
|
|
29
|
-
|
|
30
|
-
export interface MetricsConfigOptions {
|
|
31
|
-
/**
|
|
32
|
-
* Defines whether to send metrics to Cloudflare:
|
|
33
|
-
* If defined, then use this value for whether the dispatch is enabled.
|
|
34
|
-
* Otherwise, infer the enabled value from the user configuration.
|
|
35
|
-
*/
|
|
36
|
-
sendMetrics?: boolean;
|
|
37
|
-
/**
|
|
38
|
-
* When true, do not make any CF API requests.
|
|
39
|
-
*/
|
|
40
|
-
offline?: boolean;
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
/**
|
|
44
|
-
* The information needed to set up the MetricsDispatcher.
|
|
45
|
-
*/
|
|
46
|
-
export interface MetricsConfig {
|
|
47
|
-
/** True if usage tracking is enabled. */
|
|
48
|
-
enabled: boolean;
|
|
49
|
-
/** A UID that identifies this user and machine pair for Wrangler. */
|
|
50
|
-
deviceId: string;
|
|
51
|
-
/** The currently logged in user - undefined if not logged in. */
|
|
52
|
-
userId: string | undefined;
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
/**
|
|
56
|
-
* Get hold of the permissions and device-id for metrics dispatch.
|
|
57
|
-
*
|
|
58
|
-
* The device-id is just a unique identifier sent along with events to help
|
|
59
|
-
* to collate metrics. Once generated, this id is cached in the metrics config file.
|
|
60
|
-
*
|
|
61
|
-
* The permissions define whether we can send metrics or not. They can come from a variety of places:
|
|
62
|
-
* - the `send_metrics` setting in `wrangler.toml`
|
|
63
|
-
* - a cached response from the current user
|
|
64
|
-
* - prompting the user to opt-in to metrics
|
|
65
|
-
*
|
|
66
|
-
* If the user was prompted to opt-in, then their response is cached in the metrics config file.
|
|
67
|
-
*
|
|
68
|
-
* If the current process is not interactive then we will cannot prompt the user and just assume
|
|
69
|
-
* we cannot send metrics if there is no cached or project-level preference available.
|
|
70
|
-
*/
|
|
71
|
-
export async function getMetricsConfig({
|
|
72
|
-
sendMetrics,
|
|
73
|
-
offline = false,
|
|
74
|
-
}: MetricsConfigOptions): Promise<MetricsConfig> {
|
|
75
|
-
const config = readMetricsConfig();
|
|
76
|
-
const deviceId = getDeviceId(config);
|
|
77
|
-
const userId = await getUserId(offline);
|
|
78
|
-
|
|
79
|
-
// If the WRANGLER_SEND_METRICS environment variable has been set use that
|
|
80
|
-
// and ignore everything else.
|
|
81
|
-
const sendMetricsEnv = getWranglerSendMetricsFromEnv();
|
|
82
|
-
if (sendMetricsEnv !== undefined) {
|
|
83
|
-
return {
|
|
84
|
-
enabled: sendMetricsEnv.toLowerCase() === "true",
|
|
85
|
-
deviceId,
|
|
86
|
-
userId,
|
|
87
|
-
};
|
|
88
|
-
}
|
|
89
|
-
|
|
90
|
-
// If the project is explicitly set the `send_metrics` options in `wrangler.toml`
|
|
91
|
-
// then use that and ignore any user preference.
|
|
92
|
-
if (sendMetrics !== undefined) {
|
|
93
|
-
return { enabled: sendMetrics, deviceId, userId };
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
// Get the user preference from the metrics config.
|
|
97
|
-
const permission = config.permission;
|
|
98
|
-
if (permission !== undefined) {
|
|
99
|
-
if (new Date(permission.date) >= CURRENT_METRICS_DATE) {
|
|
100
|
-
return { enabled: permission.enabled, deviceId, userId };
|
|
101
|
-
} else if (permission.enabled) {
|
|
102
|
-
logger.log(
|
|
103
|
-
"Usage metrics tracking has changed since you last granted permission."
|
|
104
|
-
);
|
|
105
|
-
}
|
|
106
|
-
}
|
|
107
|
-
|
|
108
|
-
// We couldn't get the metrics permission from the project-level nor the user-level config.
|
|
109
|
-
// If we are not interactive or in a CI build then just bail out.
|
|
110
|
-
if (!isInteractive() || CI.isCI()) {
|
|
111
|
-
return { enabled: false, deviceId, userId };
|
|
112
|
-
}
|
|
113
|
-
|
|
114
|
-
// Otherwise, let's ask the user and store the result in the metrics config.
|
|
115
|
-
const enabled = await confirm(
|
|
116
|
-
"Would you like to help improve Wrangler by sending usage metrics to Cloudflare?"
|
|
117
|
-
);
|
|
118
|
-
logger.log(
|
|
119
|
-
`Your choice has been saved in the following file: ${path.relative(
|
|
120
|
-
process.cwd(),
|
|
121
|
-
getMetricsConfigPath()
|
|
122
|
-
)}.\n\n` +
|
|
123
|
-
" You can override the user level setting for a project in `wrangler.toml`:\n\n" +
|
|
124
|
-
" - to disable sending metrics for a project: `send_metrics = false`\n" +
|
|
125
|
-
" - to enable sending metrics for a project: `send_metrics = true`"
|
|
126
|
-
);
|
|
127
|
-
writeMetricsConfig({
|
|
128
|
-
permission: {
|
|
129
|
-
enabled,
|
|
130
|
-
date: CURRENT_METRICS_DATE,
|
|
131
|
-
},
|
|
132
|
-
deviceId,
|
|
133
|
-
});
|
|
134
|
-
return { enabled, deviceId, userId };
|
|
135
|
-
}
|
|
136
|
-
|
|
137
|
-
/**
|
|
138
|
-
* Stringify and write the given info to the metrics config file.
|
|
139
|
-
*/
|
|
140
|
-
export function writeMetricsConfig(config: MetricsConfigFile) {
|
|
141
|
-
mkdirSync(path.dirname(getMetricsConfigPath()), { recursive: true });
|
|
142
|
-
writeFileSync(
|
|
143
|
-
getMetricsConfigPath(),
|
|
144
|
-
JSON.stringify(
|
|
145
|
-
config,
|
|
146
|
-
(_key, value) => (value instanceof Date ? value.toISOString() : value),
|
|
147
|
-
"\t"
|
|
148
|
-
)
|
|
149
|
-
);
|
|
150
|
-
}
|
|
151
|
-
|
|
152
|
-
/**
|
|
153
|
-
* Read and parse the metrics config file.
|
|
154
|
-
*/
|
|
155
|
-
export function readMetricsConfig(): MetricsConfigFile {
|
|
156
|
-
try {
|
|
157
|
-
const config = readFileSync(getMetricsConfigPath(), "utf8");
|
|
158
|
-
return JSON.parse(config, (key, value) =>
|
|
159
|
-
key === "date" ? new Date(value) : value
|
|
160
|
-
);
|
|
161
|
-
} catch {
|
|
162
|
-
return {};
|
|
163
|
-
}
|
|
164
|
-
}
|
|
165
|
-
|
|
166
|
-
/**
|
|
167
|
-
* Get the path to the metrics config file.
|
|
168
|
-
*/
|
|
169
|
-
function getMetricsConfigPath(): string {
|
|
170
|
-
return path.resolve(getGlobalWranglerConfigPath(), "metrics.json");
|
|
171
|
-
}
|
|
172
|
-
|
|
173
|
-
/**
|
|
174
|
-
* The format of the metrics config file.
|
|
175
|
-
*/
|
|
176
|
-
export interface MetricsConfigFile {
|
|
177
|
-
permission?: {
|
|
178
|
-
/** True if Wrangler should send metrics to Cloudflare. */
|
|
179
|
-
enabled: boolean;
|
|
180
|
-
/** The date that this permission was set. */
|
|
181
|
-
date: Date;
|
|
182
|
-
};
|
|
183
|
-
/** A unique UUID that identifies this device for metrics purposes. */
|
|
184
|
-
deviceId?: string;
|
|
185
|
-
}
|
|
186
|
-
|
|
187
|
-
/**
|
|
188
|
-
* Returns an ID that uniquely identifies Wrangler on this device to help collate events.
|
|
189
|
-
*
|
|
190
|
-
* Once created this ID is stored in the metrics config file.
|
|
191
|
-
*/
|
|
192
|
-
function getDeviceId(config: MetricsConfigFile) {
|
|
193
|
-
// Get or create the deviceId.
|
|
194
|
-
const deviceId = config.deviceId ?? randomUUID();
|
|
195
|
-
if (config.deviceId === undefined) {
|
|
196
|
-
// We had to create a new deviceID so store it now.
|
|
197
|
-
writeMetricsConfig({ ...config, deviceId });
|
|
198
|
-
}
|
|
199
|
-
return deviceId;
|
|
200
|
-
}
|
|
201
|
-
|
|
202
|
-
/**
|
|
203
|
-
* Returns the ID of the current user, which will be sent with each event.
|
|
204
|
-
*
|
|
205
|
-
* The ID is retrieved from the CF API `/user` endpoint if the user is authenticated and then
|
|
206
|
-
* stored in the `node_modules/.cache`.
|
|
207
|
-
*
|
|
208
|
-
* If it is not possible to retrieve the ID (perhaps the user is not logged in) then we just use
|
|
209
|
-
* `undefined`.
|
|
210
|
-
*/
|
|
211
|
-
async function getUserId(offline: boolean) {
|
|
212
|
-
// Get the userId from the cache.
|
|
213
|
-
// If it has not been found in the cache and we are not offline then make an API call to get it.
|
|
214
|
-
// If we can't work in out then just use `anonymous`.
|
|
215
|
-
let userId = getConfigCache<{ userId: string }>(USER_ID_CACHE_PATH).userId;
|
|
216
|
-
if (userId === undefined && !offline) {
|
|
217
|
-
userId = await fetchUserId();
|
|
218
|
-
if (userId !== undefined) {
|
|
219
|
-
saveToConfigCache(USER_ID_CACHE_PATH, { userId });
|
|
220
|
-
}
|
|
221
|
-
}
|
|
222
|
-
return userId;
|
|
223
|
-
}
|
|
224
|
-
|
|
225
|
-
/**
|
|
226
|
-
* Ask the Cloudflare API for the User ID of the current user.
|
|
227
|
-
*
|
|
228
|
-
* We will only do this if we are not "offline", e.g. not running `wrangler dev --local`.
|
|
229
|
-
* Quietly return undefined if anything goes wrong.
|
|
230
|
-
*/
|
|
231
|
-
async function fetchUserId(): Promise<string | undefined> {
|
|
232
|
-
try {
|
|
233
|
-
return getAPIToken()
|
|
234
|
-
? (await fetchResult<{ id: string }>("/user")).id
|
|
235
|
-
: undefined;
|
|
236
|
-
} catch (e) {
|
|
237
|
-
return undefined;
|
|
238
|
-
}
|
|
239
|
-
}
|
|
@@ -1,96 +0,0 @@
|
|
|
1
|
-
import { fetch } from "undici";
|
|
2
|
-
import { version as wranglerVersion } from "../../package.json";
|
|
3
|
-
import { logger } from "../logger";
|
|
4
|
-
import { getMetricsConfig } from "./metrics-config";
|
|
5
|
-
import type { MetricsConfigOptions } from "./metrics-config";
|
|
6
|
-
|
|
7
|
-
// The SPARROW_SOURCE_KEY is provided at esbuild time as a `define` for production and beta
|
|
8
|
-
// releases. Otherwise it is left undefined, which automatically disables metrics requests.
|
|
9
|
-
declare const SPARROW_SOURCE_KEY: string;
|
|
10
|
-
const SPARROW_URL = "https://sparrow.cloudflare.com";
|
|
11
|
-
|
|
12
|
-
export async function getMetricsDispatcher(options: MetricsConfigOptions) {
|
|
13
|
-
return {
|
|
14
|
-
/**
|
|
15
|
-
* Dispatch a event to the analytics target.
|
|
16
|
-
*
|
|
17
|
-
* The event should follow these conventions
|
|
18
|
-
* - name is of the form `[action] [object]` (lower case)
|
|
19
|
-
* - additional properties are camelCased
|
|
20
|
-
*/
|
|
21
|
-
async sendEvent(name: string, properties: Properties = {}): Promise<void> {
|
|
22
|
-
await dispatch({ type: "event", name, properties });
|
|
23
|
-
},
|
|
24
|
-
|
|
25
|
-
/**
|
|
26
|
-
* Dispatch a user profile information to the analytics target.
|
|
27
|
-
*
|
|
28
|
-
* This call can be used to inform the analytics target of relevant properties associated
|
|
29
|
-
* with the current user.
|
|
30
|
-
*/
|
|
31
|
-
async identify(properties: Properties): Promise<void> {
|
|
32
|
-
await dispatch({ type: "identify", name: "identify", properties });
|
|
33
|
-
},
|
|
34
|
-
};
|
|
35
|
-
|
|
36
|
-
async function dispatch(event: {
|
|
37
|
-
type: "identify" | "event";
|
|
38
|
-
name: string;
|
|
39
|
-
properties: Properties;
|
|
40
|
-
}): Promise<void> {
|
|
41
|
-
if (!SPARROW_SOURCE_KEY) {
|
|
42
|
-
logger.debug(
|
|
43
|
-
"Metrics dispatcher: Source Key not provided. Be sure to initialize before sending events.",
|
|
44
|
-
event
|
|
45
|
-
);
|
|
46
|
-
return;
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
// Lazily get the config for this dispatcher only when an event is being dispatched.
|
|
50
|
-
// We must await this since it might trigger user interaction that would break other UI
|
|
51
|
-
// in Wrangler if it was allowed to run in parallel.
|
|
52
|
-
const metricsConfig = await getMetricsConfig(options);
|
|
53
|
-
if (!metricsConfig.enabled) {
|
|
54
|
-
logger.debug(
|
|
55
|
-
`Metrics dispatcher: Dispatching disabled - would have sent ${JSON.stringify(
|
|
56
|
-
event
|
|
57
|
-
)}.`
|
|
58
|
-
);
|
|
59
|
-
return;
|
|
60
|
-
}
|
|
61
|
-
|
|
62
|
-
logger.debug(`Metrics dispatcher: Posting data ${JSON.stringify(event)}`);
|
|
63
|
-
const body = JSON.stringify({
|
|
64
|
-
deviceId: metricsConfig.deviceId,
|
|
65
|
-
userId: metricsConfig.userId,
|
|
66
|
-
event: event.name,
|
|
67
|
-
properties: {
|
|
68
|
-
category: "Workers",
|
|
69
|
-
wranglerVersion,
|
|
70
|
-
os: process.platform + ":" + process.arch,
|
|
71
|
-
...event.properties,
|
|
72
|
-
},
|
|
73
|
-
});
|
|
74
|
-
|
|
75
|
-
// Do not await this fetch call.
|
|
76
|
-
// Just fire-and-forget, otherwise we might slow down the rest of Wrangler.
|
|
77
|
-
fetch(`${SPARROW_URL}/api/v1/${event.type}`, {
|
|
78
|
-
method: "POST",
|
|
79
|
-
headers: {
|
|
80
|
-
Accept: "*/*",
|
|
81
|
-
"Content-Type": "application/json",
|
|
82
|
-
"Sparrow-Source-Key": SPARROW_SOURCE_KEY,
|
|
83
|
-
},
|
|
84
|
-
mode: "cors",
|
|
85
|
-
keepalive: true,
|
|
86
|
-
body,
|
|
87
|
-
}).catch((e) => {
|
|
88
|
-
logger.debug(
|
|
89
|
-
"Metrics dispatcher: Failed to send request:",
|
|
90
|
-
(e as Error).message
|
|
91
|
-
);
|
|
92
|
-
});
|
|
93
|
-
}
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
export type Properties = Record<string, unknown>;
|
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
import { getMetricsConfig } from "./metrics-config";
|
|
2
|
-
|
|
3
|
-
/**
|
|
4
|
-
* Add an additional header to publish requests if the user has opted into sending usage metrics.
|
|
5
|
-
*
|
|
6
|
-
* This allows us to estimate the number of instances of Wrangler that have opted-in
|
|
7
|
-
* without breaking our agreement not to send stuff if you have not opted-in.
|
|
8
|
-
*/
|
|
9
|
-
export async function getMetricsUsageHeaders(
|
|
10
|
-
sendMetrics: boolean | undefined
|
|
11
|
-
): Promise<Record<string, string> | undefined> {
|
|
12
|
-
const metricsEnabled = (
|
|
13
|
-
await getMetricsConfig({
|
|
14
|
-
sendMetrics,
|
|
15
|
-
})
|
|
16
|
-
).enabled;
|
|
17
|
-
if (metricsEnabled) {
|
|
18
|
-
return {
|
|
19
|
-
metricsEnabled: "true",
|
|
20
|
-
};
|
|
21
|
-
} else {
|
|
22
|
-
return undefined;
|
|
23
|
-
}
|
|
24
|
-
}
|
|
@@ -1,99 +0,0 @@
|
|
|
1
|
-
import { logger } from "../logger";
|
|
2
|
-
import { getMetricsDispatcher } from "./metrics-dispatcher";
|
|
3
|
-
import type { MetricsConfigOptions } from "./metrics-config";
|
|
4
|
-
import type { Properties } from "./metrics-dispatcher";
|
|
5
|
-
|
|
6
|
-
/** These are event names used by this wrangler client. */
|
|
7
|
-
export type EventNames =
|
|
8
|
-
| "view accounts"
|
|
9
|
-
| "deploy worker script"
|
|
10
|
-
| "delete worker script"
|
|
11
|
-
| "begin log stream"
|
|
12
|
-
| "end log stream"
|
|
13
|
-
| "begin pages log stream"
|
|
14
|
-
| "end pages log stream"
|
|
15
|
-
| "create encrypted variable"
|
|
16
|
-
| "delete encrypted variable"
|
|
17
|
-
| "list encrypted variables"
|
|
18
|
-
| "create kv namespace"
|
|
19
|
-
| "list kv namespaces"
|
|
20
|
-
| "delete kv namespace"
|
|
21
|
-
| "write kv key-value"
|
|
22
|
-
| "list kv keys"
|
|
23
|
-
| "read kv value"
|
|
24
|
-
| "delete kv key-value"
|
|
25
|
-
| "write kv key-values (bulk)"
|
|
26
|
-
| "delete kv key-values (bulk)"
|
|
27
|
-
| "create r2 bucket"
|
|
28
|
-
| "list r2 buckets"
|
|
29
|
-
| "delete r2 bucket"
|
|
30
|
-
| "login user"
|
|
31
|
-
| "logout user"
|
|
32
|
-
| "create pubsub namespace"
|
|
33
|
-
| "list pubsub namespaces"
|
|
34
|
-
| "delete pubsub namespace"
|
|
35
|
-
| "view pubsub namespace"
|
|
36
|
-
| "create pubsub broker"
|
|
37
|
-
| "update pubsub broker"
|
|
38
|
-
| "list pubsub brokers"
|
|
39
|
-
| "delete pubsub broker"
|
|
40
|
-
| "view pubsub broker"
|
|
41
|
-
| "issue pubsub broker credentials"
|
|
42
|
-
| "revoke pubsub broker credentials"
|
|
43
|
-
| "unrevoke pubsub broker credentials"
|
|
44
|
-
| "list pubsub broker revoked credentials"
|
|
45
|
-
| "list pubsub broker public-keys"
|
|
46
|
-
| "list dispatch namespaces"
|
|
47
|
-
| "view dispatch namespace"
|
|
48
|
-
| "create dispatch namespace"
|
|
49
|
-
| "delete dispatch namespace"
|
|
50
|
-
| "rename dispatch namespace"
|
|
51
|
-
| "create pages project"
|
|
52
|
-
| "list pages projects"
|
|
53
|
-
| "create pages deployment"
|
|
54
|
-
| "list pages deployments"
|
|
55
|
-
| "build pages functions"
|
|
56
|
-
| "run dev"
|
|
57
|
-
| "run dev (api)"
|
|
58
|
-
| "run pages dev"
|
|
59
|
-
| "view docs"
|
|
60
|
-
| "view deployments"
|
|
61
|
-
| "rollback deployments";
|
|
62
|
-
|
|
63
|
-
/**
|
|
64
|
-
* Send a metrics event, with no extra properties, to Cloudflare, if usage tracking is enabled.
|
|
65
|
-
*
|
|
66
|
-
* This overload assumes that you do not want to configure analytics with options.
|
|
67
|
-
*/
|
|
68
|
-
export function sendMetricsEvent(event: EventNames): Promise<void>;
|
|
69
|
-
/**
|
|
70
|
-
* Send a metrics event, with no extra properties, to Cloudflare, if usage tracking is enabled.
|
|
71
|
-
*/
|
|
72
|
-
export function sendMetricsEvent(
|
|
73
|
-
event: EventNames,
|
|
74
|
-
options: MetricsConfigOptions
|
|
75
|
-
): Promise<void>;
|
|
76
|
-
/**
|
|
77
|
-
* Send a metrics event to Cloudflare, if usage tracking is enabled.
|
|
78
|
-
*
|
|
79
|
-
* Generally you should pass the `send_metrics` property from the wrangler.toml config here,
|
|
80
|
-
* which would override any user permissions.
|
|
81
|
-
*/
|
|
82
|
-
export function sendMetricsEvent(
|
|
83
|
-
event: EventNames,
|
|
84
|
-
properties: Properties,
|
|
85
|
-
options: MetricsConfigOptions
|
|
86
|
-
): Promise<void>;
|
|
87
|
-
export async function sendMetricsEvent(
|
|
88
|
-
event: EventNames,
|
|
89
|
-
...args: [] | [MetricsConfigOptions] | [Properties, MetricsConfigOptions]
|
|
90
|
-
): Promise<void> {
|
|
91
|
-
try {
|
|
92
|
-
const options = args.pop() ?? {};
|
|
93
|
-
const properties = (args.pop() ?? {}) as Properties;
|
|
94
|
-
const metricsDispatcher = await getMetricsDispatcher(options);
|
|
95
|
-
await metricsDispatcher.sendEvent(event, properties);
|
|
96
|
-
} catch (err) {
|
|
97
|
-
logger.debug("Error sending metrics event", err);
|
|
98
|
-
}
|
|
99
|
-
}
|
|
@@ -1,30 +0,0 @@
|
|
|
1
|
-
# Custom Miniflare CLI
|
|
2
|
-
|
|
3
|
-
This directory contains a simple wrapper around the programmatic Miniflare API,
|
|
4
|
-
which Wrangler spawns when running `wrangler dev` in local mode.
|
|
5
|
-
|
|
6
|
-
## Building
|
|
7
|
-
|
|
8
|
-
This CLI is built at the same time as Wrangler by running
|
|
9
|
-
|
|
10
|
-
```
|
|
11
|
-
npm run -w wrangler build
|
|
12
|
-
```
|
|
13
|
-
|
|
14
|
-
The output of the build is `miniflare-dist/index.mjs`.
|
|
15
|
-
|
|
16
|
-
## Running
|
|
17
|
-
|
|
18
|
-
The CLI expects a single command line argument which is the Miniflare options formatted as a string of JSON.
|
|
19
|
-
|
|
20
|
-
```bash
|
|
21
|
-
node --no-warnings ./packages/wrangler/miniflare-dist/index.mjs '{"watch": true, "script": ""}' --log VERBOSE
|
|
22
|
-
```
|
|
23
|
-
|
|
24
|
-
The `--log` argument is optional and takes one of Miniflare's LogLevels: "NONE", "ERROR", "WARN", "INFO", "DEBUG", "VERBOSE".
|
|
25
|
-
It defaults to `INFO`.
|
|
26
|
-
|
|
27
|
-
## Debugging
|
|
28
|
-
|
|
29
|
-
Simply place a breakpoint in the code and run the above command in the VS Code "JavaScript Debug Terminal".
|
|
30
|
-
The code will stop at the breakpoint as expected.
|