console-mcp

console-mcp

An MCP server for streaming and searching macOS Console.app and iOS device logs, enabling real-time log access and debugging through natural language.

Category
Visit Server

README

Console MCP Server — macOS & iOS Log Streaming for AI Assistants

An MCP (Model Context Protocol) server for streaming and searching macOS Console.app and iOS device logs directly from Claude, GitHub Copilot, or any MCP-compatible AI assistant.

Stream real-time logs, search crash reports, filter by severity, and debug iOS simulators and physical devices — all through natural language.

Features

  • List Devices - Show connected iOS devices
  • List Simulators - Show available iOS Simulators
  • Get Logs - Fetch recent logs filtered by process or subsystem
  • Get Device Logs - Fetch logs from connected iOS devices
  • Get Simulator Logs - Fetch logs from iOS Simulators
  • Get Logs by Level - Filter logs by severity (fault, error, warning, info, debug)
  • Stream Logs - Capture live logs for a specified duration
  • Search Logs - Search through historical logs (supports regex)
  • Get Crash Logs - List and read crash reports
  • Watch for Pattern - Stream until a pattern matches
  • Export Logs - Save logs to file for sharing
  • VPN Logs - Quick shortcut to get WorxVPN-specific logs

Installation

git clone https://github.com/rohithgoud30/console-mcp.git
cd console-mcp
npm install
npm run build

For iOS Device Logs

Install libimobiledevice for direct iOS device log streaming:

brew install libimobiledevice

Configuration

Add to your .vscode/mcp.json:

{
  "servers": {
    "console": {
      "command": "node",
      "args": ["/path/to/console-mcp/dist/index.js"]
    }
  }
}

Tools

list_devices

List connected iOS devices with their UDIDs.

list_simulators

List available iOS Simulators.

Parameter Type Description
onlyBooted boolean Only show running simulators (default: false)
runtime string Filter by runtime (e.g., 'iOS 17')

get_logs

Get recent logs from macOS.

Parameter Type Description
process string Filter by process name (e.g., 'Safari')
subsystem string Filter by subsystem (e.g., 'com.apple.network')
lastMinutes number Minutes of logs to fetch (default: 5)
maxLines number Max lines to return (default: 200)

get_logs_by_level

Get logs filtered by severity level.

Parameter Type Description
level string Log level: fault, error, warning, info, debug (required)
process string Filter by process name
lastMinutes number Minutes of logs to fetch (default: 5)
maxLines number Max lines to return (default: 200)

get_device_logs

Get logs from a connected iOS device. Requires libimobiledevice.

Parameter Type Description
device string Device name or UDID (required)
process string Filter by process name
lastMinutes number Minutes of logs to capture (default: 5, max: 10)
maxLines number Max lines to return (default: 200)

get_simulator_logs

Get logs from an iOS Simulator. Simulator must be booted.

Parameter Type Description
simulator string Simulator name or UDID (required)
process string Filter by process name
lastMinutes number Minutes of logs to fetch (default: 5)
maxLines number Max lines to return (default: 200)

stream_logs

Stream live logs for a duration.

Parameter Type Description
process string Filter by process name
durationSeconds number How long to stream (default: 10, max: 30)

stream_simulator_logs

Stream live logs from an iOS Simulator.

Parameter Type Description
simulator string Simulator name or UDID (required)
process string Filter by process name
durationSeconds number How long to stream (default: 10, max: 30)

search_logs

Search through recent logs with text or regex.

Parameter Type Description
query string Text or regex pattern to search for (required)
useRegex boolean Treat query as regex (default: false)
lastMinutes number Minutes to search (default: 30)
maxLines number Max matching lines (default: 100)

get_crash_logs

List recent crash reports from DiagnosticReports.

Parameter Type Description
process string Filter by process/app name
lastDays number Days to search back (default: 7)
maxReports number Max reports to list (default: 10)

read_crash_report

Read the full content of a specific crash report.

Parameter Type Description
filename string Crash report filename (required)

watch_for_pattern

Stream logs until a pattern matches. Great for test automation.

Parameter Type Description
pattern string Text or regex to watch for (required)
useRegex boolean Treat pattern as regex (default: false)
process string Filter by process name
timeoutSeconds number Max wait time (default: 30, max: 60)

export_logs

Export logs to a file on the Desktop.

Parameter Type Description
logs string Log content to export (required)
filename string Optional filename
format string Export format: txt or json (default: txt)

get_vpn_logs

Shortcut to get WorxVPN extension logs.

Parameter Type Description
lastMinutes number Minutes of logs (default: 5)
maxLines number Max lines (default: 300)

Usage Examples

// In Copilot chat:
"List my iOS simulators"
"Get logs from iPhone 15 Pro simulator"
"Show device logs from my iPhone"
"Get the last 5 minutes of Safari logs"
"Show me all error logs from the last 10 minutes"
"Search logs for 'authentication' using regex"
"Get crash logs for MyApp"
"Read the crash report MyApp-2024-12-27.crash"
"Watch for 'connection established' while I connect"
"Export these logs to a file"
"Stream logs for 15 seconds while I reproduce the bug"
"Show me WorxVPN logs"

Requirements

  • macOS 13+ (Ventura or later)
  • Node.js 18+
  • Xcode (for simulators and xcrun tools)
  • libimobiledevice (optional, for iOS device logs)

Notes

  • macOS log command is used for local logs
  • xcrun simctl is used for simulator logs
  • idevicesyslog from libimobiledevice is used for iOS device logs
  • iOS device must be paired and trusted for log access
  • Crash reports are found in ~/Library/Logs/DiagnosticReports
  • Exported logs are saved to ~/Desktop/ConsoleMCP-Exports/

Credits

Originally created by devstroop. This fork includes custom modifications and enhancements.

License

MIT

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
Audiense Insights MCP Server

Audiense Insights MCP Server

Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

graphlit-mcp-server

The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.

Official
Featured
TypeScript
Kagi MCP Server

Kagi MCP Server

An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

Exa Search

A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured