unterm

mcp
Guvenlik Denetimi
Basarisiz
Health Uyari
  • License — License: NOASSERTION
  • Description — Repository has a description
  • Active repo — Last push 0 days ago
  • Low visibility — Only 5 GitHub stars
Code Basarisiz
  • rm -rf — Recursive force deletion command in assets/icon/update.sh
Permissions Gecti
  • Permissions — No dangerous permissions requested

Bu listing icin henuz AI raporu yok.

SUMMARY

The terminal AI agents can drive — 67 MCP methods across 11 namespaces. macOS / Linux / Windows, local-first, $0, MIT.

README.md

Unterm

The terminal AI agents can drive.

Cross-platform terminal (macOS / Linux / Windows) built on a customized WezTerm engine, with one design bet: the terminal itself is controllable from the outside by any AI agent over MCP. Claude Code, Cursor, Aider, Continue, your own scripts — they all get the same JSON-RPC surface to spawn shells, run commands, read pane state, capture screenshots, change settings, and record sessions.

The other 2026 terminals each pick a different side: Warp embeds AI inside a closed cloud (Oz), Ghostty stays out of your way and lets you bring your own tools, iTerm2 is Mac-only. Unterm picks the third side — terminal as MCP-controllable surface, deliberately keep AI features out of the terminal, let external agents grip it through the API.

Practical implications:

  • Every Unterm window starts a local MCP server (line-delimited JSON-RPC over TCP) and a local HTTP settings server (Web Settings page) on auto-allocated ports. Both are auth-token gated, both are 127.0.0.1-only, no cloud round trip.
  • Settings live in the browser, not the terminal. Cell-grid TUIs can't deliver modern form UX (no proper text inputs, no live preview, no color picker). The in-terminal overlay is intentionally minimal — six quick actions and a link to the Web Settings page.
  • 9 languages out of the box: en / 简体中文 / 繁體中文 / 日本語 / 한국어 / Deutsch / Français / Italiano / हिन्दी. Auto-detects from system locale, can be overridden in Web Settings or via unterm-cli lang set <code>.
  • Multi-instance discovery: every running Unterm process owns one NATO-named instance (alpha, bravo, charlie…) and writes its ports + auth token to ~/.unterm/instances/<name>.json. Agents that drive several windows at once enumerate that directory.
  • Cross-platform parity is a correctness property: if a feature works on Windows but bails on macOS or Linux, that's a bug, not "not supported yet."
  • Subtraction over decoration: no AI overlay inside the terminal, no inline image render that wedges the GUI, no in-terminal custom right-click chrome, no Cmd+Q confirmation, no manual proxy URL config (auto-detected from system). Finder integration on macOS uses the native Finder right-click extension and Services.

Built on top of the WezTerm engine for renderer / font / TUI / SSH / mux work, with a thin product layer on top.


Install

Pre-built artifacts are published on GitHub Releases:

https://github.com/zhitongblog/unterm/releases

Platform Artifact
macOS Unterm-macos-<version>.dmg (universal arm64+x86_64, signed + notarized)
Linux unterm-<version>.deb or Unterm-<version>-x86_64.AppImage
Windows Unterm-<version>-x64.msi or Unterm-windows-<version>.zip

macOS

Double-click Unterm-macos-<version>.dmg, then drag Unterm.app onto the
Applications shortcut. The DMG is signed with a Developer ID and Apple-
notarized, so Gatekeeper opens it on first launch without warnings.

Finder integration is bundled in the DMG. After the first launch, Finder's
right-click menu can show Open in Unterm for folders and files; if macOS
doesn't refresh the extension immediately, run Repair Finder Integration.app
from the DMG once.

Linux (Debian / Ubuntu)

sudo apt install ./unterm-<version>.deb
unterm

Other distros — use the AppImage:

chmod +x Unterm-<version>-x86_64.AppImage
./Unterm-<version>-x86_64.AppImage

Windows

Run the MSI installer; it places unterm.exe in Program Files\Unterm and creates a Start Menu shortcut.


What's new

  • v0.12 — synchronous pre-show paint kills the long-standing Windows white flash on launch. The frame is rendered before the window is shown, not after.
  • v0.9 — multi-instance discovery with NATO-phonetic names. Each running Unterm writes ~/.unterm/instances/<name>.json; ~/.unterm/active.json points at the current foreground instance for single-target agents.
  • v0.7 — Windows defaults to UTF-8 out of the box. PowerShell and cmd.exe spawns are wrapped to set the code page; no more mojibake on Chinese filenames.
  • v0.5 — dogfood milestone. Default window sizing tuned for real use, scrollback line count is configurable via ~/.unterm/scrollback.json, TERM_PROGRAM overridable via ~/.unterm/compat.json, background update poller writes ~/.unterm/update_check.json.

Documentation

