๐Ÿ“ฑ MCP Server for iOS Simulator

๐Ÿ“ฑ MCP Server for iOS Simulator

A bridge between iOS simulators and the Model Context Protocol, enabling programmatic control of iOS simulators through standardized communication interfaces.

atom2ueki

Developer Tools
Visit Server

README

๐Ÿ“ฑ MCP Server for iOS Simulator

A server that implements the Model Context Protocol (MCP) for iOS simulators, built on top of appium-ios-simulator and utilizing the MCP TypeScript SDK.

๐Ÿ“‹ Overview

This project provides a bridge between iOS simulators and the Model Context Protocol, allowing for standardized communication with iOS simulator instances. It enables programmatic control of iOS simulators while leveraging the MCP protocol for consistent interfaces across different environments. The server utilizes stdio as its transport mechanism, making it ideal for integration with Claude Desktop and other MCP-compatible clients.

๐ŸŽฌ Demo

iOS Simulator Demo

Demo showing how to boot an iOS simulator using Claude AI Desktop

๐Ÿ—๏ธ Architecture

The server consists of three main components:

  1. ๐Ÿ”„ Simulator Management Layer - Handles iOS simulator lifecycle and interactions
  2. ๐Ÿ”Œ MCP Protocol Implementation - Implements the Model Context Protocol using the TypeScript SDK with stdio transport
  3. ๐Ÿ“Š Logger Component - Provides file-based logging without interfering with the stdio transport
โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”     โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”     โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”
โ”‚  MCP Protocol   โ”‚     โ”‚     Stdio       โ”‚     โ”‚    Simulator    โ”‚
โ”‚  Implementation โ”‚โ—„โ”€โ”€โ”€โ”€โ”ค    Transport    โ”‚โ—„โ”€โ”€โ”€โ”€โ”ค   Management    โ”‚
โ”‚                 โ”‚     โ”‚                 โ”‚     โ”‚      Layer      โ”‚
โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜     โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜     โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜
        โ–ฒ                                                โ–ฒ
        โ”‚                                                โ”‚
        โ–ผ                                                โ–ผ
โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”                             โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”
โ”‚   MCP Client    โ”‚                             โ”‚  iOS Simulator  โ”‚
โ”‚  (e.g. Claude)  โ”‚                             โ”‚                 โ”‚
โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜                             โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜

โœจ Features

  • ๐Ÿš€ Start, stop, and manage iOS simulator instances
  • ๐Ÿ”Œ Boot and shutdown simulators
  • ๐Ÿ“ฒ Install and launch applications on simulators
  • ๐Ÿ“ธ Take screenshots of simulator screens
  • ๐Ÿ‘† Perform taps on coordinates
  • ๐Ÿ”„ Support for multiple concurrent simulator sessions
  • ๐Ÿ“ Comprehensive file-based logging without console output
  • ๐Ÿ›ก๏ธ Error-resilient operation

๐Ÿ“‹ Prerequisites

  • ๐ŸŸข Node.js (v16 or later)
  • ๐ŸŽ macOS (required for iOS simulators)
  • ๐Ÿ› ๏ธ Xcode with iOS simulators installed
  • ๐Ÿ“œ TypeScript 4.5+

๐Ÿ”ง Installation

# Clone the repository
git clone https://github.com/atom2ueki/mcp-server-ios-simulator.git
cd mcp-server-ios-simulator

# Install dependencies
npm install

โš™๏ธ Configuration

Configuration is handled through the src/config.ts file:

const config = {
  simulator: {
    defaultDevice: process.env.SIMULATOR_DEFAULT_DEVICE || 'iPhone 16',
    defaultOS: process.env.SIMULATOR_DEFAULT_OS || '18.2',
    timeout: parseInt(process.env.SIMULATOR_TIMEOUT || '30000', 10),
  }
};

You can customize these settings by setting environment variables:

SIMULATOR_DEFAULT_DEVICE=iPhone 16
SIMULATOR_DEFAULT_OS=18.2
SIMULATOR_TIMEOUT=30000

๐Ÿš€ Usage

๐Ÿ”จ Building and Starting the Server

# Build the project
npm run build

# Start the server
npm start

๐Ÿงฐ MCP Tools

The server provides two distinct approaches for controlling iOS simulators:

๐Ÿ“ฑ Direct Simulator Management (Recommended)

These tools work directly with simulator UDIDs and don't require maintaining sessions:

  • ๐Ÿ“‹ list-available-simulators - List all available simulators with their UDIDs
  • โ–ถ๏ธ boot-simulator-by-udid - Boot a simulator directly using its UDID
  • โน๏ธ shutdown-simulator-by-udid - Shutdown a simulator directly using its UDID
  • ๐Ÿ“Š list-booted-simulators - List all currently booted simulators

Use this approach when: You just want to boot, use, and shut down simulators directly.

๐Ÿ“ฑ Session-Based Management (Advanced)

