@nocobase/plugin-idp-oauth 2.1.0-alpha.17 → 2.1.0-alpha.18

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 (214) hide show
  1. package/build.config.ts +1 -1
  2. package/dist/externalVersion.js +4 -4
  3. package/dist/node_modules/light-my-request/package.json +1 -1
  4. package/dist/node_modules/undici/LICENSE +21 -0
  5. package/dist/node_modules/undici/README.md +741 -0
  6. package/dist/node_modules/undici/docs/docs/api/Agent.md +84 -0
  7. package/dist/node_modules/undici/docs/docs/api/BalancedPool.md +99 -0
  8. package/dist/node_modules/undici/docs/docs/api/CacheStorage.md +30 -0
  9. package/dist/node_modules/undici/docs/docs/api/CacheStore.md +164 -0
  10. package/dist/node_modules/undici/docs/docs/api/Client.md +285 -0
  11. package/dist/node_modules/undici/docs/docs/api/ClientStats.md +27 -0
  12. package/dist/node_modules/undici/docs/docs/api/Connector.md +115 -0
  13. package/dist/node_modules/undici/docs/docs/api/ContentType.md +57 -0
  14. package/dist/node_modules/undici/docs/docs/api/Cookies.md +101 -0
  15. package/dist/node_modules/undici/docs/docs/api/Debug.md +62 -0
  16. package/dist/node_modules/undici/docs/docs/api/DiagnosticsChannel.md +315 -0
  17. package/dist/node_modules/undici/docs/docs/api/Dispatcher.md +1392 -0
  18. package/dist/node_modules/undici/docs/docs/api/EnvHttpProxyAgent.md +159 -0
  19. package/dist/node_modules/undici/docs/docs/api/Errors.md +49 -0
  20. package/dist/node_modules/undici/docs/docs/api/EventSource.md +45 -0
  21. package/dist/node_modules/undici/docs/docs/api/Fetch.md +60 -0
  22. package/dist/node_modules/undici/docs/docs/api/GlobalInstallation.md +139 -0
  23. package/dist/node_modules/undici/docs/docs/api/H2CClient.md +263 -0
  24. package/dist/node_modules/undici/docs/docs/api/MockAgent.md +603 -0
  25. package/dist/node_modules/undici/docs/docs/api/MockCallHistory.md +197 -0
  26. package/dist/node_modules/undici/docs/docs/api/MockCallHistoryLog.md +43 -0
  27. package/dist/node_modules/undici/docs/docs/api/MockClient.md +81 -0
  28. package/dist/node_modules/undici/docs/docs/api/MockErrors.md +12 -0
  29. package/dist/node_modules/undici/docs/docs/api/MockPool.md +555 -0
  30. package/dist/node_modules/undici/docs/docs/api/Pool.md +84 -0
  31. package/dist/node_modules/undici/docs/docs/api/PoolStats.md +35 -0
  32. package/dist/node_modules/undici/docs/docs/api/ProxyAgent.md +229 -0
  33. package/dist/node_modules/undici/docs/docs/api/RedirectHandler.md +93 -0
  34. package/dist/node_modules/undici/docs/docs/api/RetryAgent.md +50 -0
  35. package/dist/node_modules/undici/docs/docs/api/RetryHandler.md +118 -0
  36. package/dist/node_modules/undici/docs/docs/api/RoundRobinPool.md +145 -0
  37. package/dist/node_modules/undici/docs/docs/api/SnapshotAgent.md +616 -0
  38. package/dist/node_modules/undici/docs/docs/api/Socks5ProxyAgent.md +274 -0
  39. package/dist/node_modules/undici/docs/docs/api/Util.md +25 -0
  40. package/dist/node_modules/undici/docs/docs/api/WebSocket.md +141 -0
  41. package/dist/node_modules/undici/docs/docs/api/api-lifecycle.md +91 -0
  42. package/dist/node_modules/undici/docs/docs/best-practices/client-certificate.md +64 -0
  43. package/dist/node_modules/undici/docs/docs/best-practices/crawling.md +58 -0
  44. package/dist/node_modules/undici/docs/docs/best-practices/mocking-request.md +190 -0
  45. package/dist/node_modules/undici/docs/docs/best-practices/proxy.md +127 -0
  46. package/dist/node_modules/undici/docs/docs/best-practices/undici-vs-builtin-fetch.md +224 -0
  47. package/dist/node_modules/undici/docs/docs/best-practices/writing-tests.md +63 -0
  48. package/dist/node_modules/undici/index-fetch.js +65 -0
  49. package/dist/node_modules/undici/index.d.ts +3 -0
  50. package/dist/node_modules/undici/index.js +234 -0
  51. package/dist/node_modules/undici/lib/api/abort-signal.js +59 -0
  52. package/dist/node_modules/undici/lib/api/api-connect.js +110 -0
  53. package/dist/node_modules/undici/lib/api/api-pipeline.js +252 -0
  54. package/dist/node_modules/undici/lib/api/api-request.js +214 -0
  55. package/dist/node_modules/undici/lib/api/api-stream.js +209 -0
  56. package/dist/node_modules/undici/lib/api/api-upgrade.js +111 -0
  57. package/dist/node_modules/undici/lib/api/index.js +7 -0
  58. package/dist/node_modules/undici/lib/api/readable.js +580 -0
  59. package/dist/node_modules/undici/lib/cache/memory-cache-store.js +234 -0
  60. package/dist/node_modules/undici/lib/cache/sqlite-cache-store.js +461 -0
  61. package/dist/node_modules/undici/lib/core/connect.js +137 -0
  62. package/dist/node_modules/undici/lib/core/constants.js +143 -0
  63. package/dist/node_modules/undici/lib/core/diagnostics.js +227 -0
  64. package/dist/node_modules/undici/lib/core/errors.js +477 -0
  65. package/dist/node_modules/undici/lib/core/request.js +438 -0
  66. package/dist/node_modules/undici/lib/core/socks5-client.js +407 -0
  67. package/dist/node_modules/undici/lib/core/socks5-utils.js +203 -0
  68. package/dist/node_modules/undici/lib/core/symbols.js +75 -0
  69. package/dist/node_modules/undici/lib/core/tree.js +160 -0
  70. package/dist/node_modules/undici/lib/core/util.js +992 -0
  71. package/dist/node_modules/undici/lib/dispatcher/agent.js +158 -0
  72. package/dist/node_modules/undici/lib/dispatcher/balanced-pool.js +219 -0
  73. package/dist/node_modules/undici/lib/dispatcher/client-h1.js +1610 -0
  74. package/dist/node_modules/undici/lib/dispatcher/client-h2.js +995 -0
  75. package/dist/node_modules/undici/lib/dispatcher/client.js +659 -0
  76. package/dist/node_modules/undici/lib/dispatcher/dispatcher-base.js +165 -0
  77. package/dist/node_modules/undici/lib/dispatcher/dispatcher.js +48 -0
  78. package/dist/node_modules/undici/lib/dispatcher/env-http-proxy-agent.js +146 -0
  79. package/dist/node_modules/undici/lib/dispatcher/fixed-queue.js +135 -0
  80. package/dist/node_modules/undici/lib/dispatcher/h2c-client.js +51 -0
  81. package/dist/node_modules/undici/lib/dispatcher/pool-base.js +214 -0
  82. package/dist/node_modules/undici/lib/dispatcher/pool.js +118 -0
  83. package/dist/node_modules/undici/lib/dispatcher/proxy-agent.js +318 -0
  84. package/dist/node_modules/undici/lib/dispatcher/retry-agent.js +35 -0
  85. package/dist/node_modules/undici/lib/dispatcher/round-robin-pool.js +137 -0
  86. package/dist/node_modules/undici/lib/dispatcher/socks5-proxy-agent.js +249 -0
  87. package/dist/node_modules/undici/lib/encoding/index.js +33 -0
  88. package/dist/node_modules/undici/lib/global.js +50 -0
  89. package/dist/node_modules/undici/lib/handler/cache-handler.js +578 -0
  90. package/dist/node_modules/undici/lib/handler/cache-revalidation-handler.js +124 -0
  91. package/dist/node_modules/undici/lib/handler/decorator-handler.js +67 -0
  92. package/dist/node_modules/undici/lib/handler/deduplication-handler.js +460 -0
  93. package/dist/node_modules/undici/lib/handler/redirect-handler.js +238 -0
  94. package/dist/node_modules/undici/lib/handler/retry-handler.js +394 -0
  95. package/dist/node_modules/undici/lib/handler/unwrap-handler.js +100 -0
  96. package/dist/node_modules/undici/lib/handler/wrap-handler.js +105 -0
  97. package/dist/node_modules/undici/lib/interceptor/cache.js +495 -0
  98. package/dist/node_modules/undici/lib/interceptor/decompress.js +259 -0
  99. package/dist/node_modules/undici/lib/interceptor/deduplicate.js +117 -0
  100. package/dist/node_modules/undici/lib/interceptor/dns.js +571 -0
  101. package/dist/node_modules/undici/lib/interceptor/dump.js +112 -0
  102. package/dist/node_modules/undici/lib/interceptor/redirect.js +21 -0
  103. package/dist/node_modules/undici/lib/interceptor/response-error.js +95 -0
  104. package/dist/node_modules/undici/lib/interceptor/retry.js +19 -0
  105. package/dist/node_modules/undici/lib/llhttp/.gitkeep +0 -0
  106. package/dist/node_modules/undici/lib/llhttp/constants.d.ts +195 -0
  107. package/dist/node_modules/undici/lib/llhttp/constants.js +531 -0
  108. package/dist/node_modules/undici/lib/llhttp/llhttp-wasm.js +15 -0
  109. package/dist/node_modules/undici/lib/llhttp/llhttp_simd-wasm.js +15 -0
  110. package/dist/node_modules/undici/lib/llhttp/utils.d.ts +2 -0
  111. package/dist/node_modules/undici/lib/llhttp/utils.js +12 -0
  112. package/dist/node_modules/undici/lib/mock/mock-agent.js +232 -0
  113. package/dist/node_modules/undici/lib/mock/mock-call-history.js +248 -0
  114. package/dist/node_modules/undici/lib/mock/mock-client.js +68 -0
  115. package/dist/node_modules/undici/lib/mock/mock-errors.js +29 -0
  116. package/dist/node_modules/undici/lib/mock/mock-interceptor.js +209 -0
  117. package/dist/node_modules/undici/lib/mock/mock-pool.js +68 -0
  118. package/dist/node_modules/undici/lib/mock/mock-symbols.js +32 -0
  119. package/dist/node_modules/undici/lib/mock/mock-utils.js +486 -0
  120. package/dist/node_modules/undici/lib/mock/pending-interceptors-formatter.js +43 -0
  121. package/dist/node_modules/undici/lib/mock/snapshot-agent.js +353 -0
  122. package/dist/node_modules/undici/lib/mock/snapshot-recorder.js +588 -0
  123. package/dist/node_modules/undici/lib/mock/snapshot-utils.js +158 -0
  124. package/dist/node_modules/undici/lib/util/cache.js +407 -0
  125. package/dist/node_modules/undici/lib/util/date.js +653 -0
  126. package/dist/node_modules/undici/lib/util/promise.js +28 -0
  127. package/dist/node_modules/undici/lib/util/runtime-features.js +124 -0
  128. package/dist/node_modules/undici/lib/util/stats.js +32 -0
  129. package/dist/node_modules/undici/lib/util/timers.js +425 -0
  130. package/dist/node_modules/undici/lib/web/cache/cache.js +864 -0
  131. package/dist/node_modules/undici/lib/web/cache/cachestorage.js +152 -0
  132. package/dist/node_modules/undici/lib/web/cache/util.js +45 -0
  133. package/dist/node_modules/undici/lib/web/cookies/constants.js +12 -0
  134. package/dist/node_modules/undici/lib/web/cookies/index.js +199 -0
  135. package/dist/node_modules/undici/lib/web/cookies/parse.js +322 -0
  136. package/dist/node_modules/undici/lib/web/cookies/util.js +282 -0
  137. package/dist/node_modules/undici/lib/web/eventsource/eventsource-stream.js +399 -0
  138. package/dist/node_modules/undici/lib/web/eventsource/eventsource.js +501 -0
  139. package/dist/node_modules/undici/lib/web/eventsource/util.js +29 -0
  140. package/dist/node_modules/undici/lib/web/fetch/LICENSE +21 -0
  141. package/dist/node_modules/undici/lib/web/fetch/body.js +509 -0
  142. package/dist/node_modules/undici/lib/web/fetch/constants.js +131 -0
  143. package/dist/node_modules/undici/lib/web/fetch/data-url.js +596 -0
  144. package/dist/node_modules/undici/lib/web/fetch/formdata-parser.js +575 -0
  145. package/dist/node_modules/undici/lib/web/fetch/formdata.js +259 -0
  146. package/dist/node_modules/undici/lib/web/fetch/global.js +40 -0
  147. package/dist/node_modules/undici/lib/web/fetch/headers.js +719 -0
  148. package/dist/node_modules/undici/lib/web/fetch/index.js +2397 -0
  149. package/dist/node_modules/undici/lib/web/fetch/request.js +1115 -0
  150. package/dist/node_modules/undici/lib/web/fetch/response.js +641 -0
  151. package/dist/node_modules/undici/lib/web/fetch/util.js +1520 -0
  152. package/dist/node_modules/undici/lib/web/infra/index.js +229 -0
  153. package/dist/node_modules/undici/lib/web/subresource-integrity/Readme.md +9 -0
  154. package/dist/node_modules/undici/lib/web/subresource-integrity/subresource-integrity.js +307 -0
  155. package/dist/node_modules/undici/lib/web/webidl/index.js +1006 -0
  156. package/dist/node_modules/undici/lib/web/websocket/connection.js +329 -0
  157. package/dist/node_modules/undici/lib/web/websocket/constants.js +126 -0
  158. package/dist/node_modules/undici/lib/web/websocket/events.js +331 -0
  159. package/dist/node_modules/undici/lib/web/websocket/frame.js +133 -0
  160. package/dist/node_modules/undici/lib/web/websocket/permessage-deflate.js +118 -0
  161. package/dist/node_modules/undici/lib/web/websocket/receiver.js +450 -0
  162. package/dist/node_modules/undici/lib/web/websocket/sender.js +109 -0
  163. package/dist/node_modules/undici/lib/web/websocket/stream/websocketerror.js +104 -0
  164. package/dist/node_modules/undici/lib/web/websocket/stream/websocketstream.js +497 -0
  165. package/dist/node_modules/undici/lib/web/websocket/util.js +347 -0
  166. package/dist/node_modules/undici/lib/web/websocket/websocket.js +751 -0
  167. package/dist/node_modules/undici/package.json +152 -0
  168. package/dist/node_modules/undici/scripts/strip-comments.js +10 -0
  169. package/dist/node_modules/undici/types/README.md +6 -0
  170. package/dist/node_modules/undici/types/agent.d.ts +32 -0
  171. package/dist/node_modules/undici/types/api.d.ts +43 -0
  172. package/dist/node_modules/undici/types/balanced-pool.d.ts +30 -0
  173. package/dist/node_modules/undici/types/cache-interceptor.d.ts +179 -0
  174. package/dist/node_modules/undici/types/cache.d.ts +36 -0
  175. package/dist/node_modules/undici/types/client-stats.d.ts +15 -0
  176. package/dist/node_modules/undici/types/client.d.ts +123 -0
  177. package/dist/node_modules/undici/types/connector.d.ts +36 -0
  178. package/dist/node_modules/undici/types/content-type.d.ts +21 -0
  179. package/dist/node_modules/undici/types/cookies.d.ts +30 -0
  180. package/dist/node_modules/undici/types/diagnostics-channel.d.ts +74 -0
  181. package/dist/node_modules/undici/types/dispatcher.d.ts +273 -0
  182. package/dist/node_modules/undici/types/env-http-proxy-agent.d.ts +22 -0
  183. package/dist/node_modules/undici/types/errors.d.ts +177 -0
  184. package/dist/node_modules/undici/types/eventsource.d.ts +66 -0
  185. package/dist/node_modules/undici/types/fetch.d.ts +231 -0
  186. package/dist/node_modules/undici/types/formdata.d.ts +114 -0
  187. package/dist/node_modules/undici/types/global-dispatcher.d.ts +9 -0
  188. package/dist/node_modules/undici/types/global-origin.d.ts +7 -0
  189. package/dist/node_modules/undici/types/h2c-client.d.ts +73 -0
  190. package/dist/node_modules/undici/types/handlers.d.ts +14 -0
  191. package/dist/node_modules/undici/types/header.d.ts +160 -0
  192. package/dist/node_modules/undici/types/index.d.ts +91 -0
  193. package/dist/node_modules/undici/types/interceptors.d.ts +80 -0
  194. package/dist/node_modules/undici/types/mock-agent.d.ts +68 -0
  195. package/dist/node_modules/undici/types/mock-call-history.d.ts +111 -0
  196. package/dist/node_modules/undici/types/mock-client.d.ts +27 -0
  197. package/dist/node_modules/undici/types/mock-errors.d.ts +12 -0
  198. package/dist/node_modules/undici/types/mock-interceptor.d.ts +94 -0
  199. package/dist/node_modules/undici/types/mock-pool.d.ts +27 -0
  200. package/dist/node_modules/undici/types/patch.d.ts +29 -0
  201. package/dist/node_modules/undici/types/pool-stats.d.ts +19 -0
  202. package/dist/node_modules/undici/types/pool.d.ts +41 -0
  203. package/dist/node_modules/undici/types/proxy-agent.d.ts +29 -0
  204. package/dist/node_modules/undici/types/readable.d.ts +68 -0
  205. package/dist/node_modules/undici/types/retry-agent.d.ts +8 -0
  206. package/dist/node_modules/undici/types/retry-handler.d.ts +125 -0
  207. package/dist/node_modules/undici/types/round-robin-pool.d.ts +41 -0
  208. package/dist/node_modules/undici/types/snapshot-agent.d.ts +109 -0
  209. package/dist/node_modules/undici/types/socks5-proxy-agent.d.ts +25 -0
  210. package/dist/node_modules/undici/types/util.d.ts +18 -0
  211. package/dist/node_modules/undici/types/utility.d.ts +7 -0
  212. package/dist/node_modules/undici/types/webidl.d.ts +347 -0
  213. package/dist/node_modules/undici/types/websocket.d.ts +188 -0
  214. package/package.json +2 -2
