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.
Files changed (297) hide show
  1. package/README.md +4 -4
  2. package/bin/wrangler.js +9 -75
  3. package/package.json +5 -13
  4. package/templates/__tests__/tsconfig.tsbuildinfo +1 -1
  5. package/templates/checked-fetch.js +1 -1
  6. package/templates/first-party-worker-module-facade.ts +2 -2
  7. package/templates/middleware/common.ts +9 -4
  8. package/templates/middleware/loader-sw.ts +2 -7
  9. package/templates/new-worker-scheduled.ts +1 -1
  10. package/templates/new-worker.ts +1 -1
  11. package/templates/pages-dev-util.ts +4 -1
  12. package/templates/pages-shim.ts +0 -3
  13. package/templates/tsconfig.tsbuildinfo +1 -1
  14. package/wrangler-dist/cli.d.ts +149 -75
  15. package/wrangler-dist/cli.js +60062 -64338
  16. package/import_meta_url.js +0 -3
  17. package/miniflare-config-stubs/.env.empty +0 -0
  18. package/miniflare-config-stubs/package.empty.json +0 -1
  19. package/miniflare-config-stubs/wrangler.empty.toml +0 -0
  20. package/miniflare-dist/index.mjs +0 -6442
  21. package/src/__tests__/access.test.ts +0 -25
  22. package/src/__tests__/api-dev.test.ts +0 -238
  23. package/src/__tests__/api-devregistry.test.ts +0 -121
  24. package/src/__tests__/api.test.ts +0 -102
  25. package/src/__tests__/config-cache-without-cache-dir.test.ts +0 -38
  26. package/src/__tests__/config-cache.test.ts +0 -42
  27. package/src/__tests__/configuration.test.ts +0 -4517
  28. package/src/__tests__/constellation.test.ts +0 -371
  29. package/src/__tests__/d1/d1.test.ts +0 -82
  30. package/src/__tests__/d1/execute.test.ts +0 -66
  31. package/src/__tests__/d1/migrate.test.ts +0 -257
  32. package/src/__tests__/d1/splitter.test.ts +0 -255
  33. package/src/__tests__/delete.test.ts +0 -272
  34. package/src/__tests__/deployments.test.ts +0 -369
  35. package/src/__tests__/dev.test.tsx +0 -1617
  36. package/src/__tests__/generate.test.ts +0 -237
  37. package/src/__tests__/get-host-from-url.test.ts +0 -16
  38. package/src/__tests__/guess-worker-format.test.ts +0 -120
  39. package/src/__tests__/helpers/clipboardy-mock.js +0 -4
  40. package/src/__tests__/helpers/cmd-shim.d.ts +0 -11
  41. package/src/__tests__/helpers/end-event-loop.ts +0 -6
  42. package/src/__tests__/helpers/mock-account-id.ts +0 -48
  43. package/src/__tests__/helpers/mock-auth-domain.ts +0 -20
  44. package/src/__tests__/helpers/mock-bin.ts +0 -36
  45. package/src/__tests__/helpers/mock-console.ts +0 -112
  46. package/src/__tests__/helpers/mock-dialogs.ts +0 -139
  47. package/src/__tests__/helpers/mock-get-pages-upload-token.ts +0 -25
  48. package/src/__tests__/helpers/mock-get-zone-from-host.ts +0 -11
  49. package/src/__tests__/helpers/mock-http-server.ts +0 -46
  50. package/src/__tests__/helpers/mock-istty.ts +0 -74
  51. package/src/__tests__/helpers/mock-known-routes.ts +0 -12
  52. package/src/__tests__/helpers/mock-kv.ts +0 -46
  53. package/src/__tests__/helpers/mock-oauth-flow.ts +0 -263
  54. package/src/__tests__/helpers/mock-process.ts +0 -34
  55. package/src/__tests__/helpers/mock-set-timeout.ts +0 -16
  56. package/src/__tests__/helpers/mock-stdin.ts +0 -108
  57. package/src/__tests__/helpers/mock-web-socket.ts +0 -29
  58. package/src/__tests__/helpers/msw/blob-worker.cjs +0 -19
  59. package/src/__tests__/helpers/msw/handlers/access.ts +0 -13
  60. package/src/__tests__/helpers/msw/handlers/deployments.ts +0 -160
  61. package/src/__tests__/helpers/msw/handlers/namespaces.ts +0 -81
  62. package/src/__tests__/helpers/msw/handlers/oauth.ts +0 -31
  63. package/src/__tests__/helpers/msw/handlers/r2.ts +0 -60
  64. package/src/__tests__/helpers/msw/handlers/script.ts +0 -56
  65. package/src/__tests__/helpers/msw/handlers/user.ts +0 -52
  66. package/src/__tests__/helpers/msw/handlers/zones.ts +0 -20
  67. package/src/__tests__/helpers/msw/index.ts +0 -52
  68. package/src/__tests__/helpers/msw/read-file-sync.js +0 -61
  69. package/src/__tests__/helpers/run-in-tmp.ts +0 -38
  70. package/src/__tests__/helpers/run-wrangler.ts +0 -16
  71. package/src/__tests__/helpers/string-dynamic-values-matcher.ts +0 -28
  72. package/src/__tests__/helpers/worker-scripts/child-wrangler.toml +0 -1
  73. package/src/__tests__/helpers/worker-scripts/hello-world-worker.js +0 -5
  74. package/src/__tests__/helpers/worker-scripts/hello-world-wrangler.toml +0 -1
  75. package/src/__tests__/helpers/worker-scripts/parent-worker.js +0 -11
  76. package/src/__tests__/helpers/worker-scripts/parent-wrangler.toml +0 -5
  77. package/src/__tests__/helpers/write-worker-source.ts +0 -31
  78. package/src/__tests__/helpers/write-wrangler-toml.ts +0 -17
  79. package/src/__tests__/https-options.test.ts +0 -163
  80. package/src/__tests__/index.test.ts +0 -282
  81. package/src/__tests__/init.test.ts +0 -3196
  82. package/src/__tests__/jest.setup.ts +0 -179
  83. package/src/__tests__/kv.test.ts +0 -1799
  84. package/src/__tests__/logger.test.ts +0 -207
  85. package/src/__tests__/logout.test.ts +0 -47
  86. package/src/__tests__/metrics.test.ts +0 -493
  87. package/src/__tests__/middleware.scheduled.test.ts +0 -145
  88. package/src/__tests__/middleware.test.ts +0 -816
  89. package/src/__tests__/mtls-certificates.test.ts +0 -589
  90. package/src/__tests__/package-manager.test.ts +0 -353
  91. package/src/__tests__/pages/deployment-list.test.ts +0 -80
  92. package/src/__tests__/pages/functions-build.test.ts +0 -528
  93. package/src/__tests__/pages/pages.test.ts +0 -81
  94. package/src/__tests__/pages/project-create.test.ts +0 -63
  95. package/src/__tests__/pages/project-list.test.ts +0 -110
  96. package/src/__tests__/pages/project-upload.test.ts +0 -500
  97. package/src/__tests__/pages/publish.test.ts +0 -2864
  98. package/src/__tests__/pages-deployment-tail.test.ts +0 -957
  99. package/src/__tests__/parse.test.ts +0 -436
  100. package/src/__tests__/paths.test.ts +0 -39
  101. package/src/__tests__/publish.test.ts +0 -8849
  102. package/src/__tests__/pubsub.test.ts +0 -496
  103. package/src/__tests__/queues.test.ts +0 -532
  104. package/src/__tests__/r2.test.ts +0 -374
  105. package/src/__tests__/route.test.ts +0 -45
  106. package/src/__tests__/secret.test.ts +0 -693
  107. package/src/__tests__/tail.test.ts +0 -989
  108. package/src/__tests__/test-old-node-version.js +0 -31
  109. package/src/__tests__/traverse-module-graph.test.ts +0 -220
  110. package/src/__tests__/tsconfig-sanity.ts +0 -12
  111. package/src/__tests__/tsconfig.json +0 -8
  112. package/src/__tests__/tsconfig.tsbuildinfo +0 -1
  113. package/src/__tests__/type-generation.test.ts +0 -234
  114. package/src/__tests__/user.test.ts +0 -118
  115. package/src/__tests__/utils-collectKeyValues.test.ts +0 -47
  116. package/src/__tests__/validate-dev-props.test.ts +0 -56
  117. package/src/__tests__/version.test.ts +0 -35
  118. package/src/__tests__/whoami.test.tsx +0 -172
  119. package/src/__tests__/worker-namespace.test.ts +0 -340
  120. package/src/abort.d.ts +0 -3
  121. package/src/api/dev.ts +0 -321
  122. package/src/api/index.ts +0 -11
  123. package/src/api/mtls-certificate.ts +0 -148
  124. package/src/api/pages/create-worker-bundle-contents.ts +0 -77
  125. package/src/api/pages/index.ts +0 -5
  126. package/src/api/pages/publish.tsx +0 -371
  127. package/src/bundle-reporter.ts +0 -68
  128. package/src/bundle.ts +0 -929
  129. package/src/cfetch/index.ts +0 -158
  130. package/src/cfetch/internal.ts +0 -258
  131. package/src/cli.ts +0 -28
  132. package/src/config/README.md +0 -107
  133. package/src/config/config.ts +0 -282
  134. package/src/config/diagnostics.ts +0 -80
  135. package/src/config/environment.ts +0 -625
  136. package/src/config/index.ts +0 -403
  137. package/src/config/validation-helpers.ts +0 -597
  138. package/src/config/validation.ts +0 -2369
  139. package/src/config-cache.ts +0 -85
  140. package/src/constellation/createProject.tsx +0 -51
  141. package/src/constellation/deleteProject.ts +0 -51
  142. package/src/constellation/deleteProjectModel.ts +0 -68
  143. package/src/constellation/index.ts +0 -75
  144. package/src/constellation/listCatalog.tsx +0 -35
  145. package/src/constellation/listModel.tsx +0 -41
  146. package/src/constellation/listProject.tsx +0 -28
  147. package/src/constellation/listRuntime.tsx +0 -28
  148. package/src/constellation/options.ts +0 -17
  149. package/src/constellation/types.ts +0 -17
  150. package/src/constellation/uploadModel.tsx +0 -64
  151. package/src/constellation/utils.ts +0 -90
  152. package/src/create-worker-preview.ts +0 -293
  153. package/src/create-worker-upload-form.ts +0 -363
  154. package/src/d1/backups.tsx +0 -219
  155. package/src/d1/constants.ts +0 -2
  156. package/src/d1/create.tsx +0 -70
  157. package/src/d1/delete.ts +0 -53
  158. package/src/d1/execute.tsx +0 -357
  159. package/src/d1/formatTimeAgo.ts +0 -14
  160. package/src/d1/index.ts +0 -100
  161. package/src/d1/list.tsx +0 -62
  162. package/src/d1/migrations/apply.tsx +0 -212
  163. package/src/d1/migrations/create.tsx +0 -79
  164. package/src/d1/migrations/helpers.ts +0 -169
  165. package/src/d1/migrations/index.ts +0 -3
  166. package/src/d1/migrations/list.tsx +0 -95
  167. package/src/d1/migrations/options.ts +0 -23
  168. package/src/d1/options.ts +0 -22
  169. package/src/d1/splitter.ts +0 -161
  170. package/src/d1/types.ts +0 -25
  171. package/src/d1/utils.ts +0 -49
  172. package/src/delete.ts +0 -100
  173. package/src/deployments.ts +0 -368
  174. package/src/deprecated/index.ts +0 -144
  175. package/src/dev/dev-vars.ts +0 -39
  176. package/src/dev/dev.tsx +0 -605
  177. package/src/dev/get-local-persistence-path.ts +0 -31
  178. package/src/dev/local.tsx +0 -952
  179. package/src/dev/remote.tsx +0 -635
  180. package/src/dev/start-server.ts +0 -545
  181. package/src/dev/use-esbuild.ts +0 -215
  182. package/src/dev/validate-dev-props.ts +0 -40
  183. package/src/dev-registry.ts +0 -202
  184. package/src/dev.tsx +0 -934
  185. package/src/dialogs.ts +0 -136
  186. package/src/dispatch-namespace.ts +0 -211
  187. package/src/docs/helpers.ts +0 -50
  188. package/src/docs/index.ts +0 -54
  189. package/src/durable.ts +0 -102
  190. package/src/entry.ts +0 -344
  191. package/src/environment-variables/factory.ts +0 -89
  192. package/src/environment-variables/misc-variables.ts +0 -30
  193. package/src/errors.ts +0 -11
  194. package/src/generate/index.ts +0 -298
  195. package/src/git-client.ts +0 -135
  196. package/src/global-wrangler-config-path.ts +0 -26
  197. package/src/https-options.ts +0 -127
  198. package/src/index.ts +0 -768
  199. package/src/init.ts +0 -1037
  200. package/src/inspect.ts +0 -883
  201. package/src/intl-polyfill.d.ts +0 -139
  202. package/src/is-ci.ts +0 -14
  203. package/src/is-interactive.ts +0 -16
  204. package/src/jest.d.ts +0 -4
  205. package/src/kv/helpers.ts +0 -433
  206. package/src/kv/index.ts +0 -594
  207. package/src/logger.ts +0 -123
  208. package/src/metrics/index.ts +0 -5
  209. package/src/metrics/metrics-config.ts +0 -239
  210. package/src/metrics/metrics-dispatcher.ts +0 -96
  211. package/src/metrics/metrics-usage-headers.ts +0 -24
  212. package/src/metrics/send-event.ts +0 -99
  213. package/src/miniflare-cli/README.md +0 -30
  214. package/src/miniflare-cli/assets.ts +0 -251
  215. package/src/miniflare-cli/index.ts +0 -210
  216. package/src/miniflare-cli/request-context.ts +0 -40
  217. package/src/miniflare-cli/tsconfig.json +0 -9
  218. package/src/miniflare-cli/tsconfig.tsbuildinfo +0 -1
  219. package/src/miniflare-cli/types.ts +0 -11
  220. package/src/module-collection.ts +0 -333
  221. package/src/mtls-certificate/cli.ts +0 -155
  222. package/src/open-in-browser.ts +0 -17
  223. package/src/package-manager.ts +0 -219
  224. package/src/pages/build.ts +0 -423
  225. package/src/pages/buildFunctions.ts +0 -140
  226. package/src/pages/constants.ts +0 -18
  227. package/src/pages/deployment-tails.ts +0 -281
  228. package/src/pages/deployments.tsx +0 -84
  229. package/src/pages/dev.ts +0 -734
  230. package/src/pages/errors.ts +0 -67
  231. package/src/pages/functions/buildPlugin.ts +0 -114
  232. package/src/pages/functions/buildWorker.ts +0 -350
  233. package/src/pages/functions/filepath-routing.test.ts +0 -234
  234. package/src/pages/functions/filepath-routing.ts +0 -189
  235. package/src/pages/functions/identifiers.ts +0 -78
  236. package/src/pages/functions/routes-consolidation.test.ts +0 -250
  237. package/src/pages/functions/routes-consolidation.ts +0 -73
  238. package/src/pages/functions/routes-transformation.test.ts +0 -282
  239. package/src/pages/functions/routes-transformation.ts +0 -115
  240. package/src/pages/functions/routes-validation.test.ts +0 -403
  241. package/src/pages/functions/routes-validation.ts +0 -202
  242. package/src/pages/functions/routes.ts +0 -151
  243. package/src/pages/functions/tsconfig.json +0 -8
  244. package/src/pages/functions/tsconfig.tsbuildinfo +0 -1
  245. package/src/pages/functions.ts +0 -86
  246. package/src/pages/hash.ts +0 -13
  247. package/src/pages/index.ts +0 -102
  248. package/src/pages/projects.tsx +0 -159
  249. package/src/pages/prompt-select-project.tsx +0 -31
  250. package/src/pages/publish.tsx +0 -267
  251. package/src/pages/types.ts +0 -46
  252. package/src/pages/upload.tsx +0 -469
  253. package/src/pages/utils.ts +0 -23
  254. package/src/parse.ts +0 -308
  255. package/src/paths.ts +0 -71
  256. package/src/proxy.ts +0 -694
  257. package/src/publish/index.ts +0 -274
  258. package/src/publish/publish.ts +0 -1065
  259. package/src/pubsub/index.ts +0 -286
  260. package/src/pubsub/pubsub-commands.ts +0 -623
  261. package/src/queues/cli/commands/consumer/add.ts +0 -71
  262. package/src/queues/cli/commands/consumer/index.ts +0 -19
  263. package/src/queues/cli/commands/consumer/remove.ts +0 -31
  264. package/src/queues/cli/commands/create.ts +0 -25
  265. package/src/queues/cli/commands/delete.ts +0 -26
  266. package/src/queues/cli/commands/index.ts +0 -35
  267. package/src/queues/cli/commands/list.ts +0 -25
  268. package/src/queues/client.ts +0 -136
  269. package/src/queues/utils.ts +0 -18
  270. package/src/r2/constants.ts +0 -4
  271. package/src/r2/helpers.ts +0 -132
  272. package/src/r2/index.ts +0 -289
  273. package/src/routes.ts +0 -140
  274. package/src/secret/index.ts +0 -377
  275. package/src/selfsigned.d.ts +0 -29
  276. package/src/sites.ts +0 -484
  277. package/src/tail/createTail.ts +0 -415
  278. package/src/tail/filters.ts +0 -277
  279. package/src/tail/index.ts +0 -211
  280. package/src/tail/printing.ts +0 -132
  281. package/src/traverse-module-graph.ts +0 -54
  282. package/src/tsconfig-sanity.ts +0 -16
  283. package/src/type-generation.ts +0 -181
  284. package/src/update-check.ts +0 -19
  285. package/src/user/access.ts +0 -68
  286. package/src/user/auth-variables.ts +0 -113
  287. package/src/user/choose-account.tsx +0 -39
  288. package/src/user/generate-auth-url.ts +0 -33
  289. package/src/user/generate-random-state.ts +0 -16
  290. package/src/user/index.ts +0 -2
  291. package/src/user/user.ts +0 -1234
  292. package/src/utils/collectKeyValues.ts +0 -14
  293. package/src/utils/render.ts +0 -93
  294. package/src/whoami.ts +0 -135
  295. package/src/worker.ts +0 -279
  296. package/src/yargs-types.ts +0 -37
  297. package/src/zones.ts +0 -191
