vestaboard-mcp

vestaboard-mcp

Enables AI assistants to display messages on a Vestaboard via text or board mode with color and symbol support.

Category
Visit Server

README

Vestaboard MCP Server

64C141F8-7167-4460-AB9F-FA4E4BBDCE19

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

  1. Clone this repository:
git clone <repository-url>
cd vestaboard-mcp
  1. Install dependencies:
npm install

Getting Your Vestaboard API Key

  1. Visit Vestaboard Developer Portal
  2. Sign in with your Vestaboard account
  3. Go to "Read/Write API" section
  4. Generate a new API key for your board
  5. Copy the key to your .env file

Usage

Adding to Cursor as an MCP Server

  1. Open Cursor Settings (Cmd/Ctrl + ,)
  2. Go to "Features" → "Model Context Protocol"
  3. 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-mcp with the actual absolute path to your cloned repository
  • Replace your_vestaboard_api_key_here with your actual Vestaboard API key
  1. 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:

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