Metadata-Version: 2.4
Name: repowire
Version: 0.1.1
Summary: Mesh network for AI coding agents - enables Claude Code and OpenCode sessions to communicate
Author: Prassanna Ravishankar
License: MIT
Keywords: agents,ai,claude,mcp,mesh,opencode
Classifier: Development Status :: 3 - Alpha
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: MIT License
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.12
Requires-Python: >=3.10
Requires-Dist: click>=8.1.7
Requires-Dist: fastapi>=0.109.0
Requires-Dist: httpx>=0.26.0
Requires-Dist: mcp>=1.0.0
Requires-Dist: pydantic-settings>=2.1.0
Requires-Dist: pydantic>=2.5.0
Requires-Dist: pyyaml>=6.0.1
Requires-Dist: rich>=13.7.0
Requires-Dist: uvicorn[standard]>=0.27.0
Provides-Extra: all
Requires-Dist: libtmux>=0.37.0; extra == 'all'
Provides-Extra: claudemux
Requires-Dist: libtmux>=0.37.0; extra == 'claudemux'
Provides-Extra: dev
Requires-Dist: mypy>=1.0.0; extra == 'dev'
Requires-Dist: pytest-asyncio>=0.21.0; extra == 'dev'
Requires-Dist: pytest-httpx>=0.30.0; extra == 'dev'
Requires-Dist: pytest>=7.0.0; extra == 'dev'
Requires-Dist: ruff>=0.1.0; extra == 'dev'
Provides-Extra: relay
Requires-Dist: python-socketio>=5.10.0; extra == 'relay'
Requires-Dist: redis>=5.0.1; extra == 'relay'
Description-Content-Type: text/markdown

<div align="center">
  <picture>
    <source srcset="https://raw.githubusercontent.com/prassanna-ravishankar/repowire/main/images/logo-dark.webp" media="(prefers-color-scheme: dark)" width="150" height="150" />
    <img src="https://raw.githubusercontent.com/prassanna-ravishankar/repowire/main/images/logo-light.webp" alt="Repowire Logo" width="150" height="150" />
  </picture>

  <h1>Repowire</h1>
  <p>Mesh network for AI coding agents (Claude Code, OpenCode) - enables sessions to communicate.</p>
</div>

## Quick Start

```bash
# One-time setup (installs hooks + MCP server)
repowire setup --dev  # use --dev for local development

# Start daemon
repowire serve

# Start Claude in tmux windows - peers auto-register via SessionStart hook
tmux new-window -n alice
cd ~/projects/frontend && claude

tmux new-window -n bob
cd ~/projects/backend && claude
```

Alice and Bob can now talk:
```
# In Alice's Claude session:
"Ask bob what API endpoints they have"
```

## How It Works

```
┌─────────────┐                        ┌─────────────┐
│   Alice     │  ask_peer("bob", ...)  │    Bob      │
│  (claude)   │ ───────────────────►   │  (claude)   │
│             │                        │             │
│             │  ◄─────────────────    │             │
│             │   Stop hook captures   │             │
└─────────────┘   response & returns   └─────────────┘
        │                                     │
        └──────────┐           ┌──────────────┘
                   ▼           ▼
              ┌─────────────────────┐
              │   HTTP Daemon       │
              │  127.0.0.1:8377     │
              │                     │
              │  - routes queries   │
              │  - tracks pending   │
              │  - receives hooks   │
              └─────────────────────┘
```

1. **SessionStart hook** registers peer with metadata (name = folder name, git branch)
2. **SessionStart hook** injects peer context into Claude (lists available peers)
3. **ask_peer** sends query to daemon, daemon injects into target's tmux pane
4. **Target Claude** responds naturally
5. **Stop hook** fires at end of turn, captures response from transcript
6. **Response** routes back to caller via daemon

## Backends

Repowire supports two backends for different AI coding environments:

### claudemux (default)
For **Claude Code** sessions running in tmux.
- Peers auto-register via SessionStart hook
- Responses captured via Stop hook reading transcript
- Requires: tmux, Claude Code with hooks support

```bash
repowire setup --backend claudemux
repowire serve --backend claudemux
```

### opencode
For **OpenCode** sessions using the opencode-ai SDK.
- Responses returned directly from SDK (no hooks needed)
- Requires: OpenCode server running

```bash
repowire setup --backend opencode
repowire serve --backend opencode
```

Set default backend in config: `daemon.backend: "claudemux"` or `"opencode"`

## MCP Tools

| Tool | Description |
|------|-------------|
| `list_peers()` | List all registered peers and their status |
| `ask_peer(peer_name, query)` | Ask a peer a question, wait for response |
| `notify_peer(peer_name, message)` | Proactively share info (don't use for responses) |
| `broadcast(message)` | Send message to all peers (announcements only) |

Note: Peers auto-register via SessionStart hook. Your response to `ask_peer` queries is captured automatically - don't use `notify_peer` to respond.

## CLI Commands

```bash
# Peer management
repowire peer list                          # List peers and status
repowire peer register NAME -t TMUX -p PATH # Register a peer (claudemux)
repowire peer register NAME -u URL -p PATH  # Register a peer (opencode)
repowire peer unregister NAME               # Remove a peer
repowire peer ask NAME "query"              # Test: ask a peer

# Backend-specific hook/plugin management
repowire claudemux install                  # Install Claude Code hooks
repowire claudemux uninstall                # Remove hooks
repowire claudemux status                   # Check installation
repowire opencode install                   # Install OpenCode plugin
repowire opencode status                    # Check installation

# Daemon
repowire serve                              # Start daemon (default backend)
repowire serve --backend claudemux          # Start with specific backend
repowire serve --backend opencode           # Start with OpenCode backend

# Relay server (self-hosted)
repowire relay start --port 8000            # Start relay server
repowire relay generate-key                 # Generate API key

# Configuration
repowire config show                        # Show current config
repowire config path                        # Show config file path
```

## Multi-Machine Setup

For Claude sessions on different machines, use the relay server:

### 1. Deploy relay (or use repowire.io)

```bash
# Self-hosted
repowire relay start --port 8000

# Or use hosted relay at relay.repowire.io
```

### 2. Generate API key

```bash
repowire relay generate-key --user-id myuser
# Save the generated key
```

### 3. Start daemon on each machine

```bash
# Configure relay in ~/.repowire/config.yaml, then:
repowire serve
```

## Configuration

Config file: `~/.repowire/config.yaml`

```yaml
daemon:
  host: "127.0.0.1"
  port: 8377
  backend: "claudemux"  # or "opencode"
  auto_reconnect: true
  heartbeat_interval: 30

relay:
  enabled: false
  url: "wss://relay.repowire.io"
  api_key: null

# Peers auto-populate via SessionStart hook
peers:
  frontend:
    name: frontend
    path: "/Users/you/app/frontend"
    tmux_session: "0:frontend"    # claudemux backend
    session_id: "abc123..."       # set by hook
    metadata:
      branch: "feat/new-ui"       # git branch, auto-detected
  backend:
    name: backend
    path: "/Users/you/app/backend"
    opencode_url: "http://localhost:4096"  # opencode backend
    session_id: "def456..."
    metadata:
      branch: "main"
```

## Testing the Flow

Use tmux MCP to set up test peers:

1. Start daemon: `repowire serve &`
2. Create windows for alice and bob via `tmux-mcp create-window`
3. In each window, run: `cd ~/development/projects/<some-project> && claude`
4. Verify with `repowire peer list` - peers show as folder names (e.g., `a2a-chat`)
5. In alice's session: "Ask a2a-chat what this project does"
6. Clean up: kill the tmux windows via `tmux-mcp kill-window`

Note: Peer name = folder name, not tmux window name.

## Requirements

- Python 3.10+
- tmux (for claudemux backend)
- Claude Code with hooks support (for claudemux backend)
- OpenCode (for opencode backend)

## License

MIT
