ProPresenter 7 MCP Server
ProPresenter 7 MCP Server
propresenter-mcp
A comprehensive Model Context Protocol (MCP) server that provides complete control over ProPresenter presentations via the ProPresenter API. This server implements the full ProPresenter API specification with 231 endpoints organized into 27 API groups and exposed through modular client classes.
Official MCP Registry
Prerequisites
- Node.js 18 or higher
- ProPresenter 7 with API enabled
- ProPresenter running and accessible on your network
Installation
-
Clone this repository or download the source code
-
Install dependencies:
npm install
- Build the project:
npm run build
Configuration
The server connects to ProPresenter using environment variables:
PROPRESENTER_URL- The URL of your ProPresenter instance (default:http://localhost:50000)PROPRESENTER_PASSWORD- The API password (if configured in ProPresenter)
ProPresenter Setup
- Open ProPresenter preferences
- Go to the Network tab
- Enable "Network" and note the port number (default: 50000)
- Optionally set a password for API access
Usage
With Claude Desktop
Add this to your Claude Desktop configuration file:
macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
Windows: %APPDATA%\Claude\claude_desktop_config.json
{
"mcpServers": {
"propresenter": {
"command": "node",
"args": ["/absolute/path/to/propresenter-mcp/build/index.js"],
"env": {
"PROPRESENTER_URL": "http://localhost:50000",
"PROPRESENTER_PASSWORD": "your-password-if-needed"
}
}
}
}
Replace /absolute/path/to/propresenter-mcp with the actual path to this project.
With VS Code
This server can be debugged directly in VS Code using the included MCP configuration.
- Open this project in VS Code
- The server is automatically configured for debugging via
.vscode/mcp.json - Use the MCP extension to test and debug the server
Example Commands
Once connected, you can ask Claude to control ProPresenter:
Status & Information:
- "What version of ProPresenter is running?"
- "Show me the status of all screens"
- "What's the status of audience screens?"
- "Get the current slide information"
Presentations:
- "What presentation is currently active?"
- "Trigger the presentation with UUID [uuid]"
- "Go to the next slide"
- "Go to slide number 5"
- "Play the presentation timeline"
- "Show me the chord chart"
- "Get a thumbnail of slide 3"
Announcements:
- "What announcement is currently active?"
- "Trigger the next announcement cue"
- "Show me the announcement timeline status"
- "Go to announcement cue 2"
Audio & Media:
- "List all audio playlists"
- "Show me the contents of audio playlist [id]"
- "Play the next song in the active playlist"
- "Trigger the focused audio playlist"
- "List all media playlists"
- "Trigger media item [id] in playlist [playlist_id]"
Playlists:
- "List all presentation playlists"
- "Show me the active playlist"
- "Focus the next playlist"
- "Trigger the first item in the focused playlist"
- "Create a new playlist called 'Sunday Service'"
Capture:
- "What's the current capture status?"
- "Start recording"
- "Stop the capture"
- "Show me available capture encodings for RTMP"
Clear:
- "Clear the announcements layer"
- "Show me all clear groups"
- "Trigger the clear group [id]"
- "Create a new clear group"
Library:
- "List all my libraries"
- "Show presentations in library [id]"
- "Trigger presentation [id] from library [library_id]"
Looks:
- "Show me all configured looks"
- "What look is currently live?"
- "Switch to look [id]"
- "Create a new look"
Macros:
- "List all macros"
- "Trigger macro [id]"
- "Show me all macro collections"
- "Create a new macro"
Props:
- "List all props"
- "Trigger prop [id]"
- "Clear prop [id]"
- "Pause auto-clear for prop [id]"
- "List all prop collections"
Stage:
- "Show me the current stage message"
- "Display stage message [message]"
- "Hide the stage message"
- "List all stage layouts"
- "Set stage layout [layout_id] for screen [screen_id]"
Messages:
- "Show me all messages"
- "Display message [id]"
- "Hide message [id]"
- "Create a new message"
Timers:
- "List all timers"
- "Start timer [id]"
- "Stop timer [id]"
- "Reset the sermon timer"
- "Create a countdown timer"
- "Get the current system time"
Themes:
- "List all themes"
- "Show me details of theme [id]"
- "Get theme slide [slide_id] from theme [theme_id]"
Transport:
- "Play the presentation layer"
- "Pause the audio layer"
- "Skip forward 30 seconds on the announcement layer"
- "Go to the end of the presentation"
- "Get the current playback time"
Masks:
- "List all masks"
- "Show me details of mask [id]"
Triggers:
- "Trigger the next cue"
- "Trigger the previous media item"
Development
Build
npm run build
Watch Mode
npm run watch
API Reference
This server implements the complete ProPresenter API documented at https://openapi.propresenter.com/
API Coverage
- Total Endpoints: 231 REST API endpoints
- API Groups: 27 functional groups
- Client Modules: 18 TypeScript client classes
- Tool Definitions: 18 MCP tool modules
- Handler Modules: 18 request handler modules
- HTTP Methods: Full support for GET, POST, PUT, DELETE operations
- Architecture: Complete three-layer implementation (clients → tools → handlers)
See api/api.md for complete API documentation with all 231 endpoints organized by group.
Troubleshooting
Connection Issues:
- Verify ProPresenter is running and the API is enabled
- Check that the URL and port are correct
- Ensure no firewall is blocking the connection
- Verify the password if authentication is enabled
Server Not Starting:
- Make sure you've built the project with
npm run build - Check that Node.js 18+ is installed
- Verify all dependencies are installed with
npm install
Related Servers
Paprika 3
Manage your Paprika 3 recipes with an LLM. Read, create, and update recipes in your Paprika app.
WordPress Reader for Claude Desktop
Access WordPress.com feeds, notifications, tags, and manage blogs within Claude Desktop.
MCP Microsoft Office Bridge
A secure, multi-user server connecting LLMs to Microsoft 365 services.
Browser Use MCP Server
Automate browser actions using natural language commands. Powered by Playwright and supports multiple LLM providers.
WSLSnapit-MCP
Capture screenshots and read the clipboard on Windows from within a WSL environment.
MCP Personal
A collection of MCP servers for various personal productivity tools and utilities.
Intugle MCP
Generate automated semantic models using data engineering agents and built data products on demand
SpellChecker
A fast, multilingual spell-checker for Large Language Models.
Limitless MCP Server
Connect AI assistants to Limitless to access personal memory and lifelog data.
Backcast MCP Server
The Outcome Backcasting MCP is a strategic planning tool that helps you work backwards from a desired future outcome to identify the specific steps, resources, and dependencies needed to achieve your goals. Unlike traditional forward planning, backcasting starts with your end goal and creates a reverse roadmap to get there.