vestaboard-mcp
Enables AI assistants to display messages on a Vestaboard via text or board mode with color and symbol support.
README
Vestaboard MCP Server
Give Cursor agent the ability to display messages on your Vestaboard.
More examples: <img width="1301" height="733" alt="Screenshot 2025-09-12 at 8 22 42 AM" src="https://github.com/user-attachments/assets/993a6153-e100-483a-95a1-1244c04ec7f9" />
Features
- Text Mode: Send simple text messages that are automatically formatted and centered by Vestaboard
- Board Mode: Full control over the 6×22 character grid with precise positioning
- Color Support: Use Vestaboard's built-in color codes (Red, Orange, Yellow, Green, Blue, Violet, White, Black)
- Symbol Support: Display special characters, numbers, and punctuation
- MCP Integration: Works seamlessly with AI assistants that support the Model Context Protocol
Installation
- Clone this repository:
git clone <repository-url>
cd vestaboard-mcp
- Install dependencies:
npm install
Getting Your Vestaboard API Key
- Visit Vestaboard Developer Portal
- Sign in with your Vestaboard account
- Go to "Read/Write API" section
- Generate a new API key for your board
- Copy the key to your
.envfile
Usage
Adding to Cursor as an MCP Server
- Open Cursor Settings (Cmd/Ctrl + ,)
- Go to "Features" → "Model Context Protocol"
- Add a new MCP server by copying and pasting this JSON configuration:
{
"mcpServers": {
"vestaboard": {
"command": "npx",
"args": ["-y", "tsx", "path/to/vestaboard-mcp/index.ts"],
"env": {
"VESTABOARD_API_KEY": "YOUR_API_KEY"
}
}
}
Important:
- Replace
/absolute/path/to/vestaboard-mcpwith the actual absolute path to your cloned repository - Replace
your_vestaboard_api_key_herewith your actual Vestaboard API key
- Save the configuration and restart Cursor
Using with Cursor
Once configured, you can ask Cursor to display messages on your Vestaboard using natural language. Cursor will automatically use the display_message tool to send messages to your Vestaboard.
Examples:
- "Display 'Good Morning!' on my Vestaboard"
- "Show a colorful welcome message on the Vestaboard"
- "Put 'Meeting in 5 mins' on my Vestaboard in red"
- "Draw a minimal portrait of a Pikachu on my Vestaboard"
Text Mode (Default)
{
"message": "Hello World!",
"mode": "text"
}
Board Mode (Advanced)
{
"mode": "board",
"board": [
[0, 0, 8, 5, 12, 12, 15, 0, 23, 15, 18, 12, 4, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
]
}
Character and Color Codes
Letters
- A-Z: 1-26
Numbers
- 0-9: 36, 27-35
Special Characters
- Blank: 0
- !: 37
- @: 38
- #: 39
- $: 40
- (: 41
- ): 42
- -: 44
- +: 46
- &: 47
- =: 48
- ;: 49
- :: 50
- ': 52
- ": 53
- %: 54
- ,: 55
- .: 56
- /: 59
- ?: 60
- °: 62
Colors
- Red: 63
- Orange: 64
- Yellow: 65
- Green: 66
- Blue: 67
- Violet: 68
- White: 69
- Black: 70
- Filled: 71
Project Structure
vestaboard-mcp/
├── code.ts # Vestaboard character and color code mappings
├── index.ts # Main MCP server implementation
├── sendMessage.js # Test utility for sending messages
├── package.json # Node.js dependencies
└── README.md # This file
API Reference
Tool: display_message
Displays a message on the Vestaboard using either text mode or board mode.
Parameters
message(string, optional): The text message to display (required for text mode)mode(enum, optional): Display mode - "text" or "board" (default: "text")board(array, optional): 6×22 array of Vestaboard codes (required for board mode)
Response
Returns a success message indicating the content was displayed on the Vestaboard.
Examples
Simple Text Message
// When you say: "Display 'Good Morning!' on my Vestaboard"
// Cursor sends:
{
"message": "Good Morning!",
"mode": "text"
}
Colorful Message with Board Mode
// When you say: "Create a colorful hello world message on my Vestaboard"
// Cursor sends:
{
"mode": "board",
"board": [
[63, 63, 8, 5, 12, 12, 15, 63, 63, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[66, 66, 23, 15, 18, 12, 4, 66, 66, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
]
}
Requirements
- Node.js 16 or higher
- A Vestaboard device
- Vestaboard API key
- Cursor IDE with MCP support
License
This project is open source and available under the MIT License.
Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
Support
For issues related to:
- Vestaboard API: Check the Vestaboard Developer Documentation
- MCP Protocol: See the Model Context Protocol Documentation
- This Project: Open an issue in this repository
Recommended Servers
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.
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.
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.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
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.
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.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
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.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.