idb-mcp
An MCP server that uses Facebook IDB to automate iOS simulators, providing device control, input actions, and screenshots over HTTP, SSE, or stdio.
IDB-MCP
An open-source MCP server and Python library that wraps Facebook IDB to control iOS simulators for automation. Built by AskUI.
This project is based on the Facebook IDB CLI (fb-idb). See the GitHub repository (facebook/idb) and the Python package (fb-idb on PyPI).
What it is
- MCP server: Exposes a set of iOS automation tools (list/select device, screenshot, tap, swipe, type, etc.) over MCP transports (HTTP, SSE or stdio) using
fastmcp. - Python module: Import to manage and control iOS simulators programmatically.
Table of contents
Key features
- Device management 🔧: list devices, select by UDID or name, boot/shutdown, kill IDB.
- Input control 👆: tap, swipe, type text, tap keys, tap buttons.
- Screen utilities 🖼️: capture screenshots, query screen size, get view description.
- Image/coord scaling 📐: optional scaling to a target viewport for consistent coordinates.
- AskUI integration 🤝: helper to add this server to AskUI
CaesrChat.
Limitations
⚠️ Only iOS simulators are supported for UI control. Due to iOS security constraints, idb cannot interact with or automate the UI on real, physical devices. AskUI offers a solution for real-device UI automation—contact support@askui.com for more information.
Requirements
-
Runs on macOS only.
-
Python >= 3.10
-
Xcode with iOS Simulators installed and configured.
-
Verify simulators are visible:
xcrun xctrace list devices
-
-
Facebook IDB companion (using
brew):brew tap facebook/fb brew install idb-companion
Install
pip install idb-mcp
Quick start (CLI)
Why MCP?
Using MCP lets your favorite AI tools connect to idb-mcp seamlessly. The client handles launching and communicating with the server, so you can ask for screenshots, taps, swipes, and more—without leaving your workflow. ✨
Start MCP server
The package installs an idb-mcp command.
# Start MCP server over HTTP (default host/port managed by fastmcp)
idb-mcp start http
# Or start over SSE
idb-mcp start sse
# Or start over stdio
idb-mcp start stdio
# Optionally scale images/coordinates to a given target viewport (width height)
idb-mcp start http --target-screen-size 1280 800
# Discover available options
idb-mcp --help
idb-mcp start --help
Add MCP server to AskUI Caesr Chat
⚠️ Experimental Phase: This feature is currently in an experimental phase and might not work straight out of the box.
To make it easier to use the MCP server in AskUI Caesr Chat, you can add the MCP server and custom assistant to the Chat.
# Adds the MCP server and custom assistant to AskUI `Caesr` Chat.
idb-mcp add-to-caesr
Or to a specific Chat directory:
idb-mcp add-to-caesr --chat-dir /path/to/askui/caesr/chat
Programmatic usage (Python)
from idb_mcp import IDBController, IOSDevice
# Initialize the IDB controller
controller = IDBController()
# Select the device by name
selected_device: IOSDevice = controller.select_device_by_name("iPhone 17 Pro Max")
# Boot the selected device
selected_device.boot()
# Get the current view description of the selected device
current_view_description: str = selected_device.get_current_view_description()
print(current_view_description)
# Shutdown the selected device
selected_device.shutdown()
Add to your favorite tools
You can use idb-mcp in any MCP-compatible client (e.g., Cursor, Claude Desktop) by adding a server entry to your client's MCP config. The client will launch the server on demand.
Steps:
- Open your client's MCP configuration file (location varies by client).
- Add an entry named
askui-idb-mcpthat starts the server over STDIO and sets a recommended target screen size.
Example configuration:
using uv (Make sure you have uv installed):
{
"mcpServers": {
"askui-idb-mcp": {
"command": "uvx",
"args": [
"idb-mcp@latest",
"start",
"stdio",
"--target-screen-size",
"1280",
"800"
]
}
}
}
Alternative (if idb-mcp is directly on your PATH without uv):
{
"mcpServers": {
"askui-idb-mcp": {
"command": "idb-mcp",
"args": [
"start",
"stdio",
"--target-screen-size",
"1280",
"800"
]
}
}
}
Notes:
- The
--target-screen-size 1280 800setting improves coordinate reliability, especially for models like Claude.
Configuration
- Target screen size 📐: You can scale screenshots and coordinate inputs to a target viewport when starting the MCP server via CLI (
--target-screen-size W H) or programmatically (target_screen_size=(W, H)). - Mode 📐: You can start the MCP server in
stdio,http, orssemode. - Port 📐: You can start the MCP server on a specific port via CLI (
--port PORT) or programmatically (port=PORT).
Troubleshooting
-
Cannot see devices 🔍: Make sure you have an iOS simulator or device connected and running. Verify with:
xcrun xctrace list devicesExample output:
iPhone 17 Simulator (26.0) (32E2219C-ED40-452F-9A4D-XXXXXXX) iPhone 17 Pro Simulator (26.0) (764CCCB7-D84D-46EC-B62D-XXXXXXX) iPhone 17 Pro Max Simulator (26.0) (065382B5-56B4-4864-8174-XXXXXXX) -
High-resolution screenshots with some LLMs 🧠: Some LLM backends struggle to process very high-resolution images, resulting in poor coordinate detection or tapping errors. Use rescaling via
--target-screen-size(ortarget_screen_sizein Python) to downscale screenshots and coordinates. For Claude models, we recommend1280 800.
Development
This repository uses PDM and Ruff for dev tooling.
# Install dev deps
pip install pdm
pdm install --with dev
# Lint / Format
pdm run lint-check
pdm run format-check
# Type check
pdm run type-check
Contributing
Contributions are welcome! 🙌 Please open an issue or pull request on GitHub. Questions? Email us at support@askui.com.
License
MIT License
Links
- Homepage: https://github.com/askui/idb-mcp
- AskUI: https://www.askui.com
Related Servers
MCP Server
Automate data science stages using your own CSV data files.
Release Notes Server
Generates release notes from GitHub repositories by fetching and organizing commits.
MCP Builder
A Python-based server to install and configure other MCP servers from PyPI, npm, or local directories.
MCP Swagger Server
Converts OpenAPI/Swagger specifications to Model Context Protocol (MCP) format, providing a modern Web UI and a backend service.
JSONPlaceholder
A free public REST API for testing and prototyping, powered by JSONPlaceholder.
Authless Remote MCP Server
A remote MCP server deployable on Cloudflare Workers that does not require authentication.
Symphony of One
An MCP server for orchestrating multiple Claude instances to collaborate in a shared workspace with real-time communication.
MCP Bridge API
A lightweight, LLM-agnostic RESTful proxy that unifies multiple MCP servers under a single API.
Image Tools MCP
Retrieve image dimensions and compress images from URLs or local files using Tinify and Figma APIs.
MCP-RAGNAR
A local MCP server implementing Retrieval-Augmented Generation (RAG) with sentence window retrieval and support for multiple file types.