Skip to main content

The runtime for agents that act in the real world.

Project description

dendrux

Python SDK for Dendrux — the framework for building agents with tools, persistence, and observability.

Version: 0.1.0a1

Install

pip install "dendrux[all]"              # Everything
pip install "dendrux[anthropic,db]"     # Just Anthropic + SQLite
pip install "dendrux[openai,db]"        # Just OpenAI + SQLite

Quick Example

import asyncio
from dendrux import Agent, tool
from dendrux.llm.anthropic import AnthropicProvider

@tool()
async def add(a: int, b: int) -> int:
    """Add two numbers."""
    return a + b

async def main():
    async with Agent(
        provider=AnthropicProvider(model="claude-sonnet-4-6"),
        prompt="You are a calculator.",
        tools=[add],
    ) as agent:
        result = await agent.run("What is 15 + 27?")
        print(result.answer)

asyncio.run(main())

Providers

Provider Import Use case
Anthropic from dendrux.llm.anthropic import AnthropicProvider Claude models
OpenAI from dendrux.llm.openai import OpenAIProvider GPT models + vLLM, SGLang, Groq, Ollama
OpenAI Responses from dendrux.llm.openai_responses import OpenAIResponsesProvider GPT + built-in tools (web search)
Mock from dendrux.llm.mock import MockLLM Deterministic testing

API Quick Reference

from pathlib import Path
from dendrux.observers.console import ConsoleObserver

async with Agent(
    provider=provider,                  # Required: LLM provider
    prompt="...",                        # Required: system prompt
    tools=[add],                         # Optional: tool functions
    database_url=f"sqlite+aiosqlite:///{Path.home() / '.dendrux' / 'dendrux.db'}",
    redact=my_scrubber,                  # Optional: scrub persisted strings
) as agent:
    result = await agent.run(
        "What is 15 + 27?",
        observer=ConsoleObserver(),      # Optional: terminal output
        tenant_id="org-123",             # Optional: multi-tenant isolation
        metadata={"thread": "t1"},       # Optional: your linking data
    )

RunResult

result.answer          # str | None — the agent's final answer
result.status          # RunStatus — SUCCESS, ERROR, MAX_ITERATIONS, WAITING_CLIENT_TOOL, CANCELLED
result.steps           # list[AgentStep] — full reasoning chain
result.iteration_count # int — how many loop iterations ran
result.usage           # UsageStats — input_tokens, output_tokens, total_tokens
result.run_id          # str — unique run identifier (ULID)
result.error           # str | None — error message if status is ERROR

Tool Options

@tool()                                  # Basic server tool
@tool(target="client")                   # Client-side — agent pauses
@tool(max_calls_per_run=3)               # Limit calls per run
@tool(timeout_seconds=120)               # Custom timeout (default 120s)
@tool(parallel=False)                    # Run alone, not concurrently

Full Documentation

See the full documentation on GitHub for provider setup, configuration, database guide, CLI, dashboard, observer system, and examples.

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

dendrux-0.2.0a3.tar.gz (1.6 MB view details)

Uploaded Source

Built Distribution

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

dendrux-0.2.0a3-py3-none-any.whl (1.5 MB view details)

Uploaded Python 3

File details

Details for the file dendrux-0.2.0a3.tar.gz.

File metadata

  • Download URL: dendrux-0.2.0a3.tar.gz
  • Upload date:
  • Size: 1.6 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.12

File hashes

Hashes for dendrux-0.2.0a3.tar.gz
Algorithm Hash digest
SHA256 81716aaa65961c1f88677a2743e3df5ab36ab485dd0d98d0e37c1fb6a94b61ce
MD5 9ddcae385a4ec06b6ca6c2fd87f3b03a
BLAKE2b-256 cbcb4d44c3c7e6efbd3dacd7c05774cf9c049b532c67c76ff320e3d8e64dd6dd

See more details on using hashes here.

File details

Details for the file dendrux-0.2.0a3-py3-none-any.whl.

File metadata

  • Download URL: dendrux-0.2.0a3-py3-none-any.whl
  • Upload date:
  • Size: 1.5 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.12

File hashes

Hashes for dendrux-0.2.0a3-py3-none-any.whl
Algorithm Hash digest
SHA256 b31063ffe0c5d8532331c468800996655c4962d085a809320ef95391a1dfc8ca
MD5 b2a6ce1a696fe7d308aaf722b030f790
BLAKE2b-256 47f2564cb5caf1abe2fbeb8a5be8877ff90e4b3faab750eea852aba5ea1dbbee

See more details on using hashes here.

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