MCP server exposing iTerm2 to agents for observation and non-destructive annotation.
Project description
mcp-server-iterm2
A Model Context Protocol (MCP) server that exposes iTerm2 to agents for observation and non-destructive annotation. Agents can inspect sessions and decorate them (badge, title, tab color, user variables, notifications) but cannot inject keystrokes, close or spawn sessions, or otherwise alter the user's working environment.
Install
Configure your MCP client (e.g. Claude Desktop, Claude Code):
{
"mcpServers": {
"iterm2": {
"command": "uvx",
"args": ["mcp-server-iterm2"]
}
}
}
Requires macOS, iTerm2, and uv installed.
First run
On first invocation, iTerm2 prompts you to authorize API access for the script. Approve it. Subsequent runs are silent.
If you previously denied access: iTerm2 → Preferences → General → Magic → enable "Python API" and remove mcp-server-iterm2 from the denial list.
Tools
Read
| Tool | Description |
|---|---|
list_sessions |
Tree of windows → tabs → sessions, plus a top-level buried_sessions list. |
get_session_info |
Title, working dir, profile, badge, dimensions, TTY |
get_screen_contents |
Visible buffer + cursor position |
get_scrollback |
Last N lines (default 200, max 5000) |
get_recent_output |
Output since a cursor marker (cursor-based pagination) |
get_selection |
Currently-selected text |
get_variable |
Read a variable by fully-qualified name (e.g. session.path, user.badge) |
list_profiles |
Available profiles by name and GUID |
Write (non-destructive)
| Tool | Description |
|---|---|
set_badge |
Set session badge text |
set_title |
Override session title |
set_tab_color |
Tint the tab (RGB 0-255) |
set_user_variable |
Set a user.* session variable |
post_notification |
Post a macOS notification banner |
Every session-targeted tool accepts an optional session_id. If omitted, the server uses $ITERM_SESSION_ID from its environment — which works automatically when the agent runs inside iTerm2.
Notes on rendering
- Badge: for
set_badgeto display anything, your iTerm2 profile's badge format must include\(user.badge). Configure in iTerm2 → Profiles → General → Badge. - Title: whether a
set_titleoverride sticks depends on the profile's "Allow terminal apps to change title" and "Title Components" settings. The server always sets the override; iTerm2 controls the rendering. - Tab color:
set_tab_colorwrites the legacy tab color plus both light- and dark-mode variants, so the tint takes effect regardless of the profile's split-color preference. - Notifications: routed through macOS via
osascript. Make sure Terminal/iTerm2 notifications are allowed in System Settings if banners don't appear.
Excluded by design
For safety, these are not exposed: send_text/keystroke injection, closing or spawning sessions/tabs/windows, splitting panes, focus changes, broadcasting input.
Security model
Installing this server gives any MCP client that uses it broad read access to your iTerm2 sessions (screen contents, scrollback, working directories, variables) and limited write access (badge, title, tab color, user.* variables, macOS notifications). Read tools can capture passwords visible on screen; write tools can spoof titles and notifications. The full threat model and reporting flow live in SECURITY.md.
Development
uv sync
uv run pytest tests/unit # 122 unit tests
uv run ruff check . # lint
uv run ruff format --check . # format check
uv run ty check src # type check
Integration tests (pytest -m integration) and the smoke script (scripts/smoke.py) require running inside an iTerm2 session. See CONTRIBUTING.md for the full development guide and ARCHITECTURE.md for how the pieces fit together.
API stability
This project follows semantic versioning. The current release is in the 0.x series; expect schema refinements between minor versions as the tool surface settles in response to real-world feedback. Pin to a specific version in production.
From 1.0 onward the following will be part of the stable contract — breaking any of them requires a major bump:
- Tool names and the set of tools. Names and removal of tools are stable; new tools may be added in minor releases.
- Tool argument names and types. New optional arguments may be added; existing argument names, types, and required-ness do not change.
- Top-level response keys and value types. New keys may be added in minor releases; existing keys and their types do not change.
- Error envelope shape.
MCPIterm2Errorsubclasses surface actionable text viato_error_text; unknown exceptions collapse toInternal error: <ExceptionClass>. Callers may pattern-match on this envelope.
Not part of the stable surface:
- Internal Python modules (
server.py,connection.py,tools/*,errors.py,output_cursor.py) — these are implementation details. - Specific cursor payload encoding for
get_recent_output. Treat the cursor as opaque; pass back whatever the server returned. - iTerm2 SDK and macOS version compatibility windows — these follow upstream and may change in minor releases.
Documentation
- ARCHITECTURE.md — module layout, lifecycle, data flow
- CONTRIBUTING.md — dev setup, quality gates, PR process
- SECURITY.md — threat model and how to report a vulnerability
- CHANGELOG.md — version history
- CODE_OF_CONDUCT.md — community standards
License
MIT — see LICENSE.
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 mcp_server_iterm2-0.1.1.tar.gz.
File metadata
- Download URL: mcp_server_iterm2-0.1.1.tar.gz
- Upload date:
- Size: 14.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
919b2c3dafb572924229c635e1074b78ee117f5a18f366231d0cca3723b17b1d
|
|
| MD5 |
368e0abd9e574c80ee100b83bddb3ff2
|
|
| BLAKE2b-256 |
297a3290c32df98ae3cbd48ec79c64108845a9465ff4caca4876d8b5b3f2ae67
|
Provenance
The following attestation bundles were made for mcp_server_iterm2-0.1.1.tar.gz:
Publisher:
publish.yml on r6e/mcp-server-iterm2
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
mcp_server_iterm2-0.1.1.tar.gz -
Subject digest:
919b2c3dafb572924229c635e1074b78ee117f5a18f366231d0cca3723b17b1d - Sigstore transparency entry: 1563176881
- Sigstore integration time:
-
Permalink:
r6e/mcp-server-iterm2@2753a6cbabebb0972752745c37daf8b453233565 -
Branch / Tag:
refs/tags/v0.1.1 - Owner: https://github.com/r6e
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@2753a6cbabebb0972752745c37daf8b453233565 -
Trigger Event:
push
-
Statement type:
File details
Details for the file mcp_server_iterm2-0.1.1-py3-none-any.whl.
File metadata
- Download URL: mcp_server_iterm2-0.1.1-py3-none-any.whl
- Upload date:
- Size: 18.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
440c05ee5dd8177d9a35e950abb760821f720c5771ec0e9320498e9b41dd8431
|
|
| MD5 |
b5542d223194715c273dadf3d92eb319
|
|
| BLAKE2b-256 |
7313835a59d271234dfdc7688f2b0fcd1fec658434d6721f049ce54a4b104c92
|
Provenance
The following attestation bundles were made for mcp_server_iterm2-0.1.1-py3-none-any.whl:
Publisher:
publish.yml on r6e/mcp-server-iterm2
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
mcp_server_iterm2-0.1.1-py3-none-any.whl -
Subject digest:
440c05ee5dd8177d9a35e950abb760821f720c5771ec0e9320498e9b41dd8431 - Sigstore transparency entry: 1563176889
- Sigstore integration time:
-
Permalink:
r6e/mcp-server-iterm2@2753a6cbabebb0972752745c37daf8b453233565 -
Branch / Tag:
refs/tags/v0.1.1 - Owner: https://github.com/r6e
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@2753a6cbabebb0972752745c37daf8b453233565 -
Trigger Event:
push
-
Statement type: