MCP server for persistent interactive terminal orchestration
Project description
i4z-terminal-mcp
MCP server that enables AI agents to manage multiple persistent terminal sessions concurrently.
Features
- Persistent PTY-backed bash shells
- 9 MCP tools for full terminal lifecycle management
- Concurrent terminals with isolated async background readers
- Incremental cursor-based output reads
- Pattern-based output waiting
- Signal support (SIGINT, SIGTERM, SIGKILL)
- Web UI — view terminals live at
http://127.0.0.1:9020(xterm.js)
Install
uv tool install i4z-terminal-mcp
# or
pip install i4z-terminal-mcp
# or from source
uv pip install -e .
Usage
With OpenCode, add to opencode.json:
{
"mcp": {
"terminal": {
"type": "local",
"command": ["uvx", "i4z-terminal-mcp"],
"enabled": true
}
}
}
Or directly:
i4z-terminal-mcp
Tools
| Tool | Description |
|---|---|
create_terminal |
Spawn a persistent bash shell |
list_terminals |
List all active sessions |
terminal_status |
Get PID, CWD, alive, timestamps |
send_input |
Write text/commands to stdin |
read_output |
Incremental read via cursor |
send_signal |
Send SIGINT/SIGTERM/SIGKILL |
kill_terminal |
Destroy session and free resources |
wait_for_output |
Block until pattern appears |
search_output |
Search output history buffer |
Requirements
- Python 3.11+
- Linux or macOS (pexpect PTY support)
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 i4z_terminal_mcp-0.3.0.tar.gz.
File metadata
- Download URL: i4z_terminal_mcp-0.3.0.tar.gz
- Upload date:
- Size: 8.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.9.30 {"installer":{"name":"uv","version":"0.9.30","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Arch Linux","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
306df852262556cad83f6c1711a939723c6f8ff6f4a2c9371a7d9bd19da48e85
|
|
| MD5 |
ebaf31f974aea4804fadf897d64b1829
|
|
| BLAKE2b-256 |
a20dc966a4a1756c742d298ca30f57da6da4506115f555aa1dd51abf6ec69ac0
|
File details
Details for the file i4z_terminal_mcp-0.3.0-py3-none-any.whl.
File metadata
- Download URL: i4z_terminal_mcp-0.3.0-py3-none-any.whl
- Upload date:
- Size: 11.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.9.30 {"installer":{"name":"uv","version":"0.9.30","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Arch Linux","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e2d8a5069b8820ad3b487e92031dc6a401de0e09d27bac30d40e363fae997d3c
|
|
| MD5 |
f848dbcbe70ff1130ce1911d41addff2
|
|
| BLAKE2b-256 |
a00acd7bb683176218e5db41c0c3b474a1b1a2ce379a2fb7894e40f037747dda
|