Control your AI coding agents from your phone when you're away from your desk
Project description
Tether
The open source supervision layer for local AI coding agents.
You run Claude Code, Codex, OpenCode, or Pi in your terminal. Tether sits alongside and lets you watch and control those sessions from anywhere: a mobile-first web UI, or Telegram, Slack, and Discord threads with live output and approval buttons.
Claude Code / Codex / OpenCode / Pi
|
v
Tether (local)
| |
v v
Web UI (PWA) Telegram / Slack / Discord
The typical workflow
You already have an agent running. Tether attaches to it:
pipx install tether-ai
tether init # generates a token, optionally sets up a bridge
tether start # runs in the background
tether attach # pick from sessions running in the current directory
From that point the session appears in the web UI and, if you set up a bridge, gets its own Telegram topic or Discord thread where output streams live and approvals show up as buttons.
If you want to launch agents through Tether rather than directly:
# Set a default adapter once
echo "TETHER_DEFAULT_AGENT_ADAPTER=claude_auto" >> ~/.config/tether/config.env
tether new . # create a session in the current directory
tether new . -m "fix the failing tests" # create and start immediately
What you get
- Every session in one place: state, output, diffs, approvals
- Approval prompts as buttons in Telegram, Slack, or Discord, not terminal popups
- Auto-approve rules for low-risk tool patterns
- Human in the loop gates you can configure per session
- CLI client for scripting:
tether list,tether input,tether interrupt, and more - MCP server and REST API for custom agents
Install
pipx install tether-ai
Bridge dependencies are optional extras:
pip install tether-ai[telegram] # or [slack] or [discord]
Node.js is required for the Codex and OpenCode adapters. The sidecar bundles are included in the package and started automatically.
Setup
tether init # generates ~/.config/tether/config.env
tether start
Open http://localhost:8787.
tether init generates an auth token and optionally walks you through a messaging bridge. That is all it does. You do not need to configure an agent adapter to get started; just run your agents as usual and attach them.
From source
git clone https://github.com/larsderidder/tether.git
cd tether
make install
cp .env.example .env
make start
Attaching external sessions
Tether discovers sessions from Claude Code, Codex, OpenCode, and Pi that are already running on your machine. Use the external session browser in the web UI, or from the CLI:
tether list --external # show all discoverable sessions
tether attach # pick from sessions in current directory
tether attach <id-prefix> # attach by ID (prefix is fine)
tether attach <id> -p telegram # attach and create a Telegram topic
After attaching, use tether sync to pull messages that arrived before attachment.
Messaging bridges
Configure credentials in ~/.config/tether/config.env (or .env in the project root). The bridge starts automatically with tether start.
| Platform | Required vars |
|---|---|
| Telegram | TELEGRAM_BOT_TOKEN, TELEGRAM_FORUM_GROUP_ID |
| Slack | SLACK_BOT_TOKEN, SLACK_APP_TOKEN, SLACK_CHANNEL_ID |
| Discord | DISCORD_BOT_TOKEN, DISCORD_CHANNEL_ID |
Telegram requires a supergroup with Topics enabled. Each session gets its own topic. Commands work in the General topic: /list, /attach, /new, /help.
Adapters
Set TETHER_DEFAULT_AGENT_ADAPTER to use tether new or create sessions from the UI without specifying an adapter each time. If you only ever attach external sessions, you do not need this.
| Adapter | Description |
|---|---|
claude_auto |
Claude Code, auto-detects OAuth or API key |
claude_subprocess |
Claude via Agent SDK subprocess |
opencode |
OpenCode via TypeScript sidecar (auto-managed) |
codex_sdk_sidecar |
Codex via TypeScript sidecar |
pi_rpc |
Pi coding agent via JSON-RPC |
litellm |
Any model via LiteLLM (experimental) |
CLI
tether init # setup wizard
tether start # start the server
tether start --dev # dev mode (no auth)
tether start --port 9000
# attach to agents already running on your machine
tether list --external # discover Claude Code / Codex / OpenCode / Pi sessions
tether attach # pick from sessions in current directory
tether attach <id> # attach by ID prefix
tether attach <id> -p telegram # attach and bind a messaging thread
# manage Tether sessions
tether status # server health and active bridges
tether list # list Tether sessions
tether list -s running # filter by state
tether new [directory] # create a new session
tether new . -a opencode -m "..." # create and start with a prompt
tether input <id> "message" # send input
tether interrupt <id> # interrupt a running session
tether sync <id> # pull new messages from an attached session
tether watch <id> # stream live output to the terminal
tether delete <id> # delete a session
tether open # open web UI in browser
Session IDs accept short prefixes.
External Agent API
Any agent can connect to Tether via MCP or REST to get supervision without being one of the built-in adapters.
MCP
tether-mcp
Tools: create_session, send_output, request_approval, check_input.
{
"mcpServers": {
"tether": { "command": "tether-mcp" }
}
}
Install: pip install tether-ai[mcp]
REST
# Create a session
curl -X POST http://localhost:8787/api/sessions \
-H "Authorization: Bearer $TOKEN" \
-H "Content-Type: application/json" \
-d '{"name": "My Task", "agent_type": "custom"}'
# Push output
curl -X POST http://localhost:8787/api/sessions/{id}/events \
-H "Authorization: Bearer $TOKEN" \
-H "Content-Type: application/json" \
-d '{"type": "output", "data": {"text": "Hello from agent"}}'
See docs/API_REFERENCE.md for full endpoint documentation.
Configuration
Config is loaded in order: environment variables, local .env, ~/.config/tether/config.env.
TETHER_AGENT_TOKEN= # auth token (required in non-dev mode)
TETHER_DEFAULT_AGENT_ADAPTER= # default adapter for new sessions (optional)
TETHER_AGENT_HOST=0.0.0.0 # bind address
TETHER_AGENT_PORT=8787 # port
See .env.example for the full reference.
Development
make install # Python + Node dependencies
make start # build UI and start
make dev-ui # hot-reload UI dev server (run agent separately)
make test # pytest
make verify # health check
See AGENTS.md and docs/ for architecture documentation.
Running in the background
nohup tether start > ~/.local/share/tether/tether.log 2>&1 &
echo $! > ~/.local/share/tether/tether.pid
kill $(cat ~/.local/share/tether/tether.pid)
Or use systemd, launchd, etc.
License
Apache 2.0
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file tether_ai-0.3.4.tar.gz.
File metadata
- Download URL: tether_ai-0.3.4.tar.gz
- Upload date:
- Size: 693.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
25ebb04a5015d10b3c0c024356fc8f6a34cc36e882b82a24d282867fd01d8936
|
|
| MD5 |
0b5fe61d34b131949f47124852384637
|
|
| BLAKE2b-256 |
7ba644d385a8181a69ddc7ec08611cfc785f59de88975f13f462361ceaca9e20
|
Provenance
The following attestation bundles were made for tether_ai-0.3.4.tar.gz:
Publisher:
publish.yml on larsderidder/tether
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
tether_ai-0.3.4.tar.gz -
Subject digest:
25ebb04a5015d10b3c0c024356fc8f6a34cc36e882b82a24d282867fd01d8936 - Sigstore transparency entry: 1000712216
- Sigstore integration time:
-
Permalink:
larsderidder/tether@3e36a7a25406ccb8ae31fc0cde4bc3d237792b97 -
Branch / Tag:
refs/tags/v0.3.4 - Owner: https://github.com/larsderidder
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@3e36a7a25406ccb8ae31fc0cde4bc3d237792b97 -
Trigger Event:
release
-
Statement type:
File details
Details for the file tether_ai-0.3.4-py3-none-any.whl.
File metadata
- Download URL: tether_ai-0.3.4-py3-none-any.whl
- Upload date:
- Size: 659.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d31fa376235ede9017b949e556584fa8da823f44bf033eda2b313aa8cda1ddae
|
|
| MD5 |
f26ba3990cfdc232851b7390bc85ec63
|
|
| BLAKE2b-256 |
6576138bcbe016204f538a3552701818a5f924a165d1c3b85547d29773d05559
|
Provenance
The following attestation bundles were made for tether_ai-0.3.4-py3-none-any.whl:
Publisher:
publish.yml on larsderidder/tether
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
tether_ai-0.3.4-py3-none-any.whl -
Subject digest:
d31fa376235ede9017b949e556584fa8da823f44bf033eda2b313aa8cda1ddae - Sigstore transparency entry: 1000712279
- Sigstore integration time:
-
Permalink:
larsderidder/tether@3e36a7a25406ccb8ae31fc0cde4bc3d237792b97 -
Branch / Tag:
refs/tags/v0.3.4 - Owner: https://github.com/larsderidder
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@3e36a7a25406ccb8ae31fc0cde4bc3d237792b97 -
Trigger Event:
release
-
Statement type: