Skip to content
/ it2 Public

πŸ–₯️ A powerful command-line interface for controlling iTerm2 using its Python API - Send commands, manage sessions/windows/tabs, monitor output, and more!

License

Notifications You must be signed in to change notification settings

mkusaka/it2

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 

History

36 Commits
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

it2

A powerful command-line interface for controlling iTerm2 using its Python API.

Features

  • Session Management: Send text, execute commands, split panes, manage sessions
  • Window Control: Create, move, resize, and manage windows
  • Tab Operations: Create and navigate between tabs
  • Profile Management: List, create, and apply iTerm2 profiles
  • Broadcasting: Send input to multiple sessions simultaneously
  • Monitoring: Watch session output, keystrokes, and variables in real-time
  • Configuration: Define custom profiles and aliases in YAML
  • Shortcuts: Quick access to common commands

Requirements

  • macOS with iTerm2 3.3.0 or later
  • Python 3.8+
  • iTerm2 Python API enabled (Preferences > General > Magic > Enable Python API)

Installation

Using pip

pip install it2

Using uvx (recommended)

uvx it2

Quick Start

# Send text to current session
it2 send "Hello, World!"

# Run a command
it2 run "ls -la"

# Split the current pane vertically
it2 vsplit

# Create a new window
it2 new

# List all sessions
it2 ls

Basic Usage

Session Operations

# Send text (without newline)
it2 session send "text"
it2 send "text"  # shortcut

# Execute command (with newline)
it2 session run "command"
it2 run "command"  # shortcut

# Target specific session or all sessions
it2 send "text" --session <id>
it2 send "text" --all

# Split panes
it2 session split          # horizontal split
it2 session split -v       # vertical split
it2 vsplit                 # shortcut for vertical split

# Session management
it2 session list           # list all sessions
it2 session close          # close current session
it2 session restart        # restart session
it2 session clear          # clear screen

Window Operations

# Window management
it2 window new             # create new window
it2 window list            # list all windows
it2 window close           # close current window
it2 window focus <id>      # focus specific window

# Window manipulation
it2 window move 100 200    # move to position
it2 window resize 800 600  # resize window
it2 window fullscreen on   # enable fullscreen

# Window arrangements
it2 window arrange save "dev"      # save arrangement
it2 window arrange restore "dev"   # restore arrangement

Tab Operations

# Tab management
it2 tab new                # create new tab
it2 tab list               # list all tabs
it2 tab close              # close current tab
it2 tab select <id>        # select specific tab

# Tab navigation
it2 tab next               # go to next tab
it2 tab prev               # go to previous tab
it2 tab goto 2             # go to tab by index

Profile Operations

# Profile management
it2 profile list           # list all profiles
it2 profile show "Default" # show profile details
it2 profile create "MyProfile" --base "Default"
it2 profile apply "MyProfile"

# Profile configuration
it2 profile set "MyProfile" font-size 14
it2 profile set "MyProfile" bg-color "#000000"
it2 profile set "MyProfile" transparency 0.9

Application Control

# App management
it2 app activate           # bring iTerm2 to front
it2 app hide               # hide iTerm2
it2 app theme dark         # set theme

# Broadcasting
it2 app broadcast on       # enable broadcasting
it2 app broadcast off      # disable broadcasting
it2 app broadcast add session1 session2  # create broadcast group

Monitoring

# Monitor output
it2 monitor output -f                      # follow output
it2 monitor output -f -p "ERROR"           # filter by pattern

# Monitor keystrokes
it2 monitor keystroke                      # all keystrokes
it2 monitor keystroke -p "^[a-z]+$"        # filter by regex

# Monitor variables
it2 monitor variable lastCommand           # session variable
it2 monitor variable buildNumber --app     # app variable

# Monitor prompts (requires shell integration)
it2 monitor prompt

Configuration

Create ~/.it2rc.yaml to define custom profiles and aliases:

# Custom profiles
profiles:
  dev:
    - command: cd ~/project
    - split: vertical
    - pane1: npm run dev
    - pane2: npm test --watch
  
  servers:
    - split: 2x2
    - pane1: ssh server1
    - pane2: ssh server2
    - pane3: ssh server3
    - pane4: ssh server4

