fetch-hive/sdk Composer package when you want to send a message to an agent from PHP. The SDK wraps the public POST /v1/agent/invoke endpoint, handles authentication, exposes streaming responses as a generator, and accepts multimodal inputs.
Installation
Authentication
Set theFETCH_HIVE_API_KEY environment variable to your workspace API key (the client reads it automatically):
Basic example
Send a message to an agent and read the final response:Method reference
| Key | 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 | No | Caller-managed conversation history. Each item: ['role' => 'user' | 'assistant' | 'system', 'content' => string]. |
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 | array | 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 a Generator:
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 |
|---|---|---|
api_key | FETCH_HIVE_API_KEY env var | Bearer token from the dashboard |
base_url | https://api.fetchhive.com/v1 | Override the API base URL |
timeout | 120 | Request timeout in seconds |
Errors
Non-2xx responses throwFetchHive\Sdk\Exception\ApiException carrying the status code and response body:
Links
Next steps
- Run with API - The same flow with cURL
- Run with Python SDK
- Run with Node.js SDK
- Run with Ruby SDK
- Invoke Agent - Full endpoint reference