The full Unterm docs live at https://unterm.app/docs/:

  • Agent integration — how to drive Unterm from Claude Code / Cursor / Aider / your own client
  • MCP reference — every JSON-RPC method, parameters, return shape
  • Multi-instance — NATO names, instances directory, picking the right window
  • Identity profiles — one window per identity. Bind GitHub / AWS / npm / OpenAI tokens, git identity, SSH key routing all at once. CLI + MCP.
  • CLI referenceunterm-cli subcommands, flags, exit codes
  • Configuration — every file under ~/.unterm/
  • Architecture — what we forked from WezTerm and why

This README is the short version. The site is the long version.


Features

  • GPU-accelerated rendering on all three platforms (Metal / OpenGL / DirectX via ANGLE).
  • MCP server on 127.0.0.1:<auto-port> (default 19876) — JSON-RPC over TCP, auth-token gated. Method namespaces: session, exec, screen, signal, orchestrate, proxy, workspace, capture, policy, system, server, instance, profile.
  • Web Settings UI on 127.0.0.1:<auto-port> (default 19877) — open in any browser via unterm-cli settings open or the Settings (Web) item in the menu. Tailwind-styled SPA, supports all 9 languages, keyboard + mouse.
  • Auto proxy detection — reads macOS System Preferences / Windows registry / GNOME gsettings / $HTTPS_PROXY, falls back to scanning common local ports. The single proxy.json toggle is {"enabled": true|false} — no manual URL configuration needed.
  • Region screenshots from the status bar (left-click excludes the Unterm window, right-click includes it). PNG lands on disk under ~/.unterm/screenshots/, on the system image clipboard, and the path on the text clipboard.
  • Session recording → markdown with OSC 133 block segmentation and built-in redaction (GitHub tokens / KEY=value / 40+ char hex/base64 patterns are masked). Recordings are stored in the project directory under <cwd>/.unterm/sessions/<date>/<tab>-<time>.md, or in ~/.unterm/sessions/_orphan/ when no writable project context.
  • Right-click is a direct gesture, not a menu: with a selection it copies and clears; without selection it pastes.
  • Slim quick-action overlay on the tab bar's button:
    • Change Working Directory (cd current pane)
    • Open Folder in New Tab
    • Split Right (left/right pane split)
    • Toggle Session Recording
    • Export Current Session
    • Settings (Web)
  • macOS-native window decorations (traffic-light buttons + native title bar); Windows uses Windows Terminal-style integrated title buttons; Linux uses client-side decorations.

Identity profiles

Bind a window to a coherent developer identity — GitHub PAT, AWS keys, npm token, git author, SSH keys — all in one shot. New window for a different identity. The chip in the tab bar tells you which one you're in. Secrets live in the OS-native vault (Keychain / Credential Manager / Secret Service), never in ~/.unterm/.

unterm-cli profile create "Work — Acme"
unterm-cli profile set-secret "Work" GITHUB_TOKEN
unterm-cli profile spawn "Work"           # → new window bound to Work
unterm-cli profile set-default "Work"     # plain `unterm` now binds to Work
unterm-cli profile import                 # scans gh/aws/npm/ssh/docker/gcloud/netrc
                                          #   for existing credentials, read-only

Inside a profile-bound shell:

$ env | grep UNTERM_PROFILE
UNTERM_PROFILE=work-acme
# GITHUB_TOKEN, GIT_AUTHOR_NAME, AWS_*, etc. all set from the profile

Full docs: unterm.app/docs/profiles.

Multi-instance

Every running Unterm process is one instance with a NATO-phonetic name: alpha, bravo, charlie, … zulu. The first window claims alpha, the second bravo, etc. When all 26 are taken at once, the next one wraps to alpha2. Names are easy to pronounce and AI agents handle them right — no UUIDs, no ports in your head.

Each instance writes its metadata (mcp_port, http_port, auth_token, pid, started_at, version, platform) to ~/.unterm/instances/<name>.json. Agents that need to drive a specific window enumerate that directory and pick by id, cwd, or title. For single-target agents, ~/.unterm/active.json points at the most recently launched live instance, and ~/.unterm/server.json mirrors that same record for backward compat.

The MCP instance.* namespace exposes this directly: instance.list, instance.info, instance.set_title, instance.focus. See the multi-instance docs for examples and the discovery protocol.


CLI

The unterm-cli binary exposes the full Unterm product surface, transparently routing to the local MCP server. Read ~/.unterm/server.json (or any file under ~/.unterm/instances/) for current ports + auth.

# Settings + Web UI
unterm-cli settings open                       # open the Web Settings page
unterm-cli theme list / set <id>               # standard / midnight / daylight / classic
unterm-cli lang list / set <code> / current    # en-US / zh-CN / zh-TW / ja-JP / ko-KR / de-DE / fr-FR / it-IT / hi-IN

# Proxy
unterm-cli proxy status                        # auto-detect health
unterm-cli proxy nodes / switch <name> / disable / env