These tools use a session layer that tracks simulators with custom session IDs:

  • ๐Ÿ“‹ list-simulator-sessions - List all active simulator sessions
  • โž• create-simulator-session - Create a new simulator session
  • โŒ terminate-simulator-session - Terminate a session (shuts down simulator and cleans up)
  • ๐Ÿ”„ create-and-boot-simulator - Create a new simulator session and boot it
  • โ–ถ๏ธ boot-simulator - Boot a simulator for an existing session
  • โน๏ธ shutdown-simulator - Shutdown a simulator for an existing session

Use this approach when: You need to track simulator metadata, reference simulators by custom IDs, or use the more advanced management features.

๐Ÿ“ฒ Application Management

  • ๐Ÿ“ฅ install-app - Install an application on a simulator
  • ๐Ÿš€ launch-app - Launch an application on a simulator
  • ๐Ÿ›‘ terminate-app - Terminate a running application on a simulator

๐Ÿ–ฑ๏ธ Interaction Tools

  • ๐Ÿ“ท take-screenshot - Take a screenshot of the simulator screen
  • ๐Ÿ‘† tap-coordinate - Perform a tap at the specified coordinates

๐Ÿค– Example Usage with Claude Desktop

  1. Configure Claude Desktop to use this server as an MCP tool:

    • Open Claude Desktop
    • Go to Settings > Advanced
    • Add the following configuration to the "MCP Servers" section:
    {
      "mcpServers": {
        "simulator": {
          "command": "node",
          "args": [
            "/path/to/your/mcp-server-ios-simulator/dist/index.js"
          ]
        }
      }
    }
    
    • Replace /path/to/your with the actual path to where you've installed this repository
    • Save the settings and restart Claude Desktop
  2. Use the provided tools to control iOS simulators directly from Claude Desktop:

    Direct UDID Approach (Recommended):

    1. First, ask Claude to list available simulators:

      "Show me all available iOS simulators"
      
    2. Then use the UDID to boot a specific simulator:

      "Boot the iOS simulator with UDID 5272EA61-5796-4372-86FE-3B33831D5CC1"
      
    3. When finished, shut it down using the same UDID:

      "Shut down the simulator with UDID 5272EA61-5796-4372-86FE-3B33831D5CC1"
      

    The direct UDID approach is simpler and more reliable for most use cases.

    Session-Based Approach (Advanced): Only use this approach if you need the advanced features of session tracking:

    "Create a new simulator session for iPhone 16 Pro with iOS 18.2"
    "Boot the simulator for session abc-123"
    "Take a screenshot of the simulator for session abc-123"
    "Terminate the simulator session abc-123"
    

๐Ÿ‘จโ€๐Ÿ’ป Development

๐Ÿ“ Project Structure

src/
โ”œโ”€โ”€ simulator/       # Simulator management layer
โ”œโ”€โ”€ mcp/             # MCP protocol implementation
โ”œโ”€โ”€ bridge/          # Bridge component
โ”œโ”€โ”€ utils/           # Utility functions including logger
โ”œโ”€โ”€ config.ts        # Configuration handling
โ””โ”€โ”€ index.ts         # Entry point

๐Ÿ”จ Building the Project

# Install development dependencies
npm install

# Run TypeScript compiler
npm run build

๐Ÿ“œ License

This project is licensed under the MIT License - see the LICENSE file for details.

๐Ÿ™ Acknowledgments

Recommended Servers

playwright-mcp

playwright-mcp

A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.

Official
Featured
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.

Official
Featured
Local
TypeScript
MCP Package Docs Server

MCP Package Docs Server

Facilitates LLMs to efficiently access and fetch structured documentation for packages in Go, Python, and NPM, enhancing software development with multi-language support and performance optimization.

Featured
Local
TypeScript
Claude Code MCP

Claude Code MCP

An implementation of Claude Code as a Model Context Protocol server that enables using Claude's software engineering capabilities (code generation, editing, reviewing, and file operations) through the standardized MCP interface.

Featured
Local
JavaScript
@kazuph/mcp-taskmanager

@kazuph/mcp-taskmanager

Model Context Protocol server for Task Management. This allows Claude Desktop (or any MCP client) to manage and execute tasks in a queue-based system.

Featured
Local
JavaScript
Linear MCP Server

Linear MCP Server

Enables interaction with Linear's API for managing issues, teams, and projects programmatically through the Model Context Protocol.

Featured
JavaScript
mermaid-mcp-server

mermaid-mcp-server

A Model Context Protocol (MCP) server that converts Mermaid diagrams to PNG images.

Featured
JavaScript
Jira-Context-MCP

Jira-Context-MCP

MCP server to provide Jira Tickets information to AI coding agents like Cursor

Featured
TypeScript
Linear MCP Server

Linear MCP Server

A Model Context Protocol server that integrates with Linear's issue tracking system, allowing LLMs to create, update, search, and comment on Linear issues through natural language interactions.

Featured
JavaScript
Sequential Thinking MCP Server

Sequential Thinking MCP Server

This server facilitates structured problem-solving by breaking down complex issues into sequential steps, supporting revisions, and enabling multiple solution paths through full MCP integration.

Featured
Python