MCP Hub
Back to servers

mcp-buttplug

An MCP server that connects Claude and other MCP clients to buttplug.io, allowing AI models to directly control and orchestrate intimate hardware in real-time. It provides a suite of tools for device discovery and haptic commands like vibration, rotation, and patterned pulses.

glama
Updated
Mar 27, 2026

mcp-buttplug

mcp-buttplug

MCP server that gives Claude direct control over intimate hardware via buttplug.io

vibrate · rotate · oscillate · linear · pulse · wave


An MCP server that connects Claude Code (or any MCP client) to buttplug.io — the open-source intimate hardware control library. Claude gets tools to discover, control, and orchestrate haptic devices in real-time.

The LLM decides what you feel, and when.

Vibe coders can now enjoy vibe coding with a vibe in the butt.

Why

I saw girls on TikTok gooning with AI chatbots. Text-only. No haptics. Just vibes and imagination.

Also — I know many girls have toys. And many coders too ;)

Thought — what if the chatbot could actually touch you? MCP gives LLMs tool use. Buttplug.io gives software device control. This glues them together. Now the AI doesn't just talk. It acts.

That's it. That's the whole idea. The hardware is already in the drawer. This is just the software.

How It Works

Claude Code <-> MCP (stdio) <-> mcp-buttplug <-> WebSocket <-> Intiface Engine <-> Bluetooth/USB <-> Device

The server maintains a persistent connection to Intiface Engine. Each MCP tool call translates to buttplug.io protocol commands sent to the device. Patterns like pulse and wave are composed from sequences of basic commands with timing.

Getting Started

1. Install Intiface Central

Intiface Central is the server that talks to your hardware. You need it running before using mcp-buttplug.

macOS

# Option A: Mac App Store (requires macOS 11.0+, Apple Silicon)
open "https://apps.apple.com/us/app/intiface-central/id6444728067"

# Option B: Direct download
open "https://intiface.com/central/"

Windows

# Option A: Microsoft Store
start "https://www.microsoft.com/store/apps/9P246MQX7TRV"

# Option B: Direct download
start "https://intiface.com/central/"

Linux

# Option A: Flatpak
flatpak install flathub com.nonpolynomial.intiface_central

# Option B: AppImage from https://intiface.com/central/

2. Start the server

Open Intiface Central -> click Start Server.

It listens on ws://127.0.0.1:12345 by default. Leave it running.

3. Install mcp-buttplug

# Install Bun if you don't have it
curl -fsSL https://bun.sh/install | bash

# Clone and install
git clone https://github.com/chiefautism/mcp-buttplug.git
cd mcp-buttplug
bun install

4. Add to Claude Code

Create or edit ~/.claude/.mcp.json:

{
  "mcpServers": {
    "buttplug": {
      "command": "bun",
      "args": ["/absolute/path/to/mcp-buttplug/index.ts"]
    }
  }
}

5. Go

Restart Claude Code. The tools are available immediately.

Tools

ToolDescription
connectConnect to Intiface Engine via WebSocket
scanDiscover devices (Bluetooth, USB, Serial)
devicesList connected devices and their capabilities
vibrateVibrate at intensity 0.0-1.0, optional auto-stop timer
rotateRotate at speed 0.0-1.0
oscillateOscillate at intensity 0.0-1.0
linearMove to position over duration (stroker devices)
pulsePatterned pulses — count, on/off timing, intensity
waveSmooth ramp between two intensities over time
stopStop one or all devices
batteryRead device battery level
disconnectDisconnect from Intiface Engine

Usage

Once connected, just talk to Claude. It has the tools — it'll figure it out.

you: connect to my device and give me a gentle pulse

claude: [calls connect] -> [calls scan] -> [calls pulse(intensity=0.3, count=3)]
        Connected. Found your Lovense Lush 3. Sent 3 gentle pulses.
you: slowly ramp up over 10 seconds then stop

claude: [calls wave(from=0, to=0.8, duration_ms=10000)]
        [calls stop]

All device parameters (intensity, speed, position) are normalized to 0.0-1.0. Claude handles the mapping.

Ideas

Interactive fiction. Claude writes a story and controls the device based on narrative tension. Rising action, climax, resolution — mapped to intensity curves in real-time. The story isn't just text anymore.

you: write me something intense

claude: [narrates scene]
        [calls wave(from=0.1, to=0.6, duration_ms=15000)]
        [continues narrating, building tension]
        [calls vibrate(intensity=0.9, duration_ms=3000)]
        [calls wave(from=0.7, to=0.1, duration_ms=10000)]

Voice-to-touch via other MCP servers. Combine with a speech-to-text MCP — you talk, Claude interprets tone/mood/words, translates to haptic patterns. Whisper = gentle pulse. Moan = escalation. "Stop" = stop.

React to anything. Claude can read webpages, APIs, files. Stock price moves? Vibrate on green candles. Sports score? Pulse on goals. Twitch chat? Map emote spam to intensity. Claude is the bridge between any data source and physical sensation.

Vibe coding with vibes. You're pair programming with Claude. Tests pass — reward pulse. Tests fail — nothing. Clean code — gentle hum. Spaghetti code — escalating buzz until you refactor. Pavlovian code quality. Your body learns the patterns before your conscious mind does. Vibe coders rejoice — now you can literally vibe while you vibe code.

Multi-device orchestration. If you have multiple devices, Claude can control them independently — different intensities, alternating patterns, synchronized or deliberately offset. One device responds to what you say, another follows a pre-set rhythm.

Biofeedback loop. Pair with a heart rate MCP (smartwatch API). Claude reads your heart rate, adjusts intensity to keep you in a target zone — or deliberately pushes you past it.

Long-distance. Two people, two devices, one Claude session. Person A types, Claude controls Person B's device. Or Claude mediates — reading both inputs and translating them into haptic responses for the other person.

The unhinged one. Give Claude a system prompt with a persona. It decides everything — pacing, intensity, when to tease, when to stop, when to escalate. You don't control it. You just... experience it. The LLM has agency over your physical sensation and it uses context, timing, and your responses to make decisions. That's the thing that doesn't exist anywhere else.

Supported Devices

750+ devices from 30+ brands. Anything in the buttplug.io ecosystem works.

BrandDevicesConnection
LovenseLush, Hush, Edge, Nora, Max, Osci, Domi, Calor, Diamo, Ferri, Gravity, Flexer, Vulse, Solace, HyphyBluetooth LE
We-VibeSync, Melt, Vector, Nova, Rave, Pivot, Verge, Chorus, WishBluetooth LE
KiirooOnyx+, Pearl 2/3, Keon, FeelConnect, Titan, Cliona, OhMiBod FuseBluetooth LE
SatisfyerCurvy, Love Triangle, Sexy Secret, Royal One, Double Joy, Mono FlexBluetooth LE (requires CSR dongle on Windows/Linux)
The HandyThe HandyWi-Fi / API
Magic MotionFlamingo, Awaken, Equinox, Bobi, Nyx, Umi, ZenithBluetooth LE
MysteryVibeCrescendo, Tenuto, PocoBluetooth LE
SvakomElla Neo, Connexion SeriesBluetooth LE
HismithSeries with Bluetooth adapterBluetooth LE / Serial
VorzeA10 Cyclone SA, Bach, UFO SABluetooth LE / USB
LeloF1s, Hugo, TianiBluetooth LE
TCodeOSR-2, SR-6, and DIY TCode devicesSerial / USB
XinputXbox controllers, gamepads (vibration motors)USB
ButtplugGeneric WebSocket devices, DIY hardwareWebSocket

Full searchable database: iostindex.com

License

BSD-3-Clause

Reviews

No reviews yet

Sign in to write a review