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,399 +0,0 @@
|
|
|
1
|
-
'use strict'
|
|
2
|
-
const { Transform } = require('node:stream')
|
|
3
|
-
const { isASCIINumber, isValidLastEventId } = require('./util')
|
|
4
|
-
|
|
5
|
-
/**
|
|
6
|
-
* @type {number[]} BOM
|
|
7
|
-
*/
|
|
8
|
-
const BOM = [0xEF, 0xBB, 0xBF]
|
|
9
|
-
/**
|
|
10
|
-
* @type {10} LF
|
|
11
|
-
*/
|
|
12
|
-
const LF = 0x0A
|
|
13
|
-
/**
|
|
14
|
-
* @type {13} CR
|
|
15
|
-
*/
|
|
16
|
-
const CR = 0x0D
|
|
17
|
-
/**
|
|
18
|
-
* @type {58} COLON
|
|
19
|
-
*/
|
|
20
|
-
const COLON = 0x3A
|
|
21
|
-
/**
|
|
22
|
-
* @type {32} SPACE
|
|
23
|
-
*/
|
|
24
|
-
const SPACE = 0x20
|
|
25
|
-
|
|
26
|
-
/**
|
|
27
|
-
* @typedef {object} EventSourceStreamEvent
|
|
28
|
-
* @type {object}
|
|
29
|
-
* @property {string} [event] The event type.
|
|
30
|
-
* @property {string} [data] The data of the message.
|
|
31
|
-
* @property {string} [id] A unique ID for the event.
|
|
32
|
-
* @property {string} [retry] The reconnection time, in milliseconds.
|
|
33
|
-
*/
|
|
34
|
-
|
|
35
|
-
/**
|
|
36
|
-
* @typedef eventSourceSettings
|
|
37
|
-
* @type {object}
|
|
38
|
-
* @property {string} [lastEventId] The last event ID received from the server.
|
|
39
|
-
* @property {string} [origin] The origin of the event source.
|
|
40
|
-
* @property {number} [reconnectionTime] The reconnection time, in milliseconds.
|
|
41
|
-
*/
|
|
42
|
-
|
|
43
|
-
class EventSourceStream extends Transform {
|
|
44
|
-
/**
|
|
45
|
-
* @type {eventSourceSettings}
|
|
46
|
-
*/
|
|
47
|
-
state
|
|
48
|
-
|
|
49
|
-
/**
|
|
50
|
-
* Leading byte-order-mark check.
|
|
51
|
-
* @type {boolean}
|
|
52
|
-
*/
|
|
53
|
-
checkBOM = true
|
|
54
|
-
|
|
55
|
-
/**
|
|
56
|
-
* @type {boolean}
|
|
57
|
-
*/
|
|
58
|
-
crlfCheck = false
|
|
59
|
-
|
|
60
|
-
/**
|
|
61
|
-
* @type {boolean}
|
|
62
|
-
*/
|
|
63
|
-
eventEndCheck = false
|
|
64
|
-
|
|
65
|
-
/**
|
|
66
|
-
* @type {Buffer|null}
|
|
67
|
-
*/
|
|
68
|
-
buffer = null
|
|
69
|
-
|
|
70
|
-
pos = 0
|
|
71
|
-
|
|
72
|
-
event = {
|
|
73
|
-
data: undefined,
|
|
74
|
-
event: undefined,
|
|
75
|
-
id: undefined,
|
|
76
|
-
retry: undefined
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
/**
|
|
80
|
-
* @param {object} options
|
|
81
|
-
* @param {boolean} [options.readableObjectMode]
|
|
82
|
-
* @param {eventSourceSettings} [options.eventSourceSettings]
|
|
83
|
-
* @param {(chunk: any, encoding?: BufferEncoding | undefined) => boolean} [options.push]
|
|
84
|
-
*/
|
|
85
|
-
constructor (options = {}) {
|
|
86
|
-
// Enable object mode as EventSourceStream emits objects of shape
|
|
87
|
-
// EventSourceStreamEvent
|
|
88
|
-
options.readableObjectMode = true
|
|
89
|
-
|
|
90
|
-
super(options)
|
|
91
|
-
|
|
92
|
-
this.state = options.eventSourceSettings || {}
|
|
93
|
-
if (options.push) {
|
|
94
|
-
this.push = options.push
|
|
95
|
-
}
|
|
96
|
-
}
|
|
97
|
-
|
|
98
|
-
/**
|
|
99
|
-
* @param {Buffer} chunk
|
|
100
|
-
* @param {string} _encoding
|
|
101
|
-
* @param {Function} callback
|
|
102
|
-
* @returns {void}
|
|
103
|
-
*/
|
|
104
|
-
_transform (chunk, _encoding, callback) {
|
|
105
|
-
if (chunk.length === 0) {
|
|
106
|
-
callback()
|
|
107
|
-
return
|
|
108
|
-
}
|
|
109
|
-
|
|
110
|
-
// Cache the chunk in the buffer, as the data might not be complete while
|
|
111
|
-
// processing it
|
|
112
|
-
// TODO: Investigate if there is a more performant way to handle
|
|
113
|
-
// incoming chunks
|
|
114
|
-
// see: https://github.com/nodejs/undici/issues/2630
|
|
115
|
-
if (this.buffer) {
|
|
116
|
-
this.buffer = Buffer.concat([this.buffer, chunk])
|
|
117
|
-
} else {
|
|
118
|
-
this.buffer = chunk
|
|
119
|
-
}
|
|
120
|
-
|
|
121
|
-
// Strip leading byte-order-mark if we opened the stream and started
|
|
122
|
-
// the processing of the incoming data
|
|
123
|
-
if (this.checkBOM) {
|
|
124
|
-
switch (this.buffer.length) {
|
|
125
|
-
case 1:
|
|
126
|
-
// Check if the first byte is the same as the first byte of the BOM
|
|
127
|
-
if (this.buffer[0] === BOM[0]) {
|
|
128
|
-
// If it is, we need to wait for more data
|
|
129
|
-
callback()
|
|
130
|
-
return
|
|
131
|
-
}
|
|
132
|
-
// Set the checkBOM flag to false as we don't need to check for the
|
|
133
|
-
// BOM anymore
|
|
134
|
-
this.checkBOM = false
|
|
135
|
-
|
|
136
|
-
// The buffer only contains one byte so we need to wait for more data
|
|
137
|
-
callback()
|
|
138
|
-
return
|
|
139
|
-
case 2:
|
|
140
|
-
// Check if the first two bytes are the same as the first two bytes
|
|
141
|
-
// of the BOM
|
|
142
|
-
if (
|
|
143
|
-
this.buffer[0] === BOM[0] &&
|
|
144
|
-
this.buffer[1] === BOM[1]
|
|
145
|
-
) {
|
|
146
|
-
// If it is, we need to wait for more data, because the third byte
|
|
147
|
-
// is needed to determine if it is the BOM or not
|
|
148
|
-
callback()
|
|
149
|
-
return
|
|
150
|
-
}
|
|
151
|
-
|
|
152
|
-
// Set the checkBOM flag to false as we don't need to check for the
|
|
153
|
-
// BOM anymore
|
|
154
|
-
this.checkBOM = false
|
|
155
|
-
break
|
|
156
|
-
case 3:
|
|
157
|
-
// Check if the first three bytes are the same as the first three
|
|
158
|
-
// bytes of the BOM
|
|
159
|
-
if (
|
|
160
|
-
this.buffer[0] === BOM[0] &&
|
|
161
|
-
this.buffer[1] === BOM[1] &&
|
|
162
|
-
this.buffer[2] === BOM[2]
|
|
163
|
-
) {
|
|
164
|
-
// If it is, we can drop the buffered data, as it is only the BOM
|
|
165
|
-
this.buffer = Buffer.alloc(0)
|
|
166
|
-
// Set the checkBOM flag to false as we don't need to check for the
|
|
167
|
-
// BOM anymore
|
|
168
|
-
this.checkBOM = false
|
|
169
|
-
|
|
170
|
-
// Await more data
|
|
171
|
-
callback()
|
|
172
|
-
return
|
|
173
|
-
}
|
|
174
|
-
// If it is not the BOM, we can start processing the data
|
|
175
|
-
this.checkBOM = false
|
|
176
|
-
break
|
|
177
|
-
default:
|
|
178
|
-
// The buffer is longer than 3 bytes, so we can drop the BOM if it is
|
|
179
|
-
// present
|
|
180
|
-
if (
|
|
181
|
-
this.buffer[0] === BOM[0] &&
|
|
182
|
-
this.buffer[1] === BOM[1] &&
|
|
183
|
-
this.buffer[2] === BOM[2]
|
|
184
|
-
) {
|
|
185
|
-
// Remove the BOM from the buffer
|
|
186
|
-
this.buffer = this.buffer.subarray(3)
|
|
187
|
-
}
|
|
188
|
-
|
|
189
|
-
// Set the checkBOM flag to false as we don't need to check for the
|
|
190
|
-
this.checkBOM = false
|
|
191
|
-
break
|
|
192
|
-
}
|
|
193
|
-
}
|
|
194
|
-
|
|
195
|
-
while (this.pos < this.buffer.length) {
|
|
196
|
-
// If the previous line ended with an end-of-line, we need to check
|
|
197
|
-
// if the next character is also an end-of-line.
|
|
198
|
-
if (this.eventEndCheck) {
|
|
199
|
-
// If the the current character is an end-of-line, then the event
|
|
200
|
-
// is finished and we can process it
|
|
201
|
-
|
|
202
|
-
// If the previous line ended with a carriage return, we need to
|
|
203
|
-
// check if the current character is a line feed and remove it
|
|
204
|
-
// from the buffer.
|
|
205
|
-
if (this.crlfCheck) {
|
|
206
|
-
// If the current character is a line feed, we can remove it
|
|
207
|
-
// from the buffer and reset the crlfCheck flag
|
|
208
|
-
if (this.buffer[this.pos] === LF) {
|
|
209
|
-
this.buffer = this.buffer.subarray(this.pos + 1)
|
|
210
|
-
this.pos = 0
|
|
211
|
-
this.crlfCheck = false
|
|
212
|
-
|
|
213
|
-
// It is possible that the line feed is not the end of the
|
|
214
|
-
// event. We need to check if the next character is an
|
|
215
|
-
// end-of-line character to determine if the event is
|
|
216
|
-
// finished. We simply continue the loop to check the next
|
|
217
|
-
// character.
|
|
218
|
-
|
|
219
|
-
// As we removed the line feed from the buffer and set the
|
|
220
|
-
// crlfCheck flag to false, we basically don't make any
|
|
221
|
-
// distinction between a line feed and a carriage return.
|
|
222
|
-
continue
|
|
223
|
-
}
|
|
224
|
-
this.crlfCheck = false
|
|
225
|
-
}
|
|
226
|
-
|
|
227
|
-
if (this.buffer[this.pos] === LF || this.buffer[this.pos] === CR) {
|
|
228
|
-
// If the current character is a carriage return, we need to
|
|
229
|
-
// set the crlfCheck flag to true, as we need to check if the
|
|
230
|
-
// next character is a line feed so we can remove it from the
|
|
231
|
-
// buffer
|
|
232
|
-
if (this.buffer[this.pos] === CR) {
|
|
233
|
-
this.crlfCheck = true
|
|
234
|
-
}
|
|
235
|
-
|
|
236
|
-
this.buffer = this.buffer.subarray(this.pos + 1)
|
|
237
|
-
this.pos = 0
|
|
238
|
-
if (
|
|
239
|
-
this.event.data !== undefined || this.event.event || this.event.id || this.event.retry) {
|
|
240
|
-
this.processEvent(this.event)
|
|
241
|
-
}
|
|
242
|
-
this.clearEvent()
|
|
243
|
-
continue
|
|
244
|
-
}
|
|
245
|
-
// If the current character is not an end-of-line, then the event
|
|
246
|
-
// is not finished and we have to reset the eventEndCheck flag
|
|
247
|
-
this.eventEndCheck = false
|
|
248
|
-
continue
|
|
249
|
-
}
|
|
250
|
-
|
|
251
|
-
// If the current character is an end-of-line, we can process the
|
|
252
|
-
// line
|
|
253
|
-
if (this.buffer[this.pos] === LF || this.buffer[this.pos] === CR) {
|
|
254
|
-
// If the current character is a carriage return, we need to
|
|
255
|
-
// set the crlfCheck flag to true, as we need to check if the
|
|
256
|
-
// next character is a line feed
|
|
257
|
-
if (this.buffer[this.pos] === CR) {
|
|
258
|
-
this.crlfCheck = true
|
|
259
|
-
}
|
|
260
|
-
|
|
261
|
-
// In any case, we can process the line as we reached an
|
|
262
|
-
// end-of-line character
|
|
263
|
-
this.parseLine(this.buffer.subarray(0, this.pos), this.event)
|
|
264
|
-
|
|
265
|
-
// Remove the processed line from the buffer
|
|
266
|
-
this.buffer = this.buffer.subarray(this.pos + 1)
|
|
267
|
-
// Reset the position as we removed the processed line from the buffer
|
|
268
|
-
this.pos = 0
|
|
269
|
-
// A line was processed and this could be the end of the event. We need
|
|
270
|
-
// to check if the next line is empty to determine if the event is
|
|
271
|
-
// finished.
|
|
272
|
-
this.eventEndCheck = true
|
|
273
|
-
continue
|
|
274
|
-
}
|
|
275
|
-
|
|
276
|
-
this.pos++
|
|
277
|
-
}
|
|
278
|
-
|
|
279
|
-
callback()
|
|
280
|
-
}
|
|
281
|
-
|
|
282
|
-
/**
|
|
283
|
-
* @param {Buffer} line
|
|
284
|
-
* @param {EventSourceStreamEvent} event
|
|
285
|
-
*/
|
|
286
|
-
parseLine (line, event) {
|
|
287
|
-
// If the line is empty (a blank line)
|
|
288
|
-
// Dispatch the event, as defined below.
|
|
289
|
-
// This will be handled in the _transform method
|
|
290
|
-
if (line.length === 0) {
|
|
291
|
-
return
|
|
292
|
-
}
|
|
293
|
-
|
|
294
|
-
// If the line starts with a U+003A COLON character (:)
|
|
295
|
-
// Ignore the line.
|
|
296
|
-
const colonPosition = line.indexOf(COLON)
|
|
297
|
-
if (colonPosition === 0) {
|
|
298
|
-
return
|
|
299
|
-
}
|
|
300
|
-
|
|
301
|
-
let field = ''
|
|
302
|
-
let value = ''
|
|
303
|
-
|
|
304
|
-
// If the line contains a U+003A COLON character (:)
|
|
305
|
-
if (colonPosition !== -1) {
|
|
306
|
-
// Collect the characters on the line before the first U+003A COLON
|
|
307
|
-
// character (:), and let field be that string.
|
|
308
|
-
// TODO: Investigate if there is a more performant way to extract the
|
|
309
|
-
// field
|
|
310
|
-
// see: https://github.com/nodejs/undici/issues/2630
|
|
311
|
-
field = line.subarray(0, colonPosition).toString('utf8')
|
|
312
|
-
|
|
313
|
-
// Collect the characters on the line after the first U+003A COLON
|
|
314
|
-
// character (:), and let value be that string.
|
|
315
|
-
// If value starts with a U+0020 SPACE character, remove it from value.
|
|
316
|
-
let valueStart = colonPosition + 1
|
|
317
|
-
if (line[valueStart] === SPACE) {
|
|
318
|
-
++valueStart
|
|
319
|
-
}
|
|
320
|
-
// TODO: Investigate if there is a more performant way to extract the
|
|
321
|
-
// value
|
|
322
|
-
// see: https://github.com/nodejs/undici/issues/2630
|
|
323
|
-
value = line.subarray(valueStart).toString('utf8')
|
|
324
|
-
|
|
325
|
-
// Otherwise, the string is not empty but does not contain a U+003A COLON
|
|
326
|
-
// character (:)
|
|
327
|
-
} else {
|
|
328
|
-
// Process the field using the steps described below, using the whole
|
|
329
|
-
// line as the field name, and the empty string as the field value.
|
|
330
|
-
field = line.toString('utf8')
|
|
331
|
-
value = ''
|
|
332
|
-
}
|
|
333
|
-
|
|
334
|
-
// Modify the event with the field name and value. The value is also
|
|
335
|
-
// decoded as UTF-8
|
|
336
|
-
switch (field) {
|
|
337
|
-
case 'data':
|
|
338
|
-
if (event[field] === undefined) {
|
|
339
|
-
event[field] = value
|
|
340
|
-
} else {
|
|
341
|
-
event[field] += `\n${value}`
|
|
342
|
-
}
|
|
343
|
-
break
|
|
344
|
-
case 'retry':
|
|
345
|
-
if (isASCIINumber(value)) {
|
|
346
|
-
event[field] = value
|
|
347
|
-
}
|
|
348
|
-
break
|
|
349
|
-
case 'id':
|
|
350
|
-
if (isValidLastEventId(value)) {
|
|
351
|
-
event[field] = value
|
|
352
|
-
}
|
|
353
|
-
break
|
|
354
|
-
case 'event':
|
|
355
|
-
if (value.length > 0) {
|
|
356
|
-
event[field] = value
|
|
357
|
-
}
|
|
358
|
-
break
|
|
359
|
-
}
|
|
360
|
-
}
|
|
361
|
-
|
|
362
|
-
/**
|
|
363
|
-
* @param {EventSourceStreamEvent} event
|
|
364
|
-
*/
|
|
365
|
-
processEvent (event) {
|
|
366
|
-
if (event.retry && isASCIINumber(event.retry)) {
|
|
367
|
-
this.state.reconnectionTime = parseInt(event.retry, 10)
|
|
368
|
-
}
|
|
369
|
-
|
|
370
|
-
if (event.id && isValidLastEventId(event.id)) {
|
|
371
|
-
this.state.lastEventId = event.id
|
|
372
|
-
}
|
|
373
|
-
|
|
374
|
-
// only dispatch event, when data is provided
|
|
375
|
-
if (event.data !== undefined) {
|
|
376
|
-
this.push({
|
|
377
|
-
type: event.event || 'message',
|
|
378
|
-
options: {
|
|
379
|
-
data: event.data,
|
|
380
|
-
lastEventId: this.state.lastEventId,
|
|
381
|
-
origin: this.state.origin
|
|
382
|
-
}
|
|
383
|
-
})
|
|
384
|
-
}
|
|
385
|
-
}
|
|
386
|
-
|
|
387
|
-
clearEvent () {
|
|
388
|
-
this.event = {
|
|
389
|
-
data: undefined,
|
|
390
|
-
event: undefined,
|
|
391
|
-
id: undefined,
|
|
392
|
-
retry: undefined
|
|
393
|
-
}
|
|
394
|
-
}
|
|
395
|
-
}
|
|
396
|
-
|
|
397
|
-
module.exports = {
|
|
398
|
-
EventSourceStream
|
|
399
|
-
}
|