# Sessions / panes
unterm-cli session list                        # list panes
unterm-cli session record start [--id N]
unterm-cli session record stop [--id N]
unterm-cli session export [--id N] [-o FILE]
unterm-cli sessions list [--project SLUG]
unterm-cli sessions read <session-id>

# Screenshots
unterm-cli screenshot [--include-window] [-o FILE]

Pass --json to any subcommand for raw JSON-RPC output (suitable for scripts). Pass --lang <code> to override the locale for one invocation.

Multi-instance discovery is exposed over MCP rather than as a CLI subcommand — call instance.list against any running Unterm's MCP port, or just ls ~/.unterm/instances/.

AI agent auto-discovery

Unterm makes every AI coding agent on the machine aware of it, so they can drive the terminal without manual setup. On first launch (per version) the GUI runs unterm-cli setup-ai, which detects installed agents — Claude Code, Codex, Gemini CLI, Cursor, Windsurf, OpenCode — and, for each:

  • registers the unterm MCP server into the agent's global config (merging into existing config, never clobbering), so the agent can list/run/read/screenshot the real terminal the moment it starts;
  • drops a short, marker-delimited Unterm note into the agent's global context file (CLAUDE.md / AGENTS.md / GEMINI.md) so even an agent that never loads the MCP server knows Unterm is here.

The registered bridge (unterm-cli mcp-stdio) self-discovers the live instance at connect time, so a static registration keeps working across restarts and multiple windows. Agents that connect also receive a usage brief via the MCP initialize instructions field.

unterm-cli setup-ai              # detect agents + register (idempotent; safe to re-run)
unterm-cli setup-ai --dry-run    # show what would change, write nothing
unterm-cli setup-ai --no-context # register the MCP server only, don't touch context files
unterm-cli setup-ai --remove     # undo: strip the server entry + context block from every agent

Configuration

User config lives at:

Platform Location
macOS ~/.unterm/
Linux ~/.unterm/
Windows %USERPROFILE%\.unterm\

Files:

File Purpose
server.json Active instance's MCP/HTTP ports + auth token + pid (auto, mirrors the active instance for back-compat)
active.json Pointer at the current foreground instance id (auto, updated only when previous active dies)
instances/<name>.json Per-instance metadata (NATO id, ports, token, pid, started_at, version, platform)
auth_token Legacy mirror of the active auth token (for back-compat)
proxy.json `{"enabled": true
theme.json Active theme id
lang.json Persisted locale override
compat.json {"term_program": "..."} override for $TERM_PROGRAM
scrollback.json Override the default scrollback line count
update_check.json Background update-poller state (last check, latest seen version)
onboarded.json First-run flags (which items have been seen)
recording.json Recording config (redaction patterns, etc.)
sessions/ Recording metadata index (per-project subdirs)
screenshots/ Region screenshots (PNG)

Development

Prereqs: a recent stable Rust toolchain. Linux additionally needs the system deps in get-deps.

make build        # all binaries (debug)
make check        # static checks
make test         # tests

Build a release for the current platform:

cargo build --release -p unterm -p unterm-cli -p unterm-mux -p strip-ansi-escapes

Build platform packages:

# macOS — universal .app + zip (run on macOS)
ci/deploy.sh

# Linux — .deb
ci/deploy.sh
# Linux — AppImage
ci/appimage.sh

# Windows — staged release tree + zip
bash ci/deploy.sh
# Windows — MSI (requires WiX 6 at .\.tools\wix.exe — install via `dotnet tool install --tool-path .\.tools wix --version 6.0.1`)
pwsh -File ci/build-msi.ps1

macOS code-signing + notarization is local-only (no CI step) so the
Developer ID .p12 private key never has to leave your Mac. One-time
setup, on the Mac that holds the cert:

xcrun notarytool store-credentials UntermNotary \
  --apple-id <your-apple-id> --team-id 6NQM3XP5RF

Release tagging

Unterm uses 2-segment minor tags only: v0.7, v0.9, v0.12. Patches accumulate as commits on master between releases — they don't get tagged and don't trigger CI builds. Cut a tag only when a coherent batch of fixes / features is ready to ship.

git tag -a vX.Y -m "Unterm vX.Y" && git push origin vX.Y
make release-mac                    # build universal + sign + notarize + upload

make release-mac reads the tag from git describe --exact-match HEAD,
builds universal x86_64+aarch64 binaries, calls ci/sign-macos.sh with
NOTARY_PROFILE=UntermNotary, then gh release uploads the resulting
zip to the matching GitHub Release.

CI on every PR runs cargo check against macOS, Linux, and Windows.
Tagged pushes (vX.Y) trigger the release-linux and release-windows
workflows that publish those two platforms' artifacts to GitHub Releases.
macOS sits out of CI by design — see above.


Repository

This repository is the main Unterm project:

https://github.com/zhitongblog/unterm

Unterm includes modified WezTerm components. Upstream WezTerm remains a separate project by Wez Furlong and contributors.

Yorumlar (0)

Sonuc bulunamadi