Skip to main content
Glama
tinkeriotops

ESP32 MCP Server

by tinkeriotops

ESP32 MCP Server β€” Connect LLMs with IoT Devices

A lightweight Model Context Protocol (MCP) bridge that lets large language models (LLMs) directly communicate with an ESP32 running Tasmota or similar firmware.

This project demonstrates how an AI assistant (like ChatGPT or Copilot) can reason about user intent and execute physical actions β€” such as toggling relays or reading sensors β€” in real time, using standard HTTP commands.


πŸ“– Overview

Traditional IoT automation relies on fixed rules, MQTT topics, or REST endpoints.
This project replaces all that with a simple concept:

The LLM talks to your ESP32 through a universal protocol β€” MCP.

No firmware rebuilds, no MQTT brokers, no cloud dependencies.
Just plain human language turned into structured, executable commands.

You can read the full article here:
πŸ‘‰ Connecting LLMs and IoT: How an ESP32 Can Speak MCP and Follow AI Commands

And watch the walkthrough video:
πŸŽ₯ ESP32 + MCP + LLM Integration Demo


🧠 What It Does

  • Bridges MCP (Model Context Protocol) and your ESP32 firmware (e.g., Tasmota)

  • Exposes a single tool: tasmota-cmd, letting LLMs send commands like:

    /tasmota-cmd {"command": "Power1 1"}
  • Works locally β€” no API keys or external services required

  • Compatible with Visual Studio Code Copilot Chat or any LLM supporting MCP


βš™οΈ How It Works

LLM (Copilot/ChatGPT)
        ↓
     MCP Protocol
        ↓
 Node.js MCP Server
        ↓
  ESP32 (Tasmota)

The MCP server receives structured requests, converts them into Tasmota commands (e.g. Power1 ON, Backlog PulseTime1 400; Power1 1), and sends them via HTTP to your ESP32 device.
The responses are returned to the model as plain text for reasoning and follow-up actions.


πŸš€ Quick Start

1. Clone this repo

git clone https://github.com/<your-username>/esp32-mcp-server.git
cd esp32-mcp-server

2. Install dependencies

npm install

3. Configure your device IP

Edit the constant inside index.js:

const DEVICE_IP = "192.168.1.xxx";

4. Run the server

node index.js

You’ll see output similar to:

MCP HTTP server:  http://localhost:3000/mcp
Health:           http://localhost:3000/health
Debug:            http://localhost:3000/debug?command=Power1%201

πŸ’¬ MCP Server in VS Code

To connect with GitHub Copilot Chat or compatible tools, add this configuration in your .config/github-copilot/ file:

{
  "servers": {
    "esp32-mcp": {
      "url": "http://localhost:3000/mcp",
      "type": "http"
    }
  }
}

Reload Copilot, and you’ll see your new MCP tool:

/tasmota-cmd {"command": "Power1 1"}

🧩 Dependencies

  • Node.js 18+

  • @modelcontextprotocol/sdk

  • express

  • zod


🧰 Compatible Firmwares

Firmware

Compatibility

Notes

Tasmota

βœ…

Full command support (HTTP, MQTT, Serial)

ESP-AT

βš™οΈ

Limited GPIO access (requires Driver AT build)

ESPHome

⚠️

Static configuration β€” not ideal for real-time control


πŸ“Ί Reference & Resources


🧠 Concept Summary

This project proves that intelligence in IoT doesn’t need more APIs β€” it needs context.

By combining:

  • Tasmota’s readable command interface,

  • MCP’s standardized AI communication layer, and

  • ESP32’s hardware flexibility,

you get a device that can understand and act on intent, not just follow hardcoded rules.


πŸ“œ License

MIT License Β© 2025 [Your Name or tinkeriot.com]

F
license - not found
-
quality - not tested
F
maintenance

Maintenance

–Maintainers
–Response time
–Release cycle
–Releases (12mo)
Commit activity

Resources

Unclaimed servers have limited discoverability.

Looking for Admin?

If you are the server author, to access and configure the admin panel.

Latest Blog Posts

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/tinkeriotops/esp32-mcp'

If you have feedback or need assistance with the MCP directory API, please join our Discord server