@@ -1,625 +0,0 @@
1
- /**
2
- * The `Environment` interface declares all the configuration fields that
3
- * can be specified for an environment.
4
- *
5
- * This could be the top-level default environment, or a specific named environment.
6
- */
7
- export interface Environment
8
- extends EnvironmentInheritable,
9
- EnvironmentNonInheritable {}
10
-
11
- export type SimpleRoute = string;
12
- export type ZoneIdRoute = {
13
- pattern: string;
14
- zone_id: string;
15
- custom_domain?: boolean;
16
- };
17
- export type ZoneNameRoute = {
18
- pattern: string;
19
- zone_name: string;
20
- custom_domain?: boolean;
21
- };
22
- export type CustomDomainRoute = { pattern: string; custom_domain: boolean };
23
- export type Route =
24
- | SimpleRoute
25
- | ZoneIdRoute
26
- | ZoneNameRoute
27
- | CustomDomainRoute;
28
-
29
- /**
30
- * The `EnvironmentInheritable` interface declares all the configuration fields for an environment
31
- * that can be inherited (and overridden) from the top-level environment.
32
- */
33
- interface EnvironmentInheritable {
34
- /**
35
- * The name of your worker. Alphanumeric + dashes only.
36
- *
37
- * @inheritable
38
- */
39
- name: string | undefined;
40
-
41
- /**
42
- * This is the ID of the account associated with your zone.
43
- * You might have more than one account, so make sure to use
44
- * the ID of the account associated with the zone/route you
45
- * provide, if you provide one. It can also be specified through
46
- * the CLOUDFLARE_ACCOUNT_ID environment variable.
47
- *
48
- * @inheritable
49
- */
50
- account_id: string | undefined;
51
-
52
- /**
53
- * A date in the form yyyy-mm-dd, which will be used to determine
54
- * which version of the Workers runtime is used.
55
- *
56
- * More details at https://developers.cloudflare.com/workers/platform/compatibility-dates
57
- *
58
- * @inheritable
59
- */
60
- compatibility_date: string | undefined;
61
-
62
- /**
63
- * A list of flags that enable features from upcoming features of
64
- * the Workers runtime, usually used together with compatibility_flags.
65
- *
66
- * More details at https://developers.cloudflare.com/workers/platform/compatibility-dates
67
- *
68
- * @inheritable
69
- */
70
- compatibility_flags: string[];
71
-
72
- /**
73
- * The entrypoint/path to the JavaScript file that will be executed.
74
- */
75
- main: string | undefined;
76
-
77
- /**
78
- * The directory in which module rules should be evaluated in a `--no-bundle` worker
79
- * This defaults to dirname(main) when left undefined
80
- */
81
- base_dir: string | undefined;
82
-
83
- /**
84
- * Whether we use <name>.<subdomain>.workers.dev to
85
- * test and deploy your worker.
86
- *
87
- * @default `true` (This is a breaking change from Wrangler v1)
88
- * @breaking
89
- * @inheritable
90
- */
91
- workers_dev: boolean | undefined;
92
-
93
- /**
94
- * A list of routes that your worker should be published to.
95
- * Only one of `routes` or `route` is required.
96
- *
97
- * Only required when workers_dev is false, and there's no scheduled worker (see `triggers`)
98
- *
99
- * @inheritable
100
- */
101
- routes: Route[] | undefined;
102
-
103
- /**
104
- * A route that your worker should be published to. Literally
105
- * the same as routes, but only one.
106
- * Only one of `routes` or `route` is required.
107
- *
108
- * Only required when workers_dev is false, and there's no scheduled worker
109
- *
110
- * @inheritable
111
- */
112
- route: Route | undefined;
113
-
114
- /**
115
- * Path to a custom tsconfig
116
- */
117
- tsconfig: string | undefined;
118
-
119
- /**
120
- * The function to use to replace jsx syntax.
121
- *
122
- * @default `"React.createElement"`
123
- * @inheritable
124
- */
125
- jsx_factory: string;
126
-
127
- /**
128
- * The function to use to replace jsx fragment syntax.
129
- *
130
- * @default `"React.Fragment"`
131
- * @inheritable
132
- */
133
- jsx_fragment: string;
134
-
135
- /**
136
- * "Cron" definitions to trigger a worker's "scheduled" function.
137
- *
138
- * Lets you call workers periodically, much like a cron job.
139
- *
140
- * More details here https://developers.cloudflare.com/workers/platform/cron-triggers
141
- *
142
- * @default `{crons:[]}`
143
- * @inheritable
144
- */
145
- triggers: { crons: string[] };
146
-
147
- /**
148
- * Specifies the Usage Model for your Worker. There are two options -
149
- * [bundled](https://developers.cloudflare.com/workers/platform/limits#bundled-usage-model) and
150
- * [unbound](https://developers.cloudflare.com/workers/platform/limits#unbound-usage-model).
151
- * For newly created Workers, if the Usage Model is omitted
152
- * it will be set to the [default Usage Model set on the account](https://dash.cloudflare.com/?account=workers/default-usage-model).
153
- * For existing Workers, if the Usage Model is omitted, it will be
154
- * set to the Usage Model configured in the dashboard for that Worker.
155
- *
156
- * @inheritable
157
- */
158
- usage_model: "bundled" | "unbound" | undefined;
159
-
160
- /**
161
- * An ordered list of rules that define which modules to import,
162
- * and what type to import them as. You will need to specify rules
163
- * to use Text, Data, and CompiledWasm modules, or when you wish to
164
- * have a .js file be treated as an ESModule instead of CommonJS.
165
- *
166
- * @inheritable
167
- */
168
- rules: Rule[];
169
-
170
- /**
171
- * Configures a custom build step to be run by Wrangler when building your Worker.
172
- *
173
- * Refer to the [custom builds documentation](https://developers.cloudflare.com/workers/cli-wrangler/configuration#build)
174
- * for more details.
175
- *
176
- * @default {}
177
- */
178
- build: {
179
- /** The command used to build your Worker. On Linux and macOS, the command is executed in the `sh` shell and the `cmd` shell for Windows. The `&&` and `||` shell operators may be used. */
180
- command?: string;
181
- /** The directory in which the command is executed. */
182
- cwd?: string;
183
- /** The directory to watch for changes while using wrangler dev, defaults to the current working directory */
184
- watch_dir?: string | string[];
185
- /**
186
- * Deprecated field previously used to configure the build and upload of the script.
187
- * @deprecated
188
- */
189
- upload?: DeprecatedUpload;
190
- };
191
-
192
- /**
193
- * Skip internal build steps and directly publish script
194
- * @inheritable
195
- */
196
- no_bundle: boolean | undefined;
197
-
198
- /**
199
- * Minify the script before uploading.
200
- * @inheritable
201
- */
202
- minify: boolean | undefined;
203
-
204
- /**
205
- * Add polyfills for node builtin modules and globals
206
- * @inheritable
207
- */
208
- node_compat: boolean | undefined;
209
-
210
- /**
211
- * Specifies namespace bindings that are bound to this Worker environment.
212
- *
213
- * NOTE: This field is not automatically inherited from the top level environment,
214
- * and so must be specified in every named environment.
215
- *
216
- * @default `[]`
217
- * @nonInheritable
218
- */
219
- dispatch_namespaces: {
220
- /** The binding name used to refer to the bound service. */
221
- binding: string;
222
- /** The namespace to bind to. */
223
- namespace: string;
224
- }[];
225
-
226
- /**
227
- * Designates this worker as an internal-only "first-party" worker.
228
- */
229
- first_party_worker: boolean | undefined;
230
-
231
- /**
232
- * TODO: remove this as it has been deprecated.
233
- *
234
- * This is just here for now because the `route` commands use it.
235
- * So we need to include it in this type so it is available.
236
- */
237
- zone_id?: string;
238
-
239
- /**
240
- * Specify a compiled capnp schema to use
241
- * Then add a binding per field in the top level message that you will send to logfwdr
242
- *
243
- * @default `{schema:undefined,bindings:[]}`
244
- * @inheritable
245
- */
246
- logfwdr: {
247
- /** capnp schema filename */
248
- schema: string | undefined;
249
- bindings: {
250
- /** The binding name used to refer to logfwdr */
251
- name: string;
252
- /** The destination for this logged message */
253
- destination: string;
254
- }[];
255
- };
256
-
257
- /**
258
- * Send Trace Events from this worker to Workers Logpush.
259
- *
260
- * This will not configure a corresponding Logpush job automatically.
261
- *
262
- * For more information about Workers Logpush, see:
263
- * https://blog.cloudflare.com/logpush-for-workers/
264
- *
265
- * @inheritable
266
- */
267
- logpush: boolean | undefined;
268
-
269
- /**
270
- * Specify how the worker should be located to minimize round-trip time.
271
- *
272
- * More details: https://developers.cloudflare.com/workers/platform/smart-placement/
273
- */
274
- placement: { mode: "off" | "smart" } | undefined;
275
- }
276
-
277
- export type DurableObjectBindings = {
278
- /** The name of the binding used to refer to the Durable Object */
279
- name: string;
280
- /** The exported class name of the Durable Object */
281
- class_name: string;
282
- /** The script where the Durable Object is defined (if it's external to this worker) */
283
- script_name?: string;
284
- /** The service environment of the script_name to bind to */
285
- environment?: string;
286
- }[];
287
-
288
- /**
289
- * The `EnvironmentNonInheritable` interface declares all the configuration fields for an environment
290
- * that cannot be inherited from the top-level environment, and must be defined specifically.
291
- *
292
- * If any of these fields are defined at the top-level then they should also be specifically defined
293
- * for each named environment.
294
- */
295
- interface EnvironmentNonInheritable {
296
- /**
297
- * A map of values to substitute when deploying your worker.
298
- *
299
- * NOTE: This field is not automatically inherited from the top level environment,
300
- * and so must be specified in every named environment.
301
- *
302
- * @default `{}`
303
- * @nonInheritable
304
- */
305
- define: Record<string, string>;
306
- /**
307
- * A map of environment variables to set when deploying your worker.
308
- *
309
- * NOTE: This field is not automatically inherited from the top level environment,
310
- * and so must be specified in every named environment.
311
- *
312
- * @default `{}`
313
- * @nonInheritable
314
- */
315
- vars: { [key: string]: unknown };
316
-
317
- /**
318
- * A list of durable objects that your worker should be bound to.
319
- *
320
- * For more information about Durable Objects, see the documentation at
321
- * https://developers.cloudflare.com/workers/learning/using-durable-objects
322
- *
323
- * NOTE: This field is not automatically inherited from the top level environment,
324
- * and so must be specified in every named environment.
325
- *
326
- * @default `{bindings:[]}`
327
- * @nonInheritable
328
- */
329
- durable_objects: {
330
- bindings: DurableObjectBindings;
331
- };
332
-
333
- /**
334
- * These specify any Workers KV Namespaces you want to
335
- * access from inside your Worker.
336
- *
337
- * To learn more about KV Namespaces,
338
- * see the documentation at https://developers.cloudflare.com/workers/learning/how-kv-works
339
- *
340
- * NOTE: This field is not automatically inherited from the top level environment,
341
- * and so must be specified in every named environment.
342
- *
343
- * @default `[]`
344
- * @nonInheritable
345
- */
346
- kv_namespaces: {
347
- /** The binding name used to refer to the KV Namespace */
348
- binding: string;
349
- /** The ID of the KV namespace */
350
- id: string;
351
- /** The ID of the KV namespace used during `wrangler dev` */
352
- preview_id?: string;
353
- }[];
354
-
355
- /**
356
- * These specify bindings to send email from inside your Worker.
357
- *
358
- * NOTE: This field is not automatically inherited from the top level environment,
359
- * and so must be specified in every named environment.
360
- *
361
- * @default `[]`
362
- * @nonInheritable
363
- */
364
- send_email: {
365
- /** The binding name used to refer to the this binding */
366
- name: string;
367
- /** If this binding should be restricted to a specific verified address */
368
- destination_address?: string;
369
- /** If this binding should be restricted to a set of verified addresses */
370
- allowed_destination_addresses?: string[];
371
- }[];
372
-
373
- /**
374
- * Specifies Queues that are bound to this Worker environment.
375
- *
376
- * NOTE: This field is not automatically inherited from the top level environment,
377
- * and so must be specified in every named environment.
378
- *
379
- * @default `{}`
380
- * @nonInheritable
381
- */
382
- queues: {
383
- /** Producer bindings */
384
- producers?: {
385
- /** The binding name used to refer to the Queue in the worker. */
386
- binding: string;
387
-
388
- /** The name of this Queue. */
389
- queue: string;
390
- }[];
391
-
392
- /** Consumer configuration */
393
- consumers?: {
394
- /** The name of the queue from which this script should consume. */
395
- queue: string;
396
-
397
- /** The maximum number of messages per batch */
398
- max_batch_size?: number;
399
-
400
- /** The maximum number of seconds to wait to fill a batch with messages. */
401
- max_batch_timeout?: number;
402
-
403
- /** The maximum number of retries for each message. */
404
- max_retries?: number;
405
-
406
- /** The queue to send messages that failed to be consumed. */
407
- dead_letter_queue?: string;
408
-
409
- /** The maximum number of concurrent consumer Worker invocations. Leaving this unset will allow your consumer to scale to the maximum concurrency needed to keep up with the message backlog. */
410
- max_concurrency?: number | null;
411
- }[];
412
- };
413
-
414
- /**
415
- * Specifies R2 buckets that are bound to this Worker environment.
416
- *
417
- * NOTE: This field is not automatically inherited from the top level environment,
418
- * and so must be specified in every named environment.
419
- *
420
- * @default `[]`
421
- * @nonInheritable
422
- */
423
- r2_buckets: {
424
- /** The binding name used to refer to the R2 bucket in the worker. */
425
- binding: string;
426
- /** The name of this R2 bucket at the edge. */
427
- bucket_name: string;
428
- /** The preview name of this R2 bucket at the edge. */
429
- preview_bucket_name?: string;
430
- }[];
431
-
432
- /**
433
- * Specifies D1 databases that are bound to this Worker environment.
434
- *
435
- * NOTE: This field is not automatically inherited from the top level environment,
436
- * and so must be specified in every named environment.
437
- *
438
- * @default `[]`
439
- * @nonInheritable
440
- */
441
- d1_databases: {
442
- /** The binding name used to refer to the D1 database in the worker. */
443
- binding: string;
444
- /** The name of this D1 database. */
445
- database_name: string;
446
- /** The UUID of this D1 database (not required). */
447
- database_id: string;
448
- /** The UUID of this D1 database for Wrangler Dev (if specified). */
449
- preview_database_id?: string;
450
- /** The name of the migrations table for this D1 database (defaults to 'd1_migrations'). */
451
- migrations_table?: string;
452
- /** The path to the directory of migrations for this D1 database (defaults to './migrations'). */
453
- migrations_dir?: string;
454
- /** Internal use only. */
455
- database_internal_env?: string;
456
- }[];
457
-
458
- /**
459
- * Specifies service bindings (worker-to-worker) that are bound to this Worker environment.
460
- *
461
- * NOTE: This field is not automatically inherited from the top level environment,
462
- * and so must be specified in every named environment.
463
- *
464
- * @default `[]`
465
- * @nonInheritable
466
- */
467
- services:
468
- | {
469
- /** The binding name used to refer to the bound service. */
470
- binding: string;
471
- /** The name of the service. */
472
- service: string;
473
- /** The environment of the service (e.g. production, staging, etc). */
474
- environment?: string;
475
- }[]
476
- | undefined;
477
-
478
- /**
479
- * Specifies analytics engine datasets that are bound to this Worker environment.
480
- *
481
- * NOTE: This field is not automatically inherited from the top level environment,
482
- * and so must be specified in every named environment.
483
- *
484
- * @default `[]`
485
- * @nonInheritable
486
- */
487
- analytics_engine_datasets: {
488
- /** The binding name used to refer to the dataset in the worker. */
489
- binding: string;
490
- /** The name of this dataset to write to. */
491
- dataset?: string;
492
- }[];
493
-
494
- /**
495
- * "Unsafe" tables for features that aren't directly supported by wrangler.
496
- *
497
- * NOTE: This field is not automatically inherited from the top level environment,
498
- * and so must be specified in every named environment.
499
- *
500
- * @nonInheritable
501
- */
502
- unsafe: {
503
- /**
504
- * A set of bindings that should be put into a Worker's upload metadata without changes. These
505
- * can be used to implement bindings for features that haven't released and aren't supported
506
- * directly by wrangler or miniflare.
507
- */
508
- bindings?: {
509
- name: string;
510
- type: string;
511
- [key: string]: unknown;
512
- }[];
513
-
514
- /**
515
- * Arbitrary key/value pairs that will be included in the uploaded metadata. Values specified
516
- * here will always be applied to metadata last, so can add new or override existing fields.
517
- */
518
- metadata?: {
519
- [key: string]: string;
520
- };
521
- };
522
-
523
- mtls_certificates: {
524
- /** The binding name used to refer to the certificate in the worker */
525
- binding: string;
526
- /** The uuid of the uploaded mTLS certificate */
527
- certificate_id: string;
528
- }[];
529
- }
530
-
531
- /**
532
- * The environment configuration properties that have been deprecated.
533
- */
534
- interface EnvironmentDeprecated {
535
- /**
536
- * The zone ID of the zone you want to deploy to. You can find this
537
- * in your domain page on the dashboard.
538
- *
539
- * @deprecated This is unnecessary since we can deduce this from routes directly.
540
- */
541
- zone_id?: string;
542
-
543
- /**
544
- * Legacy way of defining KVNamespaces that is no longer supported.
545
- *
546
- * @deprecated DO NOT USE. This was a legacy bug from Wrangler v1, that we do not want to support.
547
- */
548
- "kv-namespaces"?: string;
549
-
550
- /**
551
- * A list of services that your worker should be bound to.
552
- *
553
- * @default `[]`
554
- * @deprecated DO NOT USE. We'd added this to test the new service binding system, but the proper way to test experimental features is to use `unsafe.bindings` configuration.
555
- */
556
- experimental_services?: {
557
- /** The binding name used to refer to the Service */
558
- name: string;
559
- /** The name of the Service being bound */
560
- service: string;
561
- /** The Service's environment */
562
- environment: string;
563
- }[];
564
- }
565
-
566
- /**
567
- * Deprecated upload configuration.
568
- */
569
- export interface DeprecatedUpload {
570
- /**
571
- * The format of the Worker script.
572
- *
573
- * @deprecated We infer the format automatically now.
574
- */
575
- format?: "modules" | "service-worker";
576
-
577
- /**
578
- * The directory you wish to upload your worker from,
579
- * relative to the wrangler.toml file.
580
- *
581
- * Defaults to the directory containing the wrangler.toml file.
582
- *
583
- * @deprecated
584
- */
585
- dir?: string;
586
-
587
- /**
588
- * The path to the Worker script, relative to `upload.dir`.
589
- *
590
- * @deprecated This will be replaced by a command line argument.
591
- */
592
- main?: string;
593
-
594
- /**
595
- * @deprecated This is now defined at the top level `rules` field.
596
- */
597
- rules?: Environment["rules"];
598
- }
599
-
600
- /**
601
- * The raw environment configuration that we read from the config file.
602
- *
603
- * All the properties are optional, and will be replaced with defaults in the configuration that
604
- * is used in the rest of the codebase.
605
- */
606
- export type RawEnvironment = Partial<Environment> & EnvironmentDeprecated;
607
-
608
- /**
609
- * A bundling resolver rule, defining the modules type for paths that match the specified globs.
610
- */
611
- export type Rule = {
612
- type: ConfigModuleRuleType;
613
- globs: string[];
614
- fallthrough?: boolean;
615
- };
616
-
617
- /**
618
- * The possible types for a `Rule`.
619
- */
620
- export type ConfigModuleRuleType =
621
- | "ESModule"
622
- | "CommonJS"
623
- | "CompiledWasm"
624
- | "Text"
625
- | "Data";