Scribbletune MCP Server
Enables AI agents to generate MIDI clips from natural language descriptions and export them for import into digital audio workstations. Wraps Scribbletune to provide music composition tools for creating riffs, chords, and arpeggios with scale-aware progressions, rhythmic patterns, and genre-specific parameters.
README
scribbletune-mcp-server
Work in progress. The server is functional but actively evolving. Feedback, ideas, bug reports, and contributions are warmly welcome — please open an issue or a PR.
An MCP (Model Context Protocol) server that brings MIDI generation into AI agent workflows. It wraps Scribbletune — a wonderful open-source library by Walmik Deshpande — and exposes it as a set of tools and resources that an LLM can call to compose and export MIDI clips.
The idea
Modern AI assistants can talk about music — genres, moods, harmony, rhythm — but they can't produce it in a form you can load into your DAW. This project bridges that gap.
The intended workflow is an AI agent acting as a creative co-producer:
- You describe a musical idea in natural language —
"2-bar Deep Tech bassline in G# minor, 131 BPM, plucky, 16th-note groove" - The agent reads the Scribbletune concept docs exposed as MCP resources to understand scales, patterns, and articulation parameters
- It translates your idea into a structured tool call, discussing options with you if needed
- The server generates a MIDI file and stores it in a key-value store
- The agent hands you a download link — drag the
.midfile straight into Ableton, Logic, FL Studio, or any DAW
No coding required on your end. The agent handles the translation from musical intent to MIDI.
Features
- Streamable HTTP transport — stateless MCP over HTTP, compatible with any MCP client (Claude Desktop, custom agents, etc.)
generate-cliptool — generate a MIDI clip from a musical description (riff, chord progression, or arpeggio)get-progressiontool — resolve scale degrees to chord names before generating a clip- 7 MCP resources — Scribbletune concept documentation as Markdown so the agent understands notes, patterns, scales, chords, progressions, and genre-specific guidance out of the box
- MIDI store service (coming soon) — dedicated service backed by Redis/Valkey for storing and serving MIDI files
- Built with NestJS, @rekog/mcp-nest, and Nx
Architecture
Your AI Agent (Claude, GPT, etc.)
│
│ MCP (Streamable HTTP, stateless)
▼
scribbletune-mcp-server :3000
│
│ POST /clips
▼
scribbletune-midi-store :3001 ← coming soon
│
▼
Redis / Valkey
↓
User downloads .mid → imports into DAW
Getting started
Prerequisites
- Node.js 20+
- npm
Install
git clone https://github.com/claboran/scribbletune-mcp-ws.git
cd scribbletune-mcp-ws
npm install
Run the dev server
npm run mcp:dev
The server starts on http://localhost:3000/mcp.
In development the MIDI store is mocked —
generate-clipgenerates real MIDI bytes but does not persist them. A[MOCK]warning is logged on each call so you know exactly what's happening.
Inspect with MCP Inspector
With the dev server running, open a second terminal:
npm run mcp:inspect
This launches the @modelcontextprotocol/inspector UI in your browser. Follow these steps to connect:
- Set Transport Type to
Streamable HTTP - Set URL to
http://localhost:3000/mcp - Click Connect
- Use the Resources tab to read the Scribbletune concept docs
- Use the Tools tab to call
generate-cliporget-progressioninteractively

Build
npm run mcp:build
MCP tools
generate-clip
Generates a MIDI clip and returns a download key and URL.
| Parameter | Type | Description |
|---|---|---|
command |
riff | chord | arp |
Type of clip: melodic line, chord block, or arpeggio |
root |
string | Root note with octave, e.g. "G#3" |
mode |
string | Scale name, e.g. "minor", "dorian", "phrygian" |
pattern |
string | Rhythm pattern: x=hit -=rest _=sustain R=random |
subdiv |
string | Step duration: "16n" "8n" "4n" "1m" … |
progression |
string | Chord names or degrees — required for chord / arp |
bpm |
number | Tempo in BPM |
sizzle |
string | Velocity envelope: sin cos rampUp rampDown |
amp |
number | Max velocity 0–127 |
accent |
string | Accent pattern, e.g. "x--x" |
arpCount |
number | Notes per chord for arp command (default 4) |
arpOrder |
string | Arp note order, e.g. "0123" ascending, "3210" descending |
Returns { key, downloadUrl, ttlSeconds, meta }.
get-progression
Resolves scale degrees to chord names. Useful before generate-clip when working with chord or arp commands. Not needed for basslines or melodic riffs.
| Parameter | Type | Description |
|---|---|---|
root |
string | Root note with octave |
mode |
enum | Scale/mode name |
degrees |
string | Space-separated degrees, e.g. "I IV V ii" — random if omitted |
count |
number | Number of chords when generating randomly (2–8) |
Returns { degrees, chordNames, hint }.
MCP resources
The agent reads these before making tool calls to avoid hallucinating invalid parameter values.
| URI | Description |
|---|---|
scribbletune://docs/overview |
What Scribbletune is, the clip model, riff/chord/arp commands |
scribbletune://docs/clip |
Full clip() parameter reference |
scribbletune://docs/notes-and-patterns |
Note naming, octaves, pattern syntax |
scribbletune://docs/scales |
All 80+ valid scale names |
scribbletune://docs/chords |
Chord types and notation |
scribbletune://docs/progression |
Progression API and scale degree tables by mode |
scribbletune://docs/genre-scale-guide |
Genre → scale, BPM, and pattern recommendations |
Project structure
This is an Nx monorepo.
apps/
scribbletune-mcp-server/ # This MCP server (operational)
scribbletune-midi-store/ # MIDI storage service (coming soon)
Roadmap
- [ ]
scribbletune-midi-store— Redis/Valkey-backed MIDI storage with HTTP download endpoint - [ ] Docker Compose setup for full local stack
- [ ] Multi-clip session tool — generate bass, chords, and melody in a single call
- [ ] Example agent system prompts and Claude Desktop configuration
Credits and acknowledgements
This project would not exist without the work of others.
Scribbletune by Walmik Deshpande is the MIDI generation engine at the heart of this server. Scribbletune is a beautifully designed library that makes programmatic music composition expressive and accessible. Please visit the project, star the repo, and consider contributing.
@rekog/mcp-nest by the rekog-labs team provides first-class NestJS integration for the Model Context Protocol and made building this server a pleasure.
Model Context Protocol by Anthropic is the open standard that makes tool-augmented AI agents possible.
Contributing
This project is in active early development and there is plenty of room to grow — in tooling, musical concepts, documentation quality, and agent integration examples.
- Open an issue to suggest features, report bugs, or discuss the direction
- PRs are welcome — please open an issue first for larger changes so we can align before you invest time
License
MIT — © 2026 the scribbletune-mcp-server contributors
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.