Skip to main content

Python SDK for the Rebuno execution runtime

Project description

Rebuno Python SDK

Python client library for the Rebuno agent execution runtime.

Installation

pip install rebuno

Quick Start

from rebuno import Client

client = Client(base_url="http://localhost:8080")

execution = await client.create("my-agent", input={"prompt": "hello"})
print(execution.id)

Client defaults to REBUNO_URL and REBUNO_API_KEY env vars when no args are passed.

Building an Agent

from rebuno import Agent, execution

agent = Agent("my-agent")

async def process(prompt: str) -> dict:
    print("running execution", execution.id)
    return {"answer": prompt.upper()}

agent.run(process)

The handler signature is the input schema — process(prompt: str) makes prompt a required field. Pass a pydantic.BaseModel parameter for validation, or input: dict for the raw claim. Use from rebuno import execution to access the current execution's id, session_id, history, etc.

Tools

from rebuno import tool

@tool("web.search")
async def search(query: str, limit: int = 10) -> list[str]:
    return [...]

Tools are plain module-level functions. The wrapper submits an intent to the kernel before running the body. Hand them to your framework as a list:

graph = create_agent(llm, [search, ...])

Building a Runner

from rebuno import Runner, tool

@tool("compute.heavy")
async def heavy(data: str) -> str:
    return process(data)

Runner("compute-1").run()

The runner advertises every @tool it imports, publishes their schemas to the kernel, and services job assignments. @tool(remote=True) lets you declare a stub in agent code for type-checked imperative calls.

Local MCP

The agent connects to the MCP server directly. Install with pip install rebuno[mcp]:

from rebuno import MCPServer

github = MCPServer(
    "github",
    url="https://api.githubcopilot.com/mcp/",
    headers={"Authorization": "Bearer xxx"},
)

# Inside your handler:
graph = create_agent(llm, [..., *github.tools])

Remote tools (incl. remote MCP)

Discover tools that runners host elsewhere — the agent never holds credentials, never opens MCP transport. Schemas come from the kernel directory.

from rebuno import remote

github_tools  = remote.Tools("github")
compute_tools = remote.Tools("compute")

# Inside your handler:
graph = create_agent(llm, [..., *github_tools, *compute_tools])
# or cherry-pick by short name:
graph = create_agent(llm, [..., github_tools["create_pr"], compute_tools["heavy"]])

Each call routes through the kernel to whichever runner advertises that tool ID. Works for any source — @tool Python functions on a runner, MCP servers hosted by a runner, or both.

Documentation

See the full documentation.

License

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

rebuno-0.4.1.tar.gz (115.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

rebuno-0.4.1-py3-none-any.whl (28.8 kB view details)

Uploaded Python 3

File details

Details for the file rebuno-0.4.1.tar.gz.

File metadata

  • Download URL: rebuno-0.4.1.tar.gz
  • Upload date:
  • Size: 115.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for rebuno-0.4.1.tar.gz
Algorithm Hash digest
SHA256 7b5fb2b2863ce36b312816fd807c7ef7b5145c5ef08544768ad0d940c25da432
MD5 b57d1977b3eb028c5d6d5c7fab9e53dd
BLAKE2b-256 24eb8fea8ba16121a87b786d02d4d989b007d2797baec5520d0f428da83a4ac5

See more details on using hashes here.

Provenance

The following attestation bundles were made for rebuno-0.4.1.tar.gz:

Publisher: publish.yml on rebuno/sdk-python

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file rebuno-0.4.1-py3-none-any.whl.

File metadata

  • Download URL: rebuno-0.4.1-py3-none-any.whl
  • Upload date:
  • Size: 28.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for rebuno-0.4.1-py3-none-any.whl
Algorithm Hash digest
SHA256 f89f8215de0a4d223740db596670f92d6df372f8a204bbe180038ab37d6b1830
MD5 5089401c7e60e48f16af9889c37cc3ef
BLAKE2b-256 ae97702450ff519154544d9e4230b32a38629856485ef177de80943a0c1541a2

See more details on using hashes here.

Provenance

The following attestation bundles were made for rebuno-0.4.1-py3-none-any.whl:

Publisher: publish.yml on rebuno/sdk-python

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page