# Command aliases
aliases:
  deploy: session run "deploy.sh" --all
  logs: monitor output -f -p "ERROR|WARN"
  dev-setup: load dev

Use configurations:

# Load a profile
it2 load dev

# Execute an alias
it2 alias deploy

# Show config path
it2 config-path

# Reload configuration
it2 config-reload

Advanced Examples

Development Environment Setup

# Create a development workspace
it2 window new --profile "Development"
it2 split
it2 send "cd ~/project && npm run dev"
it2 session focus 2
it2 send "cd ~/project && npm test --watch"

Multi-Server Management

# SSH to multiple servers with broadcasting
it2 tab new
it2 split && it2 split && it2 split
it2 app broadcast on
it2 send "ssh production-server"

Automated Deployment

Create a deployment script:

#!/bin/bash
# deploy.sh

# Create deployment window
it2 window new --profile "Deploy"

# Split for monitoring
it2 split -v

# Start deployment in first pane
it2 send "cd ~/project && ./deploy-prod.sh"

# Monitor logs in second pane
it2 session focus 2
it2 run "tail -f /var/log/deploy.log"

# Watch for errors
it2 monitor output -f -p "ERROR|FAILED"

Environment Variables

  • IT2_DEFAULT_PROFILE: Default profile name
  • IT2_CONFIG_PATH: Path to configuration file (default: ~/.it2rc.yaml)
  • IT2_TIMEOUT: Command timeout in seconds

Error Codes

  • 0: Success
  • 1: General error
  • 2: Connection error (iTerm2 not running or API not enabled)
  • 3: Target not found (session/window/tab not found)
  • 4: Invalid arguments

Development

Setup Development Environment

# Clone the repository
git clone https://github.com/mkusaka/it2.git
cd it2

# Create virtual environment
python -m venv venv
source venv/bin/activate

# Install in development mode
pip install -e ".[dev]"

# Run tests
pytest

# Run linting
ruff check .
black --check .
mypy .

Project Structure

it2/
β”œβ”€β”€ src/
β”‚   └── it2/
β”‚       β”œβ”€β”€ __init__.py
β”‚       β”œβ”€β”€ cli.py              # Main CLI entry point
β”‚       β”œβ”€β”€ commands/           # Command modules
β”‚       β”‚   β”œβ”€β”€ session.py
β”‚       β”‚   β”œβ”€β”€ window.py
β”‚       β”‚   β”œβ”€β”€ tab.py
β”‚       β”‚   β”œβ”€β”€ profile.py
β”‚       β”‚   β”œβ”€β”€ app.py
β”‚       β”‚   β”œβ”€β”€ monitor.py
β”‚       β”‚   β”œβ”€β”€ shortcuts.py
β”‚       β”‚   └── config_commands.py
β”‚       β”œβ”€β”€ core/               # Core functionality
β”‚       β”‚   β”œβ”€β”€ connection.py
β”‚       β”‚   β”œβ”€β”€ session_handler.py
β”‚       β”‚   └── errors.py
β”‚       └── utils/              # Utilities
β”‚           └── config.py
β”œβ”€β”€ tests/                      # Test files
β”œβ”€β”€ pyproject.toml              # Project configuration
β”œβ”€β”€ README.md                   # This file
└── example.it2rc.yaml          # Example configuration

Contributing

  1. Fork the repository
  2. Create a feature branch (git checkout -b feature/amazing-feature)
  3. Commit your changes (git commit -m 'Add amazing feature')
  4. Push to the branch (git push origin feature/amazing-feature)
  5. Open a Pull Request

License

MIT License - see LICENSE for details.

Acknowledgments

  • Built on the iTerm2 Python API
  • Inspired by tmux and screen command-line interfaces
  • Uses Click for CLI framework

About

πŸ–₯️ A powerful command-line interface for controlling iTerm2 using its Python API - Send commands, manage sessions/windows/tabs, monitor output, and more!

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published