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

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 (221) hide show
  1. package/build.config.ts +1 -1
  2. package/dist/externalVersion.js +6 -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/dist/server/collections/oidcStates.d.ts +10 -0
  215. package/dist/server/collections/oidcStates.js +96 -0
  216. package/dist/server/db-adapter.d.ts +25 -0
  217. package/dist/server/db-adapter.js +156 -0
  218. package/dist/server/service.js +11 -10
  219. package/package.json +2 -2
  220. package/dist/server/cache-adapter.d.ts +0 -33
  221. package/dist/server/cache-adapter.js +0 -159
@@ -0,0 +1,229 @@
1
+ # Class: ProxyAgent
2
+
3
+ Extends: `undici.Dispatcher`
4
+
5
+ A Proxy Agent class that implements the Agent API. It allows the connection through proxy in a simple way.
6
+
7
+ ## `new ProxyAgent([options])`
8
+
9
+ Arguments:
10
+
11
+ * **options** `ProxyAgentOptions` (required) - It extends the `Agent` options.
12
+
13
+ Returns: `ProxyAgent`
14
+
15
+ ### Parameter: `ProxyAgentOptions`
16
+
17
+ Extends: [`AgentOptions`](/docs/docs/api/Agent.md#parameter-agentoptions)
18
+ > It ommits `AgentOptions#connect`.
19
+
20
+ > **Note:** When `AgentOptions#connections` is set, and different from `0`, the non-standard [`proxy-connection` header](https://udger.com/resources/http-request-headers-detail?header=Proxy-Connection) will be set to `keep-alive` in the request.
21
+
22
+ * **uri** `string | URL` (required) - The URI of the proxy server. This can be provided as a string, as an instance of the URL class, or as an object with a `uri` property of type string.
23
+ If the `uri` is provided as a string or `uri` is an object with an `uri` property of type string, then it will be parsed into a `URL` object according to the [WHATWG URL Specification](https://url.spec.whatwg.org).
24
+ For detailed information on the parsing process and potential validation errors, please refer to the ["Writing" section](https://url.spec.whatwg.org/#writing) of the WHATWG URL Specification.
25
+ * **token** `string` (optional) - It can be passed by a string of token for authentication.
26
+ * **auth** `string` (**deprecated**) - Use token.
27
+ * **clientFactory** `(origin: URL, opts: Object) => Dispatcher` (optional) - Default: `(origin, opts) => new Pool(origin, opts)`
28
+ * **requestTls** `BuildOptions` (optional) - Options object passed when creating the underlying socket via the connector builder for the request. It extends from [`Client#ConnectOptions`](/docs/docs/api/Client.md#parameter-connectoptions).
29
+ * **proxyTls** `BuildOptions` (optional) - Options object passed when creating the underlying socket via the connector builder for the proxy server. It extends from [`Client#ConnectOptions`](/docs/docs/api/Client.md#parameter-connectoptions).
30
+ * **proxyTunnel** `boolean` (optional) - For connections involving secure protocols, Undici will always establish a tunnel via the HTTP2 CONNECT extension. If proxyTunnel is set to true, this will occur for unsecured proxy/endpoint connections as well. Currently, there is no way to facilitate HTTP1 IP tunneling as described in https://www.rfc-editor.org/rfc/rfc9484.html#name-http-11-request. If proxyTunnel is set to false (the default), ProxyAgent connections where both the Proxy and Endpoint are unsecured will issue all requests to the Proxy, and prefix the endpoint request path with the endpoint origin address.
31
+
32
+ Examples:
33
+
34
+ ```js
35
+ import { ProxyAgent } from 'undici'
36
+
37
+ const proxyAgent = new ProxyAgent('my.proxy.server')
38
+ // or
39
+ const proxyAgent = new ProxyAgent(new URL('my.proxy.server'))
40
+ // or
41
+ const proxyAgent = new ProxyAgent({ uri: 'my.proxy.server' })
42
+ // or
43
+ const proxyAgent = new ProxyAgent({
44
+ uri: new URL('my.proxy.server'),
45
+ proxyTls: {
46
+ signal: AbortSignal.timeout(1000)
47
+ }
48
+ })
49
+ ```
50
+
51
+ #### Example - Basic ProxyAgent instantiation
52
+
53
+ This will instantiate the ProxyAgent. It will not do anything until registered as the agent to use with requests.
54
+
55
+ ```js
56
+ import { ProxyAgent } from 'undici'
57
+
58
+ const proxyAgent = new ProxyAgent('my.proxy.server')
59
+ ```
60
+
61
+ #### Example - Basic Proxy Request with global agent dispatcher
62
+
63
+ ```js
64
+ import { setGlobalDispatcher, request, ProxyAgent } from 'undici'
65
+
66
+ const proxyAgent = new ProxyAgent('my.proxy.server')
67
+ setGlobalDispatcher(proxyAgent)
68
+
69
+ const { statusCode, body } = await request('http://localhost:3000/foo')
70
+
71
+ console.log('response received', statusCode) // response received 200
72
+
73
+ for await (const data of body) {
74
+ console.log('data', data.toString('utf8')) // data foo
75
+ }
76
+ ```
77
+
78
+ #### Example - Basic Proxy Request with local agent dispatcher
79
+
80
+ ```js
81
+ import { ProxyAgent, request } from 'undici'
82
+
83
+ const proxyAgent = new ProxyAgent('my.proxy.server')
84
+
85
+ const {
86
+ statusCode,
87
+ body
88
+ } = await request('http://localhost:3000/foo', { dispatcher: proxyAgent })
89
+
90
+ console.log('response received', statusCode) // response received 200
91
+
92
+ for await (const data of body) {
93
+ console.log('data', data.toString('utf8')) // data foo
94
+ }
95
+ ```
96
+
97
+ #### Example - Basic Proxy Request with authentication
98
+
99
+ ```js
100
+ import { setGlobalDispatcher, request, ProxyAgent } from 'undici';
101
+
102
+ const proxyAgent = new ProxyAgent({
103
+ uri: 'my.proxy.server',
104
+ // token: 'Bearer xxxx'
105
+ token: `Basic ${Buffer.from('username:password').toString('base64')}`
106
+ });
107
+ setGlobalDispatcher(proxyAgent);
108
+
109
+ const { statusCode, body } = await request('http://localhost:3000/foo');
110
+
111
+ console.log('response received', statusCode); // response received 200
112
+
113
+ for await (const data of body) {
114
+ console.log('data', data.toString('utf8')); // data foo
115
+ }
116
+ ```
117
+
118
+ ### `ProxyAgent.close()`
119
+
120
+ Closes the proxy agent and waits for registered pools and clients to also close before resolving.
121
+
122
+ Returns: `Promise<void>`
123
+
124
+ #### Example - clean up after tests are complete
125
+
126
+ ```js
127
+ import { ProxyAgent, setGlobalDispatcher } from 'undici'
128
+
129
+ const proxyAgent = new ProxyAgent('my.proxy.server')
130
+ setGlobalDispatcher(proxyAgent)
131
+
132
+ await proxyAgent.close()
133
+ ```
134
+
135
+ ### `ProxyAgent.dispatch(options, handlers)`
136
+
137
+ Implements [`Agent.dispatch(options, handlers)`](/docs/docs/api/Agent.md#parameter-agentdispatchoptions).
138
+
139
+ ### `ProxyAgent.request(options[, callback])`
140
+
141
+ See [`Dispatcher.request(options [, callback])`](/docs/docs/api/Dispatcher.md#dispatcherrequestoptions-callback).
142
+
143
+
144
+ #### Example - ProxyAgent with Fetch
145
+
146
+ This example demonstrates how to use `fetch` with a proxy via `ProxyAgent`. It is particularly useful for scenarios requiring proxy tunneling.
147
+
148
+ ```javascript
149
+ import { ProxyAgent, fetch } from 'undici';
150
+
151
+ // Define the ProxyAgent
152
+ const proxyAgent = new ProxyAgent('http://localhost:8000');
153
+
154
+ // Make a GET request through the proxy
155
+ const response = await fetch('http://localhost:3000/foo', {
156
+ dispatcher: proxyAgent,
157
+ method: 'GET',
158
+ });
159
+
160
+ console.log('Response status:', response.status);
161
+ console.log('Response data:', await response.text());
162
+ ```
163
+
164
+ ---
165
+
166
+ #### Example - ProxyAgent with a Custom Proxy Server
167
+
168
+ This example shows how to create a custom proxy server and use it with `ProxyAgent`.
169
+
170
+ ```javascript
171
+ import * as http from 'node:http';
172
+ import { createProxy } from 'proxy';
173
+ import { ProxyAgent, fetch } from 'undici';
174
+
175
+ // Create a proxy server
176
+ const proxyServer = createProxy(http.createServer());
177
+ proxyServer.listen(8000, () => {
178
+ console.log('Proxy server running on port 8000');
179
+ });
180
+
181
+ // Define and use the ProxyAgent
182
+ const proxyAgent = new ProxyAgent('http://localhost:8000');
183
+
184
+ const response = await fetch('http://example.com', {
185
+ dispatcher: proxyAgent,
186
+ method: 'GET',
187
+ });
188
+
189
+ console.log('Response status:', response.status);
190
+ console.log('Response data:', await response.text());
191
+ ```
192
+
193
+ ---
194
+
195
+ #### Example - ProxyAgent with HTTPS Tunneling
196
+
197
+ This example demonstrates how to perform HTTPS tunneling using a proxy.
198
+
199
+ ```javascript
200
+ import { ProxyAgent, fetch } from 'undici';
201
+
202
+ // Define a ProxyAgent for HTTPS proxy
203
+ const proxyAgent = new ProxyAgent('https://secure.proxy.server');
204
+
205
+ // Make a request to an HTTPS endpoint via the proxy
206
+ const response = await fetch('https://secure.endpoint.com/api/data', {
207
+ dispatcher: proxyAgent,
208
+ method: 'GET',
209
+ });
210
+
211
+ console.log('Response status:', response.status);
212
+ console.log('Response data:', await response.json());
213
+ ```
214
+
215
+ #### Example - ProxyAgent as a Global Dispatcher
216
+
217
+ `ProxyAgent` can be configured as a global dispatcher, making it available for all requests without explicitly passing it. This simplifies code and is useful when a single proxy configuration applies to all requests.
218
+
219
+ ```javascript
220
+ import { ProxyAgent, setGlobalDispatcher, fetch } from 'undici';
221
+
222
+ // Define and configure the ProxyAgent
223
+ const proxyAgent = new ProxyAgent('http://localhost:8000');
224
+ setGlobalDispatcher(proxyAgent);
225
+
226
+ // Make requests without specifying the dispatcher
227
+ const response = await fetch('http://example.com');
228
+ console.log('Response status:', response.status);
229
+ console.log('Response data:', await response.text());
@@ -0,0 +1,93 @@
1
+ # Class: RedirectHandler
2
+
3
+ A class that handles redirection logic for HTTP requests.
4
+
5
+ ## `new RedirectHandler(dispatch, maxRedirections, opts, handler)`
6
+
7
+ Arguments:
8
+
9
+ - **dispatch** `function` - The dispatch function to be called after every retry.
10
+ - **maxRedirections** `number` - Maximum number of redirections allowed.
11
+ - **opts** `object` - Options for handling redirection.
12
+ - **handler** `object` - An object containing handlers for different stages of the request lifecycle.
13
+
14
+ Returns: `RedirectHandler`
15
+
16
+ ### Parameters
17
+
18
+ - **dispatch** `(options: Dispatch.DispatchOptions, handlers: Dispatch.DispatchHandler) => Promise<Dispatch.DispatchResponse>` (required) - Dispatch function to be called after every redirection.
19
+ - **maxRedirections** `number` (required) - Maximum number of redirections allowed.
20
+ - **opts** `object` (required) - Options for handling redirection.
21
+ - **handler** `object` (required) - Handlers for different stages of the request lifecycle.
22
+
23
+ ### Properties
24
+
25
+ - **location** `string` - The current redirection location.
26
+ - **abort** `function` - The abort function.
27
+ - **opts** `object` - The options for handling redirection.
28
+ - **maxRedirections** `number` - Maximum number of redirections allowed.
29
+ - **handler** `object` - Handlers for different stages of the request lifecycle.
30
+ - **history** `Array` - An array representing the history of URLs during redirection.
31
+
32
+ ### Methods
33
+
34
+ #### `onConnect(abort)`
35
+
36
+ Called when the connection is established.
37
+
38
+ Parameters:
39
+
40
+ - **abort** `function` - The abort function.
41
+
42
+ #### `onUpgrade(statusCode, headers, socket)`
43
+
44
+ Called when an upgrade is requested.
45
+
46
+ Parameters:
47
+
48
+ - **statusCode** `number` - The HTTP status code.
49
+ - **headers** `object` - The headers received in the response.
50
+ - **socket** `object` - The socket object.
51
+
52
+ #### `onError(error)`
53
+
54
+ Called when an error occurs.
55
+
56
+ Parameters:
57
+
58
+ - **error** `Error` - The error that occurred.
59
+
60
+ #### `onHeaders(statusCode, headers, resume, statusText)`
61
+
62
+ Called when headers are received.
63
+
64
+ Parameters:
65
+
66
+ - **statusCode** `number` - The HTTP status code.
67
+ - **headers** `object` - The headers received in the response.
68
+ - **resume** `function` - The resume function.
69
+ - **statusText** `string` - The status text.
70
+
71
+ #### `onData(chunk)`
72
+
73
+ Called when data is received.
74
+
75
+ Parameters:
76
+
77
+ - **chunk** `Buffer` - The data chunk received.
78
+
79
+ #### `onComplete(trailers)`
80
+
81
+ Called when the request is complete.
82
+
83
+ Parameters:
84
+
85
+ - **trailers** `object` - The trailers received.
86
+
87
+ #### `onBodySent(chunk)`
88
+
89
+ Called when the request body is sent.
90
+
91
+ Parameters:
92
+
93
+ - **chunk** `Buffer` - The chunk of the request body sent.
@@ -0,0 +1,50 @@
1
+ # Class: RetryAgent
2
+
3
+ Extends: `undici.Dispatcher`
4
+
5
+ A `undici.Dispatcher` that allows to automatically retry a request.
6
+ Wraps a `undici.RetryHandler`.
7
+
8
+ ## `new RetryAgent(dispatcher, [options])`
9
+
10
+ Arguments:
11
+
12
+ * **dispatcher** `undici.Dispatcher` (required) - the dispatcher to wrap
13
+ * **options** `RetryHandlerOptions` (optional) - the options
14
+
15
+ Returns: `ProxyAgent`
16
+
17
+ ### Parameter: `RetryHandlerOptions`
18
+
19
+ - **throwOnError** `boolean` (optional) - Disable to prevent throwing error on last retry attept, useful if you need the body on errors from server or if you have custom error handler. Default: `true`
20
+ - **retry** `(err: Error, context: RetryContext, callback: (err?: Error | null) => void) => void` (optional) - Function to be called after every retry. It should pass error if no more retries should be performed.
21
+ - **maxRetries** `number` (optional) - Maximum number of retries. Default: `5`
22
+ - **maxTimeout** `number` (optional) - Maximum number of milliseconds to wait before retrying. Default: `30000` (30 seconds)
23
+ - **minTimeout** `number` (optional) - Minimum number of milliseconds to wait before retrying. Default: `500` (half a second)
24
+ - **timeoutFactor** `number` (optional) - Factor to multiply the timeout by for each retry attempt. Default: `2`
25
+ - **retryAfter** `boolean` (optional) - It enables automatic retry after the `Retry-After` header is received. Default: `true`
26
+ -
27
+ - **methods** `string[]` (optional) - Array of HTTP methods to retry. Default: `['GET', 'PUT', 'HEAD', 'OPTIONS', 'DELETE']`
28
+ - **statusCodes** `number[]` (optional) - Array of HTTP status codes to retry. Default: `[429, 500, 502, 503, 504]`
29
+ - **errorCodes** `string[]` (optional) - Array of Error codes to retry. Default: `['ECONNRESET', 'ECONNREFUSED', 'ENOTFOUND', 'ENETDOWN','ENETUNREACH', 'EHOSTDOWN', 'UND_ERR_SOCKET']`
30
+
31
+ **`RetryContext`**
32
+
33
+ - `state`: `RetryState` - Current retry state. It can be mutated.
34
+ - `opts`: `Dispatch.DispatchOptions & RetryOptions` - Options passed to the retry handler.
35
+
36
+ Example:
37
+
38
+ ```js
39
+ import { Agent, RetryAgent } from 'undici'
40
+
41
+ const agent = new RetryAgent(new Agent())
42
+
43
+ const res = await agent.request({
44
+ method: 'GET',
45
+ origin: 'http://example.com',
46
+ path: '/',
47
+ })
48
+ console.log(res.statusCode)
49
+ console.log(await res.body.text())
50
+ ```
@@ -0,0 +1,118 @@
1
+ # Class: RetryHandler
2
+
3
+ Extends: `undici.DispatcherHandlers`
4
+
5
+ A handler class that implements the retry logic for a request.
6
+
7
+ ## `new RetryHandler(dispatchOptions, retryHandlers, [retryOptions])`
8
+
9
+ Arguments:
10
+
11
+ - **options** `Dispatch.DispatchOptions & RetryOptions` (required) - It is an intersection of `Dispatcher.DispatchOptions` and `RetryOptions`.
12
+ - **retryHandlers** `RetryHandlers` (required) - Object containing the `dispatch` to be used on every retry, and `handler` for handling the `dispatch` lifecycle.
13
+
14
+ Returns: `retryHandler`
15
+
16
+ ### Parameter: `Dispatch.DispatchOptions & RetryOptions`
17
+
18
+ Extends: [`Dispatch.DispatchOptions`](/docs/docs/api/Dispatcher.md#parameter-dispatchoptions).
19
+
20
+ #### `RetryOptions`
21
+
22
+ - **throwOnError** `boolean` (optional) - Disable to prevent throwing error on last retry attept, useful if you need the body on errors from server or if you have custom error handler.
23
+ - **retry** `(err: Error, context: RetryContext, callback: (err?: Error | null) => void) => number | null` (optional) - Function to be called after every retry. It should pass error if no more retries should be performed.
24
+ - **maxRetries** `number` (optional) - Maximum number of retries. Default: `5`
25
+ - **maxTimeout** `number` (optional) - Maximum number of milliseconds to wait before retrying. Default: `30000` (30 seconds)
26
+ - **minTimeout** `number` (optional) - Minimum number of milliseconds to wait before retrying. Default: `500` (half a second)
27
+ - **timeoutFactor** `number` (optional) - Factor to multiply the timeout by for each retry attempt. Default: `2`
28
+ - **retryAfter** `boolean` (optional) - It enables automatic retry after the `Retry-After` header is received. Default: `true`
29
+ -
30
+ - **methods** `string[]` (optional) - Array of HTTP methods to retry. Default: `['GET', 'PUT', 'HEAD', 'OPTIONS', 'DELETE']`
31
+ - **statusCodes** `number[]` (optional) - Array of HTTP status codes to retry. Default: `[429, 500, 502, 503, 504]`
32
+ - **errorCodes** `string[]` (optional) - Array of Error codes to retry. Default: `['ECONNRESET', 'ECONNREFUSED', 'ENOTFOUND', 'ENETDOWN','ENETUNREACH', 'EHOSTDOWN', 'UND_ERR_SOCKET']`
33
+
34
+ **`RetryContext`**
35
+
36
+ - `state`: `RetryState` - Current retry state. It can be mutated.
37
+ - `opts`: `Dispatch.DispatchOptions & RetryOptions` - Options passed to the retry handler.
38
+
39
+ **`RetryState`**
40
+
41
+ It represents the retry state for a given request.
42
+
43
+ - `counter`: `number` - Current retry attempt.
44
+
45
+ ### Parameter `RetryHandlers`
46
+
47
+ - **dispatch** `(options: Dispatch.DispatchOptions, handlers: Dispatch.DispatchHandler) => Promise<Dispatch.DispatchResponse>` (required) - Dispatch function to be called after every retry.
48
+ - **handler** Extends [`Dispatch.DispatchHandler`](/docs/docs/api/Dispatcher.md#dispatcherdispatchoptions-handler) (required) - Handler function to be called after the request is successful or the retries are exhausted.
49
+
50
+ >__Note__: The `RetryHandler` does not retry over stateful bodies (e.g. streams, AsyncIterable) as those, once consumed, are left in a state that cannot be reutilized. For these situations the `RetryHandler` will identify
51
+ >the body as stateful and will not retry the request rejecting with the error `UND_ERR_REQ_RETRY`.
52
+
53
+ Examples:
54
+
55
+ ```js
56
+ const client = new Client(`http://localhost:${server.address().port}`);
57
+ const chunks = [];
58
+ const handler = new RetryHandler(
59
+ {
60
+ ...dispatchOptions,
61
+ retryOptions: {
62
+ // custom retry function
63
+ retry: function (err, state, callback) {
64
+ counter++;
65
+
66
+ if (err.code && err.code === "UND_ERR_DESTROYED") {
67
+ callback(err);
68
+ return;
69
+ }
70
+
71
+ if (err.statusCode === 206) {
72
+ callback(err);
73
+ return;
74
+ }
75
+
76
+ setTimeout(() => callback(null), 1000);
77
+ },
78
+ },
79
+ },
80
+ {
81
+ dispatch: (...args) => {
82
+ return client.dispatch(...args);
83
+ },
84
+ handler: {
85
+ onConnect() {},
86
+ onBodySent() {},
87
+ onHeaders(status, _rawHeaders, resume, _statusMessage) {
88
+ // do something with headers
89
+ },
90
+ onData(chunk) {
91
+ chunks.push(chunk);
92
+ return true;
93
+ },
94
+ onComplete() {},
95
+ onError() {
96
+ // handle error properly
97
+ },
98
+ },
99
+ }
100
+ );
101
+ ```
102
+
103
+ #### Example - Basic RetryHandler with defaults
104
+
105
+ ```js
106
+ const client = new Client(`http://localhost:${server.address().port}`);
107
+ const handler = new RetryHandler(dispatchOptions, {
108
+ dispatch: client.dispatch.bind(client),
109
+ handler: {
110
+ onConnect() {},
111
+ onBodySent() {},
112
+ onHeaders(status, _rawHeaders, resume, _statusMessage) {},
113
+ onData(chunk) {},
114
+ onComplete() {},
115
+ onError(err) {},
116
+ },
117
+ });
118
+ ```
@@ -0,0 +1,145 @@
1
+ # Class: RoundRobinPool
2
+
3
+ Extends: `undici.Dispatcher`
4
+
5
+ A pool of [Client](/docs/docs/api/Client.md) instances connected to the same upstream target with round-robin client selection.
6
+
7
+ Unlike [`Pool`](/docs/docs/api/Pool.md), which always selects the first available client, `RoundRobinPool` cycles through clients in a round-robin fashion. This ensures even distribution of requests across all connections, which is particularly useful when the upstream target is behind a load balancer that round-robins TCP connections across multiple backend servers (e.g., Kubernetes Services).
8
+
9
+ Requests are not guaranteed to be dispatched in order of invocation.
10
+
11
+ ## `new RoundRobinPool(url[, options])`
12
+
13
+ Arguments:
14
+
15
+ * **url** `URL | string` - It should only include the **protocol, hostname, and port**.
16
+ * **options** `RoundRobinPoolOptions` (optional)
17
+
18
+ ### Parameter: `RoundRobinPoolOptions`
19
+
20
+ Extends: [`ClientOptions`](/docs/docs/api/Client.md#parameter-clientoptions)
21
+
22
+ * **factory** `(origin: URL, opts: Object) => Dispatcher` - Default: `(origin, opts) => new Client(origin, opts)`
23
+ * **connections** `number | null` (optional) - Default: `null` - The number of `Client` instances to create. When set to `null`, the `RoundRobinPool` instance will create an unlimited amount of `Client` instances.
24
+ * **clientTtl** `number | null` (optional) - Default: `null` - The amount of time before a `Client` instance is removed from the `RoundRobinPool` and closed. When set to `null`, `Client` instances will not be removed or closed based on age.
25
+
26
+ ## Use Case
27
+
28
+ `RoundRobinPool` is designed for scenarios where:
29
+
30
+ 1. You connect to a single origin (e.g., `http://my-service.namespace.svc`)
31
+ 2. That origin is backed by a load balancer distributing TCP connections across multiple servers
32
+ 3. You want requests evenly distributed across all backend servers
33
+
34
+ **Example**: In Kubernetes, when using a Service DNS name with multiple Pod replicas, kube-proxy load balances TCP connections. `RoundRobinPool` ensures each connection (and thus each Pod) receives an equal share of requests.
35
+
36
+ ### Important: Backend Distribution Considerations
37
+
38
+ `RoundRobinPool` distributes **HTTP requests** evenly across **TCP connections**. Whether this translates to even backend server distribution depends on the load balancer's behavior:
39
+
40
+ **✓ Works when the load balancer**:
41
+ - Assigns different backends to different TCP connections from the same client
42
+ - Uses algorithms like: round-robin, random, least-connections (without client affinity)
43
+ - Example: Default Kubernetes Services without `sessionAffinity`
44
+
45
+ **✗ Does NOT work when**:
46
+ - Load balancer has client/source IP affinity (all connections from one IP → same backend)
47
+ - Load balancer uses source-IP-hash or sticky sessions
48
+
49
+ **How it works:**
50
+ 1. `RoundRobinPool` creates N TCP connections to the load balancer endpoint
51
+ 2. Load balancer assigns each TCP connection to a backend (per its algorithm)
52
+ 3. `RoundRobinPool` cycles HTTP requests across those N connections
53
+ 4. Result: Requests distributed proportionally to how the LB distributed the connections
54
+
55
+ If the load balancer assigns all connections to the same backend (e.g., due to session affinity), `RoundRobinPool` cannot overcome this. In such cases, consider using [`BalancedPool`](/docs/docs/api/BalancedPool.md) with direct backend addresses (e.g., individual pod IPs) instead of a load-balanced endpoint.
56
+
57
+ ## Instance Properties
58
+
59
+ ### `RoundRobinPool.closed`
60
+
61
+ Implements [Client.closed](/docs/docs/api/Client.md#clientclosed)
62
+
63
+ ### `RoundRobinPool.destroyed`
64
+
65
+ Implements [Client.destroyed](/docs/docs/api/Client.md#clientdestroyed)
66
+
67
+ ### `RoundRobinPool.stats`
68
+
69
+ Returns [`PoolStats`](PoolStats.md) instance for this pool.
70
+
71
+ ## Instance Methods
72
+
73
+ ### `RoundRobinPool.close([callback])`
74
+
75
+ Implements [`Dispatcher.close([callback])`](/docs/docs/api/Dispatcher.md#dispatcherclosecallback-promise).
76
+
77
+ ### `RoundRobinPool.destroy([error, callback])`
78
+
79
+ Implements [`Dispatcher.destroy([error, callback])`](/docs/docs/api/Dispatcher.md#dispatcherdestroyerror-callback-promise).
80
+
81
+ ### `RoundRobinPool.connect(options[, callback])`
82
+
83
+ See [`Dispatcher.connect(options[, callback])`](/docs/docs/api/Dispatcher.md#dispatcherconnectoptions-callback).
84
+
85
+ ### `RoundRobinPool.dispatch(options, handler)`
86
+
87
+ Implements [`Dispatcher.dispatch(options, handler)`](/docs/docs/api/Dispatcher.md#dispatcherdispatchoptions-handler).
88
+
89
+ ### `RoundRobinPool.pipeline(options, handler)`
90
+
91
+ See [`Dispatcher.pipeline(options, handler)`](/docs/docs/api/Dispatcher.md#dispatcherpipelineoptions-handler).
92
+
93
+ ### `RoundRobinPool.request(options[, callback])`
94
+
95
+ See [`Dispatcher.request(options [, callback])`](/docs/docs/api/Dispatcher.md#dispatcherrequestoptions-callback).
96
+
97
+ ### `RoundRobinPool.stream(options, factory[, callback])`
98
+
99
+ See [`Dispatcher.stream(options, factory[, callback])`](/docs/docs/api/Dispatcher.md#dispatcherstreamoptions-factory-callback).
100
+
101
+ ### `RoundRobinPool.upgrade(options[, callback])`
102
+
103
+ See [`Dispatcher.upgrade(options[, callback])`](/docs/docs/api/Dispatcher.md#dispatcherupgradeoptions-callback).
104
+
105
+ ## Instance Events
106
+
107
+ ### Event: `'connect'`
108
+
109
+ See [Dispatcher Event: `'connect'`](/docs/docs/api/Dispatcher.md#event-connect).
110
+
111
+ ### Event: `'disconnect'`
112
+
113
+ See [Dispatcher Event: `'disconnect'`](/docs/docs/api/Dispatcher.md#event-disconnect).
114
+
115
+ ### Event: `'drain'`
116
+
117
+ See [Dispatcher Event: `'drain'`](/docs/docs/api/Dispatcher.md#event-drain).
118
+
119
+ ## Example
120
+
121
+ ```javascript
122
+ import { RoundRobinPool } from 'undici'
123
+
124
+ const pool = new RoundRobinPool('http://my-service.default.svc.cluster.local', {
125
+ connections: 10
126
+ })
127
+
128
+ // Requests will be distributed evenly across all 10 connections
129
+ for (let i = 0; i < 100; i++) {
130
+ const { body } = await pool.request({
131
+ path: '/api/data',
132
+ method: 'GET'
133
+ })
134
+ console.log(await body.json())
135
+ }
136
+
137
+ await pool.close()
138
+ ```
139
+
140
+ ## See Also
141
+
142
+ - [Pool](/docs/docs/api/Pool.md) - Connection pool without round-robin
143
+ - [BalancedPool](/docs/docs/api/BalancedPool.md) - Load balancing across multiple origins
144
+ - [Issue #3648](https://github.com/nodejs/undici/issues/3648) - Original issue describing uneven distribution
145
+