Skip to main content

MCP server exposing iTerm2 to agents for observation and non-destructive annotation.

Project description

mcp-server-iterm2

CI PyPI Python

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_badge to display anything, your iTerm2 profile's badge format must include \(user.badge). Configure in iTerm2 → Profiles → General → Badge.
  • Title: whether a set_title override 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_color writes 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. MCPIterm2Error subclasses surface actionable text via to_error_text; unknown exceptions collapse to Internal 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

License

MIT — see LICENSE.

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

mcp_server_iterm2-0.1.1.tar.gz (14.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

mcp_server_iterm2-0.1.1-py3-none-any.whl (18.9 kB view details)

Uploaded Python 3

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

Hashes for mcp_server_iterm2-0.1.1.tar.gz
Algorithm Hash digest
SHA256 919b2c3dafb572924229c635e1074b78ee117f5a18f366231d0cca3723b17b1d
MD5 368e0abd9e574c80ee100b83bddb3ff2
BLAKE2b-256 297a3290c32df98ae3cbd48ec79c64108845a9465ff4caca4876d8b5b3f2ae67

See more details on using hashes here.

Provenance

The following attestation bundles were made for mcp_server_iterm2-0.1.1.tar.gz:

Publisher: publish.yml on r6e/mcp-server-iterm2

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file mcp_server_iterm2-0.1.1-py3-none-any.whl.

File metadata

File hashes

Hashes for mcp_server_iterm2-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 440c05ee5dd8177d9a35e950abb760821f720c5771ec0e9320498e9b41dd8431
MD5 b5542d223194715c273dadf3d92eb319
BLAKE2b-256 7313835a59d271234dfdc7688f2b0fcd1fec658434d6721f049ce54a4b104c92

See more details on using hashes here.

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

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