deepv-code 1.0.182 → 1.0.183
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundle/dvcode.js +635 -635
- package/package.json +1 -1
- package/bundle/assets/help/README.md +0 -113
- package/bundle/assets/sounds/README.md +0 -74
- package/bundle/node_modules/undici/LICENSE +0 -21
- package/bundle/node_modules/undici/README.md +0 -472
- package/bundle/node_modules/undici/docs/docs/api/Agent.md +0 -83
- package/bundle/node_modules/undici/docs/docs/api/BalancedPool.md +0 -99
- package/bundle/node_modules/undici/docs/docs/api/CacheStorage.md +0 -30
- package/bundle/node_modules/undici/docs/docs/api/CacheStore.md +0 -151
- package/bundle/node_modules/undici/docs/docs/api/Client.md +0 -281
- package/bundle/node_modules/undici/docs/docs/api/ClientStats.md +0 -27
- package/bundle/node_modules/undici/docs/docs/api/Connector.md +0 -115
- package/bundle/node_modules/undici/docs/docs/api/ContentType.md +0 -57
- package/bundle/node_modules/undici/docs/docs/api/Cookies.md +0 -101
- package/bundle/node_modules/undici/docs/docs/api/Debug.md +0 -62
- package/bundle/node_modules/undici/docs/docs/api/DiagnosticsChannel.md +0 -204
- package/bundle/node_modules/undici/docs/docs/api/Dispatcher.md +0 -1200
- package/bundle/node_modules/undici/docs/docs/api/EnvHttpProxyAgent.md +0 -159
- package/bundle/node_modules/undici/docs/docs/api/Errors.md +0 -49
- package/bundle/node_modules/undici/docs/docs/api/EventSource.md +0 -45
- package/bundle/node_modules/undici/docs/docs/api/Fetch.md +0 -52
- package/bundle/node_modules/undici/docs/docs/api/H2CClient.md +0 -262
- package/bundle/node_modules/undici/docs/docs/api/MockAgent.md +0 -603
- package/bundle/node_modules/undici/docs/docs/api/MockCallHistory.md +0 -197
- package/bundle/node_modules/undici/docs/docs/api/MockCallHistoryLog.md +0 -43
- package/bundle/node_modules/undici/docs/docs/api/MockClient.md +0 -77
- package/bundle/node_modules/undici/docs/docs/api/MockErrors.md +0 -12
- package/bundle/node_modules/undici/docs/docs/api/MockPool.md +0 -548
- package/bundle/node_modules/undici/docs/docs/api/Pool.md +0 -84
- package/bundle/node_modules/undici/docs/docs/api/PoolStats.md +0 -35
- package/bundle/node_modules/undici/docs/docs/api/ProxyAgent.md +0 -227
- package/bundle/node_modules/undici/docs/docs/api/RedirectHandler.md +0 -96
- package/bundle/node_modules/undici/docs/docs/api/RetryAgent.md +0 -45
- package/bundle/node_modules/undici/docs/docs/api/RetryHandler.md +0 -117
- package/bundle/node_modules/undici/docs/docs/api/Util.md +0 -25
- package/bundle/node_modules/undici/docs/docs/api/WebSocket.md +0 -85
- package/bundle/node_modules/undici/docs/docs/api/api-lifecycle.md +0 -91
- package/bundle/node_modules/undici/docs/docs/best-practices/client-certificate.md +0 -64
- package/bundle/node_modules/undici/docs/docs/best-practices/mocking-request.md +0 -190
- package/bundle/node_modules/undici/docs/docs/best-practices/proxy.md +0 -127
- package/bundle/node_modules/undici/docs/docs/best-practices/writing-tests.md +0 -20
- package/bundle/node_modules/undici/index-fetch.js +0 -35
- package/bundle/node_modules/undici/index.d.ts +0 -3
- package/bundle/node_modules/undici/index.js +0 -183
- package/bundle/node_modules/undici/lib/api/abort-signal.js +0 -59
- package/bundle/node_modules/undici/lib/api/api-connect.js +0 -110
- package/bundle/node_modules/undici/lib/api/api-pipeline.js +0 -252
- package/bundle/node_modules/undici/lib/api/api-request.js +0 -199
- package/bundle/node_modules/undici/lib/api/api-stream.js +0 -209
- package/bundle/node_modules/undici/lib/api/api-upgrade.js +0 -110
- package/bundle/node_modules/undici/lib/api/index.js +0 -7
- package/bundle/node_modules/undici/lib/api/readable.js +0 -558
- package/bundle/node_modules/undici/lib/api/util.js +0 -95
- package/bundle/node_modules/undici/lib/cache/memory-cache-store.js +0 -234
- package/bundle/node_modules/undici/lib/cache/sqlite-cache-store.js +0 -461
- package/bundle/node_modules/undici/lib/core/connect.js +0 -164
- package/bundle/node_modules/undici/lib/core/constants.js +0 -143
- package/bundle/node_modules/undici/lib/core/diagnostics.js +0 -196
- package/bundle/node_modules/undici/lib/core/errors.js +0 -244
- package/bundle/node_modules/undici/lib/core/request.js +0 -397
- package/bundle/node_modules/undici/lib/core/symbols.js +0 -68
- package/bundle/node_modules/undici/lib/core/tree.js +0 -160
- package/bundle/node_modules/undici/lib/core/util.js +0 -988
- package/bundle/node_modules/undici/lib/dispatcher/agent.js +0 -135
- package/bundle/node_modules/undici/lib/dispatcher/balanced-pool.js +0 -206
- package/bundle/node_modules/undici/lib/dispatcher/client-h1.js +0 -1615
- package/bundle/node_modules/undici/lib/dispatcher/client-h2.js +0 -798
- package/bundle/node_modules/undici/lib/dispatcher/client.js +0 -614
- package/bundle/node_modules/undici/lib/dispatcher/dispatcher-base.js +0 -161
- package/bundle/node_modules/undici/lib/dispatcher/dispatcher.js +0 -48
- package/bundle/node_modules/undici/lib/dispatcher/env-http-proxy-agent.js +0 -151
- package/bundle/node_modules/undici/lib/dispatcher/fixed-queue.js +0 -159
- package/bundle/node_modules/undici/lib/dispatcher/h2c-client.js +0 -122
- package/bundle/node_modules/undici/lib/dispatcher/pool-base.js +0 -191
- package/bundle/node_modules/undici/lib/dispatcher/pool.js +0 -118
- package/bundle/node_modules/undici/lib/dispatcher/proxy-agent.js +0 -275
- package/bundle/node_modules/undici/lib/dispatcher/retry-agent.js +0 -35
- package/bundle/node_modules/undici/lib/global.js +0 -32
- package/bundle/node_modules/undici/lib/handler/cache-handler.js +0 -448
- package/bundle/node_modules/undici/lib/handler/cache-revalidation-handler.js +0 -124
- package/bundle/node_modules/undici/lib/handler/decorator-handler.js +0 -67
- package/bundle/node_modules/undici/lib/handler/redirect-handler.js +0 -227
- package/bundle/node_modules/undici/lib/handler/retry-handler.js +0 -342
- package/bundle/node_modules/undici/lib/handler/unwrap-handler.js +0 -96
- package/bundle/node_modules/undici/lib/handler/wrap-handler.js +0 -95
- package/bundle/node_modules/undici/lib/interceptor/cache.js +0 -372
- package/bundle/node_modules/undici/lib/interceptor/dns.js +0 -432
- package/bundle/node_modules/undici/lib/interceptor/dump.js +0 -111
- package/bundle/node_modules/undici/lib/interceptor/redirect.js +0 -21
- package/bundle/node_modules/undici/lib/interceptor/response-error.js +0 -95
- package/bundle/node_modules/undici/lib/interceptor/retry.js +0 -19
- package/bundle/node_modules/undici/lib/llhttp/.gitkeep +0 -0
- package/bundle/node_modules/undici/lib/llhttp/constants.d.ts +0 -97
- package/bundle/node_modules/undici/lib/llhttp/constants.js +0 -498
- package/bundle/node_modules/undici/lib/llhttp/constants.js.map +0 -1
- package/bundle/node_modules/undici/lib/llhttp/llhttp-wasm.js +0 -15
- package/bundle/node_modules/undici/lib/llhttp/llhttp_simd-wasm.js +0 -15
- package/bundle/node_modules/undici/lib/llhttp/utils.d.ts +0 -2
- package/bundle/node_modules/undici/lib/llhttp/utils.js +0 -15
- package/bundle/node_modules/undici/lib/llhttp/utils.js.map +0 -1
- package/bundle/node_modules/undici/lib/mock/mock-agent.js +0 -224
- package/bundle/node_modules/undici/lib/mock/mock-call-history.js +0 -248
- package/bundle/node_modules/undici/lib/mock/mock-client.js +0 -64
- package/bundle/node_modules/undici/lib/mock/mock-errors.js +0 -19
- package/bundle/node_modules/undici/lib/mock/mock-interceptor.js +0 -209
- package/bundle/node_modules/undici/lib/mock/mock-pool.js +0 -64
- package/bundle/node_modules/undici/lib/mock/mock-symbols.js +0 -31
- package/bundle/node_modules/undici/lib/mock/mock-utils.js +0 -433
- package/bundle/node_modules/undici/lib/mock/pending-interceptors-formatter.js +0 -43
- package/bundle/node_modules/undici/lib/util/cache.js +0 -368
- package/bundle/node_modules/undici/lib/util/date.js +0 -259
- package/bundle/node_modules/undici/lib/util/stats.js +0 -32
- package/bundle/node_modules/undici/lib/util/timers.js +0 -423
- package/bundle/node_modules/undici/lib/web/cache/cache.js +0 -862
- package/bundle/node_modules/undici/lib/web/cache/cachestorage.js +0 -152
- package/bundle/node_modules/undici/lib/web/cache/util.js +0 -45
- package/bundle/node_modules/undici/lib/web/cookies/constants.js +0 -12
- package/bundle/node_modules/undici/lib/web/cookies/index.js +0 -199
- package/bundle/node_modules/undici/lib/web/cookies/parse.js +0 -322
- package/bundle/node_modules/undici/lib/web/cookies/util.js +0 -282
- package/bundle/node_modules/undici/lib/web/eventsource/eventsource-stream.js +0 -399
- package/bundle/node_modules/undici/lib/web/eventsource/eventsource.js +0 -484
- package/bundle/node_modules/undici/lib/web/eventsource/util.js +0 -37
- package/bundle/node_modules/undici/lib/web/fetch/LICENSE +0 -21
- package/bundle/node_modules/undici/lib/web/fetch/body.js +0 -532
- package/bundle/node_modules/undici/lib/web/fetch/constants.js +0 -131
- package/bundle/node_modules/undici/lib/web/fetch/data-url.js +0 -744
- package/bundle/node_modules/undici/lib/web/fetch/dispatcher-weakref.js +0 -46
- package/bundle/node_modules/undici/lib/web/fetch/formdata-parser.js +0 -501
- package/bundle/node_modules/undici/lib/web/fetch/formdata.js +0 -263
- package/bundle/node_modules/undici/lib/web/fetch/global.js +0 -40
- package/bundle/node_modules/undici/lib/web/fetch/headers.js +0 -719
- package/bundle/node_modules/undici/lib/web/fetch/index.js +0 -2258
- package/bundle/node_modules/undici/lib/web/fetch/request.js +0 -1099
- package/bundle/node_modules/undici/lib/web/fetch/response.js +0 -636
- package/bundle/node_modules/undici/lib/web/fetch/util.js +0 -1782
- package/bundle/node_modules/undici/lib/web/fetch/webidl.js +0 -740
- package/bundle/node_modules/undici/lib/web/websocket/connection.js +0 -325
- package/bundle/node_modules/undici/lib/web/websocket/constants.js +0 -126
- package/bundle/node_modules/undici/lib/web/websocket/events.js +0 -331
- package/bundle/node_modules/undici/lib/web/websocket/frame.js +0 -138
- package/bundle/node_modules/undici/lib/web/websocket/permessage-deflate.js +0 -70
- package/bundle/node_modules/undici/lib/web/websocket/receiver.js +0 -454
- package/bundle/node_modules/undici/lib/web/websocket/sender.js +0 -109
- package/bundle/node_modules/undici/lib/web/websocket/stream/websocketerror.js +0 -83
- package/bundle/node_modules/undici/lib/web/websocket/stream/websocketstream.js +0 -485
- package/bundle/node_modules/undici/lib/web/websocket/util.js +0 -338
- package/bundle/node_modules/undici/lib/web/websocket/websocket.js +0 -686
- package/bundle/node_modules/undici/package.json +0 -149
- package/bundle/node_modules/undici/scripts/strip-comments.js +0 -10
- package/bundle/node_modules/undici/types/README.md +0 -6
- package/bundle/node_modules/undici/types/agent.d.ts +0 -35
- package/bundle/node_modules/undici/types/api.d.ts +0 -43
- package/bundle/node_modules/undici/types/balanced-pool.d.ts +0 -29
- package/bundle/node_modules/undici/types/cache-interceptor.d.ts +0 -172
- package/bundle/node_modules/undici/types/cache.d.ts +0 -36
- package/bundle/node_modules/undici/types/client-stats.d.ts +0 -15
- package/bundle/node_modules/undici/types/client.d.ts +0 -110
- package/bundle/node_modules/undici/types/connector.d.ts +0 -34
- package/bundle/node_modules/undici/types/content-type.d.ts +0 -21
- package/bundle/node_modules/undici/types/cookies.d.ts +0 -30
- package/bundle/node_modules/undici/types/diagnostics-channel.d.ts +0 -66
- package/bundle/node_modules/undici/types/dispatcher.d.ts +0 -281
- package/bundle/node_modules/undici/types/env-http-proxy-agent.d.ts +0 -21
- package/bundle/node_modules/undici/types/errors.d.ts +0 -171
- package/bundle/node_modules/undici/types/eventsource.d.ts +0 -61
- package/bundle/node_modules/undici/types/fetch.d.ts +0 -210
- package/bundle/node_modules/undici/types/formdata.d.ts +0 -108
- package/bundle/node_modules/undici/types/global-dispatcher.d.ts +0 -9
- package/bundle/node_modules/undici/types/global-origin.d.ts +0 -7
- package/bundle/node_modules/undici/types/h2c-client.d.ts +0 -75
- package/bundle/node_modules/undici/types/handlers.d.ts +0 -15
- package/bundle/node_modules/undici/types/header.d.ts +0 -160
- package/bundle/node_modules/undici/types/index.d.ts +0 -75
- package/bundle/node_modules/undici/types/interceptors.d.ts +0 -34
- package/bundle/node_modules/undici/types/mock-agent.d.ts +0 -68
- package/bundle/node_modules/undici/types/mock-call-history.d.ts +0 -111
- package/bundle/node_modules/undici/types/mock-client.d.ts +0 -25
- package/bundle/node_modules/undici/types/mock-errors.d.ts +0 -12
- package/bundle/node_modules/undici/types/mock-interceptor.d.ts +0 -93
- package/bundle/node_modules/undici/types/mock-pool.d.ts +0 -25
- package/bundle/node_modules/undici/types/patch.d.ts +0 -29
- package/bundle/node_modules/undici/types/pool-stats.d.ts +0 -19
- package/bundle/node_modules/undici/types/pool.d.ts +0 -41
- package/bundle/node_modules/undici/types/proxy-agent.d.ts +0 -29
- package/bundle/node_modules/undici/types/readable.d.ts +0 -68
- package/bundle/node_modules/undici/types/retry-agent.d.ts +0 -8
- package/bundle/node_modules/undici/types/retry-handler.d.ts +0 -116
- package/bundle/node_modules/undici/types/util.d.ts +0 -18
- package/bundle/node_modules/undici/types/utility.d.ts +0 -7
- package/bundle/node_modules/undici/types/webidl.d.ts +0 -266
- package/bundle/node_modules/undici/types/websocket.d.ts +0 -184
|
@@ -1,161 +0,0 @@
|
|
|
1
|
-
'use strict'
|
|
2
|
-
|
|
3
|
-
const Dispatcher = require('./dispatcher')
|
|
4
|
-
const UnwrapHandler = require('../handler/unwrap-handler')
|
|
5
|
-
const {
|
|
6
|
-
ClientDestroyedError,
|
|
7
|
-
ClientClosedError,
|
|
8
|
-
InvalidArgumentError
|
|
9
|
-
} = require('../core/errors')
|
|
10
|
-
const { kDestroy, kClose, kClosed, kDestroyed, kDispatch } = require('../core/symbols')
|
|
11
|
-
|
|
12
|
-
const kOnDestroyed = Symbol('onDestroyed')
|
|
13
|
-
const kOnClosed = Symbol('onClosed')
|
|
14
|
-
|
|
15
|
-
class DispatcherBase extends Dispatcher {
|
|
16
|
-
constructor () {
|
|
17
|
-
super()
|
|
18
|
-
|
|
19
|
-
this[kDestroyed] = false
|
|
20
|
-
this[kOnDestroyed] = null
|
|
21
|
-
this[kClosed] = false
|
|
22
|
-
this[kOnClosed] = []
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
get destroyed () {
|
|
26
|
-
return this[kDestroyed]
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
get closed () {
|
|
30
|
-
return this[kClosed]
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
close (callback) {
|
|
34
|
-
if (callback === undefined) {
|
|
35
|
-
return new Promise((resolve, reject) => {
|
|
36
|
-
this.close((err, data) => {
|
|
37
|
-
return err ? reject(err) : resolve(data)
|
|
38
|
-
})
|
|
39
|
-
})
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
if (typeof callback !== 'function') {
|
|
43
|
-
throw new InvalidArgumentError('invalid callback')
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
if (this[kDestroyed]) {
|
|
47
|
-
queueMicrotask(() => callback(new ClientDestroyedError(), null))
|
|
48
|
-
return
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
if (this[kClosed]) {
|
|
52
|
-
if (this[kOnClosed]) {
|
|
53
|
-
this[kOnClosed].push(callback)
|
|
54
|
-
} else {
|
|
55
|
-
queueMicrotask(() => callback(null, null))
|
|
56
|
-
}
|
|
57
|
-
return
|
|
58
|
-
}
|
|
59
|
-
|
|
60
|
-
this[kClosed] = true
|
|
61
|
-
this[kOnClosed].push(callback)
|
|
62
|
-
|
|
63
|
-
const onClosed = () => {
|
|
64
|
-
const callbacks = this[kOnClosed]
|
|
65
|
-
this[kOnClosed] = null
|
|
66
|
-
for (let i = 0; i < callbacks.length; i++) {
|
|
67
|
-
callbacks[i](null, null)
|
|
68
|
-
}
|
|
69
|
-
}
|
|
70
|
-
|
|
71
|
-
// Should not error.
|
|
72
|
-
this[kClose]()
|
|
73
|
-
.then(() => this.destroy())
|
|
74
|
-
.then(() => {
|
|
75
|
-
queueMicrotask(onClosed)
|
|
76
|
-
})
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
destroy (err, callback) {
|
|
80
|
-
if (typeof err === 'function') {
|
|
81
|
-
callback = err
|
|
82
|
-
err = null
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
if (callback === undefined) {
|
|
86
|
-
return new Promise((resolve, reject) => {
|
|
87
|
-
this.destroy(err, (err, data) => {
|
|
88
|
-
return err ? /* istanbul ignore next: should never error */ reject(err) : resolve(data)
|
|
89
|
-
})
|
|
90
|
-
})
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
if (typeof callback !== 'function') {
|
|
94
|
-
throw new InvalidArgumentError('invalid callback')
|
|
95
|
-
}
|
|
96
|
-
|
|
97
|
-
if (this[kDestroyed]) {
|
|
98
|
-
if (this[kOnDestroyed]) {
|
|
99
|
-
this[kOnDestroyed].push(callback)
|
|
100
|
-
} else {
|
|
101
|
-
queueMicrotask(() => callback(null, null))
|
|
102
|
-
}
|
|
103
|
-
return
|
|
104
|
-
}
|
|
105
|
-
|
|
106
|
-
if (!err) {
|
|
107
|
-
err = new ClientDestroyedError()
|
|
108
|
-
}
|
|
109
|
-
|
|
110
|
-
this[kDestroyed] = true
|
|
111
|
-
this[kOnDestroyed] = this[kOnDestroyed] || []
|
|
112
|
-
this[kOnDestroyed].push(callback)
|
|
113
|
-
|
|
114
|
-
const onDestroyed = () => {
|
|
115
|
-
const callbacks = this[kOnDestroyed]
|
|
116
|
-
this[kOnDestroyed] = null
|
|
117
|
-
for (let i = 0; i < callbacks.length; i++) {
|
|
118
|
-
callbacks[i](null, null)
|
|
119
|
-
}
|
|
120
|
-
}
|
|
121
|
-
|
|
122
|
-
// Should not error.
|
|
123
|
-
this[kDestroy](err).then(() => {
|
|
124
|
-
queueMicrotask(onDestroyed)
|
|
125
|
-
})
|
|
126
|
-
}
|
|
127
|
-
|
|
128
|
-
dispatch (opts, handler) {
|
|
129
|
-
if (!handler || typeof handler !== 'object') {
|
|
130
|
-
throw new InvalidArgumentError('handler must be an object')
|
|
131
|
-
}
|
|
132
|
-
|
|
133
|
-
handler = UnwrapHandler.unwrap(handler)
|
|
134
|
-
|
|
135
|
-
try {
|
|
136
|
-
if (!opts || typeof opts !== 'object') {
|
|
137
|
-
throw new InvalidArgumentError('opts must be an object.')
|
|
138
|
-
}
|
|
139
|
-
|
|
140
|
-
if (this[kDestroyed] || this[kOnDestroyed]) {
|
|
141
|
-
throw new ClientDestroyedError()
|
|
142
|
-
}
|
|
143
|
-
|
|
144
|
-
if (this[kClosed]) {
|
|
145
|
-
throw new ClientClosedError()
|
|
146
|
-
}
|
|
147
|
-
|
|
148
|
-
return this[kDispatch](opts, handler)
|
|
149
|
-
} catch (err) {
|
|
150
|
-
if (typeof handler.onError !== 'function') {
|
|
151
|
-
throw err
|
|
152
|
-
}
|
|
153
|
-
|
|
154
|
-
handler.onError(err)
|
|
155
|
-
|
|
156
|
-
return false
|
|
157
|
-
}
|
|
158
|
-
}
|
|
159
|
-
}
|
|
160
|
-
|
|
161
|
-
module.exports = DispatcherBase
|
|
@@ -1,48 +0,0 @@
|
|
|
1
|
-
'use strict'
|
|
2
|
-
const EventEmitter = require('node:events')
|
|
3
|
-
const WrapHandler = require('../handler/wrap-handler')
|
|
4
|
-
|
|
5
|
-
const wrapInterceptor = (dispatch) => (opts, handler) => dispatch(opts, WrapHandler.wrap(handler))
|
|
6
|
-
|
|
7
|
-
class Dispatcher extends EventEmitter {
|
|
8
|
-
dispatch () {
|
|
9
|
-
throw new Error('not implemented')
|
|
10
|
-
}
|
|
11
|
-
|
|
12
|
-
close () {
|
|
13
|
-
throw new Error('not implemented')
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
destroy () {
|
|
17
|
-
throw new Error('not implemented')
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
compose (...args) {
|
|
21
|
-
// So we handle [interceptor1, interceptor2] or interceptor1, interceptor2, ...
|
|
22
|
-
const interceptors = Array.isArray(args[0]) ? args[0] : args
|
|
23
|
-
let dispatch = this.dispatch.bind(this)
|
|
24
|
-
|
|
25
|
-
for (const interceptor of interceptors) {
|
|
26
|
-
if (interceptor == null) {
|
|
27
|
-
continue
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
if (typeof interceptor !== 'function') {
|
|
31
|
-
throw new TypeError(`invalid interceptor, expected function received ${typeof interceptor}`)
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
dispatch = interceptor(dispatch)
|
|
35
|
-
dispatch = wrapInterceptor(dispatch)
|
|
36
|
-
|
|
37
|
-
if (dispatch == null || typeof dispatch !== 'function' || dispatch.length !== 2) {
|
|
38
|
-
throw new TypeError('invalid interceptor')
|
|
39
|
-
}
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
return new Proxy(this, {
|
|
43
|
-
get: (target, key) => key === 'dispatch' ? dispatch : target[key]
|
|
44
|
-
})
|
|
45
|
-
}
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
module.exports = Dispatcher
|
|
@@ -1,151 +0,0 @@
|
|
|
1
|
-
'use strict'
|
|
2
|
-
|
|
3
|
-
const DispatcherBase = require('./dispatcher-base')
|
|
4
|
-
const { kClose, kDestroy, kClosed, kDestroyed, kDispatch, kNoProxyAgent, kHttpProxyAgent, kHttpsProxyAgent } = require('../core/symbols')
|
|
5
|
-
const ProxyAgent = require('./proxy-agent')
|
|
6
|
-
const Agent = require('./agent')
|
|
7
|
-
|
|
8
|
-
const DEFAULT_PORTS = {
|
|
9
|
-
'http:': 80,
|
|
10
|
-
'https:': 443
|
|
11
|
-
}
|
|
12
|
-
|
|
13
|
-
class EnvHttpProxyAgent extends DispatcherBase {
|
|
14
|
-
#noProxyValue = null
|
|
15
|
-
#noProxyEntries = null
|
|
16
|
-
#opts = null
|
|
17
|
-
|
|
18
|
-
constructor (opts = {}) {
|
|
19
|
-
super()
|
|
20
|
-
this.#opts = opts
|
|
21
|
-
|
|
22
|
-
const { httpProxy, httpsProxy, noProxy, ...agentOpts } = opts
|
|
23
|
-
|
|
24
|
-
this[kNoProxyAgent] = new Agent(agentOpts)
|
|
25
|
-
|
|
26
|
-
const HTTP_PROXY = httpProxy ?? process.env.http_proxy ?? process.env.HTTP_PROXY
|
|
27
|
-
if (HTTP_PROXY) {
|
|
28
|
-
this[kHttpProxyAgent] = new ProxyAgent({ ...agentOpts, uri: HTTP_PROXY })
|
|
29
|
-
} else {
|
|
30
|
-
this[kHttpProxyAgent] = this[kNoProxyAgent]
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
const HTTPS_PROXY = httpsProxy ?? process.env.https_proxy ?? process.env.HTTPS_PROXY
|
|
34
|
-
if (HTTPS_PROXY) {
|
|
35
|
-
this[kHttpsProxyAgent] = new ProxyAgent({ ...agentOpts, uri: HTTPS_PROXY })
|
|
36
|
-
} else {
|
|
37
|
-
this[kHttpsProxyAgent] = this[kHttpProxyAgent]
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
this.#parseNoProxy()
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
[kDispatch] (opts, handler) {
|
|
44
|
-
const url = new URL(opts.origin)
|
|
45
|
-
const agent = this.#getProxyAgentForUrl(url)
|
|
46
|
-
return agent.dispatch(opts, handler)
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
async [kClose] () {
|
|
50
|
-
await this[kNoProxyAgent].close()
|
|
51
|
-
if (!this[kHttpProxyAgent][kClosed]) {
|
|
52
|
-
await this[kHttpProxyAgent].close()
|
|
53
|
-
}
|
|
54
|
-
if (!this[kHttpsProxyAgent][kClosed]) {
|
|
55
|
-
await this[kHttpsProxyAgent].close()
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
async [kDestroy] (err) {
|
|
60
|
-
await this[kNoProxyAgent].destroy(err)
|
|
61
|
-
if (!this[kHttpProxyAgent][kDestroyed]) {
|
|
62
|
-
await this[kHttpProxyAgent].destroy(err)
|
|
63
|
-
}
|
|
64
|
-
if (!this[kHttpsProxyAgent][kDestroyed]) {
|
|
65
|
-
await this[kHttpsProxyAgent].destroy(err)
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
|
|
69
|
-
#getProxyAgentForUrl (url) {
|
|
70
|
-
let { protocol, host: hostname, port } = url
|
|
71
|
-
|
|
72
|
-
// Stripping ports in this way instead of using parsedUrl.hostname to make
|
|
73
|
-
// sure that the brackets around IPv6 addresses are kept.
|
|
74
|
-
hostname = hostname.replace(/:\d*$/, '').toLowerCase()
|
|
75
|
-
port = Number.parseInt(port, 10) || DEFAULT_PORTS[protocol] || 0
|
|
76
|
-
if (!this.#shouldProxy(hostname, port)) {
|
|
77
|
-
return this[kNoProxyAgent]
|
|
78
|
-
}
|
|
79
|
-
if (protocol === 'https:') {
|
|
80
|
-
return this[kHttpsProxyAgent]
|
|
81
|
-
}
|
|
82
|
-
return this[kHttpProxyAgent]
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
#shouldProxy (hostname, port) {
|
|
86
|
-
if (this.#noProxyChanged) {
|
|
87
|
-
this.#parseNoProxy()
|
|
88
|
-
}
|
|
89
|
-
|
|
90
|
-
if (this.#noProxyEntries.length === 0) {
|
|
91
|
-
return true // Always proxy if NO_PROXY is not set or empty.
|
|
92
|
-
}
|
|
93
|
-
if (this.#noProxyValue === '*') {
|
|
94
|
-
return false // Never proxy if wildcard is set.
|
|
95
|
-
}
|
|
96
|
-
|
|
97
|
-
for (let i = 0; i < this.#noProxyEntries.length; i++) {
|
|
98
|
-
const entry = this.#noProxyEntries[i]
|
|
99
|
-
if (entry.port && entry.port !== port) {
|
|
100
|
-
continue // Skip if ports don't match.
|
|
101
|
-
}
|
|
102
|
-
if (!/^[.*]/.test(entry.hostname)) {
|
|
103
|
-
// No wildcards, so don't proxy only if there is not an exact match.
|
|
104
|
-
if (hostname === entry.hostname) {
|
|
105
|
-
return false
|
|
106
|
-
}
|
|
107
|
-
} else {
|
|
108
|
-
// Don't proxy if the hostname ends with the no_proxy host.
|
|
109
|
-
if (hostname.endsWith(entry.hostname.replace(/^\*/, ''))) {
|
|
110
|
-
return false
|
|
111
|
-
}
|
|
112
|
-
}
|
|
113
|
-
}
|
|
114
|
-
|
|
115
|
-
return true
|
|
116
|
-
}
|
|
117
|
-
|
|
118
|
-
#parseNoProxy () {
|
|
119
|
-
const noProxyValue = this.#opts.noProxy ?? this.#noProxyEnv
|
|
120
|
-
const noProxySplit = noProxyValue.split(/[,\s]/)
|
|
121
|
-
const noProxyEntries = []
|
|
122
|
-
|
|
123
|
-
for (let i = 0; i < noProxySplit.length; i++) {
|
|
124
|
-
const entry = noProxySplit[i]
|
|
125
|
-
if (!entry) {
|
|
126
|
-
continue
|
|
127
|
-
}
|
|
128
|
-
const parsed = entry.match(/^(.+):(\d+)$/)
|
|
129
|
-
noProxyEntries.push({
|
|
130
|
-
hostname: (parsed ? parsed[1] : entry).toLowerCase(),
|
|
131
|
-
port: parsed ? Number.parseInt(parsed[2], 10) : 0
|
|
132
|
-
})
|
|
133
|
-
}
|
|
134
|
-
|
|
135
|
-
this.#noProxyValue = noProxyValue
|
|
136
|
-
this.#noProxyEntries = noProxyEntries
|
|
137
|
-
}
|
|
138
|
-
|
|
139
|
-
get #noProxyChanged () {
|
|
140
|
-
if (this.#opts.noProxy !== undefined) {
|
|
141
|
-
return false
|
|
142
|
-
}
|
|
143
|
-
return this.#noProxyValue !== this.#noProxyEnv
|
|
144
|
-
}
|
|
145
|
-
|
|
146
|
-
get #noProxyEnv () {
|
|
147
|
-
return process.env.no_proxy ?? process.env.NO_PROXY ?? ''
|
|
148
|
-
}
|
|
149
|
-
}
|
|
150
|
-
|
|
151
|
-
module.exports = EnvHttpProxyAgent
|
|
@@ -1,159 +0,0 @@
|
|
|
1
|
-
'use strict'
|
|
2
|
-
|
|
3
|
-
// Extracted from node/lib/internal/fixed_queue.js
|
|
4
|
-
|
|
5
|
-
// Currently optimal queue size, tested on V8 6.0 - 6.6. Must be power of two.
|
|
6
|
-
const kSize = 2048
|
|
7
|
-
const kMask = kSize - 1
|
|
8
|
-
|
|
9
|
-
// The FixedQueue is implemented as a singly-linked list of fixed-size
|
|
10
|
-
// circular buffers. It looks something like this:
|
|
11
|
-
//
|
|
12
|
-
// head tail
|
|
13
|
-
// | |
|
|
14
|
-
// v v
|
|
15
|
-
// +-----------+ <-----\ +-----------+ <------\ +-----------+
|
|
16
|
-
// | [null] | \----- | next | \------- | next |
|
|
17
|
-
// +-----------+ +-----------+ +-----------+
|
|
18
|
-
// | item | <-- bottom | item | <-- bottom | undefined |
|
|
19
|
-
// | item | | item | | undefined |
|
|
20
|
-
// | item | | item | | undefined |
|
|
21
|
-
// | item | | item | | undefined |
|
|
22
|
-
// | item | | item | bottom --> | item |
|
|
23
|
-
// | item | | item | | item |
|
|
24
|
-
// | ... | | ... | | ... |
|
|
25
|
-
// | item | | item | | item |
|
|
26
|
-
// | item | | item | | item |
|
|
27
|
-
// | undefined | <-- top | item | | item |
|
|
28
|
-
// | undefined | | item | | item |
|
|
29
|
-
// | undefined | | undefined | <-- top top --> | undefined |
|
|
30
|
-
// +-----------+ +-----------+ +-----------+
|
|
31
|
-
//
|
|
32
|
-
// Or, if there is only one circular buffer, it looks something
|
|
33
|
-
// like either of these:
|
|
34
|
-
//
|
|
35
|
-
// head tail head tail
|
|
36
|
-
// | | | |
|
|
37
|
-
// v v v v
|
|
38
|
-
// +-----------+ +-----------+
|
|
39
|
-
// | [null] | | [null] |
|
|
40
|
-
// +-----------+ +-----------+
|
|
41
|
-
// | undefined | | item |
|
|
42
|
-
// | undefined | | item |
|
|
43
|
-
// | item | <-- bottom top --> | undefined |
|
|
44
|
-
// | item | | undefined |
|
|
45
|
-
// | undefined | <-- top bottom --> | item |
|
|
46
|
-
// | undefined | | item |
|
|
47
|
-
// +-----------+ +-----------+
|
|
48
|
-
//
|
|
49
|
-
// Adding a value means moving `top` forward by one, removing means
|
|
50
|
-
// moving `bottom` forward by one. After reaching the end, the queue
|
|
51
|
-
// wraps around.
|
|
52
|
-
//
|
|
53
|
-
// When `top === bottom` the current queue is empty and when
|
|
54
|
-
// `top + 1 === bottom` it's full. This wastes a single space of storage
|
|
55
|
-
// but allows much quicker checks.
|
|
56
|
-
|
|
57
|
-
/**
|
|
58
|
-
* @type {FixedCircularBuffer}
|
|
59
|
-
* @template T
|
|
60
|
-
*/
|
|
61
|
-
class FixedCircularBuffer {
|
|
62
|
-
constructor () {
|
|
63
|
-
/**
|
|
64
|
-
* @type {number}
|
|
65
|
-
*/
|
|
66
|
-
this.bottom = 0
|
|
67
|
-
/**
|
|
68
|
-
* @type {number}
|
|
69
|
-
*/
|
|
70
|
-
this.top = 0
|
|
71
|
-
/**
|
|
72
|
-
* @type {Array<T|undefined>}
|
|
73
|
-
*/
|
|
74
|
-
this.list = new Array(kSize).fill(undefined)
|
|
75
|
-
/**
|
|
76
|
-
* @type {T|null}
|
|
77
|
-
*/
|
|
78
|
-
this.next = null
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
/**
|
|
82
|
-
* @returns {boolean}
|
|
83
|
-
*/
|
|
84
|
-
isEmpty () {
|
|
85
|
-
return this.top === this.bottom
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
/**
|
|
89
|
-
* @returns {boolean}
|
|
90
|
-
*/
|
|
91
|
-
isFull () {
|
|
92
|
-
return ((this.top + 1) & kMask) === this.bottom
|
|
93
|
-
}
|
|
94
|
-
|
|
95
|
-
/**
|
|
96
|
-
* @param {T} data
|
|
97
|
-
* @returns {void}
|
|
98
|
-
*/
|
|
99
|
-
push (data) {
|
|
100
|
-
this.list[this.top] = data
|
|
101
|
-
this.top = (this.top + 1) & kMask
|
|
102
|
-
}
|
|
103
|
-
|
|
104
|
-
/**
|
|
105
|
-
* @returns {T|null}
|
|
106
|
-
*/
|
|
107
|
-
shift () {
|
|
108
|
-
const nextItem = this.list[this.bottom]
|
|
109
|
-
if (nextItem === undefined) { return null }
|
|
110
|
-
this.list[this.bottom] = undefined
|
|
111
|
-
this.bottom = (this.bottom + 1) & kMask
|
|
112
|
-
return nextItem
|
|
113
|
-
}
|
|
114
|
-
}
|
|
115
|
-
|
|
116
|
-
/**
|
|
117
|
-
* @template T
|
|
118
|
-
*/
|
|
119
|
-
module.exports = class FixedQueue {
|
|
120
|
-
constructor () {
|
|
121
|
-
/**
|
|
122
|
-
* @type {FixedCircularBuffer<T>}
|
|
123
|
-
*/
|
|
124
|
-
this.head = this.tail = new FixedCircularBuffer()
|
|
125
|
-
}
|
|
126
|
-
|
|
127
|
-
/**
|
|
128
|
-
* @returns {boolean}
|
|
129
|
-
*/
|
|
130
|
-
isEmpty () {
|
|
131
|
-
return this.head.isEmpty()
|
|
132
|
-
}
|
|
133
|
-
|
|
134
|
-
/**
|
|
135
|
-
* @param {T} data
|
|
136
|
-
*/
|
|
137
|
-
push (data) {
|
|
138
|
-
if (this.head.isFull()) {
|
|
139
|
-
// Head is full: Creates a new queue, sets the old queue's `.next` to it,
|
|
140
|
-
// and sets it as the new main queue.
|
|
141
|
-
this.head = this.head.next = new FixedCircularBuffer()
|
|
142
|
-
}
|
|
143
|
-
this.head.push(data)
|
|
144
|
-
}
|
|
145
|
-
|
|
146
|
-
/**
|
|
147
|
-
* @returns {T|null}
|
|
148
|
-
*/
|
|
149
|
-
shift () {
|
|
150
|
-
const tail = this.tail
|
|
151
|
-
const next = tail.shift()
|
|
152
|
-
if (tail.isEmpty() && tail.next !== null) {
|
|
153
|
-
// If there is another queue, it forms the new tail.
|
|
154
|
-
this.tail = tail.next
|
|
155
|
-
tail.next = null
|
|
156
|
-
}
|
|
157
|
-
return next
|
|
158
|
-
}
|
|
159
|
-
}
|
|
@@ -1,122 +0,0 @@
|
|
|
1
|
-
'use strict'
|
|
2
|
-
const { connect } = require('node:net')
|
|
3
|
-
|
|
4
|
-
const { kClose, kDestroy } = require('../core/symbols')
|
|
5
|
-
const { InvalidArgumentError } = require('../core/errors')
|
|
6
|
-
const util = require('../core/util')
|
|
7
|
-
|
|
8
|
-
const Client = require('./client')
|
|
9
|
-
const DispatcherBase = require('./dispatcher-base')
|
|
10
|
-
|
|
11
|
-
class H2CClient extends DispatcherBase {
|
|
12
|
-
#client = null
|
|
13
|
-
|
|
14
|
-
constructor (origin, clientOpts) {
|
|
15
|
-
super()
|
|
16
|
-
|
|
17
|
-
if (typeof origin === 'string') {
|
|
18
|
-
origin = new URL(origin)
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
if (origin.protocol !== 'http:') {
|
|
22
|
-
throw new InvalidArgumentError(
|
|
23
|
-
'h2c-client: Only h2c protocol is supported'
|
|
24
|
-
)
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
const { connect, maxConcurrentStreams, pipelining, ...opts } =
|
|
28
|
-
clientOpts ?? {}
|
|
29
|
-
let defaultMaxConcurrentStreams = 100
|
|
30
|
-
let defaultPipelining = 100
|
|
31
|
-
|
|
32
|
-
if (
|
|
33
|
-
maxConcurrentStreams != null &&
|
|
34
|
-
Number.isInteger(maxConcurrentStreams) &&
|
|
35
|
-
maxConcurrentStreams > 0
|
|
36
|
-
) {
|
|
37
|
-
defaultMaxConcurrentStreams = maxConcurrentStreams
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
if (pipelining != null && Number.isInteger(pipelining) && pipelining > 0) {
|
|
41
|
-
defaultPipelining = pipelining
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
if (defaultPipelining > defaultMaxConcurrentStreams) {
|
|
45
|
-
throw new InvalidArgumentError(
|
|
46
|
-
'h2c-client: pipelining cannot be greater than maxConcurrentStreams'
|
|
47
|
-
)
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
this.#client = new Client(origin, {
|
|
51
|
-
...opts,
|
|
52
|
-
connect: this.#buildConnector(connect),
|
|
53
|
-
maxConcurrentStreams: defaultMaxConcurrentStreams,
|
|
54
|
-
pipelining: defaultPipelining,
|
|
55
|
-
allowH2: true
|
|
56
|
-
})
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
#buildConnector (connectOpts) {
|
|
60
|
-
return (opts, callback) => {
|
|
61
|
-
const timeout = connectOpts?.connectOpts ?? 10e3
|
|
62
|
-
const { hostname, port, pathname } = opts
|
|
63
|
-
const socket = connect({
|
|
64
|
-
...opts,
|
|
65
|
-
host: hostname,
|
|
66
|
-
port,
|
|
67
|
-
pathname
|
|
68
|
-
})
|
|
69
|
-
|
|
70
|
-
// Set TCP keep alive options on the socket here instead of in connect() for the case of assigning the socket
|
|
71
|
-
if (opts.keepAlive == null || opts.keepAlive) {
|
|
72
|
-
const keepAliveInitialDelay =
|
|
73
|
-
opts.keepAliveInitialDelay == null ? 60e3 : opts.keepAliveInitialDelay
|
|
74
|
-
socket.setKeepAlive(true, keepAliveInitialDelay)
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
socket.alpnProtocol = 'h2'
|
|
78
|
-
|
|
79
|
-
const clearConnectTimeout = util.setupConnectTimeout(
|
|
80
|
-
new WeakRef(socket),
|
|
81
|
-
{ timeout, hostname, port }
|
|
82
|
-
)
|
|
83
|
-
|
|
84
|
-
socket
|
|
85
|
-
.setNoDelay(true)
|
|
86
|
-
.once('connect', function () {
|
|
87
|
-
queueMicrotask(clearConnectTimeout)
|
|
88
|
-
|
|
89
|
-
if (callback) {
|
|
90
|
-
const cb = callback
|
|
91
|
-
callback = null
|
|
92
|
-
cb(null, this)
|
|
93
|
-
}
|
|
94
|
-
})
|
|
95
|
-
.on('error', function (err) {
|
|
96
|
-
queueMicrotask(clearConnectTimeout)
|
|
97
|
-
|
|
98
|
-
if (callback) {
|
|
99
|
-
const cb = callback
|
|
100
|
-
callback = null
|
|
101
|
-
cb(err)
|
|
102
|
-
}
|
|
103
|
-
})
|
|
104
|
-
|
|
105
|
-
return socket
|
|
106
|
-
}
|
|
107
|
-
}
|
|
108
|
-
|
|
109
|
-
dispatch (opts, handler) {
|
|
110
|
-
return this.#client.dispatch(opts, handler)
|
|
111
|
-
}
|
|
112
|
-
|
|
113
|
-
async [kClose] () {
|
|
114
|
-
await this.#client.close()
|
|
115
|
-
}
|
|
116
|
-
|
|
117
|
-
async [kDestroy] () {
|
|
118
|
-
await this.#client.destroy()
|
|
119
|
-
}
|
|
120
|
-
}
|
|
121
|
-
|
|
122
|
-
module.exports = H2CClient
|