@fetch-hive/sdk package when you want to send a message to an agent from Node.js or TypeScript. The SDK wraps the public POST /v1/agent/invoke endpoint, handles authentication, exposes streaming as an AsyncIterable, and supports multimodal inputs.
Installation
fetch) and ships with TypeScript types.
Authentication
Set theFETCH_HIVE_API_KEY environment variable to your workspace API key:
Basic example
Send a message to an agent and read the final response:Method reference
| Field | Type | Required | Description |
|---|---|---|---|
agent | string | Yes | The agent ID |
message | string | Yes | The message you want to send |
thread_id | string | No | An arbitrary string identifying a persistent conversation thread |
messages | Array<{ role, content, image_urls? }> | No | Caller-managed conversation history |
image_urls | string[] | No | HTTPS image URLs attached to the current message for multimodal inputs |
user | string | No | Opaque caller identifier surfaced in User Tracking |
metadata | Record<string, string | number | boolean | null> | No | Flat caller-defined metadata for audit and log filtering. See Invoke metadata |
streaming: false for invokeAgent. To stream, use invokeAgentStream (below).
Handling the response
Streaming
UseinvokeAgentStream to receive Server-Sent Events as they arrive. The method returns an AsyncIterable:
summary (when auto-summarization fires), reasoning, response, tool, a final usage event, or an error event if the provider fails mid-stream.
Multi-turn conversations
Persistent threads
Pass any string asthread_id and Fetch Hive will create the thread on the first call and resume it on subsequent calls with the same value:
Stateless history
Manage state yourself by passing the previous turns inmessages. Fetch Hive uses the supplied history for context but does not persist it:
Multimodal inputs
Attach images to the current message withimage_urls:
https://.
Configuration
| Option | Default | Description |
|---|---|---|
apiKey | process.env.FETCH_HIVE_API_KEY | Bearer token from the dashboard |
baseURL | https://api.fetchhive.com/v1 | Override the API base URL |
Errors
Non-2xx responses throw anError whose message includes the status code and response body:
Links
Next steps
- Run with API - The same flow with cURL
- Run with Python SDK
- Run with Ruby SDK
- Run with PHP SDK
- Invoke Agent - Full endpoint reference

