For the complete documentation index, see llms.txt. This page is also available as Markdown.

Run with Ruby SDK

Invoke an agent from Ruby with the fetch_hive gem

Use the official fetch_hive gem when you want to send a message to an agent from Ruby. The SDK wraps the public POST /v1/agent/invoke endpoint, handles authentication, supports streaming via a block, and accepts multimodal inputs.

Installation

Add to your Gemfile:

gem "fetch_hive"

Then run:

bundle install

Or install directly:

gem install fetch_hive

The gem uses faraday under the hood and supports Ruby 3.0+.

Authentication

Set the FETCH_HIVE_API_KEY environment variable to your workspace API key (the client reads it automatically):

export FETCH_HIVE_API_KEY=fhk_...
require "fetch_hive"

client = FetchHive::Client.new

Or pass the key explicitly:

See API Keys for how to create and rotate keys.

Basic example

Send a message to an agent and read the final response:

See the non-streaming response shape.

Method reference

Keyword
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<Hash>

No

Caller-managed conversation history. Each item: { role: "user" | "assistant" | "system", content: String }.

image_urls

Array<String>

No

HTTPS image URLs attached to the current message for multimodal inputs

user

String

No

Opaque caller identifier surfaced in User Tracking

metadata

Hash

No

Flat caller-defined metadata for audit and log filtering. See Invoke metadata

The SDK injects streaming: false for invoke_agent. To stream, use invoke_agent_stream (below).

Handling the response

Streaming

Use invoke_agent_stream to receive Server-Sent Events as they arrive. The method yields each parsed event hash to the block:

The stream yields the same event types documented in Invoke Agent → Response: summary (when auto-summarization fires), reasoning, response, tool, a final usage event, or an error event if the provider fails mid-stream.

If you omit the block, the method returns an Enumerator you can pass around:

Multi-turn conversations

Persistent threads

Pass any string as thread_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 in messages. Fetch Hive uses the supplied history for context but does not persist it:

Multimodal inputs

Attach images to the current message with image_urls:

URLs must start with https://.

Configuration

Option
Default
Description

api_key

ENV["FETCH_HIVE_API_KEY"]

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 raise a RuntimeError with the status code and body. Rescue them if you need to handle failures:

See Errors and Rate Limits for status code meanings.

Next steps

Last updated