@@ -0,0 +1,641 @@
1
+ 'use strict'
2
+
3
+ const { Headers, HeadersList, fill, getHeadersGuard, setHeadersGuard, setHeadersList } = require('./headers')
4
+ const { extractBody, cloneBody, mixinBody, streamRegistry, bodyUnusable } = require('./body')
5
+ const util = require('../../core/util')
6
+ const nodeUtil = require('node:util')
7
+ const { kEnumerableProperty } = util
8
+ const {
9
+ isValidReasonPhrase,
10
+ isCancelled,
11
+ isAborted,
12
+ isErrorLike,
13
+ environmentSettingsObject: relevantRealm
14
+ } = require('./util')
15
+ const {
16
+ redirectStatusSet,
17
+ nullBodyStatus
18
+ } = require('./constants')
19
+ const { webidl } = require('../webidl')
20
+ const { URLSerializer } = require('./data-url')
21
+ const { kConstruct } = require('../../core/symbols')
22
+ const assert = require('node:assert')
23
+ const { isomorphicEncode, serializeJavascriptValueToJSONString } = require('../infra')
24
+
25
+ const textEncoder = new TextEncoder('utf-8')
26
+
27
+ // https://fetch.spec.whatwg.org/#response-class
28
+ class Response {
29
+ /** @type {Headers} */
30
+ #headers
31
+
32
+ #state
33
+
34
+ // Creates network error Response.
35
+ static error () {
36
+ // The static error() method steps are to return the result of creating a
37
+ // Response object, given a new network error, "immutable", and this’s
38
+ // relevant Realm.
39
+ const responseObject = fromInnerResponse(makeNetworkError(), 'immutable')
40
+
41
+ return responseObject
42
+ }
43
+
44
+ // https://fetch.spec.whatwg.org/#dom-response-json
45
+ static json (data, init = undefined) {
46
+ webidl.argumentLengthCheck(arguments, 1, 'Response.json')
47
+
48
+ if (init !== null) {
49
+ init = webidl.converters.ResponseInit(init)
50
+ }
51
+
52
+ // 1. Let bytes the result of running serialize a JavaScript value to JSON bytes on data.
53
+ const bytes = textEncoder.encode(
54
+ serializeJavascriptValueToJSONString(data)
55
+ )
56
+
57
+ // 2. Let body be the result of extracting bytes.
58
+ const body = extractBody(bytes)
59
+
60
+ // 3. Let responseObject be the result of creating a Response object, given a new response,
61
+ // "response", and this’s relevant Realm.
62
+ const responseObject = fromInnerResponse(makeResponse({}), 'response')
63
+
64
+ // 4. Perform initialize a response given responseObject, init, and (body, "application/json").
65
+ initializeResponse(responseObject, init, { body: body[0], type: 'application/json' })
66
+
67
+ // 5. Return responseObject.
68
+ return responseObject
69
+ }
70
+
71
+ // Creates a redirect Response that redirects to url with status status.
72
+ static redirect (url, status = 302) {
73
+ webidl.argumentLengthCheck(arguments, 1, 'Response.redirect')
74
+
75
+ url = webidl.converters.USVString(url)
76
+ status = webidl.converters['unsigned short'](status)
77
+
78
+ // 1. Let parsedURL be the result of parsing url with current settings
79
+ // object’s API base URL.
80
+ // 2. If parsedURL is failure, then throw a TypeError.
81
+ // TODO: base-URL?
82
+ let parsedURL
83
+ try {
84
+ parsedURL = new URL(url, relevantRealm.settingsObject.baseUrl)
85
+ } catch (err) {
86
+ throw new TypeError(`Failed to parse URL from ${url}`, { cause: err })
87
+ }
88
+
89
+ // 3. If status is not a redirect status, then throw a RangeError.
90
+ if (!redirectStatusSet.has(status)) {
91
+ throw new RangeError(`Invalid status code ${status}`)
92
+ }
93
+
94
+ // 4. Let responseObject be the result of creating a Response object,
95
+ // given a new response, "immutable", and this’s relevant Realm.
96
+ const responseObject = fromInnerResponse(makeResponse({}), 'immutable')
97
+
98
+ // 5. Set responseObject’s response’s status to status.
99
+ responseObject.#state.status = status
100
+
101
+ // 6. Let value be parsedURL, serialized and isomorphic encoded.
102
+ const value = isomorphicEncode(URLSerializer(parsedURL))
103
+
104
+ // 7. Append `Location`/value to responseObject’s response’s header list.
105
+ responseObject.#state.headersList.append('location', value, true)
106
+
107
+ // 8. Return responseObject.
108
+ return responseObject
109
+ }
110
+
111
+ // https://fetch.spec.whatwg.org/#dom-response
112
+ constructor (body = null, init = undefined) {
113
+ webidl.util.markAsUncloneable(this)
114
+
115
+ if (body === kConstruct) {
116
+ return
117
+ }
118
+
119
+ if (body !== null) {
120
+ body = webidl.converters.BodyInit(body, 'Response', 'body')
121
+ }
122
+
123
+ init = webidl.converters.ResponseInit(init)
124
+
125
+ // 1. Set this’s response to a new response.
126
+ this.#state = makeResponse({})
127
+
128
+ // 2. Set this’s headers to a new Headers object with this’s relevant
129
+ // Realm, whose header list is this’s response’s header list and guard
130
+ // is "response".
131
+ this.#headers = new Headers(kConstruct)
132
+ setHeadersGuard(this.#headers, 'response')
133
+ setHeadersList(this.#headers, this.#state.headersList)
134
+
135
+ // 3. Let bodyWithType be null.
136
+ let bodyWithType = null
137
+
138
+ // 4. If body is non-null, then set bodyWithType to the result of extracting body.
139
+ if (body != null) {
140
+ const [extractedBody, type] = extractBody(body)
141
+ bodyWithType = { body: extractedBody, type }
142
+ }
143
+
144
+ // 5. Perform initialize a response given this, init, and bodyWithType.
145
+ initializeResponse(this, init, bodyWithType)
146
+ }
147
+
148
+ // Returns response’s type, e.g., "cors".
149
+ get type () {
150
+ webidl.brandCheck(this, Response)
151
+
152
+ // The type getter steps are to return this’s response’s type.
153
+ return this.#state.type
154
+ }
155
+
156
+ // Returns response’s URL, if it has one; otherwise the empty string.
157
+ get url () {
158
+ webidl.brandCheck(this, Response)
159
+
160
+ const urlList = this.#state.urlList
161
+
162
+ // The url getter steps are to return the empty string if this’s
163
+ // response’s URL is null; otherwise this’s response’s URL,
164
+ // serialized with exclude fragment set to true.
165
+ const url = urlList[urlList.length - 1] ?? null
166
+
167
+ if (url === null) {
168
+ return ''
169
+ }
170
+
171
+ return URLSerializer(url, true)
172
+ }
173
+
174
+ // Returns whether response was obtained through a redirect.
175
+ get redirected () {
176
+ webidl.brandCheck(this, Response)
177
+
178
+ // The redirected getter steps are to return true if this’s response’s URL
179
+ // list has more than one item; otherwise false.
180
+ return this.#state.urlList.length > 1
181
+ }
182
+
183
+ // Returns response’s status.
184
+ get status () {
185
+ webidl.brandCheck(this, Response)
186
+
187
+ // The status getter steps are to return this’s response’s status.
188
+ return this.#state.status
189
+ }
190
+
191
+ // Returns whether response’s status is an ok status.
192
+ get ok () {
193
+ webidl.brandCheck(this, Response)
194
+
195
+ // The ok getter steps are to return true if this’s response’s status is an
196
+ // ok status; otherwise false.
197
+ return this.#state.status >= 200 && this.#state.status <= 299
198
+ }
199
+
200
+ // Returns response’s status message.
201
+ get statusText () {
202
+ webidl.brandCheck(this, Response)
203
+
204
+ // The statusText getter steps are to return this’s response’s status
205
+ // message.
206
+ return this.#state.statusText
207
+ }
208
+
209
+ // Returns response’s headers as Headers.
210
+ get headers () {
211
+ webidl.brandCheck(this, Response)
212
+
213
+ // The headers getter steps are to return this’s headers.
214
+ return this.#headers
215
+ }
216
+
217
+ get body () {
218
+ webidl.brandCheck(this, Response)
219
+
220
+ return this.#state.body ? this.#state.body.stream : null
221
+ }
222
+
223
+ get bodyUsed () {
224
+ webidl.brandCheck(this, Response)
225
+
226
+ return !!this.#state.body && util.isDisturbed(this.#state.body.stream)
227
+ }
228
+
229
+ // Returns a clone of response.
230
+ clone () {
231
+ webidl.brandCheck(this, Response)
232
+
233
+ // 1. If this is unusable, then throw a TypeError.
234
+ if (bodyUnusable(this.#state)) {
235
+ throw webidl.errors.exception({
236
+ header: 'Response.clone',
237
+ message: 'Body has already been consumed.'
238
+ })
239
+ }
240
+
241
+ // 2. Let clonedResponse be the result of cloning this’s response.
242
+ const clonedResponse = cloneResponse(this.#state)
243
+
244
+ // Note: To re-register because of a new stream.
245
+ // Don't set finalizers other than for fetch responses.
246
+ if (this.#state.urlList.length !== 0 && this.#state.body?.stream) {
247
+ streamRegistry.register(this, new WeakRef(this.#state.body.stream))
248
+ }
249
+
250
+ // 3. Return the result of creating a Response object, given
251
+ // clonedResponse, this’s headers’s guard, and this’s relevant Realm.
252
+ return fromInnerResponse(clonedResponse, getHeadersGuard(this.#headers))
253
+ }
254
+
255
+ [nodeUtil.inspect.custom] (depth, options) {
256
+ if (options.depth === null) {
257
+ options.depth = 2
258
+ }
259
+
260
+ options.colors ??= true
261
+
262
+ const properties = {
263
+ status: this.status,
264
+ statusText: this.statusText,
265
+ headers: this.headers,
266
+ body: this.body,
267
+ bodyUsed: this.bodyUsed,
268
+ ok: this.ok,
269
+ redirected: this.redirected,
270
+ type: this.type,
271
+ url: this.url
272
+ }
273
+
274
+ return `Response ${nodeUtil.formatWithOptions(options, properties)}`
275
+ }
276
+
277
+ /**
278
+ * @param {Response} response
279
+ */
280
+ static getResponseHeaders (response) {
281
+ return response.#headers
282
+ }
283
+
284
+ /**
285
+ * @param {Response} response
286
+ * @param {Headers} newHeaders
287
+ */
288
+ static setResponseHeaders (response, newHeaders) {
289
+ response.#headers = newHeaders
290
+ }
291
+
292
+ /**
293
+ * @param {Response} response
294
+ */
295
+ static getResponseState (response) {
296
+ return response.#state
297
+ }
298
+
299
+ /**
300
+ * @param {Response} response
301
+ * @param {any} newState
302
+ */
303
+ static setResponseState (response, newState) {
304
+ response.#state = newState
305
+ }
306
+ }
307
+
308
+ const { getResponseHeaders, setResponseHeaders, getResponseState, setResponseState } = Response
309
+ Reflect.deleteProperty(Response, 'getResponseHeaders')
310
+ Reflect.deleteProperty(Response, 'setResponseHeaders')
311
+ Reflect.deleteProperty(Response, 'getResponseState')
312
+ Reflect.deleteProperty(Response, 'setResponseState')
313
+
314
+ mixinBody(Response, getResponseState)
315
+
316
+ Object.defineProperties(Response.prototype, {
317
+ type: kEnumerableProperty,
318
+ url: kEnumerableProperty,
319
+ status: kEnumerableProperty,
320
+ ok: kEnumerableProperty,
321
+ redirected: kEnumerableProperty,
322
+ statusText: kEnumerableProperty,
323
+ headers: kEnumerableProperty,
324
+ clone: kEnumerableProperty,
325
+ body: kEnumerableProperty,
326
+ bodyUsed: kEnumerableProperty,
327
+ [Symbol.toStringTag]: {
328
+ value: 'Response',
329
+ configurable: true
330
+ }
331
+ })
332
+
333
+ Object.defineProperties(Response, {
334
+ json: kEnumerableProperty,
335
+ redirect: kEnumerableProperty,
336
+ error: kEnumerableProperty
337
+ })
338
+
339
+ // https://fetch.spec.whatwg.org/#concept-response-clone
340
+ function cloneResponse (response) {
341
+ // To clone a response response, run these steps:
342
+
343
+ // 1. If response is a filtered response, then return a new identical
344
+ // filtered response whose internal response is a clone of response’s
345
+ // internal response.
346
+ if (response.internalResponse) {
347
+ return filterResponse(
348
+ cloneResponse(response.internalResponse),
349
+ response.type
350
+ )
351
+ }
352
+
353
+ // 2. Let newResponse be a copy of response, except for its body.
354
+ const newResponse = makeResponse({ ...response, body: null })
355
+
356
+ // 3. If response’s body is non-null, then set newResponse’s body to the
357
+ // result of cloning response’s body.
358
+ if (response.body != null) {
359
+ newResponse.body = cloneBody(response.body)
360
+ }
361
+
362
+ // 4. Return newResponse.
363
+ return newResponse
364
+ }
365
+
366
+ function makeResponse (init) {
367
+ return {
368
+ aborted: false,
369
+ rangeRequested: false,
370
+ timingAllowPassed: false,
371
+ requestIncludesCredentials: false,
372
+ type: 'default',
373
+ status: 200,
374
+ timingInfo: null,
375
+ cacheState: '',
376
+ statusText: '',
377
+ ...init,
378
+ headersList: init?.headersList
379
+ ? new HeadersList(init?.headersList)
380
+ : new HeadersList(),
381
+ urlList: init?.urlList ? [...init.urlList] : []
382
+ }
383
+ }
384
+
385
+ function makeNetworkError (reason) {
386
+ const isError = isErrorLike(reason)
387
+ return makeResponse({
388
+ type: 'error',
389
+ status: 0,
390
+ error: isError
391
+ ? reason
392
+ : new Error(reason ? String(reason) : reason),
393
+ aborted: reason && reason.name === 'AbortError'
394
+ })
395
+ }
396
+
397
+ // @see https://fetch.spec.whatwg.org/#concept-network-error
398
+ function isNetworkError (response) {
399
+ return (
400
+ // A network error is a response whose type is "error",
401
+ response.type === 'error' &&
402
+ // status is 0
403
+ response.status === 0
404
+ )
405
+ }
406
+
407
+ function makeFilteredResponse (response, state) {
408
+ state = {
409
+ internalResponse: response,
410
+ ...state
411
+ }
412
+
413
+ return new Proxy(response, {
414
+ get (target, p) {
415
+ return p in state ? state[p] : target[p]
416
+ },
417
+ set (target, p, value) {
418
+ assert(!(p in state))
419
+ target[p] = value
420
+ return true
421
+ }
422
+ })
423
+ }
424
+
425
+ // https://fetch.spec.whatwg.org/#concept-filtered-response
426
+ function filterResponse (response, type) {
427
+ // Set response to the following filtered response with response as its
428
+ // internal response, depending on request’s response tainting:
429
+ if (type === 'basic') {
430
+ // A basic filtered response is a filtered response whose type is "basic"
431
+ // and header list excludes any headers in internal response’s header list
432
+ // whose name is a forbidden response-header name.
433
+
434
+ // Note: undici does not implement forbidden response-header names
435
+ return makeFilteredResponse(response, {
436
+ type: 'basic',
437
+ headersList: response.headersList
438
+ })
439
+ } else if (type === 'cors') {
440
+ // A CORS filtered response is a filtered response whose type is "cors"
441
+ // and header list excludes any headers in internal response’s header
442
+ // list whose name is not a CORS-safelisted response-header name, given
443
+ // internal response’s CORS-exposed header-name list.
444
+
445
+ // Note: undici does not implement CORS-safelisted response-header names
446
+ return makeFilteredResponse(response, {
447
+ type: 'cors',
448
+ headersList: response.headersList
449
+ })
450
+ } else if (type === 'opaque') {
451
+ // An opaque filtered response is a filtered response whose type is
452
+ // "opaque", URL list is the empty list, status is 0, status message
453
+ // is the empty byte sequence, header list is empty, and body is null.
454
+
455
+ return makeFilteredResponse(response, {
456
+ type: 'opaque',
457
+ urlList: [],
458
+ status: 0,
459
+ statusText: '',
460
+ body: null
461
+ })
462
+ } else if (type === 'opaqueredirect') {
463
+ // An opaque-redirect filtered response is a filtered response whose type
464
+ // is "opaqueredirect", status is 0, status message is the empty byte
465
+ // sequence, header list is empty, and body is null.
466
+
467
+ return makeFilteredResponse(response, {
468
+ type: 'opaqueredirect',
469
+ status: 0,
470
+ statusText: '',
471
+ headersList: [],
472
+ body: null
473
+ })
474
+ } else {
475
+ assert(false)
476
+ }
477
+ }
478
+
479
+ // https://fetch.spec.whatwg.org/#appropriate-network-error
480
+ function makeAppropriateNetworkError (fetchParams, err = null) {
481
+ // 1. Assert: fetchParams is canceled.
482
+ assert(isCancelled(fetchParams))
483
+
484
+ // 2. Return an aborted network error if fetchParams is aborted;
485
+ // otherwise return a network error.
486
+ return isAborted(fetchParams)
487
+ ? makeNetworkError(Object.assign(new DOMException('The operation was aborted.', 'AbortError'), { cause: err }))
488
+ : makeNetworkError(Object.assign(new DOMException('Request was cancelled.'), { cause: err }))
489
+ }
490
+
491
+ // https://whatpr.org/fetch/1392.html#initialize-a-response
492
+ function initializeResponse (response, init, body) {
493
+ // 1. If init["status"] is not in the range 200 to 599, inclusive, then
494
+ // throw a RangeError.
495
+ if (init.status !== null && (init.status < 200 || init.status > 599)) {
496
+ throw new RangeError('init["status"] must be in the range of 200 to 599, inclusive.')
497
+ }
498
+
499
+ // 2. If init["statusText"] does not match the reason-phrase token production,
500
+ // then throw a TypeError.
501
+ if ('statusText' in init && init.statusText != null) {
502
+ // See, https://datatracker.ietf.org/doc/html/rfc7230#section-3.1.2:
503
+ // reason-phrase = *( HTAB / SP / VCHAR / obs-text )
504
+ if (!isValidReasonPhrase(String(init.statusText))) {
505
+ throw new TypeError('Invalid statusText')
506
+ }
507
+ }
508
+
509
+ // 3. Set response’s response’s status to init["status"].
510
+ if ('status' in init && init.status != null) {
511
+ getResponseState(response).status = init.status
512
+ }
513
+
514
+ // 4. Set response’s response’s status message to init["statusText"].
515
+ if ('statusText' in init && init.statusText != null) {
516
+ getResponseState(response).statusText = init.statusText
517
+ }
518
+
519
+ // 5. If init["headers"] exists, then fill response’s headers with init["headers"].
520
+ if ('headers' in init && init.headers != null) {
521
+ fill(getResponseHeaders(response), init.headers)
522
+ }
523
+
524
+ // 6. If body was given, then:
525
+ if (body) {
526
+ // 1. If response's status is a null body status, then throw a TypeError.
527
+ if (nullBodyStatus.includes(response.status)) {
528
+ throw webidl.errors.exception({
529
+ header: 'Response constructor',
530
+ message: `Invalid response status code ${response.status}`
531
+ })
532
+ }
533
+
534
+ // 2. Set response's body to body's body.
535
+ getResponseState(response).body = body.body
536
+
537
+ // 3. If body's type is non-null and response's header list does not contain
538
+ // `Content-Type`, then append (`Content-Type`, body's type) to response's header list.
539
+ if (body.type != null && !getResponseState(response).headersList.contains('content-type', true)) {
540
+ getResponseState(response).headersList.append('content-type', body.type, true)
541
+ }
542
+ }
543
+ }
544
+
545
+ /**
546
+ * @see https://fetch.spec.whatwg.org/#response-create
547
+ * @param {any} innerResponse
548
+ * @param {'request' | 'immutable' | 'request-no-cors' | 'response' | 'none'} guard
549
+ * @returns {Response}
550
+ */
551
+ function fromInnerResponse (innerResponse, guard) {
552
+ const response = new Response(kConstruct)
553
+ setResponseState(response, innerResponse)
554
+ const headers = new Headers(kConstruct)
555
+ setResponseHeaders(response, headers)
556
+ setHeadersList(headers, innerResponse.headersList)
557
+ setHeadersGuard(headers, guard)
558
+
559
+ // Note: If innerResponse's urlList contains a URL, it is a fetch response.
560
+ if (innerResponse.urlList.length !== 0 && innerResponse.body?.stream) {
561
+ // If the target (response) is reclaimed, the cleanup callback may be called at some point with
562
+ // the held value provided for it (innerResponse.body.stream). The held value can be any value:
563
+ // a primitive or an object, even undefined. If the held value is an object, the registry keeps
564
+ // a strong reference to it (so it can pass it to the cleanup callback later). Reworded from
565
+ // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/FinalizationRegistry
566
+ streamRegistry.register(response, new WeakRef(innerResponse.body.stream))
567
+ }
568
+
569
+ return response
570
+ }
571
+
572
+ // https://fetch.spec.whatwg.org/#typedefdef-xmlhttprequestbodyinit
573
+ webidl.converters.XMLHttpRequestBodyInit = function (V, prefix, name) {
574
+ if (typeof V === 'string') {
575
+ return webidl.converters.USVString(V, prefix, name)
576
+ }
577
+
578
+ if (webidl.is.Blob(V)) {
579
+ return V
580
+ }
581
+
582
+ if (webidl.is.BufferSource(V)) {
583
+ return V
584
+ }
585
+
586
+ if (webidl.is.FormData(V)) {
587
+ return V
588
+ }
589
+
590
+ if (webidl.is.URLSearchParams(V)) {
591
+ return V
592
+ }
593
+
594
+ return webidl.converters.DOMString(V, prefix, name)
595
+ }
596
+
597
+ // https://fetch.spec.whatwg.org/#bodyinit
598
+ webidl.converters.BodyInit = function (V, prefix, argument) {
599
+ if (webidl.is.ReadableStream(V)) {
600
+ return V
601
+ }
602
+
603
+ // Note: the spec doesn't include async iterables,
604
+ // this is an undici extension.
605
+ if (V?.[Symbol.asyncIterator]) {
606
+ return V
607
+ }
608
+
609
+ return webidl.converters.XMLHttpRequestBodyInit(V, prefix, argument)
610
+ }
611
+
612
+ webidl.converters.ResponseInit = webidl.dictionaryConverter([
613
+ {
614
+ key: 'status',
615
+ converter: webidl.converters['unsigned short'],
616
+ defaultValue: () => 200
617
+ },
618
+ {
619
+ key: 'statusText',
620
+ converter: webidl.converters.ByteString,
621
+ defaultValue: () => ''
622
+ },
623
+ {
624
+ key: 'headers',
625
+ converter: webidl.converters.HeadersInit
626
+ }
627
+ ])
628
+
629
+ webidl.is.Response = webidl.util.MakeTypeAssertion(Response)
630
+
631
+ module.exports = {
632
+ isNetworkError,
633
+ makeNetworkError,
634
+ makeResponse,
635
+ makeAppropriateNetworkError,
636
+ filterResponse,
637
+ Response,
638
+ cloneResponse,
639
+ fromInnerResponse,
640
+ getResponseState
641
+ }