@anvia/core 0.1.0 → 0.1.1
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 +21 -0
- package/README.md +64 -0
- package/dist/agent/index.d.ts +7 -3
- package/dist/agent/index.js +7 -1
- package/dist/{agent-C6h6YrRU.d.ts → agent-Bj0UqYMp.d.ts} +30 -4
- package/dist/{chunk-LMBOJMNB.js → chunk-C7XTEV5W.js} +2 -2
- package/dist/{chunk-IQBY2GCF.js → chunk-JQCRURY2.js} +214 -27
- package/dist/chunk-JQCRURY2.js.map +1 -0
- package/dist/{chunk-IA76K5UX.js → chunk-O3TUS5RB.js} +2 -2
- package/dist/chunk-XXT2UCAR.js +11 -0
- package/dist/chunk-XXT2UCAR.js.map +1 -0
- package/dist/evals/index.d.ts +2 -1
- package/dist/evals/index.js +4 -3
- package/dist/extractor/index.d.ts +2 -1
- package/dist/extractor/index.js +3 -2
- package/dist/index.d.ts +2 -1
- package/dist/index.js +13 -7
- package/dist/memory/index.d.ts +43 -0
- package/dist/memory/index.js +7 -0
- package/dist/memory/index.js.map +1 -0
- package/dist/pipeline/index.d.ts +2 -1
- package/package.json +11 -7
- package/dist/chunk-IQBY2GCF.js.map +0 -1
- /package/dist/{chunk-LMBOJMNB.js.map → chunk-C7XTEV5W.js.map} +0 -0
- /package/dist/{chunk-IA76K5UX.js.map → chunk-O3TUS5RB.js.map} +0 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/agent/agent.ts","../src/observability/group.ts","../src/agent/errors.ts","../src/agent/hooks.ts","../src/agent/utils.ts","../src/agent/stream-accumulator.ts","../src/agent/request.ts","../src/agent/builder.ts"],"sourcesContent":["import { z } from \"zod\";\nimport type {\n CompletionModel,\n Document,\n JsonObject,\n JsonValue,\n Message as MessageType,\n ToolChoice,\n} from \"../completion/index\";\nimport type { MemoryRegistration, SessionOptions } from \"../memory\";\nimport type { AgentObserverRegistration } from \"../observability\";\nimport { createTool } from \"../tool/create-tool\";\nimport type { ToolSearchDocument } from \"../tool/dynamic-tools\";\nimport type { AnyTool, Tool } from \"../tool/tool\";\nimport { ToolSet } from \"../tool/tool-set\";\nimport type { VectorFilter, VectorSearchIndex, VectorSearchResult } from \"../vector-store\";\nimport type { PromptHook } from \"./hooks\";\nimport { PromptRequest } from \"./request\";\n\nexport type AgentOptions<M extends CompletionModel = CompletionModel> = {\n id: string;\n name?: string | undefined;\n description?: string | undefined;\n model: M;\n instructions?: string | undefined;\n staticContext?: Document[];\n temperature?: number | undefined;\n maxTokens?: number | undefined;\n additionalParams?: JsonValue | undefined;\n toolSet?: ToolSet | undefined;\n toolChoice?: ToolChoice | undefined;\n defaultMaxTurns?: number | undefined;\n hook?: PromptHook | undefined;\n outputSchema?: JsonObject | undefined;\n observers?: AgentObserverRegistration[] | undefined;\n dynamicContexts?: DynamicContextRegistration[] | undefined;\n dynamicTools?: DynamicToolRegistration[] | undefined;\n memory?: MemoryRegistration | undefined;\n};\n\nexport const DEFAULT_MAX_TURNS = 20;\n\nexport type AgentToolOptions = {\n name: string;\n description?: string | undefined;\n maxTurns?: number | undefined;\n};\n\nexport type DynamicContextOptions<T = unknown> = {\n topK: number;\n threshold?: number | undefined;\n filter?: VectorFilter | undefined;\n format?: ((result: VectorSearchResult<T>) => Document) | undefined;\n};\n\nexport type DynamicContextRegistration<T = unknown> = {\n index: VectorSearchIndex<T>;\n options: DynamicContextOptions<T>;\n};\n\nexport type DynamicToolOptions = {\n topK: number;\n threshold?: number | undefined;\n filter?: VectorFilter | undefined;\n};\n\nexport type DynamicToolRegistration = {\n index: VectorSearchIndex<ToolSearchDocument>;\n options: DynamicToolOptions;\n};\n\nexport class Agent<M extends CompletionModel = CompletionModel> {\n readonly id: string;\n readonly name: string | undefined;\n readonly description: string | undefined;\n readonly model: M;\n readonly instructions: string | undefined;\n readonly staticContext: Document[];\n readonly temperature: number | undefined;\n readonly maxTokens: number | undefined;\n readonly additionalParams: JsonValue | undefined;\n readonly toolSet: ToolSet;\n readonly toolChoice: ToolChoice | undefined;\n readonly defaultMaxTurns: number | undefined;\n readonly hook: PromptHook | undefined;\n readonly outputSchema: JsonObject | undefined;\n readonly observers: AgentObserverRegistration[];\n readonly dynamicContexts: DynamicContextRegistration[];\n readonly dynamicTools: DynamicToolRegistration[];\n readonly memory: MemoryRegistration | undefined;\n\n constructor(options: AgentOptions<M>) {\n this.id = normalizeAgentId(options.id);\n this.name = options.name;\n this.description = options.description;\n this.model = options.model;\n this.instructions = options.instructions;\n this.staticContext = options.staticContext ?? [];\n this.temperature = options.temperature;\n this.maxTokens = options.maxTokens;\n this.additionalParams = options.additionalParams;\n this.toolSet = options.toolSet ?? new ToolSet();\n this.toolChoice = options.toolChoice;\n this.defaultMaxTurns = options.defaultMaxTurns ?? DEFAULT_MAX_TURNS;\n this.hook = options.hook;\n this.outputSchema = options.outputSchema;\n this.observers = options.observers ?? [];\n this.dynamicContexts = options.dynamicContexts ?? [];\n this.dynamicTools = options.dynamicTools ?? [];\n this.memory = options.memory;\n }\n\n prompt(prompt: string | MessageType | MessageType[]): PromptRequest<M> {\n return PromptRequest.fromAgent(this, prompt);\n }\n\n session(sessionId: string, options: SessionOptions = {}): AgentSession<M> {\n if (this.memory === undefined) {\n throw new Error(`Agent \"${this.id}\" has no memory store configured.`);\n }\n const normalized = sessionId.trim();\n if (normalized.length === 0) {\n throw new TypeError(\"Session id must be a non-empty string.\");\n }\n return new AgentSession(this, {\n sessionId: normalized,\n ...(options.userId === undefined ? {} : { userId: options.userId }),\n ...(options.metadata === undefined ? {} : { metadata: options.metadata }),\n });\n }\n\n asTool(options: AgentToolOptions): Tool<{ prompt: string }, string> {\n const description =\n options.description ?? this.description ?? `Prompt the ${options.name} agent.`;\n\n return createTool({\n name: options.name,\n description,\n input: z.object({\n prompt: z.string().describe(\"The prompt to send to the agent.\"),\n }),\n output: z.string(),\n execute: async ({ prompt }) => {\n const request = this.prompt(prompt);\n const response =\n options.maxTurns === undefined\n ? await request.send()\n : await request.maxTurns(options.maxTurns).send();\n return response.output;\n },\n });\n }\n\n getTool(toolName: string): AnyTool | undefined {\n const staticTool = this.toolSet.get(toolName);\n if (staticTool !== undefined) {\n return staticTool;\n }\n\n for (const registration of this.dynamicTools) {\n const dynamicTool = dynamicToolSetFromIndex(registration.index)?.get(toolName);\n if (dynamicTool !== undefined) {\n return dynamicTool;\n }\n }\n\n return undefined;\n }\n\n async callTool(toolName: string, args: string): Promise<string> {\n if (this.toolSet.contains(toolName)) {\n return this.toolSet.call(toolName, args);\n }\n\n for (const registration of this.dynamicTools) {\n const toolSet = dynamicToolSetFromIndex(registration.index);\n if (toolSet?.contains(toolName)) {\n return toolSet.call(toolName, args);\n }\n }\n\n return this.toolSet.call(toolName, args);\n }\n}\n\nexport class AgentSession<M extends CompletionModel = CompletionModel> {\n constructor(\n private readonly agent: Agent<M>,\n private readonly context: {\n sessionId: string;\n userId?: string | undefined;\n metadata?: JsonObject | undefined;\n },\n ) {}\n\n prompt(prompt: string | MessageType): PromptRequest<M> {\n if (Array.isArray(prompt)) {\n throw new TypeError(\"AgentSession.prompt does not accept Message[] transcripts.\");\n }\n return PromptRequest.fromAgent(this.agent, prompt, { memoryContext: this.context });\n }\n\n async messages(): Promise<MessageType[]> {\n const memory = this.agent.memory;\n if (memory === undefined) {\n throw new Error(`Agent \"${this.agent.id}\" has no memory store configured.`);\n }\n return memory.store.load(this.context);\n }\n\n async clear(): Promise<void> {\n const memory = this.agent.memory;\n if (memory === undefined) {\n throw new Error(`Agent \"${this.agent.id}\" has no memory store configured.`);\n }\n await memory.store.clear(this.context);\n }\n}\n\nfunction dynamicToolSetFromIndex(\n index: VectorSearchIndex<ToolSearchDocument>,\n): ToolSet | undefined {\n const maybeIndex = index as { toolSet?: unknown };\n return maybeIndex.toolSet instanceof ToolSet ? maybeIndex.toolSet : undefined;\n}\n\nfunction normalizeAgentId(id: string): string {\n if (typeof id !== \"string\") {\n throw new TypeError(\"Agent id must be a string.\");\n }\n\n const normalized = id.trim();\n if (normalized.length === 0) {\n throw new TypeError(\"Agent id must be a non-empty string.\");\n }\n\n return normalized;\n}\n","import type {\n AgentGenerationEndArgs,\n AgentGenerationErrorArgs,\n AgentGenerationObserver,\n AgentGenerationStartArgs,\n AgentObserverRegistration,\n AgentRunEndArgs,\n AgentRunErrorArgs,\n AgentRunObserver,\n AgentRunStartArgs,\n AgentToolEndArgs,\n AgentToolErrorArgs,\n AgentToolObserver,\n AgentToolStartArgs,\n AgentTraceInfo,\n} from \"./types\";\n\nexport async function startAgentRunObservers(\n registrations: AgentObserverRegistration[],\n args: AgentRunStartArgs,\n failOnObserverError: boolean,\n): Promise<ActiveAgentRunObservers> {\n const runObservers: AgentRunObserver[] = [];\n for (const registration of registrations) {\n try {\n const runObserver = await registration.observer.startRun(args);\n if (runObserver !== undefined) {\n runObservers.push(runObserver);\n }\n } catch (error) {\n if (failOnObserverError || registration.failOnObserverError === true) {\n throw error;\n }\n }\n }\n\n return new ActiveAgentRunObservers(runObservers, failOnObserverError);\n}\n\nexport class ActiveAgentRunObservers {\n readonly trace: AgentTraceInfo | undefined;\n\n constructor(\n private readonly runObservers: AgentRunObserver[],\n private readonly failOnObserverError: boolean,\n ) {\n this.trace = runObservers.find((observer) => observer.trace !== undefined)?.trace;\n }\n\n async startGeneration(args: AgentGenerationStartArgs): Promise<ActiveGenerationObservers> {\n const generationObservers: AgentGenerationObserver[] = [];\n for (const runObserver of this.runObservers) {\n if (runObserver.startGeneration === undefined) {\n continue;\n }\n try {\n const generationObserver = await runObserver.startGeneration(args);\n if (generationObserver !== undefined) {\n generationObservers.push(generationObserver);\n }\n } catch (error) {\n this.handleError(error);\n }\n }\n return new ActiveGenerationObservers(generationObservers, this.failOnObserverError);\n }\n\n async startTool(args: AgentToolStartArgs): Promise<ActiveToolObservers> {\n const toolObservers: AgentToolObserver[] = [];\n for (const runObserver of this.runObservers) {\n if (runObserver.startTool === undefined) {\n continue;\n }\n try {\n const toolObserver = await runObserver.startTool(args);\n if (toolObserver !== undefined) {\n toolObservers.push(toolObserver);\n }\n } catch (error) {\n this.handleError(error);\n }\n }\n return new ActiveToolObservers(toolObservers, this.failOnObserverError);\n }\n\n async end(args: AgentRunEndArgs): Promise<void> {\n for (const runObserver of this.runObservers) {\n try {\n await runObserver.end(args);\n } catch (error) {\n this.handleError(error);\n }\n }\n }\n\n async error(args: AgentRunErrorArgs): Promise<void> {\n for (const runObserver of this.runObservers) {\n if (runObserver.error === undefined) {\n continue;\n }\n try {\n await runObserver.error(args);\n } catch (error) {\n this.handleError(error);\n }\n }\n }\n\n private handleError(error: unknown): void {\n if (this.failOnObserverError) {\n throw error;\n }\n }\n}\n\nexport class ActiveGenerationObservers {\n constructor(\n private readonly generationObservers: AgentGenerationObserver[],\n private readonly failOnObserverError: boolean,\n ) {}\n\n async end(args: AgentGenerationEndArgs): Promise<void> {\n for (const observer of this.generationObservers) {\n try {\n await observer.end(args);\n } catch (error) {\n this.handleError(error);\n }\n }\n }\n\n async error(args: AgentGenerationErrorArgs): Promise<void> {\n for (const observer of this.generationObservers) {\n if (observer.error === undefined) {\n continue;\n }\n try {\n await observer.error(args);\n } catch (error) {\n this.handleError(error);\n }\n }\n }\n\n private handleError(error: unknown): void {\n if (this.failOnObserverError) {\n throw error;\n }\n }\n}\n\nexport class ActiveToolObservers {\n constructor(\n private readonly toolObservers: AgentToolObserver[],\n private readonly failOnObserverError: boolean,\n ) {}\n\n async end(args: AgentToolEndArgs): Promise<void> {\n for (const observer of this.toolObservers) {\n try {\n await observer.end(args);\n } catch (error) {\n this.handleError(error);\n }\n }\n }\n\n async error(args: AgentToolErrorArgs): Promise<void> {\n for (const observer of this.toolObservers) {\n if (observer.error === undefined) {\n continue;\n }\n try {\n await observer.error(args);\n } catch (error) {\n this.handleError(error);\n }\n }\n }\n\n private handleError(error: unknown): void {\n if (this.failOnObserverError) {\n throw error;\n }\n }\n}\n","import type { Message } from \"../completion/index\";\n\nexport class MaxTurnsError extends Error {\n constructor(\n readonly maxTurns: number,\n readonly chatHistory: Message[],\n readonly prompt: Message,\n ) {\n super(`Reached max turn limit: ${maxTurns}`);\n this.name = \"MaxTurnsError\";\n }\n}\n\nexport class PromptCancelledError extends Error {\n constructor(\n readonly chatHistory: Message[],\n readonly reason: string,\n ) {\n super(`Prompt cancelled: ${reason}`);\n this.name = \"PromptCancelledError\";\n }\n}\n","import type { CompletionResponse, Message } from \"../completion/index\";\n\nexport type HookAction = { type: \"continue\" } | { type: \"terminate\"; reason: string };\nexport type ToolCallHookAction =\n | { type: \"continue\" }\n | { type: \"skip\"; reason: string }\n | { type: \"terminate\"; reason: string };\n\nexport type RunControl = {\n continue(): HookAction;\n cancel(reason: string): HookAction;\n};\n\nexport type ToolCallControl = {\n run(): ToolCallHookAction;\n skip(reason: string): ToolCallHookAction;\n cancel(reason: string): ToolCallHookAction;\n};\n\nexport type HookResult = HookAction | undefined;\nexport type ToolCallHookResult = ToolCallHookAction | undefined;\n\ntype HookCallback<Args> = (\n args: Args,\n) => HookAction | Promise<HookAction | undefined> | Promise<void> | void;\ntype ToolCallHookCallback<Args> = (\n args: Args,\n) => ToolCallHookAction | Promise<ToolCallHookAction | undefined> | Promise<void> | void;\n\nexport type CompletionCallHookArgs = {\n prompt: Message;\n history: Message[];\n run: RunControl;\n};\n\nexport type CompletionResponseHookArgs<RawResponse = unknown> = {\n prompt: Message;\n response: CompletionResponse<RawResponse>;\n run: RunControl;\n};\n\nexport type ToolHookArgs = {\n toolName: string;\n toolCallId?: string;\n internalCallId: string;\n args: string;\n};\n\nexport type ToolCallHookArgs = ToolHookArgs & {\n tool: ToolCallControl;\n};\n\nexport type ToolResultHookArgs = ToolHookArgs & {\n result: string;\n run: RunControl;\n};\n\nexport function createHook<RawResponse = unknown>(\n hook: PromptHook<RawResponse>,\n): PromptHook<RawResponse> {\n return hook;\n}\n\nexport function cancelPrompt(reason: string): HookAction {\n return { type: \"terminate\", reason };\n}\n\nexport function skipTool(reason: string): ToolCallHookAction {\n return { type: \"skip\", reason };\n}\n\nexport const runControl: RunControl = {\n continue() {\n return { type: \"continue\" };\n },\n cancel(reason: string) {\n return cancelPrompt(reason);\n },\n};\n\nexport const toolCallControl: ToolCallControl = {\n run() {\n return { type: \"continue\" };\n },\n skip(reason: string) {\n return skipTool(reason);\n },\n cancel(reason: string) {\n return { type: \"terminate\", reason };\n },\n};\n\nexport interface PromptHook<RawResponse = unknown> {\n onCompletionCall?: HookCallback<CompletionCallHookArgs>;\n onCompletionResponse?: HookCallback<CompletionResponseHookArgs<RawResponse>>;\n onToolCall?: ToolCallHookCallback<ToolCallHookArgs>;\n onToolResult?: HookCallback<ToolResultHookArgs>;\n}\n","import type {\n CompletionModel,\n JsonValue,\n Message as MessageType,\n StreamingCompletionModel,\n} from \"../completion/index\";\n\nexport function isStreamingCompletionModel(\n model: CompletionModel,\n): model is StreamingCompletionModel {\n return \"streamCompletion\" in model && typeof model.streamCompletion === \"function\";\n}\n\nexport function extractRagText(message: MessageType): string | undefined {\n if (message.role === \"user\") {\n return message.content.flatMap((item) => (item.type === \"text\" ? [item.text] : [])).join(\"\\n\");\n }\n\n if (message.role === \"tool\") {\n return message.content\n .flatMap((item) => item.content.flatMap((part) => (part.type === \"text\" ? [part.text] : [])))\n .join(\"\\n\");\n }\n\n return undefined;\n}\n\nexport function parseJsonValue(text: string): JsonValue {\n if (text.trim().length === 0) {\n return {};\n }\n try {\n return JSON.parse(text) as JsonValue;\n } catch {\n return text;\n }\n}\n\nexport async function mapWithConcurrency<T, R>(\n items: T[],\n concurrency: number,\n mapper: (item: T) => Promise<R>,\n): Promise<R[]> {\n const results: R[] = [];\n let next = 0;\n\n async function worker(): Promise<void> {\n while (next < items.length) {\n const index = next;\n next += 1;\n const item = items[index];\n if (item !== undefined) {\n results[index] = await mapper(item);\n }\n }\n }\n\n const workerCount = Math.min(concurrency, items.length);\n await Promise.all(Array.from({ length: workerCount }, () => worker()));\n return results;\n}\n","import type {\n AssistantContent as AssistantContentType,\n CompletionResponse,\n CompletionStreamEvent,\n ReasoningContent,\n ReasoningContentType,\n ToolCall,\n} from \"../completion/index\";\nimport { Usage } from \"../completion/index\";\nimport { parseJsonValue } from \"./utils\";\n\nexport type AgentDeltaEvent =\n | { type: \"text_delta\"; delta: string }\n | {\n type: \"reasoning_delta\";\n delta: string;\n id?: string;\n contentType?: ReasoningContentType;\n signature?: string;\n }\n | { type: \"tool_call\"; toolCall: ToolCall };\n\ntype ReasoningState = {\n text: string;\n content?: ReasoningContent[];\n};\n\ntype PartialToolCall = {\n id: string;\n callId?: string;\n name: string;\n argumentsText: string;\n signature?: string;\n};\n\nexport class CompletionStreamAccumulator<RawResponse = unknown> {\n private static readonly defaultReasoningKey = \"reasoning\";\n private text = \"\";\n private reasoningById = new Map<string, ReasoningState>();\n private reasoningOrder: string[] = [];\n private toolCalls = new Map<string, PartialToolCall>();\n private toolCallOrder: string[] = [];\n private finalResponse: CompletionResponse<RawResponse> | undefined;\n private messageId: string | undefined;\n\n accept(event: CompletionStreamEvent<RawResponse>): AgentDeltaEvent | undefined {\n if (event.type === \"text_delta\") {\n this.text += event.delta;\n return { type: \"text_delta\", delta: event.delta };\n }\n\n if (event.type === \"reasoning_delta\") {\n const key = event.id ?? CompletionStreamAccumulator.defaultReasoningKey;\n const existing = this.reasoningById.get(key);\n const reasoning = existing ?? { text: \"\" };\n if (!existing) {\n this.reasoningOrder.push(key);\n }\n this.appendReasoning(reasoning, event);\n this.reasoningById.set(key, reasoning);\n return reasoningDeltaEvent(event);\n }\n\n if (event.type === \"tool_call_delta\") {\n const existing = this.toolCalls.get(event.id);\n const toolCall = existing ?? {\n id: event.id,\n name: \"\",\n argumentsText: \"\",\n };\n if (!existing) {\n this.toolCallOrder.push(event.id);\n }\n if (event.callId !== undefined) toolCall.callId = event.callId;\n if (event.name !== undefined) toolCall.name = event.name;\n if (event.signature !== undefined) toolCall.signature = event.signature;\n if (event.argumentsDelta !== undefined) {\n toolCall.argumentsText += event.argumentsDelta;\n }\n this.toolCalls.set(event.id, toolCall);\n return undefined;\n }\n\n if (event.type === \"tool_call\") {\n this.upsertToolCall(event.toolCall);\n return undefined;\n }\n\n if (event.type === \"message_id\") {\n this.messageId = event.id;\n return undefined;\n }\n\n if (event.type === \"final\") {\n this.finalResponse = event.response;\n return undefined;\n }\n\n return undefined;\n }\n\n response(): CompletionResponse<RawResponse> {\n if (this.finalResponse !== undefined) {\n if (this.finalResponse.choice.length === 0) {\n const response = {\n ...this.buildAccumulatedResponse(),\n usage: this.finalResponse.usage,\n rawResponse: this.finalResponse.rawResponse,\n };\n if (this.finalResponse.messageId !== undefined) {\n response.messageId = this.finalResponse.messageId;\n }\n return response;\n }\n return this.finalResponse;\n }\n\n return this.buildAccumulatedResponse();\n }\n\n private buildAccumulatedResponse(): CompletionResponse<RawResponse> {\n const choice: AssistantContentType[] = [];\n if (this.text.length > 0) {\n choice.push({ type: \"text\", text: this.text });\n }\n for (const key of this.reasoningOrder) {\n const reasoning = this.reasoningById.get(key) ?? { text: \"\" };\n const id = key === CompletionStreamAccumulator.defaultReasoningKey ? undefined : key;\n const content =\n reasoning.content === undefined\n ? { type: \"reasoning\" as const, text: reasoning.text }\n : { type: \"reasoning\" as const, text: reasoning.text, content: reasoning.content };\n choice.push(id === undefined ? content : { ...content, id });\n }\n for (const id of this.toolCallOrder) {\n const toolCall = this.toolCalls.get(id);\n if (toolCall !== undefined) {\n const content: ToolCall = {\n type: \"tool_call\",\n id: toolCall.id,\n function: {\n name: toolCall.name,\n arguments: parseJsonValue(toolCall.argumentsText),\n },\n };\n if (toolCall.callId !== undefined) {\n content.callId = toolCall.callId;\n }\n if (toolCall.signature !== undefined) {\n content.signature = toolCall.signature;\n }\n choice.push(content);\n }\n }\n\n const response: CompletionResponse<RawResponse> = {\n choice,\n usage: Usage.empty(),\n rawResponse: undefined as RawResponse,\n };\n if (this.messageId !== undefined) {\n response.messageId = this.messageId;\n }\n return response;\n }\n\n private upsertToolCall(toolCall: ToolCall): void {\n if (!this.toolCalls.has(toolCall.id)) {\n this.toolCallOrder.push(toolCall.id);\n }\n const partial: PartialToolCall = {\n id: toolCall.id,\n name: toolCall.function.name,\n argumentsText: JSON.stringify(toolCall.function.arguments ?? {}),\n };\n if (toolCall.callId !== undefined) {\n partial.callId = toolCall.callId;\n }\n if (toolCall.signature !== undefined) {\n partial.signature = toolCall.signature;\n }\n this.toolCalls.set(toolCall.id, partial);\n }\n\n private appendReasoning(\n reasoning: ReasoningState,\n event: Extract<CompletionStreamEvent<RawResponse>, { type: \"reasoning_delta\" }>,\n ): void {\n const contentType = event.contentType ?? \"text\";\n if (contentType === \"text\" || contentType === \"summary\") {\n reasoning.text += event.delta;\n }\n\n if (event.contentType === undefined && event.signature === undefined) {\n return;\n }\n\n reasoning.content ??= [];\n const last = reasoning.content.at(-1);\n if (contentType === \"text\") {\n if (last?.type === \"text\") {\n last.text += event.delta;\n if (event.signature !== undefined) {\n last.signature = event.signature;\n }\n } else {\n reasoning.content.push(\n event.signature === undefined\n ? { type: \"text\", text: event.delta }\n : { type: \"text\", text: event.delta, signature: event.signature },\n );\n }\n return;\n }\n\n if (contentType === \"summary\") {\n if (last?.type === \"summary\") {\n last.text += event.delta;\n } else {\n reasoning.content.push({ type: \"summary\", text: event.delta });\n }\n return;\n }\n\n if (contentType === \"encrypted\") {\n reasoning.content.push({ type: \"encrypted\", data: event.delta });\n return;\n }\n\n reasoning.content.push({ type: \"redacted\", data: event.delta });\n }\n}\n\nfunction reasoningDeltaEvent(\n event: Extract<CompletionStreamEvent, { type: \"reasoning_delta\" }>,\n): AgentDeltaEvent {\n const mapped: AgentDeltaEvent = { type: \"reasoning_delta\", delta: event.delta };\n if (event.id !== undefined) mapped.id = event.id;\n if (event.contentType !== undefined) mapped.contentType = event.contentType;\n if (event.signature !== undefined) mapped.signature = event.signature;\n return mapped;\n}\n","import {\n assertCompletionRequestSupported,\n type CompletionModel,\n CompletionRequestBuilder,\n type CompletionResponse,\n type Document,\n Message,\n type Message as MessageType,\n type ReasoningContentType,\n type ToolCall,\n ToolContent,\n type ToolDefinition,\n type ToolResult,\n textFromAssistantContent,\n Usage,\n} from \"../completion/index\";\nimport type { MemoryContext, MemoryRegistration, MemorySavePolicy } from \"../memory\";\nimport {\n type ActiveAgentRunObservers,\n type ActiveToolObservers,\n startAgentRunObservers,\n} from \"../observability/group\";\nimport type { AgentTraceInfo, AgentTraceOptions } from \"../observability/types\";\nimport { toReadableStream } from \"../streaming\";\nimport type { Agent } from \"./agent\";\nimport { MaxTurnsError, PromptCancelledError } from \"./errors\";\nimport type { PromptHook, ToolHookArgs } from \"./hooks\";\nimport { runControl, toolCallControl } from \"./hooks\";\nimport { type AgentDeltaEvent, CompletionStreamAccumulator } from \"./stream-accumulator\";\nimport { extractRagText, isStreamingCompletionModel, mapWithConcurrency } from \"./utils\";\n\nexport type PromptResponse = {\n output: string;\n usage: Usage;\n messages: MessageType[];\n trace?: AgentTraceInfo | undefined;\n};\n\nexport type AgentStreamEvent<RawResponse = unknown> =\n | {\n type: \"turn_start\";\n turn: number;\n prompt: MessageType;\n history: MessageType[];\n }\n | {\n type: \"text_delta\";\n turn: number;\n delta: string;\n }\n | {\n type: \"reasoning_delta\";\n turn: number;\n delta: string;\n id?: string;\n contentType?: ReasoningContentType;\n signature?: string;\n }\n | {\n type: \"tool_call\";\n turn: number;\n toolCall: ToolCall;\n }\n | {\n type: \"tool_result\";\n turn: number;\n toolName: string;\n toolCallId?: string;\n internalCallId: string;\n args: string;\n result: string;\n }\n | {\n type: \"turn_end\";\n turn: number;\n response: CompletionResponse<RawResponse>;\n }\n | {\n type: \"final\";\n output: string;\n usage: Usage;\n messages: MessageType[];\n trace?: AgentTraceInfo | undefined;\n }\n | {\n type: \"error\";\n error: unknown;\n };\n\nexport class PromptRequest<M extends CompletionModel = CompletionModel> {\n private chatHistory: MessageType[];\n private maxTurnCount: number;\n private activeHook: PromptHook | undefined;\n private concurrency = 1;\n private traceOptions: AgentTraceOptions | undefined;\n\n private constructor(\n private readonly agent: Agent<M>,\n private readonly promptMessage: MessageType,\n private readonly initialHistory: MessageType[] = [],\n private readonly memoryContext: MemoryContext | undefined = undefined,\n ) {\n this.chatHistory = initialHistory;\n this.maxTurnCount = agent.defaultMaxTurns ?? 0;\n this.activeHook = agent.hook;\n }\n\n static fromAgent<M extends CompletionModel>(\n agent: Agent<M>,\n prompt: string | MessageType | MessageType[],\n options: { memoryContext?: MemoryContext | undefined } = {},\n ): PromptRequest<M> {\n const normalized = normalizePromptInput(prompt);\n return new PromptRequest(agent, normalized.prompt, normalized.history, options.memoryContext);\n }\n\n maxTurns(maxTurns: number): this {\n this.maxTurnCount = maxTurns;\n return this;\n }\n\n requestHook(hook: PromptHook): this {\n this.activeHook = hook;\n return this;\n }\n\n withToolConcurrency(concurrency: number): this {\n this.concurrency = Math.max(1, concurrency);\n return this;\n }\n\n withTrace(trace: AgentTraceOptions): this {\n this.traceOptions = trace;\n return this;\n }\n\n async send(): Promise<PromptResponse> {\n const runId = globalThis.crypto.randomUUID();\n const newMessages: MessageType[] = [this.promptMessage];\n await this.prepareMemoryRun(runId, newMessages);\n const pendingTurnMessages = this.memoryPolicy() === \"turn\" ? [...newMessages] : [];\n let usage = Usage.empty();\n let currentTurns = 0;\n let lastPrompt = this.promptMessage;\n const runObservers = await this.startRunObservers();\n\n try {\n while (currentTurns <= this.maxTurnCount + 1) {\n const prompt = newMessages.at(-1);\n if (prompt === undefined) {\n throw new Error(\"PromptRequest requires at least one message\");\n }\n\n lastPrompt = prompt;\n currentTurns += 1;\n\n const historyForRequest = [...this.chatHistory, ...newMessages.slice(0, -1)];\n await this.runCompletionCallHook(prompt, historyForRequest, newMessages);\n\n const ragText = extractRagText(prompt);\n const dynamicContext = await this.fetchDynamicContext(ragText);\n const toolDefs = await this.fetchToolDefinitions(ragText);\n const request = new CompletionRequestBuilder(this.agent.model, prompt)\n .instructions(this.agent.instructions)\n .messages(historyForRequest)\n .documents([...this.agent.staticContext, ...dynamicContext])\n .tools(toolDefs)\n .temperature(this.agent.temperature)\n .maxTokens(this.agent.maxTokens)\n .additionalParams(this.agent.additionalParams)\n .toolChoice(this.agent.toolChoice)\n .outputSchema(this.agent.outputSchema)\n .build();\n\n const response = await this.runCompletion(request, currentTurns, runObservers);\n usage = Usage.add(usage, response.usage);\n await this.runCompletionResponseHook(prompt, response, newMessages);\n\n const assistantMessage = Message.assistant(response.choice, response.messageId);\n newMessages.push(assistantMessage);\n await this.commitMemoryMessages(\n runId,\n currentTurns,\n [assistantMessage],\n pendingTurnMessages,\n );\n const toolCalls = response.choice.filter(\n (item): item is ToolCall => item.type === \"tool_call\",\n );\n if (toolCalls.length === 0) {\n await this.commitCompletedMemoryRun(\n runId,\n currentTurns,\n newMessages,\n pendingTurnMessages,\n );\n const result: PromptResponse = {\n output: textFromAssistantContent(response.choice),\n usage,\n messages: [...newMessages],\n trace: runObservers.trace,\n };\n await runObservers.end(result);\n return result;\n }\n\n const toolResults = await this.executeToolCalls(toolCalls, newMessages, undefined, {\n turn: currentTurns,\n runObservers,\n });\n const toolMessage = Message.tool(toolResults);\n newMessages.push(toolMessage);\n await this.commitMemoryMessages(runId, currentTurns, [toolMessage], pendingTurnMessages);\n await this.commitCompletedMemoryTurn(runId, currentTurns, pendingTurnMessages);\n }\n\n throw new MaxTurnsError(this.maxTurnCount, [...this.chatHistory, ...newMessages], lastPrompt);\n } catch (error) {\n await runObservers.error({ error, usage, messages: [...newMessages] });\n await this.recordMemoryError(runId, error, newMessages);\n throw error;\n }\n }\n\n async *stream(): AsyncIterable<AgentStreamEvent> {\n if (!this.agent.model.capabilities.streaming || !isStreamingCompletionModel(this.agent.model)) {\n throw new Error(\"This completion model does not support streaming\");\n }\n\n const runId = globalThis.crypto.randomUUID();\n const newMessages: MessageType[] = [this.promptMessage];\n await this.prepareMemoryRun(runId, newMessages);\n const pendingTurnMessages = this.memoryPolicy() === \"turn\" ? [...newMessages] : [];\n let usage = Usage.empty();\n let currentTurns = 0;\n let lastPrompt = this.promptMessage;\n const runObservers = await this.startRunObservers();\n\n try {\n while (currentTurns <= this.maxTurnCount + 1) {\n const prompt = newMessages.at(-1);\n if (prompt === undefined) {\n throw new Error(\"PromptRequest requires at least one message\");\n }\n\n lastPrompt = prompt;\n currentTurns += 1;\n\n const historyForRequest = [...this.chatHistory, ...newMessages.slice(0, -1)];\n yield {\n type: \"turn_start\",\n turn: currentTurns,\n prompt,\n history: historyForRequest,\n };\n await this.runCompletionCallHook(prompt, historyForRequest, newMessages);\n\n const ragText = extractRagText(prompt);\n const dynamicContext = await this.fetchDynamicContext(ragText);\n const toolDefs = await this.fetchToolDefinitions(ragText);\n const request = new CompletionRequestBuilder(this.agent.model, prompt)\n .instructions(this.agent.instructions)\n .messages(historyForRequest)\n .documents([...this.agent.staticContext, ...dynamicContext])\n .tools(toolDefs)\n .temperature(this.agent.temperature)\n .maxTokens(this.agent.maxTokens)\n .additionalParams(this.agent.additionalParams)\n .toolChoice(this.agent.toolChoice)\n .outputSchema(this.agent.outputSchema)\n .build();\n\n assertCompletionRequestSupported(this.agent.model, request, { streaming: true });\n const generationObservers = await runObservers.startGeneration({\n turn: currentTurns,\n request,\n });\n const accumulator = new CompletionStreamAccumulator();\n const generationStartedAt = Date.now();\n let firstDeltaMs: number | undefined;\n try {\n for await (const event of this.agent.model.streamCompletion(request)) {\n if (firstDeltaMs === undefined && isGenerationDeltaEvent(event.type)) {\n firstDeltaMs = Date.now() - generationStartedAt;\n }\n const mapped = accumulator.accept(event);\n if (event.type === \"error\") {\n throw event.error;\n }\n if (mapped !== undefined) {\n yield addTurn(currentTurns, mapped);\n }\n }\n } catch (error) {\n await generationObservers.error({ turn: currentTurns, error });\n throw error;\n }\n\n const response = accumulator.response();\n await generationObservers.end({\n turn: currentTurns,\n response,\n ...(firstDeltaMs === undefined ? {} : { firstDeltaMs }),\n });\n usage = Usage.add(usage, response.usage);\n await this.runCompletionResponseHook(prompt, response, newMessages);\n\n const assistantMessage = Message.assistant(response.choice, response.messageId);\n newMessages.push(assistantMessage);\n await this.commitMemoryMessages(\n runId,\n currentTurns,\n [assistantMessage],\n pendingTurnMessages,\n );\n const toolCalls = response.choice.filter(\n (item): item is ToolCall => item.type === \"tool_call\",\n );\n for (const toolCall of toolCalls) {\n yield { type: \"tool_call\", turn: currentTurns, toolCall };\n }\n yield { type: \"turn_end\", turn: currentTurns, response };\n\n if (toolCalls.length === 0) {\n const output = textFromAssistantContent(response.choice);\n await this.commitCompletedMemoryRun(\n runId,\n currentTurns,\n newMessages,\n pendingTurnMessages,\n );\n yield {\n type: \"final\",\n output,\n usage,\n messages: [...newMessages],\n trace: runObservers.trace,\n };\n await runObservers.end({ output, usage, messages: [...newMessages] });\n return;\n }\n\n const toolResultEvents = createAsyncQueue<ToolResultEventPayload>();\n const toolResultsPromise = this.executeToolCalls(\n toolCalls,\n newMessages,\n (result) => {\n toolResultEvents.enqueue(result);\n },\n {\n turn: currentTurns,\n runObservers,\n },\n );\n toolResultsPromise.then(\n () => toolResultEvents.close(),\n (error: unknown) => toolResultEvents.throw(error),\n );\n for await (const result of toolResultEvents) {\n yield { type: \"tool_result\", turn: currentTurns, ...result };\n }\n const toolResults = await toolResultsPromise;\n const toolMessage = Message.tool(toolResults);\n newMessages.push(toolMessage);\n await this.commitMemoryMessages(runId, currentTurns, [toolMessage], pendingTurnMessages);\n await this.commitCompletedMemoryTurn(runId, currentTurns, pendingTurnMessages);\n }\n\n throw new MaxTurnsError(this.maxTurnCount, [...this.chatHistory, ...newMessages], lastPrompt);\n } catch (error) {\n await runObservers.error({ error, usage, messages: [...newMessages] });\n await this.recordMemoryError(runId, error, newMessages);\n yield { type: \"error\", error };\n throw error;\n }\n }\n\n readableStream(): ReadableStream<Uint8Array> {\n return toReadableStream(this.stream());\n }\n\n private async runCompletion(\n request: ReturnType<CompletionRequestBuilder[\"build\"]>,\n turn: number,\n runObservers: ActiveAgentRunObservers,\n ): Promise<CompletionResponse> {\n assertCompletionRequestSupported(this.agent.model, request);\n const generationObservers = await runObservers.startGeneration({ turn, request });\n try {\n const response = await this.agent.model.completion(request);\n await generationObservers.end({ turn, response });\n return response;\n } catch (error) {\n await generationObservers.error({ turn, error });\n throw error;\n }\n }\n\n private async executeToolCalls(\n toolCalls: ToolCall[],\n newMessages: MessageType[],\n onResult?: (result: ToolResultEventPayload) => void,\n observation?: {\n turn: number;\n runObservers: ActiveAgentRunObservers;\n },\n ): Promise<ToolResult[]> {\n return mapWithConcurrency(toolCalls, this.concurrency, async (toolCall) => {\n const args = JSON.stringify(toolCall.function.arguments ?? {});\n const internalCallId = globalThis.crypto.randomUUID();\n const hookArgs: ToolHookArgs = {\n toolName: toolCall.function.name,\n internalCallId,\n args,\n };\n if (toolCall.callId !== undefined) {\n hookArgs.toolCallId = toolCall.callId;\n }\n\n const toolObservers = await observation?.runObservers.startTool({\n turn: observation.turn,\n toolCall,\n toolName: toolCall.function.name,\n internalCallId,\n args,\n toolCallId: toolCall.callId,\n });\n\n const callAction = await this.activeHook?.onToolCall?.({\n ...hookArgs,\n tool: toolCallControl,\n });\n if (callAction?.type === \"terminate\") {\n await this.recordToolError(\n toolObservers,\n observation?.turn,\n toolCall,\n internalCallId,\n args,\n callAction.reason,\n );\n throw this.cancelled(newMessages, callAction.reason);\n }\n\n let output: string;\n let skipped = false;\n if (callAction?.type === \"skip\") {\n output = callAction.reason;\n skipped = true;\n } else {\n try {\n output = await this.agent.callTool(toolCall.function.name, args);\n } catch (error) {\n output = error instanceof Error ? error.toString() : String(error);\n }\n }\n\n const resultAction = await this.activeHook?.onToolResult?.({\n ...hookArgs,\n result: output,\n run: runControl,\n });\n await toolObservers?.end({\n turn: observation?.turn ?? 0,\n toolCall,\n toolName: toolCall.function.name,\n internalCallId,\n args,\n result: output,\n skipped,\n toolCallId: toolCall.callId,\n });\n if (resultAction?.type === \"terminate\") {\n throw this.cancelled(newMessages, resultAction.reason);\n }\n\n const resultPayload: ToolResultEventPayload = {\n toolName: toolCall.function.name,\n internalCallId,\n args,\n result: output,\n };\n if (toolCall.callId !== undefined) {\n resultPayload.toolCallId = toolCall.callId;\n }\n onResult?.(resultPayload);\n return ToolContent.toolResult(toolCall.id, output, toolCall.callId);\n });\n }\n\n private async startRunObservers(): Promise<ActiveAgentRunObservers> {\n const failOnObserverError =\n this.traceOptions?.failOnObserverError === true ||\n this.agent.observers.some((registration) => registration.failOnObserverError === true);\n return startAgentRunObservers(\n this.agent.observers,\n {\n agentName: this.agent.name,\n agentDescription: this.agent.description,\n instructions: this.agent.instructions,\n trace: this.traceOptions,\n prompt: this.promptMessage,\n history: this.chatHistory,\n maxTurns: this.maxTurnCount,\n },\n failOnObserverError,\n );\n }\n\n private async fetchDynamicContext(ragText: string | undefined): Promise<Document[]> {\n if (ragText === undefined || ragText.length === 0 || this.agent.dynamicContexts.length === 0) {\n return [];\n }\n\n const documents: Document[] = [];\n for (const registration of this.agent.dynamicContexts) {\n const results = await registration.index.search({\n query: ragText,\n topK: registration.options.topK,\n threshold: registration.options.threshold,\n filter: registration.options.filter,\n });\n for (const result of results) {\n const formatted = registration.options.format?.(result);\n if (formatted !== undefined) {\n documents.push(formatted);\n } else {\n const metadata = formatMetadata(result.metadata);\n documents.push({\n id: result.id,\n text:\n typeof result.document === \"string\"\n ? result.document\n : JSON.stringify(result.document, null, 2),\n ...(metadata === undefined ? {} : { additionalProps: metadata }),\n });\n }\n }\n }\n return documents;\n }\n\n private async fetchToolDefinitions(ragText: string | undefined): Promise<ToolDefinition[]> {\n const staticDefinitions = await this.agent.toolSet.getToolDefinitions(ragText);\n if (ragText === undefined || ragText.length === 0 || this.agent.dynamicTools.length === 0) {\n return staticDefinitions;\n }\n\n const definitions = [...staticDefinitions];\n const names = new Set(staticDefinitions.map((definition) => definition.name));\n for (const registration of this.agent.dynamicTools) {\n const results = await registration.index.search({\n query: ragText,\n topK: registration.options.topK,\n threshold: registration.options.threshold,\n filter: registration.options.filter,\n });\n for (const result of results) {\n if (names.has(result.document.toolName)) {\n continue;\n }\n names.add(result.document.toolName);\n definitions.push(result.document.definition);\n }\n }\n return definitions;\n }\n\n private async recordToolError(\n toolObservers: ActiveToolObservers | undefined,\n turn: number | undefined,\n toolCall: ToolCall,\n internalCallId: string,\n args: string,\n error: unknown,\n ): Promise<void> {\n await toolObservers?.error({\n turn: turn ?? 0,\n toolCall,\n toolName: toolCall.function.name,\n internalCallId,\n args,\n error,\n toolCallId: toolCall.callId,\n });\n }\n\n private async runCompletionCallHook(\n prompt: MessageType,\n history: MessageType[],\n newMessages: MessageType[],\n ): Promise<void> {\n const action = await this.activeHook?.onCompletionCall?.({\n prompt,\n history,\n run: runControl,\n });\n if (action?.type === \"terminate\") {\n throw this.cancelled(newMessages, action.reason);\n }\n }\n\n private async runCompletionResponseHook(\n prompt: MessageType,\n response:\n | Awaited<ReturnType<M[\"completion\"]>>\n | Awaited<ReturnType<CompletionModel[\"completion\"]>>,\n newMessages: MessageType[],\n ): Promise<void> {\n const action = await this.activeHook?.onCompletionResponse?.({\n prompt,\n response,\n run: runControl,\n });\n if (action?.type === \"terminate\") {\n throw this.cancelled(newMessages, action.reason);\n }\n }\n\n private cancelled(newMessages: MessageType[], reason: string): PromptCancelledError {\n return new PromptCancelledError([...this.chatHistory, ...newMessages], reason);\n }\n\n private memory(): MemoryRegistration | undefined {\n return this.memoryContext === undefined ? undefined : this.agent.memory;\n }\n\n private memoryPolicy(): MemorySavePolicy | undefined {\n return this.memory()?.options.savePolicy;\n }\n\n private async prepareMemoryRun(runId: string, newMessages: MessageType[]): Promise<void> {\n const memory = this.memory();\n if (memory === undefined || this.memoryContext === undefined) {\n this.chatHistory = this.initialHistory;\n return;\n }\n\n const memoryHistory = await memory.store.load(this.memoryContext);\n this.chatHistory = [...memoryHistory, ...this.initialHistory];\n if (memory.options.savePolicy === \"message\") {\n await memory.store.append({\n context: this.memoryContext,\n runId,\n turn: 1,\n messages: newMessages,\n });\n }\n }\n\n private async commitMemoryMessages(\n runId: string,\n turn: number,\n messages: MessageType[],\n pendingTurnMessages: MessageType[],\n ): Promise<void> {\n const memory = this.memory();\n if (memory === undefined || this.memoryContext === undefined || messages.length === 0) {\n return;\n }\n if (memory.options.savePolicy === \"message\") {\n await memory.store.append({\n context: this.memoryContext,\n runId,\n turn,\n messages,\n });\n } else if (memory.options.savePolicy === \"turn\") {\n pendingTurnMessages.push(...messages);\n }\n }\n\n private async commitCompletedMemoryTurn(\n runId: string,\n turn: number,\n pendingTurnMessages: MessageType[],\n ): Promise<void> {\n const memory = this.memory();\n if (\n memory === undefined ||\n this.memoryContext === undefined ||\n memory.options.savePolicy !== \"turn\" ||\n pendingTurnMessages.length === 0\n ) {\n return;\n }\n await memory.store.append({\n context: this.memoryContext,\n runId,\n turn,\n messages: [...pendingTurnMessages],\n });\n pendingTurnMessages.length = 0;\n }\n\n private async commitCompletedMemoryRun(\n runId: string,\n turn: number,\n newMessages: MessageType[],\n pendingTurnMessages: MessageType[],\n ): Promise<void> {\n await this.commitCompletedMemoryTurn(runId, turn, pendingTurnMessages);\n const memory = this.memory();\n if (\n memory === undefined ||\n this.memoryContext === undefined ||\n memory.options.savePolicy !== \"run\"\n ) {\n return;\n }\n await memory.store.append({\n context: this.memoryContext,\n runId,\n turn,\n messages: [...newMessages],\n });\n }\n\n private async recordMemoryError(\n runId: string,\n error: unknown,\n newMessages: MessageType[],\n ): Promise<void> {\n const memory = this.memory();\n if (memory === undefined || this.memoryContext === undefined) {\n return;\n }\n await memory.store.recordError?.({\n context: this.memoryContext,\n runId,\n error,\n messages: [...newMessages],\n });\n }\n}\n\nfunction normalizePromptInput(prompt: string | MessageType | MessageType[]): {\n prompt: MessageType;\n history: MessageType[];\n} {\n if (typeof prompt === \"string\") {\n return { prompt: Message.user(prompt), history: [] };\n }\n if (!Array.isArray(prompt)) {\n return { prompt, history: [] };\n }\n if (prompt.length === 0) {\n throw new TypeError(\"Prompt transcript must contain at least one message.\");\n }\n const activePrompt = prompt.at(-1);\n if (activePrompt === undefined) {\n throw new TypeError(\"Prompt transcript must contain at least one message.\");\n }\n return {\n prompt: activePrompt,\n history: prompt.slice(0, -1),\n };\n}\n\ntype ToolResultEventPayload = {\n toolName: string;\n toolCallId?: string;\n internalCallId: string;\n args: string;\n result: string;\n};\n\ntype AsyncQueueWaiter<T> = {\n resolve: (result: IteratorResult<T>) => void;\n reject: (error: unknown) => void;\n};\n\nfunction createAsyncQueue<T>(): AsyncIterable<T> & {\n enqueue(value: T): void;\n close(): void;\n throw(error: unknown): void;\n} {\n const values: T[] = [];\n const waiters: AsyncQueueWaiter<T>[] = [];\n let closed = false;\n let error: unknown;\n\n function flush(): void {\n while (waiters.length > 0 && values.length > 0) {\n const waiter = waiters.shift();\n const value = values.shift() as T;\n if (waiter !== undefined) {\n waiter.resolve({ value, done: false });\n }\n }\n\n if (values.length > 0 || waiters.length === 0 || !closed) {\n return;\n }\n\n while (waiters.length > 0) {\n const waiter = waiters.shift();\n if (waiter === undefined) {\n continue;\n }\n if (error !== undefined) {\n waiter.reject(error);\n } else {\n waiter.resolve({ value: undefined, done: true });\n }\n }\n }\n\n return {\n enqueue(value: T): void {\n if (closed) {\n return;\n }\n values.push(value);\n flush();\n },\n close(): void {\n closed = true;\n flush();\n },\n throw(thrown: unknown): void {\n closed = true;\n error = thrown;\n flush();\n },\n [Symbol.asyncIterator](): AsyncIterator<T> {\n return {\n next(): Promise<IteratorResult<T>> {\n if (values.length > 0) {\n const value = values.shift() as T;\n return Promise.resolve({ value, done: false });\n }\n if (error !== undefined) {\n return Promise.reject(error);\n }\n if (closed) {\n return Promise.resolve({ value: undefined, done: true });\n }\n return new Promise((resolve, reject) => {\n waiters.push({ resolve, reject });\n });\n },\n };\n },\n };\n}\n\nfunction addTurn(turn: number, event: AgentDeltaEvent): AgentStreamEvent {\n if (event.type === \"text_delta\") {\n return { type: \"text_delta\", turn, delta: event.delta };\n }\n if (event.type === \"reasoning_delta\") {\n const mapped: AgentStreamEvent = { type: \"reasoning_delta\", turn, delta: event.delta };\n if (event.id !== undefined) mapped.id = event.id;\n if (event.contentType !== undefined) mapped.contentType = event.contentType;\n if (event.signature !== undefined) mapped.signature = event.signature;\n return mapped;\n }\n return { type: \"tool_call\", turn, toolCall: event.toolCall };\n}\n\nfunction isGenerationDeltaEvent(type: string): boolean {\n return (\n type === \"text_delta\" ||\n type === \"reasoning_delta\" ||\n type === \"tool_call_delta\" ||\n type === \"tool_call\"\n );\n}\n\nfunction formatMetadata(\n metadata: Record<string, unknown> | undefined,\n): Record<string, string> | undefined {\n if (metadata === undefined) {\n return undefined;\n }\n\n return Object.fromEntries(Object.entries(metadata).map(([key, value]) => [key, String(value)]));\n}\n","import type { CompletionModel, Document, JsonObject, JsonValue, ToolChoice } from \"../completion\";\nimport type { McpServer } from \"../mcp\";\nimport {\n type MemoryOptions,\n type MemoryRegistration,\n type MemoryStore,\n resolveMemoryOptions,\n} from \"../memory\";\nimport type { AgentObserver, AgentObserverRegistration, ObserveOptions } from \"../observability\";\nimport { toProviderJsonSchema, type ZodSchema } from \"../schema/zod-schema\";\nimport type { SkillSet } from \"../skills\";\nimport type { ToolSearchDocument } from \"../tool/dynamic-tools\";\nimport type { AnyTool } from \"../tool/tool\";\nimport { ToolSet } from \"../tool/tool-set\";\nimport type { VectorSearchIndex } from \"../vector-store\";\nimport {\n Agent,\n type DynamicContextOptions,\n type DynamicContextRegistration,\n type DynamicToolOptions,\n type DynamicToolRegistration,\n} from \"./agent\";\nimport type { PromptHook } from \"./hooks\";\n\nexport class AgentBuilder<M extends CompletionModel = CompletionModel> {\n private readonly agentId: string;\n private agentName: string | undefined;\n private agentDescription: string | undefined;\n private instructionBlocks: string[] = [];\n private contextDocs: Document[] = [];\n private temp: number | undefined;\n private maxTokenCount: number | undefined;\n private params: JsonValue | undefined;\n private choice: ToolChoice | undefined;\n private turns: number | undefined;\n private requestHook: PromptHook | undefined;\n private schema: JsonObject | undefined;\n private skillInstructionBlocks: string[] = [];\n private observerRegistrations: AgentObserverRegistration[] = [];\n private dynamicContextRegistrations: DynamicContextRegistration[] = [];\n private dynamicToolRegistrations: DynamicToolRegistration[] = [];\n private memoryRegistration: MemoryRegistration | undefined;\n private activeToolSet = new ToolSet();\n\n constructor(\n agentId: string,\n private readonly completionModel: M,\n ) {\n this.agentId = normalizeAgentId(agentId);\n }\n\n name(name: string): this {\n this.agentName = name;\n return this;\n }\n\n description(description: string): this {\n this.agentDescription = description;\n return this;\n }\n\n instructions(instructions: string): this {\n if (instructions.length > 0) {\n this.instructionBlocks.push(instructions);\n }\n return this;\n }\n\n context(text: string, id = `static_doc_${this.contextDocs.length}`): this {\n this.contextDocs.push({ id, text });\n return this;\n }\n\n dynamicContext<T>(index: VectorSearchIndex<T>, options: DynamicContextOptions<T>): this {\n this.dynamicContextRegistrations.push({ index, options } as DynamicContextRegistration);\n return this;\n }\n\n dynamicTools(index: VectorSearchIndex<ToolSearchDocument>, options: DynamicToolOptions): this {\n this.dynamicToolRegistrations.push({ index, options });\n return this;\n }\n\n tool(tool: AnyTool): this {\n this.activeToolSet.addTool(tool);\n return this;\n }\n\n tools(tools: AnyTool[]): this {\n this.activeToolSet.addTools(tools);\n return this;\n }\n\n mcp(servers: McpServer[]): this {\n for (const server of servers) {\n this.activeToolSet.addTools(server.tools);\n }\n return this;\n }\n\n skills(skillSet: SkillSet): this {\n if (skillSet.instructions.length > 0) {\n this.skillInstructionBlocks.push(skillSet.instructions);\n }\n this.activeToolSet.addTools(skillSet.tools);\n return this;\n }\n\n useToolSet(toolSet: ToolSet): this {\n toolSet.addTools(this.activeToolSet);\n this.activeToolSet = toolSet;\n return this;\n }\n\n temperature(temperature: number): this {\n this.temp = temperature;\n return this;\n }\n\n maxTokens(maxTokens: number): this {\n this.maxTokenCount = maxTokens;\n return this;\n }\n\n additionalParams(params: JsonValue): this {\n this.params = params;\n return this;\n }\n\n toolChoice(toolChoice: ToolChoice): this {\n this.choice = toolChoice;\n return this;\n }\n\n defaultMaxTurns(defaultMaxTurns: number): this {\n this.turns = defaultMaxTurns;\n return this;\n }\n\n hook(hook: PromptHook): this {\n this.requestHook = hook;\n return this;\n }\n\n observe(observer: AgentObserver, options: ObserveOptions = {}): this {\n this.observerRegistrations.push({\n observer,\n failOnObserverError: options.failOnObserverError,\n });\n return this;\n }\n\n memory(store: MemoryStore, options: MemoryOptions = {}): this {\n this.memoryRegistration = {\n store,\n options: resolveMemoryOptions(options),\n };\n return this;\n }\n\n outputSchema(schema: ZodSchema): this {\n this.schema = toProviderJsonSchema(schema);\n return this;\n }\n\n build(): Agent<M> {\n return new Agent({\n id: this.agentId,\n name: this.agentName,\n description: this.agentDescription,\n model: this.completionModel,\n instructions: this.buildInstructions(),\n staticContext: this.contextDocs,\n temperature: this.temp,\n maxTokens: this.maxTokenCount,\n additionalParams: this.params,\n toolSet: this.activeToolSet,\n toolChoice: this.choice,\n defaultMaxTurns: this.turns,\n hook: this.requestHook,\n outputSchema: this.schema,\n observers: this.observerRegistrations,\n dynamicContexts: this.dynamicContextRegistrations,\n dynamicTools: this.dynamicToolRegistrations,\n memory: this.memoryRegistration,\n });\n }\n\n private buildInstructions(): string | undefined {\n const parts = [...this.instructionBlocks, ...this.skillInstructionBlocks].filter(\n (part): part is string => part !== undefined && part.length > 0,\n );\n return parts.length === 0 ? undefined : parts.join(\"\\n\\n\");\n }\n}\n\nfunction normalizeAgentId(id: string): string {\n if (typeof id !== \"string\") {\n throw new TypeError(\"Agent id must be a string.\");\n }\n\n const normalized = id.trim();\n if (normalized.length === 0) {\n throw new TypeError(\"Agent id must be a non-empty string.\");\n }\n\n return normalized;\n}\n"],"mappings":"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","names":["normalizeAgentId"]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import {
|
|
2
2
|
AgentBuilder
|
|
3
|
-
} from "./chunk-
|
|
3
|
+
} from "./chunk-JQCRURY2.js";
|
|
4
4
|
import {
|
|
5
5
|
createTool
|
|
6
6
|
} from "./chunk-B4QHQN5K.js";
|
|
@@ -139,4 +139,4 @@ export {
|
|
|
139
139
|
Extractor,
|
|
140
140
|
ExtractorBuilder
|
|
141
141
|
};
|
|
142
|
-
//# sourceMappingURL=chunk-
|
|
142
|
+
//# sourceMappingURL=chunk-O3TUS5RB.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/memory/index.ts"],"sourcesContent":["import type { JsonObject, Message } from \"../completion\";\n\nexport type MemorySavePolicy = \"message\" | \"turn\" | \"run\";\n\nexport type MemoryContext = {\n sessionId: string;\n userId?: string | undefined;\n metadata?: JsonObject | undefined;\n};\n\nexport type MemoryAppendInput = {\n context: MemoryContext;\n runId: string;\n turn: number;\n messages: Message[];\n};\n\nexport type MemoryErrorInput = {\n context: MemoryContext;\n runId: string;\n error: unknown;\n messages: Message[];\n};\n\nexport interface MemoryStore {\n load(context: MemoryContext): Promise<Message[]>;\n append(input: MemoryAppendInput): Promise<void>;\n clear(context: MemoryContext): Promise<void>;\n recordError?(input: MemoryErrorInput): Promise<void>;\n}\n\nexport type MemoryOptions = {\n savePolicy?: MemorySavePolicy | undefined;\n};\n\nexport type ResolvedMemoryOptions = {\n savePolicy: MemorySavePolicy;\n};\n\nexport type MemoryRegistration = {\n store: MemoryStore;\n options: ResolvedMemoryOptions;\n};\n\nexport type SessionOptions = {\n userId?: string | undefined;\n metadata?: JsonObject | undefined;\n};\n\nexport function resolveMemoryOptions(options: MemoryOptions = {}): ResolvedMemoryOptions {\n return {\n savePolicy: options.savePolicy ?? \"message\",\n };\n}\n"],"mappings":";AAiDO,SAAS,qBAAqB,UAAyB,CAAC,GAA0B;AACvF,SAAO;AAAA,IACL,YAAY,QAAQ,cAAc;AAAA,EACpC;AACF;","names":[]}
|
package/dist/evals/index.d.ts
CHANGED
|
@@ -1,7 +1,8 @@
|
|
|
1
|
-
import { k as PromptResponse, A as Agent } from '../agent-C6h6YrRU.js';
|
|
2
1
|
import { j as JsonValue, M as Message, b as CompletionModel } from '../types-BrxLd7ay.js';
|
|
2
|
+
import { l as PromptResponse, A as Agent } from '../agent-Bj0UqYMp.js';
|
|
3
3
|
import { Z as ZodSchema } from '../zod-schema-DJTEgQBq.js';
|
|
4
4
|
import { EmbeddingModel } from '../embeddings/index.js';
|
|
5
|
+
import '../memory/index.js';
|
|
5
6
|
import '../observability/index.js';
|
|
6
7
|
import '../tool-DhuBQ3yb.js';
|
|
7
8
|
import '../vector-store/index.js';
|
package/dist/evals/index.js
CHANGED
|
@@ -7,11 +7,12 @@ import {
|
|
|
7
7
|
llmScore,
|
|
8
8
|
runEvalSuite,
|
|
9
9
|
semanticSimilarity
|
|
10
|
-
} from "../chunk-
|
|
11
|
-
import "../chunk-
|
|
10
|
+
} from "../chunk-C7XTEV5W.js";
|
|
11
|
+
import "../chunk-O3TUS5RB.js";
|
|
12
12
|
import "../chunk-X6FBOU2P.js";
|
|
13
13
|
import "../chunk-SRGJPXKT.js";
|
|
14
|
-
import "../chunk-
|
|
14
|
+
import "../chunk-JQCRURY2.js";
|
|
15
|
+
import "../chunk-XXT2UCAR.js";
|
|
15
16
|
import "../chunk-XUUY2L2D.js";
|
|
16
17
|
import "../chunk-GNWMOSNR.js";
|
|
17
18
|
import "../chunk-B4QHQN5K.js";
|
|
@@ -1,6 +1,7 @@
|
|
|
1
|
-
import { A as Agent } from '../agent-C6h6YrRU.js';
|
|
2
1
|
import { U as Usage, M as Message, b as CompletionModel, j as JsonValue, o as ToolChoice } from '../types-BrxLd7ay.js';
|
|
2
|
+
import { A as Agent } from '../agent-Bj0UqYMp.js';
|
|
3
3
|
import { Z as ZodSchema } from '../zod-schema-DJTEgQBq.js';
|
|
4
|
+
import '../memory/index.js';
|
|
4
5
|
import '../observability/index.js';
|
|
5
6
|
import '../tool-DhuBQ3yb.js';
|
|
6
7
|
import '../vector-store/index.js';
|
package/dist/extractor/index.js
CHANGED
|
@@ -2,10 +2,11 @@ import {
|
|
|
2
2
|
ExtractionError,
|
|
3
3
|
Extractor,
|
|
4
4
|
ExtractorBuilder
|
|
5
|
-
} from "../chunk-
|
|
5
|
+
} from "../chunk-O3TUS5RB.js";
|
|
6
6
|
import "../chunk-X6FBOU2P.js";
|
|
7
7
|
import "../chunk-SRGJPXKT.js";
|
|
8
|
-
import "../chunk-
|
|
8
|
+
import "../chunk-JQCRURY2.js";
|
|
9
|
+
import "../chunk-XXT2UCAR.js";
|
|
9
10
|
import "../chunk-XUUY2L2D.js";
|
|
10
11
|
import "../chunk-GNWMOSNR.js";
|
|
11
12
|
import "../chunk-B4QHQN5K.js";
|
package/dist/index.d.ts
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
export {
|
|
1
|
+
export { MemoryAppendInput, MemoryContext, MemoryErrorInput, MemoryOptions, MemoryRegistration, MemorySavePolicy, MemoryStore, ResolvedMemoryOptions, SessionOptions, resolveMemoryOptions } from './memory/index.js';
|
|
2
|
+
export { A as Agent, a as AgentOptions, b as AgentSession, c as AgentStreamEvent, d as AgentToolOptions, C as CompletionCallHookArgs, e as CompletionResponseHookArgs, D as DEFAULT_MAX_TURNS, f as DynamicContextOptions, g as DynamicContextRegistration, h as DynamicToolOptions, i as DynamicToolRegistration, H as HookAction, j as HookResult, P as PromptHook, k as PromptRequest, l as PromptResponse, R as RunControl, T as ToolCallControl, m as ToolCallHookAction, n as ToolCallHookArgs, o as ToolCallHookResult, p as ToolHookArgs, q as ToolResultHookArgs, r as cancelPrompt, s as createHook, t as runControl, u as skipTool, v as toolCallControl } from './agent-Bj0UqYMp.js';
|
|
2
3
|
export { AgentBuilder, MaxTurnsError, PromptCancelledError } from './agent/index.js';
|
|
3
4
|
export { AudioGenerationModel, AudioGenerationRequest, AudioGenerationRequestBuilder, AudioGenerationResponse, audioGenerationRequest } from './audio-generation/index.js';
|
|
4
5
|
export { CompletionRequestBuilder, formatDocument, normalizeDocuments } from './completion/index.js';
|
package/dist/index.js
CHANGED
|
@@ -1,3 +1,7 @@
|
|
|
1
|
+
import {
|
|
2
|
+
TranscriptionRequestBuilder,
|
|
3
|
+
transcriptionRequest
|
|
4
|
+
} from "./chunk-7QI6ZAFI.js";
|
|
1
5
|
import {
|
|
2
6
|
connectMcp,
|
|
3
7
|
mcp
|
|
@@ -14,10 +18,6 @@ import {
|
|
|
14
18
|
loadSkills,
|
|
15
19
|
skill
|
|
16
20
|
} from "./chunk-KSIY7KJA.js";
|
|
17
|
-
import {
|
|
18
|
-
TranscriptionRequestBuilder,
|
|
19
|
-
transcriptionRequest
|
|
20
|
-
} from "./chunk-7QI6ZAFI.js";
|
|
21
21
|
import {
|
|
22
22
|
AudioGenerationRequestBuilder,
|
|
23
23
|
audioGenerationRequest
|
|
@@ -31,12 +31,12 @@ import {
|
|
|
31
31
|
llmScore,
|
|
32
32
|
runEvalSuite,
|
|
33
33
|
semanticSimilarity
|
|
34
|
-
} from "./chunk-
|
|
34
|
+
} from "./chunk-C7XTEV5W.js";
|
|
35
35
|
import {
|
|
36
36
|
ExtractionError,
|
|
37
37
|
Extractor,
|
|
38
38
|
ExtractorBuilder
|
|
39
|
-
} from "./chunk-
|
|
39
|
+
} from "./chunk-O3TUS5RB.js";
|
|
40
40
|
import {
|
|
41
41
|
createThinkTool,
|
|
42
42
|
createToolIndex,
|
|
@@ -52,6 +52,7 @@ import {
|
|
|
52
52
|
import {
|
|
53
53
|
Agent,
|
|
54
54
|
AgentBuilder,
|
|
55
|
+
AgentSession,
|
|
55
56
|
DEFAULT_MAX_TURNS,
|
|
56
57
|
MaxTurnsError,
|
|
57
58
|
PromptCancelledError,
|
|
@@ -61,7 +62,10 @@ import {
|
|
|
61
62
|
runControl,
|
|
62
63
|
skipTool,
|
|
63
64
|
toolCallControl
|
|
64
|
-
} from "./chunk-
|
|
65
|
+
} from "./chunk-JQCRURY2.js";
|
|
66
|
+
import {
|
|
67
|
+
resolveMemoryOptions
|
|
68
|
+
} from "./chunk-XXT2UCAR.js";
|
|
65
69
|
import {
|
|
66
70
|
toReadableStream
|
|
67
71
|
} from "./chunk-XUUY2L2D.js";
|
|
@@ -108,6 +112,7 @@ import {
|
|
|
108
112
|
export {
|
|
109
113
|
Agent,
|
|
110
114
|
AgentBuilder,
|
|
115
|
+
AgentSession,
|
|
111
116
|
AssistantContent,
|
|
112
117
|
AudioGenerationRequestBuilder,
|
|
113
118
|
CompletionCapabilityError,
|
|
@@ -168,6 +173,7 @@ export {
|
|
|
168
173
|
normalizeDocuments,
|
|
169
174
|
parseToolArgs,
|
|
170
175
|
reasoningDisplayText,
|
|
176
|
+
resolveMemoryOptions,
|
|
171
177
|
runControl,
|
|
172
178
|
runEvalSuite,
|
|
173
179
|
semanticSimilarity,
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { J as JsonObject, M as Message } from '../types-BrxLd7ay.js';
|
|
2
|
+
|
|
3
|
+
type MemorySavePolicy = "message" | "turn" | "run";
|
|
4
|
+
type MemoryContext = {
|
|
5
|
+
sessionId: string;
|
|
6
|
+
userId?: string | undefined;
|
|
7
|
+
metadata?: JsonObject | undefined;
|
|
8
|
+
};
|
|
9
|
+
type MemoryAppendInput = {
|
|
10
|
+
context: MemoryContext;
|
|
11
|
+
runId: string;
|
|
12
|
+
turn: number;
|
|
13
|
+
messages: Message[];
|
|
14
|
+
};
|
|
15
|
+
type MemoryErrorInput = {
|
|
16
|
+
context: MemoryContext;
|
|
17
|
+
runId: string;
|
|
18
|
+
error: unknown;
|
|
19
|
+
messages: Message[];
|
|
20
|
+
};
|
|
21
|
+
interface MemoryStore {
|
|
22
|
+
load(context: MemoryContext): Promise<Message[]>;
|
|
23
|
+
append(input: MemoryAppendInput): Promise<void>;
|
|
24
|
+
clear(context: MemoryContext): Promise<void>;
|
|
25
|
+
recordError?(input: MemoryErrorInput): Promise<void>;
|
|
26
|
+
}
|
|
27
|
+
type MemoryOptions = {
|
|
28
|
+
savePolicy?: MemorySavePolicy | undefined;
|
|
29
|
+
};
|
|
30
|
+
type ResolvedMemoryOptions = {
|
|
31
|
+
savePolicy: MemorySavePolicy;
|
|
32
|
+
};
|
|
33
|
+
type MemoryRegistration = {
|
|
34
|
+
store: MemoryStore;
|
|
35
|
+
options: ResolvedMemoryOptions;
|
|
36
|
+
};
|
|
37
|
+
type SessionOptions = {
|
|
38
|
+
userId?: string | undefined;
|
|
39
|
+
metadata?: JsonObject | undefined;
|
|
40
|
+
};
|
|
41
|
+
declare function resolveMemoryOptions(options?: MemoryOptions): ResolvedMemoryOptions;
|
|
42
|
+
|
|
43
|
+
export { type MemoryAppendInput, type MemoryContext, type MemoryErrorInput, type MemoryOptions, type MemoryRegistration, type MemorySavePolicy, type MemoryStore, type ResolvedMemoryOptions, type SessionOptions, resolveMemoryOptions };
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
|
package/dist/pipeline/index.d.ts
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
|
-
import { A as Agent } from '../agent-C6h6YrRU.js';
|
|
2
1
|
import { b as CompletionModel } from '../types-BrxLd7ay.js';
|
|
2
|
+
import { A as Agent } from '../agent-Bj0UqYMp.js';
|
|
3
3
|
import { Extractor } from '../extractor/index.js';
|
|
4
|
+
import '../memory/index.js';
|
|
4
5
|
import '../observability/index.js';
|
|
5
6
|
import '../zod-schema-DJTEgQBq.js';
|
|
6
7
|
import '../embeddings/index.js';
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@anvia/core",
|
|
3
|
-
"version": "0.1.
|
|
3
|
+
"version": "0.1.1",
|
|
4
4
|
"description": "Core runtime primitives for context-aware Anvia agents.",
|
|
5
5
|
"author": "anvia",
|
|
6
6
|
"maintainer": "Indra Zulfi",
|
|
@@ -48,6 +48,10 @@
|
|
|
48
48
|
"types": "./dist/mcp/index.d.ts",
|
|
49
49
|
"import": "./dist/mcp/index.js"
|
|
50
50
|
},
|
|
51
|
+
"./memory": {
|
|
52
|
+
"types": "./dist/memory/index.d.ts",
|
|
53
|
+
"import": "./dist/memory/index.js"
|
|
54
|
+
},
|
|
51
55
|
"./observability": {
|
|
52
56
|
"types": "./dist/observability/index.d.ts",
|
|
53
57
|
"import": "./dist/observability/index.js"
|
|
@@ -81,11 +85,6 @@
|
|
|
81
85
|
"import": "./dist/vector-store/index.js"
|
|
82
86
|
}
|
|
83
87
|
},
|
|
84
|
-
"scripts": {
|
|
85
|
-
"build": "tsup src/index.ts src/agent/index.ts src/audio-generation/index.ts src/completion/index.ts src/embeddings/index.ts src/evals/index.ts src/image-generation/index.ts src/loaders/index.ts src/extractor/index.ts src/mcp/index.ts src/observability/index.ts src/pipeline/index.ts src/skills/index.ts src/streaming/index.ts src/tool/index.ts src/transcription/index.ts src/vector-store/index.ts --format esm --dts --sourcemap --clean",
|
|
86
|
-
"test": "vitest run",
|
|
87
|
-
"typecheck": "tsc --noEmit"
|
|
88
|
-
},
|
|
89
88
|
"dependencies": {
|
|
90
89
|
"@modelcontextprotocol/sdk": "^1.29.0",
|
|
91
90
|
"pdfjs-dist": "^5.7.284",
|
|
@@ -98,5 +97,10 @@
|
|
|
98
97
|
"tsup": "^8.5.0",
|
|
99
98
|
"typescript": "^5.9.3",
|
|
100
99
|
"vitest": "^4.0.8"
|
|
100
|
+
},
|
|
101
|
+
"scripts": {
|
|
102
|
+
"build": "tsup src/index.ts src/agent/index.ts src/audio-generation/index.ts src/completion/index.ts src/embeddings/index.ts src/evals/index.ts src/image-generation/index.ts src/loaders/index.ts src/extractor/index.ts src/mcp/index.ts src/memory/index.ts src/observability/index.ts src/pipeline/index.ts src/skills/index.ts src/streaming/index.ts src/tool/index.ts src/transcription/index.ts src/vector-store/index.ts --format esm --dts --sourcemap --clean",
|
|
103
|
+
"test": "vitest run",
|
|
104
|
+
"typecheck": "tsc --noEmit"
|
|
101
105
|
}
|
|
102
|
-
}
|
|
106
|
+
}
|