@azure/core-sse 2.1.4-alpha.20250318.3 → 2.1.4-alpha.20250320.7
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/dist/browser/index.d.ts +1 -1
- package/dist/browser/index.js.map +1 -1
- package/dist/browser/models.d.ts +11 -0
- package/dist/browser/models.js.map +1 -1
- package/dist/browser/sse.d.ts +10 -4
- package/dist/browser/sse.js.map +1 -1
- package/dist/browser/utils.d.ts +2 -5
- package/dist/browser/utils.js +7 -6
- package/dist/browser/utils.js.map +1 -1
- package/dist/commonjs/index.d.ts +1 -1
- package/dist/commonjs/index.js.map +1 -1
- package/dist/commonjs/models.d.ts +11 -0
- package/dist/commonjs/models.js.map +1 -1
- package/dist/commonjs/sse.d.ts +10 -4
- package/dist/commonjs/sse.js.map +1 -1
- package/dist/commonjs/utils.d.ts +2 -5
- package/dist/commonjs/utils.js +7 -6
- package/dist/commonjs/utils.js.map +1 -1
- package/dist/esm/index.d.ts +1 -1
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/models.d.ts +11 -0
- package/dist/esm/models.js.map +1 -1
- package/dist/esm/sse.d.ts +10 -4
- package/dist/esm/sse.js.map +1 -1
- package/dist/esm/utils.d.ts +2 -5
- package/dist/esm/utils.js +7 -6
- package/dist/esm/utils.js.map +1 -1
- package/dist/react-native/index.d.ts +1 -1
- package/dist/react-native/index.js.map +1 -1
- package/dist/react-native/models.d.ts +11 -0
- package/dist/react-native/models.js.map +1 -1
- package/dist/react-native/sse.d.ts +10 -4
- package/dist/react-native/sse.js.map +1 -1
- package/dist/react-native/utils.d.ts +2 -5
- package/dist/react-native/utils.js +7 -6
- package/dist/react-native/utils.js.map +1 -1
- package/package.json +1 -1
package/dist/browser/index.d.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,uCAAuC;AACvC,kCAAkC;AAElC,OAAO,EAAE,eAAe,EAAE,MAAM,UAAU,CAAC","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nexport { createSseStream } from \"./sse.js\";\nexport { EventMessage, EventMessageStream } from \"./models.js\";\n"]}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,uCAAuC;AACvC,kCAAkC;AAElC,OAAO,EAAE,eAAe,EAAE,MAAM,UAAU,CAAC","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nexport { createSseStream } from \"./sse.js\";\nexport { EventMessage, EventMessageStream, NodeJSReadableStream } from \"./models.js\";\n"]}
|
package/dist/browser/models.d.ts
CHANGED
|
@@ -18,4 +18,15 @@ export interface EventMessage {
|
|
|
18
18
|
export interface EventMessageStream extends ReadableStream<EventMessage>, AsyncDisposable, AsyncIterable<EventMessage> {
|
|
19
19
|
}
|
|
20
20
|
export type PartialSome<T, K extends keyof T> = Omit<T, K> & Partial<Pick<T, K>>;
|
|
21
|
+
/**
|
|
22
|
+
* A Node.js Readable stream that also has a `destroy` method.
|
|
23
|
+
*/
|
|
24
|
+
export interface NodeJSReadableStream extends NodeJS.ReadableStream {
|
|
25
|
+
/**
|
|
26
|
+
* Destroy the stream. Optionally emit an 'error' event, and emit a
|
|
27
|
+
* 'close' event (unless emitClose is set to false). After this call,
|
|
28
|
+
* internal resources will be released.
|
|
29
|
+
*/
|
|
30
|
+
destroy(error?: Error): void;
|
|
31
|
+
}
|
|
21
32
|
//# sourceMappingURL=models.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"models.js","sourceRoot":"","sources":["../../src/models.ts"],"names":[],"mappings":"AAAA,uCAAuC;AACvC,kCAAkC","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\n/**\n * Represents a message sent in an event stream\n * https://developer.mozilla.org/en-US/docs/Web/API/Server-sent_events/Using_server-sent_events#Event_stream_format\n */\nexport interface EventMessage {\n /** The event ID to set the EventSource object's last event ID value. */\n id: string;\n /** A string identifying the type of event described. */\n event: string;\n /** The event data */\n data: string;\n /** The reconnection interval (in milliseconds) to wait before retrying the connection */\n retry?: number;\n}\n\n/**\n * A stream of event messages\n */\nexport interface EventMessageStream\n extends ReadableStream<EventMessage>,\n AsyncDisposable,\n AsyncIterable<EventMessage> {}\n\nexport type PartialSome<T, K extends keyof T> = Omit<T, K> & Partial<Pick<T, K>>;\n"]}
|
|
1
|
+
{"version":3,"file":"models.js","sourceRoot":"","sources":["../../src/models.ts"],"names":[],"mappings":"AAAA,uCAAuC;AACvC,kCAAkC","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\n/**\n * Represents a message sent in an event stream\n * https://developer.mozilla.org/en-US/docs/Web/API/Server-sent_events/Using_server-sent_events#Event_stream_format\n */\nexport interface EventMessage {\n /** The event ID to set the EventSource object's last event ID value. */\n id: string;\n /** A string identifying the type of event described. */\n event: string;\n /** The event data */\n data: string;\n /** The reconnection interval (in milliseconds) to wait before retrying the connection */\n retry?: number;\n}\n\n/**\n * A stream of event messages\n */\nexport interface EventMessageStream\n extends ReadableStream<EventMessage>,\n AsyncDisposable,\n AsyncIterable<EventMessage> {}\n\nexport type PartialSome<T, K extends keyof T> = Omit<T, K> & Partial<Pick<T, K>>;\n\n/**\n * A Node.js Readable stream that also has a `destroy` method.\n */\nexport interface NodeJSReadableStream extends NodeJS.ReadableStream {\n /**\n * Destroy the stream. Optionally emit an 'error' event, and emit a\n * 'close' event (unless emitClose is set to false). After this call,\n * internal resources will be released.\n */\n destroy(error?: Error): void;\n}\n"]}
|
package/dist/browser/sse.d.ts
CHANGED
|
@@ -1,15 +1,21 @@
|
|
|
1
1
|
import type { IncomingMessage } from "node:http";
|
|
2
|
-
import type { EventMessageStream } from "./models.js";
|
|
2
|
+
import type { EventMessageStream, NodeJSReadableStream } from "./models.js";
|
|
3
3
|
/**
|
|
4
4
|
* Processes a response stream into a stream of events.
|
|
5
5
|
* @param chunkStream - A stream of Uint8Array chunks
|
|
6
|
-
* @returns
|
|
6
|
+
* @returns A stream of EventMessage objects
|
|
7
7
|
*/
|
|
8
8
|
export declare function createSseStream(chunkStream: ReadableStream<Uint8Array>): EventMessageStream;
|
|
9
9
|
/**
|
|
10
10
|
* Processes a response stream into a stream of events.
|
|
11
|
-
* @param chunkStream -
|
|
12
|
-
* @returns
|
|
11
|
+
* @param chunkStream - A NodeJS HTTP response
|
|
12
|
+
* @returns A stream of EventMessage objects
|
|
13
13
|
*/
|
|
14
14
|
export declare function createSseStream(chunkStream: IncomingMessage): EventMessageStream;
|
|
15
|
+
/**
|
|
16
|
+
* Processes a response stream into a stream of events.
|
|
17
|
+
* @param chunkStream - A NodeJS Readable stream
|
|
18
|
+
* @returns A stream of EventMessage objects
|
|
19
|
+
*/
|
|
20
|
+
export declare function createSseStream(chunkStream: NodeJSReadableStream): EventMessageStream;
|
|
15
21
|
//# sourceMappingURL=sse.d.ts.map
|
package/dist/browser/sse.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sse.js","sourceRoot":"","sources":["../../src/sse.ts"],"names":[],"mappings":"AAAA,uCAAuC;AACvC,kCAAkC;;
|
|
1
|
+
{"version":3,"file":"sse.js","sourceRoot":"","sources":["../../src/sse.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nimport type { IncomingMessage } from \"node:http\";\nimport type {\n EventMessage,\n EventMessageStream,\n NodeJSReadableStream,\n PartialSome,\n} from \"./models.js\";\nimport { createStream, ensureAsyncIterable } from \"./utils.js\";\n\nenum ControlChars {\n NewLine = 10,\n CarriageReturn = 13,\n Space = 32,\n Colon = 58,\n}\n\n/**\n * Processes a response stream into a stream of events.\n * @param chunkStream - A stream of Uint8Array chunks\n * @returns A stream of EventMessage objects\n */\nexport function createSseStream(chunkStream: ReadableStream<Uint8Array>): EventMessageStream;\n/**\n * Processes a response stream into a stream of events.\n * @param chunkStream - A NodeJS HTTP response\n * @returns A stream of EventMessage objects\n */\nexport function createSseStream(chunkStream: IncomingMessage): EventMessageStream;\n/**\n * Processes a response stream into a stream of events.\n * @param chunkStream - A NodeJS Readable stream\n * @returns A stream of EventMessage objects\n */\nexport function createSseStream(chunkStream: NodeJSReadableStream): EventMessageStream;\nexport function createSseStream(\n chunkStream: IncomingMessage | NodeJSReadableStream | ReadableStream<Uint8Array>,\n): EventMessageStream {\n const { cancel, iterable } = ensureAsyncIterable(chunkStream);\n const asyncIter = toMessage(toLine(iterable));\n return createStream(asyncIter, cancel);\n}\n\nfunction concatBuffer(a: Uint8Array, b: Uint8Array): Uint8Array {\n const res = new Uint8Array(a.length + b.length);\n res.set(a);\n res.set(b, a.length);\n return res;\n}\n\nfunction createMessage(): PartialSome<EventMessage, \"data\"> {\n return {\n data: undefined,\n event: \"\",\n id: \"\",\n retry: undefined,\n };\n}\n\nasync function* toLine(\n chunkIter: AsyncIterable<Uint8Array>,\n): AsyncIterable<{ line: Uint8Array; fieldLen: number }> {\n let buf: Uint8Array | undefined;\n let bufIdx = 0;\n let fieldLen = -1;\n let discardTrailingNewline = false;\n for await (const chunk of chunkIter) {\n if (buf === undefined) {\n buf = chunk;\n bufIdx = 0;\n fieldLen = -1;\n } else {\n buf = concatBuffer(buf, chunk);\n }\n const bufLen = buf.length;\n let start = 0;\n while (bufIdx < bufLen) {\n if (discardTrailingNewline) {\n if (buf[bufIdx] === ControlChars.NewLine) {\n start = ++bufIdx;\n }\n discardTrailingNewline = false;\n }\n let end = -1;\n for (; bufIdx < bufLen && end === -1; ++bufIdx) {\n switch (buf[bufIdx]) {\n case ControlChars.Colon:\n if (fieldLen === -1) {\n fieldLen = bufIdx - start;\n }\n break;\n case ControlChars.CarriageReturn:\n // We need to discard the trailing newline if any but can't do\n // that now because we need to dispatch the current line first.\n discardTrailingNewline = true;\n end = bufIdx;\n break;\n case ControlChars.NewLine:\n end = bufIdx;\n break;\n }\n }\n if (end === -1) {\n // We reached the end of the buffer but the line hasn't ended.\n // Wait for the next chunk and then continue parsing:\n break;\n }\n yield { line: buf.subarray(start, end), fieldLen };\n start = bufIdx; // we're now on the next line\n fieldLen = -1;\n }\n if (start === bufLen) {\n buf = undefined;\n } else if (start !== 0) {\n // discard already processed lines\n buf = buf.subarray(start);\n bufIdx -= start;\n }\n }\n}\n\nasync function* toMessage(\n lineIter: AsyncIterable<{ line: Uint8Array; fieldLen: number }>,\n): AsyncIterableIterator<EventMessage> {\n let message = createMessage();\n const decoder = new TextDecoder();\n for await (const { line, fieldLen } of lineIter) {\n if (line.length === 0 && message.data !== undefined) {\n // empty line denotes end of message. Yield and start a new message:\n yield message as EventMessage;\n message = createMessage();\n } else if (fieldLen > 0) {\n // exclude comments and lines with no values\n // line is of format \"<field>:<value>\" or \"<field>: <value>\"\n // https://html.spec.whatwg.org/multipage/server-sent-events.html#event-stream-interpretation\n const field = decoder.decode(line.subarray(0, fieldLen));\n const valueOffset = fieldLen + (line[fieldLen + 1] === ControlChars.Space ? 2 : 1);\n const value = decoder.decode(line.subarray(valueOffset));\n\n switch (field) {\n case \"data\":\n message.data = message.data ? message.data + \"\\n\" + value : value;\n break;\n case \"event\":\n message.event = value;\n break;\n case \"id\":\n message.id = value;\n break;\n case \"retry\": {\n const retry = parseInt(value, 10);\n if (!isNaN(retry)) {\n message.retry = retry;\n }\n break;\n }\n }\n }\n }\n}\n"]}
|
package/dist/browser/utils.d.ts
CHANGED
|
@@ -1,11 +1,8 @@
|
|
|
1
1
|
import type { IncomingMessage } from "node:http";
|
|
2
|
-
type
|
|
3
|
-
[P in K]: T[P] | null;
|
|
4
|
-
} & Omit<T, K>;
|
|
2
|
+
import type { NodeJSReadableStream } from "./models.js";
|
|
5
3
|
export declare function createStream<T>(asyncIter: AsyncIterableIterator<T>, cancel: () => PromiseLike<void>): ReadableStream<T> & AsyncDisposable & AsyncIterable<T>;
|
|
6
|
-
export declare function ensureAsyncIterable(stream:
|
|
4
|
+
export declare function ensureAsyncIterable(stream: IncomingMessage | NodeJSReadableStream | ReadableStream<Uint8Array>): {
|
|
7
5
|
cancel(): Promise<void>;
|
|
8
6
|
iterable: AsyncIterable<Uint8Array>;
|
|
9
7
|
};
|
|
10
|
-
export {};
|
|
11
8
|
//# sourceMappingURL=utils.d.ts.map
|
package/dist/browser/utils.js
CHANGED
|
@@ -51,12 +51,13 @@ export function ensureAsyncIterable(stream) {
|
|
|
51
51
|
else {
|
|
52
52
|
return {
|
|
53
53
|
cancel: async () => {
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
54
|
+
// socket could be null if the connection is already closed
|
|
55
|
+
if ("socket" in stream && stream.socket) {
|
|
56
|
+
stream.socket.end();
|
|
57
|
+
}
|
|
58
|
+
else {
|
|
59
|
+
stream.destroy();
|
|
60
|
+
}
|
|
60
61
|
},
|
|
61
62
|
iterable: stream,
|
|
62
63
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../src/utils.ts"],"names":[],"mappings":"AAAA,uCAAuC;AACvC,kCAAkC;;
|
|
1
|
+
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../src/utils.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nimport type { IncomingMessage } from \"node:http\";\nimport type { NodeJSReadableStream } from \"./models.js\";\n\nexport function createStream<T>(\n asyncIter: AsyncIterableIterator<T>,\n cancel: () => PromiseLike<void>,\n): ReadableStream<T> & AsyncDisposable & AsyncIterable<T> {\n const stream = iteratorToStream(asyncIter, cancel);\n /** TODO: remove these polyfills once all supported runtimes support them */\n return polyfillStream(stream, cancel);\n}\n\nfunction polyfillStream<T>(\n stream: ReadableStream<T>,\n dispose: () => PromiseLike<void>,\n): ReadableStream<T> & AsyncIterable<T> & AsyncDisposable {\n makeAsyncIterable<T>(stream);\n makeAsyncDisposable(stream, dispose);\n return stream;\n}\n\nfunction makeAsyncDisposable<T>(\n webStream: any,\n dispose: () => PromiseLike<void>,\n): asserts webStream is ReadableStream<T> & AsyncDisposable {\n (Symbol.asyncDispose as any) ??= Symbol(\"Symbol.asyncDispose\");\n if (!webStream[Symbol.asyncDispose]) {\n webStream[Symbol.asyncDispose] = () => dispose();\n }\n}\n\nfunction makeAsyncIterable<T>(\n webStream: any,\n): asserts webStream is ReadableStream<T> & AsyncIterable<T> {\n if (!webStream[Symbol.asyncIterator]) {\n webStream[Symbol.asyncIterator] = () => toAsyncIterable(webStream);\n }\n\n if (!webStream.values) {\n webStream.values = () => toAsyncIterable(webStream);\n }\n}\n\nfunction iteratorToStream<T>(\n iterator: AsyncIterableIterator<T>,\n cancel: () => PromiseLike<void>,\n): ReadableStream<T> {\n return new ReadableStream({\n async pull(controller) {\n const { value, done } = await iterator.next();\n if (done) {\n controller.close();\n } else {\n controller.enqueue(value);\n }\n },\n cancel,\n });\n}\n\nexport function ensureAsyncIterable(\n stream: IncomingMessage | NodeJSReadableStream | ReadableStream<Uint8Array>,\n): {\n cancel(): Promise<void>;\n iterable: AsyncIterable<Uint8Array>;\n} {\n if (isReadableStream(stream)) {\n makeAsyncIterable<Uint8Array>(stream);\n return {\n cancel: () => stream.cancel(),\n iterable: stream,\n };\n } else {\n return {\n cancel: async () => {\n // socket could be null if the connection is already closed\n if (\"socket\" in stream && stream.socket) {\n stream.socket.end();\n } else {\n stream.destroy();\n }\n },\n iterable: stream as AsyncIterable<Uint8Array>,\n };\n }\n}\n\nfunction isReadableStream(body: unknown): body is ReadableStream {\n return Boolean(\n body &&\n typeof (body as ReadableStream).getReader === \"function\" &&\n typeof (body as ReadableStream).tee === \"function\",\n );\n}\n\nasync function* toAsyncIterable<T>(stream: ReadableStream<T>): AsyncIterableIterator<T> {\n const reader = stream.getReader();\n try {\n while (true) {\n const { value, done } = await reader.read();\n if (done) {\n return;\n }\n yield value;\n }\n } finally {\n const cancelPromise = reader.cancel();\n reader.releaseLock();\n await cancelPromise;\n }\n}\n"]}
|
package/dist/commonjs/index.d.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":";AAAA,uCAAuC;AACvC,kCAAkC;;;AAElC,mCAA2C;AAAlC,yGAAA,eAAe,OAAA","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nexport { createSseStream } from \"./sse.js\";\nexport { EventMessage, EventMessageStream } from \"./models.js\";\n"]}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":";AAAA,uCAAuC;AACvC,kCAAkC;;;AAElC,mCAA2C;AAAlC,yGAAA,eAAe,OAAA","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nexport { createSseStream } from \"./sse.js\";\nexport { EventMessage, EventMessageStream, NodeJSReadableStream } from \"./models.js\";\n"]}
|
|
@@ -18,4 +18,15 @@ export interface EventMessage {
|
|
|
18
18
|
export interface EventMessageStream extends ReadableStream<EventMessage>, AsyncDisposable, AsyncIterable<EventMessage> {
|
|
19
19
|
}
|
|
20
20
|
export type PartialSome<T, K extends keyof T> = Omit<T, K> & Partial<Pick<T, K>>;
|
|
21
|
+
/**
|
|
22
|
+
* A Node.js Readable stream that also has a `destroy` method.
|
|
23
|
+
*/
|
|
24
|
+
export interface NodeJSReadableStream extends NodeJS.ReadableStream {
|
|
25
|
+
/**
|
|
26
|
+
* Destroy the stream. Optionally emit an 'error' event, and emit a
|
|
27
|
+
* 'close' event (unless emitClose is set to false). After this call,
|
|
28
|
+
* internal resources will be released.
|
|
29
|
+
*/
|
|
30
|
+
destroy(error?: Error): void;
|
|
31
|
+
}
|
|
21
32
|
//# sourceMappingURL=models.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"models.js","sourceRoot":"","sources":["../../src/models.ts"],"names":[],"mappings":";AAAA,uCAAuC;AACvC,kCAAkC","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\n/**\n * Represents a message sent in an event stream\n * https://developer.mozilla.org/en-US/docs/Web/API/Server-sent_events/Using_server-sent_events#Event_stream_format\n */\nexport interface EventMessage {\n /** The event ID to set the EventSource object's last event ID value. */\n id: string;\n /** A string identifying the type of event described. */\n event: string;\n /** The event data */\n data: string;\n /** The reconnection interval (in milliseconds) to wait before retrying the connection */\n retry?: number;\n}\n\n/**\n * A stream of event messages\n */\nexport interface EventMessageStream\n extends ReadableStream<EventMessage>,\n AsyncDisposable,\n AsyncIterable<EventMessage> {}\n\nexport type PartialSome<T, K extends keyof T> = Omit<T, K> & Partial<Pick<T, K>>;\n"]}
|
|
1
|
+
{"version":3,"file":"models.js","sourceRoot":"","sources":["../../src/models.ts"],"names":[],"mappings":";AAAA,uCAAuC;AACvC,kCAAkC","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\n/**\n * Represents a message sent in an event stream\n * https://developer.mozilla.org/en-US/docs/Web/API/Server-sent_events/Using_server-sent_events#Event_stream_format\n */\nexport interface EventMessage {\n /** The event ID to set the EventSource object's last event ID value. */\n id: string;\n /** A string identifying the type of event described. */\n event: string;\n /** The event data */\n data: string;\n /** The reconnection interval (in milliseconds) to wait before retrying the connection */\n retry?: number;\n}\n\n/**\n * A stream of event messages\n */\nexport interface EventMessageStream\n extends ReadableStream<EventMessage>,\n AsyncDisposable,\n AsyncIterable<EventMessage> {}\n\nexport type PartialSome<T, K extends keyof T> = Omit<T, K> & Partial<Pick<T, K>>;\n\n/**\n * A Node.js Readable stream that also has a `destroy` method.\n */\nexport interface NodeJSReadableStream extends NodeJS.ReadableStream {\n /**\n * Destroy the stream. Optionally emit an 'error' event, and emit a\n * 'close' event (unless emitClose is set to false). After this call,\n * internal resources will be released.\n */\n destroy(error?: Error): void;\n}\n"]}
|
package/dist/commonjs/sse.d.ts
CHANGED
|
@@ -1,15 +1,21 @@
|
|
|
1
1
|
import type { IncomingMessage } from "node:http";
|
|
2
|
-
import type { EventMessageStream } from "./models.js";
|
|
2
|
+
import type { EventMessageStream, NodeJSReadableStream } from "./models.js";
|
|
3
3
|
/**
|
|
4
4
|
* Processes a response stream into a stream of events.
|
|
5
5
|
* @param chunkStream - A stream of Uint8Array chunks
|
|
6
|
-
* @returns
|
|
6
|
+
* @returns A stream of EventMessage objects
|
|
7
7
|
*/
|
|
8
8
|
export declare function createSseStream(chunkStream: ReadableStream<Uint8Array>): EventMessageStream;
|
|
9
9
|
/**
|
|
10
10
|
* Processes a response stream into a stream of events.
|
|
11
|
-
* @param chunkStream -
|
|
12
|
-
* @returns
|
|
11
|
+
* @param chunkStream - A NodeJS HTTP response
|
|
12
|
+
* @returns A stream of EventMessage objects
|
|
13
13
|
*/
|
|
14
14
|
export declare function createSseStream(chunkStream: IncomingMessage): EventMessageStream;
|
|
15
|
+
/**
|
|
16
|
+
* Processes a response stream into a stream of events.
|
|
17
|
+
* @param chunkStream - A NodeJS Readable stream
|
|
18
|
+
* @returns A stream of EventMessage objects
|
|
19
|
+
*/
|
|
20
|
+
export declare function createSseStream(chunkStream: NodeJSReadableStream): EventMessageStream;
|
|
15
21
|
//# sourceMappingURL=sse.d.ts.map
|
package/dist/commonjs/sse.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sse.js","sourceRoot":"","sources":["../../src/sse.ts"],"names":[],"mappings":";AAAA,uCAAuC;AACvC,kCAAkC;;
|
|
1
|
+
{"version":3,"file":"sse.js","sourceRoot":"","sources":["../../src/sse.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nimport type { IncomingMessage } from \"node:http\";\nimport type {\n EventMessage,\n EventMessageStream,\n NodeJSReadableStream,\n PartialSome,\n} from \"./models.js\";\nimport { createStream, ensureAsyncIterable } from \"./utils.js\";\n\nenum ControlChars {\n NewLine = 10,\n CarriageReturn = 13,\n Space = 32,\n Colon = 58,\n}\n\n/**\n * Processes a response stream into a stream of events.\n * @param chunkStream - A stream of Uint8Array chunks\n * @returns A stream of EventMessage objects\n */\nexport function createSseStream(chunkStream: ReadableStream<Uint8Array>): EventMessageStream;\n/**\n * Processes a response stream into a stream of events.\n * @param chunkStream - A NodeJS HTTP response\n * @returns A stream of EventMessage objects\n */\nexport function createSseStream(chunkStream: IncomingMessage): EventMessageStream;\n/**\n * Processes a response stream into a stream of events.\n * @param chunkStream - A NodeJS Readable stream\n * @returns A stream of EventMessage objects\n */\nexport function createSseStream(chunkStream: NodeJSReadableStream): EventMessageStream;\nexport function createSseStream(\n chunkStream: IncomingMessage | NodeJSReadableStream | ReadableStream<Uint8Array>,\n): EventMessageStream {\n const { cancel, iterable } = ensureAsyncIterable(chunkStream);\n const asyncIter = toMessage(toLine(iterable));\n return createStream(asyncIter, cancel);\n}\n\nfunction concatBuffer(a: Uint8Array, b: Uint8Array): Uint8Array {\n const res = new Uint8Array(a.length + b.length);\n res.set(a);\n res.set(b, a.length);\n return res;\n}\n\nfunction createMessage(): PartialSome<EventMessage, \"data\"> {\n return {\n data: undefined,\n event: \"\",\n id: \"\",\n retry: undefined,\n };\n}\n\nasync function* toLine(\n chunkIter: AsyncIterable<Uint8Array>,\n): AsyncIterable<{ line: Uint8Array; fieldLen: number }> {\n let buf: Uint8Array | undefined;\n let bufIdx = 0;\n let fieldLen = -1;\n let discardTrailingNewline = false;\n for await (const chunk of chunkIter) {\n if (buf === undefined) {\n buf = chunk;\n bufIdx = 0;\n fieldLen = -1;\n } else {\n buf = concatBuffer(buf, chunk);\n }\n const bufLen = buf.length;\n let start = 0;\n while (bufIdx < bufLen) {\n if (discardTrailingNewline) {\n if (buf[bufIdx] === ControlChars.NewLine) {\n start = ++bufIdx;\n }\n discardTrailingNewline = false;\n }\n let end = -1;\n for (; bufIdx < bufLen && end === -1; ++bufIdx) {\n switch (buf[bufIdx]) {\n case ControlChars.Colon:\n if (fieldLen === -1) {\n fieldLen = bufIdx - start;\n }\n break;\n case ControlChars.CarriageReturn:\n // We need to discard the trailing newline if any but can't do\n // that now because we need to dispatch the current line first.\n discardTrailingNewline = true;\n end = bufIdx;\n break;\n case ControlChars.NewLine:\n end = bufIdx;\n break;\n }\n }\n if (end === -1) {\n // We reached the end of the buffer but the line hasn't ended.\n // Wait for the next chunk and then continue parsing:\n break;\n }\n yield { line: buf.subarray(start, end), fieldLen };\n start = bufIdx; // we're now on the next line\n fieldLen = -1;\n }\n if (start === bufLen) {\n buf = undefined;\n } else if (start !== 0) {\n // discard already processed lines\n buf = buf.subarray(start);\n bufIdx -= start;\n }\n }\n}\n\nasync function* toMessage(\n lineIter: AsyncIterable<{ line: Uint8Array; fieldLen: number }>,\n): AsyncIterableIterator<EventMessage> {\n let message = createMessage();\n const decoder = new TextDecoder();\n for await (const { line, fieldLen } of lineIter) {\n if (line.length === 0 && message.data !== undefined) {\n // empty line denotes end of message. Yield and start a new message:\n yield message as EventMessage;\n message = createMessage();\n } else if (fieldLen > 0) {\n // exclude comments and lines with no values\n // line is of format \"<field>:<value>\" or \"<field>: <value>\"\n // https://html.spec.whatwg.org/multipage/server-sent-events.html#event-stream-interpretation\n const field = decoder.decode(line.subarray(0, fieldLen));\n const valueOffset = fieldLen + (line[fieldLen + 1] === ControlChars.Space ? 2 : 1);\n const value = decoder.decode(line.subarray(valueOffset));\n\n switch (field) {\n case \"data\":\n message.data = message.data ? message.data + \"\\n\" + value : value;\n break;\n case \"event\":\n message.event = value;\n break;\n case \"id\":\n message.id = value;\n break;\n case \"retry\": {\n const retry = parseInt(value, 10);\n if (!isNaN(retry)) {\n message.retry = retry;\n }\n break;\n }\n }\n }\n }\n}\n"]}
|
package/dist/commonjs/utils.d.ts
CHANGED
|
@@ -1,11 +1,8 @@
|
|
|
1
1
|
import type { IncomingMessage } from "node:http";
|
|
2
|
-
type
|
|
3
|
-
[P in K]: T[P] | null;
|
|
4
|
-
} & Omit<T, K>;
|
|
2
|
+
import type { NodeJSReadableStream } from "./models.js";
|
|
5
3
|
export declare function createStream<T>(asyncIter: AsyncIterableIterator<T>, cancel: () => PromiseLike<void>): ReadableStream<T> & AsyncDisposable & AsyncIterable<T>;
|
|
6
|
-
export declare function ensureAsyncIterable(stream:
|
|
4
|
+
export declare function ensureAsyncIterable(stream: IncomingMessage | NodeJSReadableStream | ReadableStream<Uint8Array>): {
|
|
7
5
|
cancel(): Promise<void>;
|
|
8
6
|
iterable: AsyncIterable<Uint8Array>;
|
|
9
7
|
};
|
|
10
|
-
export {};
|
|
11
8
|
//# sourceMappingURL=utils.d.ts.map
|
package/dist/commonjs/utils.js
CHANGED
|
@@ -55,12 +55,13 @@ function ensureAsyncIterable(stream) {
|
|
|
55
55
|
else {
|
|
56
56
|
return {
|
|
57
57
|
cancel: async () => {
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
58
|
+
// socket could be null if the connection is already closed
|
|
59
|
+
if ("socket" in stream && stream.socket) {
|
|
60
|
+
stream.socket.end();
|
|
61
|
+
}
|
|
62
|
+
else {
|
|
63
|
+
stream.destroy();
|
|
64
|
+
}
|
|
64
65
|
},
|
|
65
66
|
iterable: stream,
|
|
66
67
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../src/utils.ts"],"names":[],"mappings":";AAAA,uCAAuC;AACvC,kCAAkC;;
|
|
1
|
+
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../src/utils.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nimport type { IncomingMessage } from \"node:http\";\nimport type { NodeJSReadableStream } from \"./models.js\";\n\nexport function createStream<T>(\n asyncIter: AsyncIterableIterator<T>,\n cancel: () => PromiseLike<void>,\n): ReadableStream<T> & AsyncDisposable & AsyncIterable<T> {\n const stream = iteratorToStream(asyncIter, cancel);\n /** TODO: remove these polyfills once all supported runtimes support them */\n return polyfillStream(stream, cancel);\n}\n\nfunction polyfillStream<T>(\n stream: ReadableStream<T>,\n dispose: () => PromiseLike<void>,\n): ReadableStream<T> & AsyncIterable<T> & AsyncDisposable {\n makeAsyncIterable<T>(stream);\n makeAsyncDisposable(stream, dispose);\n return stream;\n}\n\nfunction makeAsyncDisposable<T>(\n webStream: any,\n dispose: () => PromiseLike<void>,\n): asserts webStream is ReadableStream<T> & AsyncDisposable {\n (Symbol.asyncDispose as any) ??= Symbol(\"Symbol.asyncDispose\");\n if (!webStream[Symbol.asyncDispose]) {\n webStream[Symbol.asyncDispose] = () => dispose();\n }\n}\n\nfunction makeAsyncIterable<T>(\n webStream: any,\n): asserts webStream is ReadableStream<T> & AsyncIterable<T> {\n if (!webStream[Symbol.asyncIterator]) {\n webStream[Symbol.asyncIterator] = () => toAsyncIterable(webStream);\n }\n\n if (!webStream.values) {\n webStream.values = () => toAsyncIterable(webStream);\n }\n}\n\nfunction iteratorToStream<T>(\n iterator: AsyncIterableIterator<T>,\n cancel: () => PromiseLike<void>,\n): ReadableStream<T> {\n return new ReadableStream({\n async pull(controller) {\n const { value, done } = await iterator.next();\n if (done) {\n controller.close();\n } else {\n controller.enqueue(value);\n }\n },\n cancel,\n });\n}\n\nexport function ensureAsyncIterable(\n stream: IncomingMessage | NodeJSReadableStream | ReadableStream<Uint8Array>,\n): {\n cancel(): Promise<void>;\n iterable: AsyncIterable<Uint8Array>;\n} {\n if (isReadableStream(stream)) {\n makeAsyncIterable<Uint8Array>(stream);\n return {\n cancel: () => stream.cancel(),\n iterable: stream,\n };\n } else {\n return {\n cancel: async () => {\n // socket could be null if the connection is already closed\n if (\"socket\" in stream && stream.socket) {\n stream.socket.end();\n } else {\n stream.destroy();\n }\n },\n iterable: stream as AsyncIterable<Uint8Array>,\n };\n }\n}\n\nfunction isReadableStream(body: unknown): body is ReadableStream {\n return Boolean(\n body &&\n typeof (body as ReadableStream).getReader === \"function\" &&\n typeof (body as ReadableStream).tee === \"function\",\n );\n}\n\nasync function* toAsyncIterable<T>(stream: ReadableStream<T>): AsyncIterableIterator<T> {\n const reader = stream.getReader();\n try {\n while (true) {\n const { value, done } = await reader.read();\n if (done) {\n return;\n }\n yield value;\n }\n } finally {\n const cancelPromise = reader.cancel();\n reader.releaseLock();\n await cancelPromise;\n }\n}\n"]}
|
package/dist/esm/index.d.ts
CHANGED
package/dist/esm/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,uCAAuC;AACvC,kCAAkC;AAElC,OAAO,EAAE,eAAe,EAAE,MAAM,UAAU,CAAC","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nexport { createSseStream } from \"./sse.js\";\nexport { EventMessage, EventMessageStream } from \"./models.js\";\n"]}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,uCAAuC;AACvC,kCAAkC;AAElC,OAAO,EAAE,eAAe,EAAE,MAAM,UAAU,CAAC","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nexport { createSseStream } from \"./sse.js\";\nexport { EventMessage, EventMessageStream, NodeJSReadableStream } from \"./models.js\";\n"]}
|
package/dist/esm/models.d.ts
CHANGED
|
@@ -18,4 +18,15 @@ export interface EventMessage {
|
|
|
18
18
|
export interface EventMessageStream extends ReadableStream<EventMessage>, AsyncDisposable, AsyncIterable<EventMessage> {
|
|
19
19
|
}
|
|
20
20
|
export type PartialSome<T, K extends keyof T> = Omit<T, K> & Partial<Pick<T, K>>;
|
|
21
|
+
/**
|
|
22
|
+
* A Node.js Readable stream that also has a `destroy` method.
|
|
23
|
+
*/
|
|
24
|
+
export interface NodeJSReadableStream extends NodeJS.ReadableStream {
|
|
25
|
+
/**
|
|
26
|
+
* Destroy the stream. Optionally emit an 'error' event, and emit a
|
|
27
|
+
* 'close' event (unless emitClose is set to false). After this call,
|
|
28
|
+
* internal resources will be released.
|
|
29
|
+
*/
|
|
30
|
+
destroy(error?: Error): void;
|
|
31
|
+
}
|
|
21
32
|
//# sourceMappingURL=models.d.ts.map
|
package/dist/esm/models.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"models.js","sourceRoot":"","sources":["../../src/models.ts"],"names":[],"mappings":"AAAA,uCAAuC;AACvC,kCAAkC","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\n/**\n * Represents a message sent in an event stream\n * https://developer.mozilla.org/en-US/docs/Web/API/Server-sent_events/Using_server-sent_events#Event_stream_format\n */\nexport interface EventMessage {\n /** The event ID to set the EventSource object's last event ID value. */\n id: string;\n /** A string identifying the type of event described. */\n event: string;\n /** The event data */\n data: string;\n /** The reconnection interval (in milliseconds) to wait before retrying the connection */\n retry?: number;\n}\n\n/**\n * A stream of event messages\n */\nexport interface EventMessageStream\n extends ReadableStream<EventMessage>,\n AsyncDisposable,\n AsyncIterable<EventMessage> {}\n\nexport type PartialSome<T, K extends keyof T> = Omit<T, K> & Partial<Pick<T, K>>;\n"]}
|
|
1
|
+
{"version":3,"file":"models.js","sourceRoot":"","sources":["../../src/models.ts"],"names":[],"mappings":"AAAA,uCAAuC;AACvC,kCAAkC","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\n/**\n * Represents a message sent in an event stream\n * https://developer.mozilla.org/en-US/docs/Web/API/Server-sent_events/Using_server-sent_events#Event_stream_format\n */\nexport interface EventMessage {\n /** The event ID to set the EventSource object's last event ID value. */\n id: string;\n /** A string identifying the type of event described. */\n event: string;\n /** The event data */\n data: string;\n /** The reconnection interval (in milliseconds) to wait before retrying the connection */\n retry?: number;\n}\n\n/**\n * A stream of event messages\n */\nexport interface EventMessageStream\n extends ReadableStream<EventMessage>,\n AsyncDisposable,\n AsyncIterable<EventMessage> {}\n\nexport type PartialSome<T, K extends keyof T> = Omit<T, K> & Partial<Pick<T, K>>;\n\n/**\n * A Node.js Readable stream that also has a `destroy` method.\n */\nexport interface NodeJSReadableStream extends NodeJS.ReadableStream {\n /**\n * Destroy the stream. Optionally emit an 'error' event, and emit a\n * 'close' event (unless emitClose is set to false). After this call,\n * internal resources will be released.\n */\n destroy(error?: Error): void;\n}\n"]}
|
package/dist/esm/sse.d.ts
CHANGED
|
@@ -1,15 +1,21 @@
|
|
|
1
1
|
import type { IncomingMessage } from "node:http";
|
|
2
|
-
import type { EventMessageStream } from "./models.js";
|
|
2
|
+
import type { EventMessageStream, NodeJSReadableStream } from "./models.js";
|
|
3
3
|
/**
|
|
4
4
|
* Processes a response stream into a stream of events.
|
|
5
5
|
* @param chunkStream - A stream of Uint8Array chunks
|
|
6
|
-
* @returns
|
|
6
|
+
* @returns A stream of EventMessage objects
|
|
7
7
|
*/
|
|
8
8
|
export declare function createSseStream(chunkStream: ReadableStream<Uint8Array>): EventMessageStream;
|
|
9
9
|
/**
|
|
10
10
|
* Processes a response stream into a stream of events.
|
|
11
|
-
* @param chunkStream -
|
|
12
|
-
* @returns
|
|
11
|
+
* @param chunkStream - A NodeJS HTTP response
|
|
12
|
+
* @returns A stream of EventMessage objects
|
|
13
13
|
*/
|
|
14
14
|
export declare function createSseStream(chunkStream: IncomingMessage): EventMessageStream;
|
|
15
|
+
/**
|
|
16
|
+
* Processes a response stream into a stream of events.
|
|
17
|
+
* @param chunkStream - A NodeJS Readable stream
|
|
18
|
+
* @returns A stream of EventMessage objects
|
|
19
|
+
*/
|
|
20
|
+
export declare function createSseStream(chunkStream: NodeJSReadableStream): EventMessageStream;
|
|
15
21
|
//# sourceMappingURL=sse.d.ts.map
|
package/dist/esm/sse.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sse.js","sourceRoot":"","sources":["../../src/sse.ts"],"names":[],"mappings":"AAAA,uCAAuC;AACvC,kCAAkC;;
|
|
1
|
+
{"version":3,"file":"sse.js","sourceRoot":"","sources":["../../src/sse.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nimport type { IncomingMessage } from \"node:http\";\nimport type {\n EventMessage,\n EventMessageStream,\n NodeJSReadableStream,\n PartialSome,\n} from \"./models.js\";\nimport { createStream, ensureAsyncIterable } from \"./utils.js\";\n\nenum ControlChars {\n NewLine = 10,\n CarriageReturn = 13,\n Space = 32,\n Colon = 58,\n}\n\n/**\n * Processes a response stream into a stream of events.\n * @param chunkStream - A stream of Uint8Array chunks\n * @returns A stream of EventMessage objects\n */\nexport function createSseStream(chunkStream: ReadableStream<Uint8Array>): EventMessageStream;\n/**\n * Processes a response stream into a stream of events.\n * @param chunkStream - A NodeJS HTTP response\n * @returns A stream of EventMessage objects\n */\nexport function createSseStream(chunkStream: IncomingMessage): EventMessageStream;\n/**\n * Processes a response stream into a stream of events.\n * @param chunkStream - A NodeJS Readable stream\n * @returns A stream of EventMessage objects\n */\nexport function createSseStream(chunkStream: NodeJSReadableStream): EventMessageStream;\nexport function createSseStream(\n chunkStream: IncomingMessage | NodeJSReadableStream | ReadableStream<Uint8Array>,\n): EventMessageStream {\n const { cancel, iterable } = ensureAsyncIterable(chunkStream);\n const asyncIter = toMessage(toLine(iterable));\n return createStream(asyncIter, cancel);\n}\n\nfunction concatBuffer(a: Uint8Array, b: Uint8Array): Uint8Array {\n const res = new Uint8Array(a.length + b.length);\n res.set(a);\n res.set(b, a.length);\n return res;\n}\n\nfunction createMessage(): PartialSome<EventMessage, \"data\"> {\n return {\n data: undefined,\n event: \"\",\n id: \"\",\n retry: undefined,\n };\n}\n\nasync function* toLine(\n chunkIter: AsyncIterable<Uint8Array>,\n): AsyncIterable<{ line: Uint8Array; fieldLen: number }> {\n let buf: Uint8Array | undefined;\n let bufIdx = 0;\n let fieldLen = -1;\n let discardTrailingNewline = false;\n for await (const chunk of chunkIter) {\n if (buf === undefined) {\n buf = chunk;\n bufIdx = 0;\n fieldLen = -1;\n } else {\n buf = concatBuffer(buf, chunk);\n }\n const bufLen = buf.length;\n let start = 0;\n while (bufIdx < bufLen) {\n if (discardTrailingNewline) {\n if (buf[bufIdx] === ControlChars.NewLine) {\n start = ++bufIdx;\n }\n discardTrailingNewline = false;\n }\n let end = -1;\n for (; bufIdx < bufLen && end === -1; ++bufIdx) {\n switch (buf[bufIdx]) {\n case ControlChars.Colon:\n if (fieldLen === -1) {\n fieldLen = bufIdx - start;\n }\n break;\n case ControlChars.CarriageReturn:\n // We need to discard the trailing newline if any but can't do\n // that now because we need to dispatch the current line first.\n discardTrailingNewline = true;\n end = bufIdx;\n break;\n case ControlChars.NewLine:\n end = bufIdx;\n break;\n }\n }\n if (end === -1) {\n // We reached the end of the buffer but the line hasn't ended.\n // Wait for the next chunk and then continue parsing:\n break;\n }\n yield { line: buf.subarray(start, end), fieldLen };\n start = bufIdx; // we're now on the next line\n fieldLen = -1;\n }\n if (start === bufLen) {\n buf = undefined;\n } else if (start !== 0) {\n // discard already processed lines\n buf = buf.subarray(start);\n bufIdx -= start;\n }\n }\n}\n\nasync function* toMessage(\n lineIter: AsyncIterable<{ line: Uint8Array; fieldLen: number }>,\n): AsyncIterableIterator<EventMessage> {\n let message = createMessage();\n const decoder = new TextDecoder();\n for await (const { line, fieldLen } of lineIter) {\n if (line.length === 0 && message.data !== undefined) {\n // empty line denotes end of message. Yield and start a new message:\n yield message as EventMessage;\n message = createMessage();\n } else if (fieldLen > 0) {\n // exclude comments and lines with no values\n // line is of format \"<field>:<value>\" or \"<field>: <value>\"\n // https://html.spec.whatwg.org/multipage/server-sent-events.html#event-stream-interpretation\n const field = decoder.decode(line.subarray(0, fieldLen));\n const valueOffset = fieldLen + (line[fieldLen + 1] === ControlChars.Space ? 2 : 1);\n const value = decoder.decode(line.subarray(valueOffset));\n\n switch (field) {\n case \"data\":\n message.data = message.data ? message.data + \"\\n\" + value : value;\n break;\n case \"event\":\n message.event = value;\n break;\n case \"id\":\n message.id = value;\n break;\n case \"retry\": {\n const retry = parseInt(value, 10);\n if (!isNaN(retry)) {\n message.retry = retry;\n }\n break;\n }\n }\n }\n }\n}\n"]}
|
package/dist/esm/utils.d.ts
CHANGED
|
@@ -1,11 +1,8 @@
|
|
|
1
1
|
import type { IncomingMessage } from "node:http";
|
|
2
|
-
type
|
|
3
|
-
[P in K]: T[P] | null;
|
|
4
|
-
} & Omit<T, K>;
|
|
2
|
+
import type { NodeJSReadableStream } from "./models.js";
|
|
5
3
|
export declare function createStream<T>(asyncIter: AsyncIterableIterator<T>, cancel: () => PromiseLike<void>): ReadableStream<T> & AsyncDisposable & AsyncIterable<T>;
|
|
6
|
-
export declare function ensureAsyncIterable(stream:
|
|
4
|
+
export declare function ensureAsyncIterable(stream: IncomingMessage | NodeJSReadableStream | ReadableStream<Uint8Array>): {
|
|
7
5
|
cancel(): Promise<void>;
|
|
8
6
|
iterable: AsyncIterable<Uint8Array>;
|
|
9
7
|
};
|
|
10
|
-
export {};
|
|
11
8
|
//# sourceMappingURL=utils.d.ts.map
|
package/dist/esm/utils.js
CHANGED
|
@@ -51,12 +51,13 @@ export function ensureAsyncIterable(stream) {
|
|
|
51
51
|
else {
|
|
52
52
|
return {
|
|
53
53
|
cancel: async () => {
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
54
|
+
// socket could be null if the connection is already closed
|
|
55
|
+
if ("socket" in stream && stream.socket) {
|
|
56
|
+
stream.socket.end();
|
|
57
|
+
}
|
|
58
|
+
else {
|
|
59
|
+
stream.destroy();
|
|
60
|
+
}
|
|
60
61
|
},
|
|
61
62
|
iterable: stream,
|
|
62
63
|
};
|
package/dist/esm/utils.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../src/utils.ts"],"names":[],"mappings":"AAAA,uCAAuC;AACvC,kCAAkC;;
|
|
1
|
+
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../src/utils.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nimport type { IncomingMessage } from \"node:http\";\nimport type { NodeJSReadableStream } from \"./models.js\";\n\nexport function createStream<T>(\n asyncIter: AsyncIterableIterator<T>,\n cancel: () => PromiseLike<void>,\n): ReadableStream<T> & AsyncDisposable & AsyncIterable<T> {\n const stream = iteratorToStream(asyncIter, cancel);\n /** TODO: remove these polyfills once all supported runtimes support them */\n return polyfillStream(stream, cancel);\n}\n\nfunction polyfillStream<T>(\n stream: ReadableStream<T>,\n dispose: () => PromiseLike<void>,\n): ReadableStream<T> & AsyncIterable<T> & AsyncDisposable {\n makeAsyncIterable<T>(stream);\n makeAsyncDisposable(stream, dispose);\n return stream;\n}\n\nfunction makeAsyncDisposable<T>(\n webStream: any,\n dispose: () => PromiseLike<void>,\n): asserts webStream is ReadableStream<T> & AsyncDisposable {\n (Symbol.asyncDispose as any) ??= Symbol(\"Symbol.asyncDispose\");\n if (!webStream[Symbol.asyncDispose]) {\n webStream[Symbol.asyncDispose] = () => dispose();\n }\n}\n\nfunction makeAsyncIterable<T>(\n webStream: any,\n): asserts webStream is ReadableStream<T> & AsyncIterable<T> {\n if (!webStream[Symbol.asyncIterator]) {\n webStream[Symbol.asyncIterator] = () => toAsyncIterable(webStream);\n }\n\n if (!webStream.values) {\n webStream.values = () => toAsyncIterable(webStream);\n }\n}\n\nfunction iteratorToStream<T>(\n iterator: AsyncIterableIterator<T>,\n cancel: () => PromiseLike<void>,\n): ReadableStream<T> {\n return new ReadableStream({\n async pull(controller) {\n const { value, done } = await iterator.next();\n if (done) {\n controller.close();\n } else {\n controller.enqueue(value);\n }\n },\n cancel,\n });\n}\n\nexport function ensureAsyncIterable(\n stream: IncomingMessage | NodeJSReadableStream | ReadableStream<Uint8Array>,\n): {\n cancel(): Promise<void>;\n iterable: AsyncIterable<Uint8Array>;\n} {\n if (isReadableStream(stream)) {\n makeAsyncIterable<Uint8Array>(stream);\n return {\n cancel: () => stream.cancel(),\n iterable: stream,\n };\n } else {\n return {\n cancel: async () => {\n // socket could be null if the connection is already closed\n if (\"socket\" in stream && stream.socket) {\n stream.socket.end();\n } else {\n stream.destroy();\n }\n },\n iterable: stream as AsyncIterable<Uint8Array>,\n };\n }\n}\n\nfunction isReadableStream(body: unknown): body is ReadableStream {\n return Boolean(\n body &&\n typeof (body as ReadableStream).getReader === \"function\" &&\n typeof (body as ReadableStream).tee === \"function\",\n );\n}\n\nasync function* toAsyncIterable<T>(stream: ReadableStream<T>): AsyncIterableIterator<T> {\n const reader = stream.getReader();\n try {\n while (true) {\n const { value, done } = await reader.read();\n if (done) {\n return;\n }\n yield value;\n }\n } finally {\n const cancelPromise = reader.cancel();\n reader.releaseLock();\n await cancelPromise;\n }\n}\n"]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,uCAAuC;AACvC,kCAAkC;AAElC,OAAO,EAAE,eAAe,EAAE,MAAM,UAAU,CAAC","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nexport { createSseStream } from \"./sse.js\";\nexport { EventMessage, EventMessageStream } from \"./models.js\";\n"]}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,uCAAuC;AACvC,kCAAkC;AAElC,OAAO,EAAE,eAAe,EAAE,MAAM,UAAU,CAAC","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nexport { createSseStream } from \"./sse.js\";\nexport { EventMessage, EventMessageStream, NodeJSReadableStream } from \"./models.js\";\n"]}
|
|
@@ -18,4 +18,15 @@ export interface EventMessage {
|
|
|
18
18
|
export interface EventMessageStream extends ReadableStream<EventMessage>, AsyncDisposable, AsyncIterable<EventMessage> {
|
|
19
19
|
}
|
|
20
20
|
export type PartialSome<T, K extends keyof T> = Omit<T, K> & Partial<Pick<T, K>>;
|
|
21
|
+
/**
|
|
22
|
+
* A Node.js Readable stream that also has a `destroy` method.
|
|
23
|
+
*/
|
|
24
|
+
export interface NodeJSReadableStream extends NodeJS.ReadableStream {
|
|
25
|
+
/**
|
|
26
|
+
* Destroy the stream. Optionally emit an 'error' event, and emit a
|
|
27
|
+
* 'close' event (unless emitClose is set to false). After this call,
|
|
28
|
+
* internal resources will be released.
|
|
29
|
+
*/
|
|
30
|
+
destroy(error?: Error): void;
|
|
31
|
+
}
|
|
21
32
|
//# sourceMappingURL=models.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"models.js","sourceRoot":"","sources":["../../src/models.ts"],"names":[],"mappings":"AAAA,uCAAuC;AACvC,kCAAkC","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\n/**\n * Represents a message sent in an event stream\n * https://developer.mozilla.org/en-US/docs/Web/API/Server-sent_events/Using_server-sent_events#Event_stream_format\n */\nexport interface EventMessage {\n /** The event ID to set the EventSource object's last event ID value. */\n id: string;\n /** A string identifying the type of event described. */\n event: string;\n /** The event data */\n data: string;\n /** The reconnection interval (in milliseconds) to wait before retrying the connection */\n retry?: number;\n}\n\n/**\n * A stream of event messages\n */\nexport interface EventMessageStream\n extends ReadableStream<EventMessage>,\n AsyncDisposable,\n AsyncIterable<EventMessage> {}\n\nexport type PartialSome<T, K extends keyof T> = Omit<T, K> & Partial<Pick<T, K>>;\n"]}
|
|
1
|
+
{"version":3,"file":"models.js","sourceRoot":"","sources":["../../src/models.ts"],"names":[],"mappings":"AAAA,uCAAuC;AACvC,kCAAkC","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\n/**\n * Represents a message sent in an event stream\n * https://developer.mozilla.org/en-US/docs/Web/API/Server-sent_events/Using_server-sent_events#Event_stream_format\n */\nexport interface EventMessage {\n /** The event ID to set the EventSource object's last event ID value. */\n id: string;\n /** A string identifying the type of event described. */\n event: string;\n /** The event data */\n data: string;\n /** The reconnection interval (in milliseconds) to wait before retrying the connection */\n retry?: number;\n}\n\n/**\n * A stream of event messages\n */\nexport interface EventMessageStream\n extends ReadableStream<EventMessage>,\n AsyncDisposable,\n AsyncIterable<EventMessage> {}\n\nexport type PartialSome<T, K extends keyof T> = Omit<T, K> & Partial<Pick<T, K>>;\n\n/**\n * A Node.js Readable stream that also has a `destroy` method.\n */\nexport interface NodeJSReadableStream extends NodeJS.ReadableStream {\n /**\n * Destroy the stream. Optionally emit an 'error' event, and emit a\n * 'close' event (unless emitClose is set to false). After this call,\n * internal resources will be released.\n */\n destroy(error?: Error): void;\n}\n"]}
|
|
@@ -1,15 +1,21 @@
|
|
|
1
1
|
import type { IncomingMessage } from "node:http";
|
|
2
|
-
import type { EventMessageStream } from "./models.js";
|
|
2
|
+
import type { EventMessageStream, NodeJSReadableStream } from "./models.js";
|
|
3
3
|
/**
|
|
4
4
|
* Processes a response stream into a stream of events.
|
|
5
5
|
* @param chunkStream - A stream of Uint8Array chunks
|
|
6
|
-
* @returns
|
|
6
|
+
* @returns A stream of EventMessage objects
|
|
7
7
|
*/
|
|
8
8
|
export declare function createSseStream(chunkStream: ReadableStream<Uint8Array>): EventMessageStream;
|
|
9
9
|
/**
|
|
10
10
|
* Processes a response stream into a stream of events.
|
|
11
|
-
* @param chunkStream -
|
|
12
|
-
* @returns
|
|
11
|
+
* @param chunkStream - A NodeJS HTTP response
|
|
12
|
+
* @returns A stream of EventMessage objects
|
|
13
13
|
*/
|
|
14
14
|
export declare function createSseStream(chunkStream: IncomingMessage): EventMessageStream;
|
|
15
|
+
/**
|
|
16
|
+
* Processes a response stream into a stream of events.
|
|
17
|
+
* @param chunkStream - A NodeJS Readable stream
|
|
18
|
+
* @returns A stream of EventMessage objects
|
|
19
|
+
*/
|
|
20
|
+
export declare function createSseStream(chunkStream: NodeJSReadableStream): EventMessageStream;
|
|
15
21
|
//# sourceMappingURL=sse.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sse.js","sourceRoot":"","sources":["../../src/sse.ts"],"names":[],"mappings":"AAAA,uCAAuC;AACvC,kCAAkC;;
|
|
1
|
+
{"version":3,"file":"sse.js","sourceRoot":"","sources":["../../src/sse.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nimport type { IncomingMessage } from \"node:http\";\nimport type {\n EventMessage,\n EventMessageStream,\n NodeJSReadableStream,\n PartialSome,\n} from \"./models.js\";\nimport { createStream, ensureAsyncIterable } from \"./utils.js\";\n\nenum ControlChars {\n NewLine = 10,\n CarriageReturn = 13,\n Space = 32,\n Colon = 58,\n}\n\n/**\n * Processes a response stream into a stream of events.\n * @param chunkStream - A stream of Uint8Array chunks\n * @returns A stream of EventMessage objects\n */\nexport function createSseStream(chunkStream: ReadableStream<Uint8Array>): EventMessageStream;\n/**\n * Processes a response stream into a stream of events.\n * @param chunkStream - A NodeJS HTTP response\n * @returns A stream of EventMessage objects\n */\nexport function createSseStream(chunkStream: IncomingMessage): EventMessageStream;\n/**\n * Processes a response stream into a stream of events.\n * @param chunkStream - A NodeJS Readable stream\n * @returns A stream of EventMessage objects\n */\nexport function createSseStream(chunkStream: NodeJSReadableStream): EventMessageStream;\nexport function createSseStream(\n chunkStream: IncomingMessage | NodeJSReadableStream | ReadableStream<Uint8Array>,\n): EventMessageStream {\n const { cancel, iterable } = ensureAsyncIterable(chunkStream);\n const asyncIter = toMessage(toLine(iterable));\n return createStream(asyncIter, cancel);\n}\n\nfunction concatBuffer(a: Uint8Array, b: Uint8Array): Uint8Array {\n const res = new Uint8Array(a.length + b.length);\n res.set(a);\n res.set(b, a.length);\n return res;\n}\n\nfunction createMessage(): PartialSome<EventMessage, \"data\"> {\n return {\n data: undefined,\n event: \"\",\n id: \"\",\n retry: undefined,\n };\n}\n\nasync function* toLine(\n chunkIter: AsyncIterable<Uint8Array>,\n): AsyncIterable<{ line: Uint8Array; fieldLen: number }> {\n let buf: Uint8Array | undefined;\n let bufIdx = 0;\n let fieldLen = -1;\n let discardTrailingNewline = false;\n for await (const chunk of chunkIter) {\n if (buf === undefined) {\n buf = chunk;\n bufIdx = 0;\n fieldLen = -1;\n } else {\n buf = concatBuffer(buf, chunk);\n }\n const bufLen = buf.length;\n let start = 0;\n while (bufIdx < bufLen) {\n if (discardTrailingNewline) {\n if (buf[bufIdx] === ControlChars.NewLine) {\n start = ++bufIdx;\n }\n discardTrailingNewline = false;\n }\n let end = -1;\n for (; bufIdx < bufLen && end === -1; ++bufIdx) {\n switch (buf[bufIdx]) {\n case ControlChars.Colon:\n if (fieldLen === -1) {\n fieldLen = bufIdx - start;\n }\n break;\n case ControlChars.CarriageReturn:\n // We need to discard the trailing newline if any but can't do\n // that now because we need to dispatch the current line first.\n discardTrailingNewline = true;\n end = bufIdx;\n break;\n case ControlChars.NewLine:\n end = bufIdx;\n break;\n }\n }\n if (end === -1) {\n // We reached the end of the buffer but the line hasn't ended.\n // Wait for the next chunk and then continue parsing:\n break;\n }\n yield { line: buf.subarray(start, end), fieldLen };\n start = bufIdx; // we're now on the next line\n fieldLen = -1;\n }\n if (start === bufLen) {\n buf = undefined;\n } else if (start !== 0) {\n // discard already processed lines\n buf = buf.subarray(start);\n bufIdx -= start;\n }\n }\n}\n\nasync function* toMessage(\n lineIter: AsyncIterable<{ line: Uint8Array; fieldLen: number }>,\n): AsyncIterableIterator<EventMessage> {\n let message = createMessage();\n const decoder = new TextDecoder();\n for await (const { line, fieldLen } of lineIter) {\n if (line.length === 0 && message.data !== undefined) {\n // empty line denotes end of message. Yield and start a new message:\n yield message as EventMessage;\n message = createMessage();\n } else if (fieldLen > 0) {\n // exclude comments and lines with no values\n // line is of format \"<field>:<value>\" or \"<field>: <value>\"\n // https://html.spec.whatwg.org/multipage/server-sent-events.html#event-stream-interpretation\n const field = decoder.decode(line.subarray(0, fieldLen));\n const valueOffset = fieldLen + (line[fieldLen + 1] === ControlChars.Space ? 2 : 1);\n const value = decoder.decode(line.subarray(valueOffset));\n\n switch (field) {\n case \"data\":\n message.data = message.data ? message.data + \"\\n\" + value : value;\n break;\n case \"event\":\n message.event = value;\n break;\n case \"id\":\n message.id = value;\n break;\n case \"retry\": {\n const retry = parseInt(value, 10);\n if (!isNaN(retry)) {\n message.retry = retry;\n }\n break;\n }\n }\n }\n }\n}\n"]}
|
|
@@ -1,11 +1,8 @@
|
|
|
1
1
|
import type { IncomingMessage } from "node:http";
|
|
2
|
-
type
|
|
3
|
-
[P in K]: T[P] | null;
|
|
4
|
-
} & Omit<T, K>;
|
|
2
|
+
import type { NodeJSReadableStream } from "./models.js";
|
|
5
3
|
export declare function createStream<T>(asyncIter: AsyncIterableIterator<T>, cancel: () => PromiseLike<void>): ReadableStream<T> & AsyncDisposable & AsyncIterable<T>;
|
|
6
|
-
export declare function ensureAsyncIterable(stream:
|
|
4
|
+
export declare function ensureAsyncIterable(stream: IncomingMessage | NodeJSReadableStream | ReadableStream<Uint8Array>): {
|
|
7
5
|
cancel(): Promise<void>;
|
|
8
6
|
iterable: AsyncIterable<Uint8Array>;
|
|
9
7
|
};
|
|
10
|
-
export {};
|
|
11
8
|
//# sourceMappingURL=utils.d.ts.map
|
|
@@ -51,12 +51,13 @@ export function ensureAsyncIterable(stream) {
|
|
|
51
51
|
else {
|
|
52
52
|
return {
|
|
53
53
|
cancel: async () => {
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
54
|
+
// socket could be null if the connection is already closed
|
|
55
|
+
if ("socket" in stream && stream.socket) {
|
|
56
|
+
stream.socket.end();
|
|
57
|
+
}
|
|
58
|
+
else {
|
|
59
|
+
stream.destroy();
|
|
60
|
+
}
|
|
60
61
|
},
|
|
61
62
|
iterable: stream,
|
|
62
63
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../src/utils.ts"],"names":[],"mappings":"AAAA,uCAAuC;AACvC,kCAAkC;;
|
|
1
|
+
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../src/utils.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright (c) Microsoft Corporation.\n// Licensed under the MIT License.\n\nimport type { IncomingMessage } from \"node:http\";\nimport type { NodeJSReadableStream } from \"./models.js\";\n\nexport function createStream<T>(\n asyncIter: AsyncIterableIterator<T>,\n cancel: () => PromiseLike<void>,\n): ReadableStream<T> & AsyncDisposable & AsyncIterable<T> {\n const stream = iteratorToStream(asyncIter, cancel);\n /** TODO: remove these polyfills once all supported runtimes support them */\n return polyfillStream(stream, cancel);\n}\n\nfunction polyfillStream<T>(\n stream: ReadableStream<T>,\n dispose: () => PromiseLike<void>,\n): ReadableStream<T> & AsyncIterable<T> & AsyncDisposable {\n makeAsyncIterable<T>(stream);\n makeAsyncDisposable(stream, dispose);\n return stream;\n}\n\nfunction makeAsyncDisposable<T>(\n webStream: any,\n dispose: () => PromiseLike<void>,\n): asserts webStream is ReadableStream<T> & AsyncDisposable {\n (Symbol.asyncDispose as any) ??= Symbol(\"Symbol.asyncDispose\");\n if (!webStream[Symbol.asyncDispose]) {\n webStream[Symbol.asyncDispose] = () => dispose();\n }\n}\n\nfunction makeAsyncIterable<T>(\n webStream: any,\n): asserts webStream is ReadableStream<T> & AsyncIterable<T> {\n if (!webStream[Symbol.asyncIterator]) {\n webStream[Symbol.asyncIterator] = () => toAsyncIterable(webStream);\n }\n\n if (!webStream.values) {\n webStream.values = () => toAsyncIterable(webStream);\n }\n}\n\nfunction iteratorToStream<T>(\n iterator: AsyncIterableIterator<T>,\n cancel: () => PromiseLike<void>,\n): ReadableStream<T> {\n return new ReadableStream({\n async pull(controller) {\n const { value, done } = await iterator.next();\n if (done) {\n controller.close();\n } else {\n controller.enqueue(value);\n }\n },\n cancel,\n });\n}\n\nexport function ensureAsyncIterable(\n stream: IncomingMessage | NodeJSReadableStream | ReadableStream<Uint8Array>,\n): {\n cancel(): Promise<void>;\n iterable: AsyncIterable<Uint8Array>;\n} {\n if (isReadableStream(stream)) {\n makeAsyncIterable<Uint8Array>(stream);\n return {\n cancel: () => stream.cancel(),\n iterable: stream,\n };\n } else {\n return {\n cancel: async () => {\n // socket could be null if the connection is already closed\n if (\"socket\" in stream && stream.socket) {\n stream.socket.end();\n } else {\n stream.destroy();\n }\n },\n iterable: stream as AsyncIterable<Uint8Array>,\n };\n }\n}\n\nfunction isReadableStream(body: unknown): body is ReadableStream {\n return Boolean(\n body &&\n typeof (body as ReadableStream).getReader === \"function\" &&\n typeof (body as ReadableStream).tee === \"function\",\n );\n}\n\nasync function* toAsyncIterable<T>(stream: ReadableStream<T>): AsyncIterableIterator<T> {\n const reader = stream.getReader();\n try {\n while (true) {\n const { value, done } = await reader.read();\n if (done) {\n return;\n }\n yield value;\n }\n } finally {\n const cancelPromise = reader.cancel();\n reader.releaseLock();\n await cancelPromise;\n }\n}\n"]}
|
package/package.json
CHANGED