Fluree MCP Server
A Node.js gateway that exposes FlureeDB functionality through MCP, enabling LLM clients to query, mutate, and manage Fluree ledgers interactively.
README
Fluree MCP Server
A modern Node.js gateway that exposes FlureeDB functionality through the Model Context Protocol (MCP). It combines a rich set of MCP tools, structured prompts, and session-aware routing so any LLM-powered client (IDE, chat, or custom app) can query, mutate, and manage a Fluree ledger safely and interactively.
β¨ Key Features
| Category | Highlights |
|---|---|
| MCP Tools | 15+ tools: query, transact, block/block-range, history, network status, key generation, schema management (create / update / validate / export / import), database diagnostics, echo |
| Structured Prompts | Every tool ships with a matching prompt template; clients discover via prompts/list, retrieve with prompts/get, and enjoy argument completion support |
| Session Management | First initialize call establishes a session & stores connection info (dbUrl, network, ledger) so subsequent requests are stateless for the client |
| Validation & Safety | All tool inputs validated with Zod; errors surfaced as JSON-RPC -32602 or -32603 |
| Hot-Reload Friendly | Tools & prompts registered dynamically; add new modules under src/tools or src/prompts and restart |
| Extensible | Written in ES Modules, small surface areaβdrop in new handlers, middlewares, or MCP capabilities |
ποΈ Project Structure
src/
ββ config/ # Constant defaults & env helpers
ββ controllers/ # MCP server controller (session init, tool/prompt registration)
ββ routes/ # Express routes (`/api/v1/mcp`)
ββ tools/ # Individual MCP tools (each default export = { name, config, handler })
ββ prompts/ # Prompt templates mirrored one-to-one with tools
ββ index.js # Express bootstrap
.env.example # Sample environment variables
README.md # β you are here
π Quick Start
-
Clone & Install
git clone https://github.com/UDAIBHAT/Fluree_MCP_Server.git cd fluree-mcp-server npm install cp .env.example .env # adjust DB connection defaults if desired -
Run
npm start # serves http://localhost:3000 -
Initialize a Session
POST http://localhost:3000/api/v1/mcp Headers: { "Content-Type":"application/json" } Body: { "jsonrpc":"2.0", "id":1, "method":"initialize", "params":{ "dbUrl":"Your_DBurl", "network":"Your_Network", "ledger":"Your_Ledger" } }The response includes
mcp-session-idβadd it to all subsequent requests. -
Discover Tools & Prompts
{ "jsonrpc":"2.0", "id":2, "method":"prompts/list", "params":{} }
π₯οΈ IDE & Non-IDE Client Setup
IDE clients
Cursor, Windsurf,Google Gemini . RooCode can add the server definition to their settings. Two examples are shown below β one for Cursor and one for Windsurf:
CURSOR IDE
- Just insert this Patch of Json-code under the MCP-Section in the Cursor settings and you are good to go.....
{
"mcpServers": {
"Fluree_MCP_Server": {
"url": "http://localhost:3000/api/v1/mcp",
"headers": {
"dburl": "Your_DBurl",
"network": "Your_Network",
"ledger": "Your_Ledger"
}
}
}
}
WINDSURF IDE
- Just insert this Patch of Json-code under the MCP-Section in the Windsurf Cascade settings and you are good to go.....
{
"mcpServers": {
"Fluree_MCP_Server": {
"serverUrl": "http://localhost:3000/api/v1/mcp",
"headers": {
"dbUrl": "Your_DBurl",
"network": "Your_Network",
"ledger": "Your_Ledger"
}
}
}
}
GOOGLE GEMINI
- Use the following JSON patch in your Gemini .settings
[ Currently Gemini doesnt support Streamable HTTP transport]
{
"mcpServers": {
"Fluree_MCP_Server": {
"httpUrl": "http://localhost:3000/api/v1/mcp?dburl=<Your_DBurl>&network=<Your_Network>&ledger=<Your_Ledger>",
"timeout": 30000,
"trust": true
}
}
}
Non-IDE clients
Can simply POST to /api/v1/mcp (or /mcp) with a JSON body containing dbUrl, network, and ledger as shown in the Quick-Start initialization request.
π§ Tools Overview
| Name | Purpose | Input Parameters |
|---|---|---|
flureeQueryTool |
Select data via FlureeQL | selectFields (array|"*"), fromCollection |
flureeTransact |
Create random collections | count (1-50) |
flureeSchemaCreate |
Create collection + predicates | collectionName, predicates[], doc? |
flureeSchemaUpdate |
Update collection/predicates | collectionName, updateType, etc. |
| β¦ | See src/tools for the rest |
Each tool handler returns { content:[ {type:"text"|"json", text:string|object} ] }, ready for LLM streaming.
π¬ Prompt Workflow
- List β
method:"prompts/list" - Get β
method:"prompts/get", pass promptname+argumentsobject - (Optional) Suggest β
method:"completion/suggest"for auto-complete while filling arguments
Prompts use Mustache-style placeholders ({{argument}}) inside user messages to instruct the assistant to call the correct tool.
βοΈ Environment Variables
| Variable | Default | Description |
|---|---|---|
PORT |
3000 |
Server port |
FLUREE_DB_URL |
http://localhost:8090 |
Base Fluree URL |
FLUREE_NETWORK |
test |
Default network |
FLUREE_LEDGER |
demo |
Default ledger |
π API Collection
A ready-to-import Postman collection lives at docs/postman/Fluree_MCP.postman_collection.json (or generate it from the sample snippet in this README).
-
You can also make a new collection with specified MCP endpoint ,postman supports the mcp endpoints so just inseret the server url then it will give you the whole list of tools.
-
Just Import the collection and call the
Initialize_reqthis will make Initialization_Connection to the MCP_Server and you can also change theparamslikedbUrl,network,ledger -
The mcp-session-id is dynamically stored in every request through Postman Post-Req Scripts
π£οΈ Roadmap / Nice-to-Haves
- JWT authentication & role-based prompt permissions
- Rate limiting & CORS controls
- WebSocket support for real-time block watch
- Production observability: Prometheus exporter & Grafana dashboard
- Docker Compose bundle (Fluree + MCP + Grafana)
π License
MIT Β© UDAI BHAT
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.