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.5.tar.gz (149.1 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.5-py3-none-any.whl (33.2 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: shinox_agent_sdk-0.1.5.tar.gz
  • Upload date:
  • Size: 149.1 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.5.tar.gz
Algorithm Hash digest
SHA256 04ff473eadc69624f5119c9dc797c925241f05c2b44b8a431112a28470c8b68c
MD5 0ea2f90e558460aef25d67896dabefe3
BLAKE2b-256 ba80e9b3824aa8097a54e29b7958136d58ef327611e8c9862076be4c5ab6fd46

See more details on using hashes here.

Provenance

The following attestation bundles were made for shinox_agent_sdk-0.1.5.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.5-py3-none-any.whl.

File metadata

File hashes

Hashes for shinox_agent_sdk-0.1.5-py3-none-any.whl
Algorithm Hash digest
SHA256 176a60934a1c70c4509c9eb42eabc923251b742aefbe8a4d326365ad3b02e168
MD5 85355261d57f480e13bdc123d58571f7
BLAKE2b-256 b79ec57762f1f4fb9cfd6a358ab9799db865f3e1072bada3a5ed953154dc0449

See more details on using hashes here.

Provenance

The following attestation bundles were made for shinox_agent_sdk-0.1.5-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