Skip to main content

SDK for building agents in the Shinox decentralized mesh network

Project description

Shinox Agent SDK

A Python library for building agents in the Shinox decentralized mesh network.

Installation

# Using pip
pip install shinox-agent-sdk

# Using uv
uv add shinox-agent-sdk

# With LangChain support
pip install shinox-agent-sdk[langchain]

For local development:

cd shinox-agent-sdk
pip install -e .

Quick Start

Worker Agent (Simple)

For agents that execute tasks and return results:

from shinox_agent import ShinoxWorkerAgent
from brain import brain  # Your LangGraph/LangChain brain
from agent import agent_card  # Your A2A AgentCard

agent = ShinoxWorkerAgent(
    agent_card=agent_card,
    brain=brain,
    triggers=["calculate", "process"],  # Optional custom wake-up words
)

app = agent.app

# Run with: faststream run main:app

The worker automatically:

  • Registers with the agent registry
  • Joins sessions when invited by Director
  • Wakes up when @mentioned or targeted
  • Invokes your brain and publishes results

Custom Agent (Advanced)

For agents with complex logic (like Squad Lead):

from shinox_agent import ShinoxAgent, AgentMessage

async def my_handler(msg: AgentMessage, agent: ShinoxAgent):
    headers = msg.headers

    # Custom wake-up logic
    if headers.interaction_type == "SESSION_BRIEFING":
        # Handle briefing
        pass

    if headers.target_agent_id == agent.agent_id:
        # Process and respond
        await agent.publish_message(
            content="Task completed",
            conversation_id=headers.conversation_id,
            interaction_type="TASK_RESULT",
        )

agent = ShinoxAgent(
    agent_card=agent_card,
    session_handler=my_handler,
    triggers=["coordinate", "plan"],
)

app = agent.app

API Reference

ShinoxAgent

Base class for all agents.

ShinoxAgent(
    agent_card: AgentCard,           # A2A agent card
    session_handler: Callable,        # async def handler(msg, agent)
    triggers: list[str] = None,       # Wake-up keywords
    agent_url: str = None,            # URL for registry (default: env AGENT_URL)
)

Attributes:

  • agent_id: str - Generated from agent_card.name
  • active_sessions: set[str] - Currently joined sessions
  • broker: KafkaBroker - FastStream Kafka broker
  • app: FastStream - FastStream application

Methods:

  • publish_message(content, conversation_id, interaction_type, target_agent_id=None)
  • publish_update(content, conversation_id, interaction_type) - Alias for publish_message
  • resolve_agent_inbox(agent_id) -> str - Get inbox topic for an agent
  • fetch_available_agents(exclude_self=True) -> list[str] - Get active agents from registry

ShinoxWorkerAgent

Worker agent with default wake-up logic.

ShinoxWorkerAgent(
    agent_card: AgentCard,
    brain: Any,                       # LangGraph brain with ainvoke()
    agent_url: str = None,
    triggers: list[str] = None,       # Additional wake-up keywords
)

Additional Methods:

  • publish_task_result(content, conversation_id, target_agent_id=None)

Default Wake-up Triggers:

  • target_agent_id matches this agent
  • @{agent_id} mentioned in content
  • Any custom trigger word found (case-insensitive)

Message Schemas

from shinox_agent import AgentMessage, A2AHeaders

# Create a message
msg = AgentMessage(
    content="Hello",
    headers=A2AHeaders(
        source_agent_id="my-agent",
        interaction_type="INFO_UPDATE",
        conversation_id="session.123",
    )
)

Environment Variables

Variable Default Description
KAFKA_BOOTSTRAP_SERVERS localhost:19092 Kafka/Redpanda broker URL
AGENT_REGISTRY_URL http://localhost:9000 Agent registry URL
AGENT_URL http://localhost:8001 This agent's URL for registry

Architecture

┌─────────────────────────────────────────────────────────────┐
│                    ShinoxAgent (Base)                        │
├─────────────────────────────────────────────────────────────┤
│  • Broker setup (Kafka/Redpanda)                            │
│  • Registry registration                                     │
│  • Inbox subscription (mesh.agent.{id}.inbox)               │
│  • Dynamic session subscription                              │
│  • Message parsing                                           │
│  • publish_message(), resolve_agent_inbox()                  │
└─────────────────────────────────────────────────────────────┘
                              │
                              │ extends
                              ▼
┌─────────────────────────────────────────────────────────────┐
│                  ShinoxWorkerAgent                           │
├─────────────────────────────────────────────────────────────┤
│  • Default wake-up logic                                     │
│  • Brain invocation                                          │
│  • publish_task_result()                                     │
└─────────────────────────────────────────────────────────────┘

Message Flow

  1. Director sends JOIN_SESSION to agent inbox
  2. Agent joins session, subscribes to session topic, sends acknowledgment
  3. Director sends SESSION_BRIEFING to session topic
  4. Agent wakes up (if triggered), invokes brain, publishes result

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

shinox_agent_sdk-0.1.3.tar.gz (146.2 kB view details)

Uploaded Source

Built Distribution

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

shinox_agent_sdk-0.1.3-py3-none-any.whl (31.2 kB view details)

Uploaded Python 3

File details

Details for the file shinox_agent_sdk-0.1.3.tar.gz.

File metadata

  • Download URL: shinox_agent_sdk-0.1.3.tar.gz
  • Upload date:
  • Size: 146.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for shinox_agent_sdk-0.1.3.tar.gz
Algorithm Hash digest
SHA256 29f88938db1b4aba1860ad9edef1e6e71ab024c27cd31f0e72a607bbce248133
MD5 0444fb2f391d15fc55bcbced25a5a529
BLAKE2b-256 24190738358777195e5af2496b9355eaa69ceedd874f5226f0c6bdd0bd04e4d4

See more details on using hashes here.

Provenance

The following attestation bundles were made for shinox_agent_sdk-0.1.3.tar.gz:

Publisher: publish.yml on Shinox-lab/shinox-agent-sdk

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

File details

Details for the file shinox_agent_sdk-0.1.3-py3-none-any.whl.

File metadata

File hashes

Hashes for shinox_agent_sdk-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 64c649bc1fbd35114ea3861cdd294ec84e2a70949ca940b975ee009d100d1853
MD5 e74eb46b94429c7397856ce725c06779
BLAKE2b-256 d3e7b59bf6cb2951f8e4d93529f4e7be6eb10547b80e777ec03d5aea33d34516

See more details on using hashes here.

Provenance

The following attestation bundles were made for shinox_agent_sdk-0.1.3-py3-none-any.whl:

Publisher: publish.yml on Shinox-lab/shinox-agent-sdk

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