llama-stack-client 0.0.1-alpha.0
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/LICENSE +201 -0
- package/README.md +298 -0
- package/_shims/MultipartBody.d.ts +9 -0
- package/_shims/MultipartBody.d.ts.map +1 -0
- package/_shims/MultipartBody.js +16 -0
- package/_shims/MultipartBody.js.map +1 -0
- package/_shims/MultipartBody.mjs +12 -0
- package/_shims/MultipartBody.mjs.map +1 -0
- package/_shims/README.md +46 -0
- package/_shims/auto/runtime-bun.d.ts +5 -0
- package/_shims/auto/runtime-bun.d.ts.map +1 -0
- package/_shims/auto/runtime-bun.js +21 -0
- package/_shims/auto/runtime-bun.js.map +1 -0
- package/_shims/auto/runtime-bun.mjs +2 -0
- package/_shims/auto/runtime-bun.mjs.map +1 -0
- package/_shims/auto/runtime-node.d.ts +5 -0
- package/_shims/auto/runtime-node.d.ts.map +1 -0
- package/_shims/auto/runtime-node.js +21 -0
- package/_shims/auto/runtime-node.js.map +1 -0
- package/_shims/auto/runtime-node.mjs +2 -0
- package/_shims/auto/runtime-node.mjs.map +1 -0
- package/_shims/auto/runtime.d.ts +5 -0
- package/_shims/auto/runtime.d.ts.map +1 -0
- package/_shims/auto/runtime.js +21 -0
- package/_shims/auto/runtime.js.map +1 -0
- package/_shims/auto/runtime.mjs +2 -0
- package/_shims/auto/runtime.mjs.map +1 -0
- package/_shims/auto/types-node.d.ts +5 -0
- package/_shims/auto/types-node.d.ts.map +1 -0
- package/_shims/auto/types-node.js +21 -0
- package/_shims/auto/types-node.js.map +1 -0
- package/_shims/auto/types-node.mjs +2 -0
- package/_shims/auto/types-node.mjs.map +1 -0
- package/_shims/auto/types.d.ts +101 -0
- package/_shims/auto/types.js +3 -0
- package/_shims/auto/types.mjs +3 -0
- package/_shims/bun-runtime.d.ts +6 -0
- package/_shims/bun-runtime.d.ts.map +1 -0
- package/_shims/bun-runtime.js +14 -0
- package/_shims/bun-runtime.js.map +1 -0
- package/_shims/bun-runtime.mjs +10 -0
- package/_shims/bun-runtime.mjs.map +1 -0
- package/_shims/index.d.ts +81 -0
- package/_shims/index.js +13 -0
- package/_shims/index.mjs +7 -0
- package/_shims/manual-types.d.ts +12 -0
- package/_shims/manual-types.js +3 -0
- package/_shims/manual-types.mjs +3 -0
- package/_shims/node-runtime.d.ts +3 -0
- package/_shims/node-runtime.d.ts.map +1 -0
- package/_shims/node-runtime.js +89 -0
- package/_shims/node-runtime.js.map +1 -0
- package/_shims/node-runtime.mjs +56 -0
- package/_shims/node-runtime.mjs.map +1 -0
- package/_shims/node-types.d.ts +42 -0
- package/_shims/node-types.js +3 -0
- package/_shims/node-types.mjs +3 -0
- package/_shims/registry.d.ts +37 -0
- package/_shims/registry.d.ts.map +1 -0
- package/_shims/registry.js +41 -0
- package/_shims/registry.js.map +1 -0
- package/_shims/registry.mjs +37 -0
- package/_shims/registry.mjs.map +1 -0
- package/_shims/web-runtime.d.ts +5 -0
- package/_shims/web-runtime.d.ts.map +1 -0
- package/_shims/web-runtime.js +78 -0
- package/_shims/web-runtime.js.map +1 -0
- package/_shims/web-runtime.mjs +71 -0
- package/_shims/web-runtime.mjs.map +1 -0
- package/_shims/web-types.d.ts +83 -0
- package/_shims/web-types.js +3 -0
- package/_shims/web-types.mjs +3 -0
- package/core.d.ts +243 -0
- package/core.d.ts.map +1 -0
- package/core.js +900 -0
- package/core.js.map +1 -0
- package/core.mjs +869 -0
- package/core.mjs.map +1 -0
- package/error.d.ts +53 -0
- package/error.d.ts.map +1 -0
- package/error.js +143 -0
- package/error.js.map +1 -0
- package/error.mjs +127 -0
- package/error.mjs.map +1 -0
- package/index.d.mts +215 -0
- package/index.d.ts +215 -0
- package/index.d.ts.map +1 -0
- package/index.js +137 -0
- package/index.js.map +1 -0
- package/index.mjs +109 -0
- package/index.mjs.map +1 -0
- package/package.json +102 -0
- package/resource.d.ts +6 -0
- package/resource.d.ts.map +1 -0
- package/resource.js +11 -0
- package/resource.js.map +1 -0
- package/resource.mjs +7 -0
- package/resource.mjs.map +1 -0
- package/resources/agents/agents.d.ts +233 -0
- package/resources/agents/agents.d.ts.map +1 -0
- package/resources/agents/agents.js +73 -0
- package/resources/agents/agents.js.map +1 -0
- package/resources/agents/agents.mjs +46 -0
- package/resources/agents/agents.mjs.map +1 -0
- package/resources/agents/index.d.ts +5 -0
- package/resources/agents/index.d.ts.map +1 -0
- package/resources/agents/index.js +13 -0
- package/resources/agents/index.js.map +1 -0
- package/resources/agents/index.mjs +6 -0
- package/resources/agents/index.mjs.map +1 -0
- package/resources/agents/sessions.d.ts +76 -0
- package/resources/agents/sessions.d.ts.map +1 -0
- package/resources/agents/sessions.js +52 -0
- package/resources/agents/sessions.js.map +1 -0
- package/resources/agents/sessions.mjs +48 -0
- package/resources/agents/sessions.mjs.map +1 -0
- package/resources/agents/steps.d.ts +34 -0
- package/resources/agents/steps.d.ts.map +1 -0
- package/resources/agents/steps.js +24 -0
- package/resources/agents/steps.js.map +1 -0
- package/resources/agents/steps.mjs +20 -0
- package/resources/agents/steps.mjs.map +1 -0
- package/resources/agents/turns.d.ts +133 -0
- package/resources/agents/turns.d.ts.map +1 -0
- package/resources/agents/turns.js +38 -0
- package/resources/agents/turns.js.map +1 -0
- package/resources/agents/turns.mjs +34 -0
- package/resources/agents/turns.mjs.map +1 -0
- package/resources/batch-inference.d.ts +99 -0
- package/resources/batch-inference.d.ts.map +1 -0
- package/resources/batch-inference.js +37 -0
- package/resources/batch-inference.js.map +1 -0
- package/resources/batch-inference.mjs +33 -0
- package/resources/batch-inference.mjs.map +1 -0
- package/resources/datasets.d.ts +57 -0
- package/resources/datasets.d.ts.map +1 -0
- package/resources/datasets.js +52 -0
- package/resources/datasets.js.map +1 -0
- package/resources/datasets.mjs +48 -0
- package/resources/datasets.mjs.map +1 -0
- package/resources/evaluate/evaluate.d.ts +29 -0
- package/resources/evaluate/evaluate.d.ts.map +1 -0
- package/resources/evaluate/evaluate.js +49 -0
- package/resources/evaluate/evaluate.js.map +1 -0
- package/resources/evaluate/evaluate.mjs +22 -0
- package/resources/evaluate/evaluate.mjs.map +1 -0
- package/resources/evaluate/index.d.ts +6 -0
- package/resources/evaluate/index.d.ts.map +1 -0
- package/resources/evaluate/index.js +15 -0
- package/resources/evaluate/index.js.map +1 -0
- package/resources/evaluate/index.mjs +7 -0
- package/resources/evaluate/index.mjs.map +1 -0
- package/resources/evaluate/jobs/artifacts.d.ts +22 -0
- package/resources/evaluate/jobs/artifacts.d.ts.map +1 -0
- package/resources/evaluate/jobs/artifacts.js +24 -0
- package/resources/evaluate/jobs/artifacts.js.map +1 -0
- package/resources/evaluate/jobs/artifacts.mjs +20 -0
- package/resources/evaluate/jobs/artifacts.mjs.map +1 -0
- package/resources/evaluate/jobs/index.d.ts +5 -0
- package/resources/evaluate/jobs/index.d.ts.map +1 -0
- package/resources/evaluate/jobs/index.js +13 -0
- package/resources/evaluate/jobs/index.js.map +1 -0
- package/resources/evaluate/jobs/index.mjs +6 -0
- package/resources/evaluate/jobs/index.mjs.map +1 -0
- package/resources/evaluate/jobs/jobs.d.ts +56 -0
- package/resources/evaluate/jobs/jobs.d.ts.map +1 -0
- package/resources/evaluate/jobs/jobs.js +76 -0
- package/resources/evaluate/jobs/jobs.js.map +1 -0
- package/resources/evaluate/jobs/jobs.mjs +49 -0
- package/resources/evaluate/jobs/jobs.mjs.map +1 -0
- package/resources/evaluate/jobs/logs.d.ts +22 -0
- package/resources/evaluate/jobs/logs.d.ts.map +1 -0
- package/resources/evaluate/jobs/logs.js +24 -0
- package/resources/evaluate/jobs/logs.js.map +1 -0
- package/resources/evaluate/jobs/logs.mjs +20 -0
- package/resources/evaluate/jobs/logs.mjs.map +1 -0
- package/resources/evaluate/jobs/status.d.ts +22 -0
- package/resources/evaluate/jobs/status.d.ts.map +1 -0
- package/resources/evaluate/jobs/status.js +24 -0
- package/resources/evaluate/jobs/status.js.map +1 -0
- package/resources/evaluate/jobs/status.mjs +20 -0
- package/resources/evaluate/jobs/status.mjs.map +1 -0
- package/resources/evaluate/question-answering.d.ts +22 -0
- package/resources/evaluate/question-answering.d.ts.map +1 -0
- package/resources/evaluate/question-answering.js +24 -0
- package/resources/evaluate/question-answering.js.map +1 -0
- package/resources/evaluate/question-answering.mjs +20 -0
- package/resources/evaluate/question-answering.mjs.map +1 -0
- package/resources/evaluate/summarization.d.ts +4 -0
- package/resources/evaluate/summarization.d.ts.map +1 -0
- package/resources/evaluate/summarization.js +9 -0
- package/resources/evaluate/summarization.js.map +1 -0
- package/resources/evaluate/summarization.mjs +5 -0
- package/resources/evaluate/summarization.mjs.map +1 -0
- package/resources/evaluate/text-generation.d.ts +4 -0
- package/resources/evaluate/text-generation.d.ts.map +1 -0
- package/resources/evaluate/text-generation.js +9 -0
- package/resources/evaluate/text-generation.js.map +1 -0
- package/resources/evaluate/text-generation.mjs +5 -0
- package/resources/evaluate/text-generation.mjs.map +1 -0
- package/resources/evaluations.d.ts +35 -0
- package/resources/evaluations.d.ts.map +1 -0
- package/resources/evaluations.js +37 -0
- package/resources/evaluations.js.map +1 -0
- package/resources/evaluations.mjs +33 -0
- package/resources/evaluations.mjs.map +1 -0
- package/resources/index.d.ts +17 -0
- package/resources/index.d.ts.map +1 -0
- package/resources/index.js +50 -0
- package/resources/index.js.map +1 -0
- package/resources/index.mjs +18 -0
- package/resources/index.mjs.map +1 -0
- package/resources/inference/embeddings.d.ts +29 -0
- package/resources/inference/embeddings.d.ts.map +1 -0
- package/resources/inference/embeddings.js +49 -0
- package/resources/inference/embeddings.js.map +1 -0
- package/resources/inference/embeddings.mjs +22 -0
- package/resources/inference/embeddings.mjs.map +1 -0
- package/resources/inference/index.d.ts +3 -0
- package/resources/inference/index.d.ts.map +1 -0
- package/resources/inference/index.js +9 -0
- package/resources/inference/index.js.map +1 -0
- package/resources/inference/index.mjs +4 -0
- package/resources/inference/index.mjs.map +1 -0
- package/resources/inference/inference.d.ts +172 -0
- package/resources/inference/inference.d.ts.map +1 -0
- package/resources/inference/inference.js +67 -0
- package/resources/inference/inference.js.map +1 -0
- package/resources/inference/inference.mjs +40 -0
- package/resources/inference/inference.mjs.map +1 -0
- package/resources/memory/documents.d.ts +49 -0
- package/resources/memory/documents.d.ts.map +1 -0
- package/resources/memory/documents.js +39 -0
- package/resources/memory/documents.js.map +1 -0
- package/resources/memory/documents.mjs +35 -0
- package/resources/memory/documents.mjs.map +1 -0
- package/resources/memory/index.d.ts +3 -0
- package/resources/memory/index.d.ts.map +1 -0
- package/resources/memory/index.js +9 -0
- package/resources/memory/index.js.map +1 -0
- package/resources/memory/index.mjs +4 -0
- package/resources/memory/index.mjs.map +1 -0
- package/resources/memory/memory.d.ts +158 -0
- package/resources/memory/memory.d.ts.map +1 -0
- package/resources/memory/memory.js +137 -0
- package/resources/memory/memory.js.map +1 -0
- package/resources/memory/memory.mjs +110 -0
- package/resources/memory/memory.mjs.map +1 -0
- package/resources/memory-banks.d.ts +42 -0
- package/resources/memory-banks.d.ts.map +1 -0
- package/resources/memory-banks.js +40 -0
- package/resources/memory-banks.js.map +1 -0
- package/resources/memory-banks.mjs +36 -0
- package/resources/memory-banks.mjs.map +1 -0
- package/resources/models.d.ts +46 -0
- package/resources/models.d.ts.map +1 -0
- package/resources/models.js +40 -0
- package/resources/models.js.map +1 -0
- package/resources/models.mjs +36 -0
- package/resources/models.mjs.map +1 -0
- package/resources/post-training/index.d.ts +3 -0
- package/resources/post-training/index.d.ts.map +1 -0
- package/resources/post-training/index.js +9 -0
- package/resources/post-training/index.js.map +1 -0
- package/resources/post-training/index.mjs +4 -0
- package/resources/post-training/index.mjs.map +1 -0
- package/resources/post-training/jobs.d.ts +91 -0
- package/resources/post-training/jobs.d.ts.map +1 -0
- package/resources/post-training/jobs.js +80 -0
- package/resources/post-training/jobs.js.map +1 -0
- package/resources/post-training/jobs.mjs +76 -0
- package/resources/post-training/jobs.mjs.map +1 -0
- package/resources/post-training/post-training.d.ts +183 -0
- package/resources/post-training/post-training.d.ts.map +1 -0
- package/resources/post-training/post-training.js +66 -0
- package/resources/post-training/post-training.js.map +1 -0
- package/resources/post-training/post-training.mjs +39 -0
- package/resources/post-training/post-training.mjs.map +1 -0
- package/resources/reward-scoring.d.ts +47 -0
- package/resources/reward-scoring.d.ts.map +1 -0
- package/resources/reward-scoring.js +24 -0
- package/resources/reward-scoring.js.map +1 -0
- package/resources/reward-scoring.mjs +20 -0
- package/resources/reward-scoring.mjs.map +1 -0
- package/resources/safety.d.ts +41 -0
- package/resources/safety.d.ts.map +1 -0
- package/resources/safety.js +24 -0
- package/resources/safety.js.map +1 -0
- package/resources/safety.mjs +20 -0
- package/resources/safety.mjs.map +1 -0
- package/resources/shared.d.ts +42 -0
- package/resources/shared.d.ts.map +1 -0
- package/resources/shared.js +4 -0
- package/resources/shared.js.map +1 -0
- package/resources/shared.mjs +3 -0
- package/resources/shared.mjs.map +1 -0
- package/resources/shields.d.ts +42 -0
- package/resources/shields.d.ts.map +1 -0
- package/resources/shields.js +40 -0
- package/resources/shields.js.map +1 -0
- package/resources/shields.mjs +36 -0
- package/resources/shields.mjs.map +1 -0
- package/resources/synthetic-data-generation.d.ts +36 -0
- package/resources/synthetic-data-generation.d.ts.map +1 -0
- package/resources/synthetic-data-generation.js +24 -0
- package/resources/synthetic-data-generation.js.map +1 -0
- package/resources/synthetic-data-generation.mjs +20 -0
- package/resources/synthetic-data-generation.mjs.map +1 -0
- package/resources/telemetry.d.ts +81 -0
- package/resources/telemetry.d.ts.map +1 -0
- package/resources/telemetry.js +38 -0
- package/resources/telemetry.js.map +1 -0
- package/resources/telemetry.mjs +34 -0
- package/resources/telemetry.mjs.map +1 -0
- package/shims/node.d.ts +30 -0
- package/shims/node.d.ts.map +1 -0
- package/shims/node.js +31 -0
- package/shims/node.js.map +1 -0
- package/shims/node.mjs +5 -0
- package/shims/node.mjs.map +1 -0
- package/shims/web.d.ts +26 -0
- package/shims/web.d.ts.map +1 -0
- package/shims/web.js +31 -0
- package/shims/web.js.map +1 -0
- package/shims/web.mjs +5 -0
- package/shims/web.mjs.map +1 -0
- package/src/_shims/MultipartBody.ts +9 -0
- package/src/_shims/README.md +46 -0
- package/src/_shims/auto/runtime-bun.ts +4 -0
- package/src/_shims/auto/runtime-node.ts +4 -0
- package/src/_shims/auto/runtime.ts +4 -0
- package/src/_shims/auto/types-node.ts +4 -0
- package/src/_shims/auto/types.d.ts +101 -0
- package/src/_shims/auto/types.js +3 -0
- package/src/_shims/auto/types.mjs +3 -0
- package/src/_shims/bun-runtime.ts +14 -0
- package/src/_shims/index.d.ts +81 -0
- package/src/_shims/index.js +13 -0
- package/src/_shims/index.mjs +7 -0
- package/src/_shims/manual-types.d.ts +12 -0
- package/src/_shims/manual-types.js +3 -0
- package/src/_shims/manual-types.mjs +3 -0
- package/src/_shims/node-runtime.ts +81 -0
- package/src/_shims/node-types.d.ts +42 -0
- package/src/_shims/node-types.js +3 -0
- package/src/_shims/node-types.mjs +3 -0
- package/src/_shims/registry.ts +67 -0
- package/src/_shims/web-runtime.ts +103 -0
- package/src/_shims/web-types.d.ts +83 -0
- package/src/_shims/web-types.js +3 -0
- package/src/_shims/web-types.mjs +3 -0
- package/src/core.ts +1195 -0
- package/src/error.ts +146 -0
- package/src/index.ts +298 -0
- package/src/lib/.keep +4 -0
- package/src/resource.ts +11 -0
- package/src/resources/agents/agents.ts +383 -0
- package/src/resources/agents/index.ts +33 -0
- package/src/resources/agents/sessions.ts +135 -0
- package/src/resources/agents/steps.ts +58 -0
- package/src/resources/agents/turns.ts +231 -0
- package/src/resources/batch-inference.ts +154 -0
- package/src/resources/datasets.ts +110 -0
- package/src/resources/evaluate/evaluate.ts +35 -0
- package/src/resources/evaluate/index.ts +14 -0
- package/src/resources/evaluate/jobs/artifacts.ts +42 -0
- package/src/resources/evaluate/jobs/index.ts +13 -0
- package/src/resources/evaluate/jobs/jobs.ts +99 -0
- package/src/resources/evaluate/jobs/logs.ts +42 -0
- package/src/resources/evaluate/jobs/status.ts +42 -0
- package/src/resources/evaluate/question-answering.ts +42 -0
- package/src/resources/evaluate/summarization.ts +5 -0
- package/src/resources/evaluate/text-generation.ts +5 -0
- package/src/resources/evaluations.ts +73 -0
- package/src/resources/index.ts +84 -0
- package/src/resources/inference/embeddings.ts +48 -0
- package/src/resources/inference/index.ts +15 -0
- package/src/resources/inference/inference.ts +268 -0
- package/src/resources/memory/documents.ts +92 -0
- package/src/resources/memory/index.ts +23 -0
- package/src/resources/memory/memory.ts +297 -0
- package/src/resources/memory-banks.ts +84 -0
- package/src/resources/models.ts +88 -0
- package/src/resources/post-training/index.ts +19 -0
- package/src/resources/post-training/jobs.ts +192 -0
- package/src/resources/post-training/post-training.ts +285 -0
- package/src/resources/reward-scoring.ts +82 -0
- package/src/resources/safety.ts +66 -0
- package/src/resources/shared.ts +75 -0
- package/src/resources/shields.ts +84 -0
- package/src/resources/synthetic-data-generation.ts +62 -0
- package/src/resources/telemetry.ts +150 -0
- package/src/shims/node.ts +50 -0
- package/src/shims/web.ts +50 -0
- package/src/streaming.ts +475 -0
- package/src/tsconfig.json +11 -0
- package/src/uploads.ts +255 -0
- package/src/version.ts +1 -0
- package/streaming.d.ts +41 -0
- package/streaming.d.ts.map +1 -0
- package/streaming.js +403 -0
- package/streaming.js.map +1 -0
- package/streaming.mjs +396 -0
- package/streaming.mjs.map +1 -0
- package/uploads.d.ts +75 -0
- package/uploads.d.ts.map +1 -0
- package/uploads.js +171 -0
- package/uploads.js.map +1 -0
- package/uploads.mjs +158 -0
- package/uploads.mjs.map +1 -0
- package/version.d.ts +2 -0
- package/version.d.ts.map +1 -0
- package/version.js +5 -0
- package/version.js.map +1 -0
- package/version.mjs +2 -0
- package/version.mjs.map +1 -0
package/src/streaming.ts
ADDED
|
@@ -0,0 +1,475 @@
|
|
|
1
|
+
import { ReadableStream, type Response } from './_shims/index';
|
|
2
|
+
import { LlamaStackClientError } from './error';
|
|
3
|
+
|
|
4
|
+
type Bytes = string | ArrayBuffer | Uint8Array | Buffer | null | undefined;
|
|
5
|
+
|
|
6
|
+
export type ServerSentEvent = {
|
|
7
|
+
event: string | null;
|
|
8
|
+
data: string;
|
|
9
|
+
raw: string[];
|
|
10
|
+
};
|
|
11
|
+
|
|
12
|
+
export class Stream<Item> implements AsyncIterable<Item> {
|
|
13
|
+
controller: AbortController;
|
|
14
|
+
|
|
15
|
+
constructor(
|
|
16
|
+
private iterator: () => AsyncIterator<Item>,
|
|
17
|
+
controller: AbortController,
|
|
18
|
+
) {
|
|
19
|
+
this.controller = controller;
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
static fromSSEResponse<Item>(response: Response, controller: AbortController) {
|
|
23
|
+
let consumed = false;
|
|
24
|
+
|
|
25
|
+
async function* iterator(): AsyncIterator<Item, any, undefined> {
|
|
26
|
+
if (consumed) {
|
|
27
|
+
throw new Error('Cannot iterate over a consumed stream, use `.tee()` to split the stream.');
|
|
28
|
+
}
|
|
29
|
+
consumed = true;
|
|
30
|
+
let done = false;
|
|
31
|
+
try {
|
|
32
|
+
for await (const sse of _iterSSEMessages(response, controller)) {
|
|
33
|
+
try {
|
|
34
|
+
yield JSON.parse(sse.data);
|
|
35
|
+
} catch (e) {
|
|
36
|
+
console.error(`Could not parse message into JSON:`, sse.data);
|
|
37
|
+
console.error(`From chunk:`, sse.raw);
|
|
38
|
+
throw e;
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
done = true;
|
|
42
|
+
} catch (e) {
|
|
43
|
+
// If the user calls `stream.controller.abort()`, we should exit without throwing.
|
|
44
|
+
if (e instanceof Error && e.name === 'AbortError') return;
|
|
45
|
+
throw e;
|
|
46
|
+
} finally {
|
|
47
|
+
// If the user `break`s, abort the ongoing request.
|
|
48
|
+
if (!done) controller.abort();
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
return new Stream(iterator, controller);
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
/**
|
|
56
|
+
* Generates a Stream from a newline-separated ReadableStream
|
|
57
|
+
* where each item is a JSON value.
|
|
58
|
+
*/
|
|
59
|
+
static fromReadableStream<Item>(readableStream: ReadableStream, controller: AbortController) {
|
|
60
|
+
let consumed = false;
|
|
61
|
+
|
|
62
|
+
async function* iterLines(): AsyncGenerator<string, void, unknown> {
|
|
63
|
+
const lineDecoder = new LineDecoder();
|
|
64
|
+
|
|
65
|
+
const iter = readableStreamAsyncIterable<Bytes>(readableStream);
|
|
66
|
+
for await (const chunk of iter) {
|
|
67
|
+
for (const line of lineDecoder.decode(chunk)) {
|
|
68
|
+
yield line;
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
for (const line of lineDecoder.flush()) {
|
|
73
|
+
yield line;
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
async function* iterator(): AsyncIterator<Item, any, undefined> {
|
|
78
|
+
if (consumed) {
|
|
79
|
+
throw new Error('Cannot iterate over a consumed stream, use `.tee()` to split the stream.');
|
|
80
|
+
}
|
|
81
|
+
consumed = true;
|
|
82
|
+
let done = false;
|
|
83
|
+
try {
|
|
84
|
+
for await (const line of iterLines()) {
|
|
85
|
+
if (done) continue;
|
|
86
|
+
if (line) yield JSON.parse(line);
|
|
87
|
+
}
|
|
88
|
+
done = true;
|
|
89
|
+
} catch (e) {
|
|
90
|
+
// If the user calls `stream.controller.abort()`, we should exit without throwing.
|
|
91
|
+
if (e instanceof Error && e.name === 'AbortError') return;
|
|
92
|
+
throw e;
|
|
93
|
+
} finally {
|
|
94
|
+
// If the user `break`s, abort the ongoing request.
|
|
95
|
+
if (!done) controller.abort();
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
return new Stream(iterator, controller);
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
[Symbol.asyncIterator](): AsyncIterator<Item> {
|
|
103
|
+
return this.iterator();
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
/**
|
|
107
|
+
* Splits the stream into two streams which can be
|
|
108
|
+
* independently read from at different speeds.
|
|
109
|
+
*/
|
|
110
|
+
tee(): [Stream<Item>, Stream<Item>] {
|
|
111
|
+
const left: Array<Promise<IteratorResult<Item>>> = [];
|
|
112
|
+
const right: Array<Promise<IteratorResult<Item>>> = [];
|
|
113
|
+
const iterator = this.iterator();
|
|
114
|
+
|
|
115
|
+
const teeIterator = (queue: Array<Promise<IteratorResult<Item>>>): AsyncIterator<Item> => {
|
|
116
|
+
return {
|
|
117
|
+
next: () => {
|
|
118
|
+
if (queue.length === 0) {
|
|
119
|
+
const result = iterator.next();
|
|
120
|
+
left.push(result);
|
|
121
|
+
right.push(result);
|
|
122
|
+
}
|
|
123
|
+
return queue.shift()!;
|
|
124
|
+
},
|
|
125
|
+
};
|
|
126
|
+
};
|
|
127
|
+
|
|
128
|
+
return [
|
|
129
|
+
new Stream(() => teeIterator(left), this.controller),
|
|
130
|
+
new Stream(() => teeIterator(right), this.controller),
|
|
131
|
+
];
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
/**
|
|
135
|
+
* Converts this stream to a newline-separated ReadableStream of
|
|
136
|
+
* JSON stringified values in the stream
|
|
137
|
+
* which can be turned back into a Stream with `Stream.fromReadableStream()`.
|
|
138
|
+
*/
|
|
139
|
+
toReadableStream(): ReadableStream {
|
|
140
|
+
const self = this;
|
|
141
|
+
let iter: AsyncIterator<Item>;
|
|
142
|
+
const encoder = new TextEncoder();
|
|
143
|
+
|
|
144
|
+
return new ReadableStream({
|
|
145
|
+
async start() {
|
|
146
|
+
iter = self[Symbol.asyncIterator]();
|
|
147
|
+
},
|
|
148
|
+
async pull(ctrl: any) {
|
|
149
|
+
try {
|
|
150
|
+
const { value, done } = await iter.next();
|
|
151
|
+
if (done) return ctrl.close();
|
|
152
|
+
|
|
153
|
+
const bytes = encoder.encode(JSON.stringify(value) + '\n');
|
|
154
|
+
|
|
155
|
+
ctrl.enqueue(bytes);
|
|
156
|
+
} catch (err) {
|
|
157
|
+
ctrl.error(err);
|
|
158
|
+
}
|
|
159
|
+
},
|
|
160
|
+
async cancel() {
|
|
161
|
+
await iter.return?.();
|
|
162
|
+
},
|
|
163
|
+
});
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
|
|
167
|
+
export async function* _iterSSEMessages(
|
|
168
|
+
response: Response,
|
|
169
|
+
controller: AbortController,
|
|
170
|
+
): AsyncGenerator<ServerSentEvent, void, unknown> {
|
|
171
|
+
if (!response.body) {
|
|
172
|
+
controller.abort();
|
|
173
|
+
throw new LlamaStackClientError(`Attempted to iterate over a response with no body`);
|
|
174
|
+
}
|
|
175
|
+
|
|
176
|
+
const sseDecoder = new SSEDecoder();
|
|
177
|
+
const lineDecoder = new LineDecoder();
|
|
178
|
+
|
|
179
|
+
const iter = readableStreamAsyncIterable<Bytes>(response.body);
|
|
180
|
+
for await (const sseChunk of iterSSEChunks(iter)) {
|
|
181
|
+
for (const line of lineDecoder.decode(sseChunk)) {
|
|
182
|
+
const sse = sseDecoder.decode(line);
|
|
183
|
+
if (sse) yield sse;
|
|
184
|
+
}
|
|
185
|
+
}
|
|
186
|
+
|
|
187
|
+
for (const line of lineDecoder.flush()) {
|
|
188
|
+
const sse = sseDecoder.decode(line);
|
|
189
|
+
if (sse) yield sse;
|
|
190
|
+
}
|
|
191
|
+
}
|
|
192
|
+
|
|
193
|
+
/**
|
|
194
|
+
* Given an async iterable iterator, iterates over it and yields full
|
|
195
|
+
* SSE chunks, i.e. yields when a double new-line is encountered.
|
|
196
|
+
*/
|
|
197
|
+
async function* iterSSEChunks(iterator: AsyncIterableIterator<Bytes>): AsyncGenerator<Uint8Array> {
|
|
198
|
+
let data = new Uint8Array();
|
|
199
|
+
|
|
200
|
+
for await (const chunk of iterator) {
|
|
201
|
+
if (chunk == null) {
|
|
202
|
+
continue;
|
|
203
|
+
}
|
|
204
|
+
|
|
205
|
+
const binaryChunk =
|
|
206
|
+
chunk instanceof ArrayBuffer ? new Uint8Array(chunk)
|
|
207
|
+
: typeof chunk === 'string' ? new TextEncoder().encode(chunk)
|
|
208
|
+
: chunk;
|
|
209
|
+
|
|
210
|
+
let newData = new Uint8Array(data.length + binaryChunk.length);
|
|
211
|
+
newData.set(data);
|
|
212
|
+
newData.set(binaryChunk, data.length);
|
|
213
|
+
data = newData;
|
|
214
|
+
|
|
215
|
+
let patternIndex;
|
|
216
|
+
while ((patternIndex = findDoubleNewlineIndex(data)) !== -1) {
|
|
217
|
+
yield data.slice(0, patternIndex);
|
|
218
|
+
data = data.slice(patternIndex);
|
|
219
|
+
}
|
|
220
|
+
}
|
|
221
|
+
|
|
222
|
+
if (data.length > 0) {
|
|
223
|
+
yield data;
|
|
224
|
+
}
|
|
225
|
+
}
|
|
226
|
+
|
|
227
|
+
function findDoubleNewlineIndex(buffer: Uint8Array): number {
|
|
228
|
+
// This function searches the buffer for the end patterns (\r\r, \n\n, \r\n\r\n)
|
|
229
|
+
// and returns the index right after the first occurrence of any pattern,
|
|
230
|
+
// or -1 if none of the patterns are found.
|
|
231
|
+
const newline = 0x0a; // \n
|
|
232
|
+
const carriage = 0x0d; // \r
|
|
233
|
+
|
|
234
|
+
for (let i = 0; i < buffer.length - 2; i++) {
|
|
235
|
+
if (buffer[i] === newline && buffer[i + 1] === newline) {
|
|
236
|
+
// \n\n
|
|
237
|
+
return i + 2;
|
|
238
|
+
}
|
|
239
|
+
if (buffer[i] === carriage && buffer[i + 1] === carriage) {
|
|
240
|
+
// \r\r
|
|
241
|
+
return i + 2;
|
|
242
|
+
}
|
|
243
|
+
if (
|
|
244
|
+
buffer[i] === carriage &&
|
|
245
|
+
buffer[i + 1] === newline &&
|
|
246
|
+
i + 3 < buffer.length &&
|
|
247
|
+
buffer[i + 2] === carriage &&
|
|
248
|
+
buffer[i + 3] === newline
|
|
249
|
+
) {
|
|
250
|
+
// \r\n\r\n
|
|
251
|
+
return i + 4;
|
|
252
|
+
}
|
|
253
|
+
}
|
|
254
|
+
|
|
255
|
+
return -1;
|
|
256
|
+
}
|
|
257
|
+
|
|
258
|
+
class SSEDecoder {
|
|
259
|
+
private data: string[];
|
|
260
|
+
private event: string | null;
|
|
261
|
+
private chunks: string[];
|
|
262
|
+
|
|
263
|
+
constructor() {
|
|
264
|
+
this.event = null;
|
|
265
|
+
this.data = [];
|
|
266
|
+
this.chunks = [];
|
|
267
|
+
}
|
|
268
|
+
|
|
269
|
+
decode(line: string) {
|
|
270
|
+
if (line.endsWith('\r')) {
|
|
271
|
+
line = line.substring(0, line.length - 1);
|
|
272
|
+
}
|
|
273
|
+
|
|
274
|
+
if (!line) {
|
|
275
|
+
// empty line and we didn't previously encounter any messages
|
|
276
|
+
if (!this.event && !this.data.length) return null;
|
|
277
|
+
|
|
278
|
+
const sse: ServerSentEvent = {
|
|
279
|
+
event: this.event,
|
|
280
|
+
data: this.data.join('\n'),
|
|
281
|
+
raw: this.chunks,
|
|
282
|
+
};
|
|
283
|
+
|
|
284
|
+
this.event = null;
|
|
285
|
+
this.data = [];
|
|
286
|
+
this.chunks = [];
|
|
287
|
+
|
|
288
|
+
return sse;
|
|
289
|
+
}
|
|
290
|
+
|
|
291
|
+
this.chunks.push(line);
|
|
292
|
+
|
|
293
|
+
if (line.startsWith(':')) {
|
|
294
|
+
return null;
|
|
295
|
+
}
|
|
296
|
+
|
|
297
|
+
let [fieldname, _, value] = partition(line, ':');
|
|
298
|
+
|
|
299
|
+
if (value.startsWith(' ')) {
|
|
300
|
+
value = value.substring(1);
|
|
301
|
+
}
|
|
302
|
+
|
|
303
|
+
if (fieldname === 'event') {
|
|
304
|
+
this.event = value;
|
|
305
|
+
} else if (fieldname === 'data') {
|
|
306
|
+
this.data.push(value);
|
|
307
|
+
}
|
|
308
|
+
|
|
309
|
+
return null;
|
|
310
|
+
}
|
|
311
|
+
}
|
|
312
|
+
|
|
313
|
+
/**
|
|
314
|
+
* A re-implementation of httpx's `LineDecoder` in Python that handles incrementally
|
|
315
|
+
* reading lines from text.
|
|
316
|
+
*
|
|
317
|
+
* https://github.com/encode/httpx/blob/920333ea98118e9cf617f246905d7b202510941c/httpx/_decoders.py#L258
|
|
318
|
+
*/
|
|
319
|
+
class LineDecoder {
|
|
320
|
+
// prettier-ignore
|
|
321
|
+
static NEWLINE_CHARS = new Set(['\n', '\r']);
|
|
322
|
+
static NEWLINE_REGEXP = /\r\n|[\n\r]/g;
|
|
323
|
+
|
|
324
|
+
buffer: string[];
|
|
325
|
+
trailingCR: boolean;
|
|
326
|
+
textDecoder: any; // TextDecoder found in browsers; not typed to avoid pulling in either "dom" or "node" types.
|
|
327
|
+
|
|
328
|
+
constructor() {
|
|
329
|
+
this.buffer = [];
|
|
330
|
+
this.trailingCR = false;
|
|
331
|
+
}
|
|
332
|
+
|
|
333
|
+
decode(chunk: Bytes): string[] {
|
|
334
|
+
let text = this.decodeText(chunk);
|
|
335
|
+
|
|
336
|
+
if (this.trailingCR) {
|
|
337
|
+
text = '\r' + text;
|
|
338
|
+
this.trailingCR = false;
|
|
339
|
+
}
|
|
340
|
+
if (text.endsWith('\r')) {
|
|
341
|
+
this.trailingCR = true;
|
|
342
|
+
text = text.slice(0, -1);
|
|
343
|
+
}
|
|
344
|
+
|
|
345
|
+
if (!text) {
|
|
346
|
+
return [];
|
|
347
|
+
}
|
|
348
|
+
|
|
349
|
+
const trailingNewline = LineDecoder.NEWLINE_CHARS.has(text[text.length - 1] || '');
|
|
350
|
+
let lines = text.split(LineDecoder.NEWLINE_REGEXP);
|
|
351
|
+
|
|
352
|
+
// if there is a trailing new line then the last entry will be an empty
|
|
353
|
+
// string which we don't care about
|
|
354
|
+
if (trailingNewline) {
|
|
355
|
+
lines.pop();
|
|
356
|
+
}
|
|
357
|
+
|
|
358
|
+
if (lines.length === 1 && !trailingNewline) {
|
|
359
|
+
this.buffer.push(lines[0]!);
|
|
360
|
+
return [];
|
|
361
|
+
}
|
|
362
|
+
|
|
363
|
+
if (this.buffer.length > 0) {
|
|
364
|
+
lines = [this.buffer.join('') + lines[0], ...lines.slice(1)];
|
|
365
|
+
this.buffer = [];
|
|
366
|
+
}
|
|
367
|
+
|
|
368
|
+
if (!trailingNewline) {
|
|
369
|
+
this.buffer = [lines.pop() || ''];
|
|
370
|
+
}
|
|
371
|
+
|
|
372
|
+
return lines;
|
|
373
|
+
}
|
|
374
|
+
|
|
375
|
+
decodeText(bytes: Bytes): string {
|
|
376
|
+
if (bytes == null) return '';
|
|
377
|
+
if (typeof bytes === 'string') return bytes;
|
|
378
|
+
|
|
379
|
+
// Node:
|
|
380
|
+
if (typeof Buffer !== 'undefined') {
|
|
381
|
+
if (bytes instanceof Buffer) {
|
|
382
|
+
return bytes.toString();
|
|
383
|
+
}
|
|
384
|
+
if (bytes instanceof Uint8Array) {
|
|
385
|
+
return Buffer.from(bytes).toString();
|
|
386
|
+
}
|
|
387
|
+
|
|
388
|
+
throw new LlamaStackClientError(
|
|
389
|
+
`Unexpected: received non-Uint8Array (${bytes.constructor.name}) stream chunk in an environment with a global "Buffer" defined, which this library assumes to be Node. Please report this error.`,
|
|
390
|
+
);
|
|
391
|
+
}
|
|
392
|
+
|
|
393
|
+
// Browser
|
|
394
|
+
if (typeof TextDecoder !== 'undefined') {
|
|
395
|
+
if (bytes instanceof Uint8Array || bytes instanceof ArrayBuffer) {
|
|
396
|
+
this.textDecoder ??= new TextDecoder('utf8');
|
|
397
|
+
return this.textDecoder.decode(bytes);
|
|
398
|
+
}
|
|
399
|
+
|
|
400
|
+
throw new LlamaStackClientError(
|
|
401
|
+
`Unexpected: received non-Uint8Array/ArrayBuffer (${
|
|
402
|
+
(bytes as any).constructor.name
|
|
403
|
+
}) in a web platform. Please report this error.`,
|
|
404
|
+
);
|
|
405
|
+
}
|
|
406
|
+
|
|
407
|
+
throw new LlamaStackClientError(
|
|
408
|
+
`Unexpected: neither Buffer nor TextDecoder are available as globals. Please report this error.`,
|
|
409
|
+
);
|
|
410
|
+
}
|
|
411
|
+
|
|
412
|
+
flush(): string[] {
|
|
413
|
+
if (!this.buffer.length && !this.trailingCR) {
|
|
414
|
+
return [];
|
|
415
|
+
}
|
|
416
|
+
|
|
417
|
+
const lines = [this.buffer.join('')];
|
|
418
|
+
this.buffer = [];
|
|
419
|
+
this.trailingCR = false;
|
|
420
|
+
return lines;
|
|
421
|
+
}
|
|
422
|
+
}
|
|
423
|
+
|
|
424
|
+
/** This is an internal helper function that's just used for testing */
|
|
425
|
+
export function _decodeChunks(chunks: string[]): string[] {
|
|
426
|
+
const decoder = new LineDecoder();
|
|
427
|
+
const lines: string[] = [];
|
|
428
|
+
for (const chunk of chunks) {
|
|
429
|
+
lines.push(...decoder.decode(chunk));
|
|
430
|
+
}
|
|
431
|
+
|
|
432
|
+
return lines;
|
|
433
|
+
}
|
|
434
|
+
|
|
435
|
+
function partition(str: string, delimiter: string): [string, string, string] {
|
|
436
|
+
const index = str.indexOf(delimiter);
|
|
437
|
+
if (index !== -1) {
|
|
438
|
+
return [str.substring(0, index), delimiter, str.substring(index + delimiter.length)];
|
|
439
|
+
}
|
|
440
|
+
|
|
441
|
+
return [str, '', ''];
|
|
442
|
+
}
|
|
443
|
+
|
|
444
|
+
/**
|
|
445
|
+
* Most browsers don't yet have async iterable support for ReadableStream,
|
|
446
|
+
* and Node has a very different way of reading bytes from its "ReadableStream".
|
|
447
|
+
*
|
|
448
|
+
* This polyfill was pulled from https://github.com/MattiasBuelens/web-streams-polyfill/pull/122#issuecomment-1627354490
|
|
449
|
+
*/
|
|
450
|
+
export function readableStreamAsyncIterable<T>(stream: any): AsyncIterableIterator<T> {
|
|
451
|
+
if (stream[Symbol.asyncIterator]) return stream;
|
|
452
|
+
|
|
453
|
+
const reader = stream.getReader();
|
|
454
|
+
return {
|
|
455
|
+
async next() {
|
|
456
|
+
try {
|
|
457
|
+
const result = await reader.read();
|
|
458
|
+
if (result?.done) reader.releaseLock(); // release lock when stream becomes closed
|
|
459
|
+
return result;
|
|
460
|
+
} catch (e) {
|
|
461
|
+
reader.releaseLock(); // release lock when stream becomes errored
|
|
462
|
+
throw e;
|
|
463
|
+
}
|
|
464
|
+
},
|
|
465
|
+
async return() {
|
|
466
|
+
const cancelPromise = reader.cancel();
|
|
467
|
+
reader.releaseLock();
|
|
468
|
+
await cancelPromise;
|
|
469
|
+
return { done: true, value: undefined };
|
|
470
|
+
},
|
|
471
|
+
[Symbol.asyncIterator]() {
|
|
472
|
+
return this;
|
|
473
|
+
},
|
|
474
|
+
};
|
|
475
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
{
|
|
2
|
+
// this config is included in the published src directory to prevent TS errors
|
|
3
|
+
// from appearing when users go to source, and VSCode opens the source .ts file
|
|
4
|
+
// via declaration maps
|
|
5
|
+
"include": ["index.ts"],
|
|
6
|
+
"compilerOptions": {
|
|
7
|
+
"target": "es2015",
|
|
8
|
+
"lib": ["DOM"],
|
|
9
|
+
"moduleResolution": "node"
|
|
10
|
+
}
|
|
11
|
+
}
|