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.6.tar.gz (150.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.6-py3-none-any.whl (33.7 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: shinox_agent_sdk-0.1.6.tar.gz
  • Upload date:
  • Size: 150.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.6.tar.gz
Algorithm Hash digest
SHA256 42120acbbf6377baac4e8200aae56a45c1b7be96990ce86bdee8ab39d868314b
MD5 7c28d9cc235089881e608d50bf7b2b4e
BLAKE2b-256 cb9ca62921983034e3a874da0a217d38ff350ea8289829829debc7428fe6f334

See more details on using hashes here.

Provenance

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

File metadata

File hashes

Hashes for shinox_agent_sdk-0.1.6-py3-none-any.whl
Algorithm Hash digest
SHA256 c1fcff19b8bbb05bb628ff8837a8ecdbc6aa1cb6f476f9c3364e752267cf259f
MD5 c0c2e7edd5cd8aa81bdbe9bbd24c4022
BLAKE2b-256 04f796ddf766f0f9099044a1d26798dc2f01d75691b26554c6e2526c9a67fc8d

See more details on using hashes here.

Provenance

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