Konect Database MCP Server
Enables querying MongoDB collections from the Drivio application using Mongoose models, with support for filters, sorting, pagination, and population.
README
Konect Database MCP Server
An MCP (Model Context Protocol) server that provides database query capabilities for the Drivio application. This server allows you to query MongoDB collections using the same models and schemas used in the main application.
✅ Current Status
Fully Working:
- ✅ All 19 models automatically loaded and registered
- ✅ MongoDB connection (local and Atlas)
- ✅ Database queries working correctly
- ✅ Model validation and error handling
- ✅ Tested and verified with real database queries
Tested Models: All 19 models are successfully loaded: AddOn, ApiKey, BlockedDate, Booking, Calendar, Conversation, Document, Favorite, Keystore, Message, Notification, PaymentMethod, PayoutMethod, Review, Role, SupportRequest, Transaction, User, Vehicle
Features
- ✅ Automatic Model Loading: Automatically loads all 19 Mongoose models from drivio-web-service
- ✅ Real Database Queries: Direct MongoDB connection with full query support
- ✅ MongoDB Query Operators: Support for $gt, $gte, $lt, $lte, $in, $ne, $regex, etc.
- ✅ Field Projection: Include/exclude specific fields in results
- ✅ Sorting & Pagination: Full support for sorting and pagination (skip/limit)
- ✅ Population: Populate referenced documents (e.g., guest, host, vehicle in bookings)
- ✅ Type-Safe: Validated model names and query parameters
- ✅ Error Handling: Comprehensive error handling with clear messages
Available Models
The server supports querying the following models:
- User - User accounts and profiles
- Vehicle - Vehicle listings
- Booking - Rental bookings
- Transaction - Payment transactions
- Review - User and vehicle reviews
- AddOn - Additional services/features
- Conversation - User conversations
- Message - Chat messages
- Document - Uploaded documents
- PaymentMethod - Payment methods
- PayoutMethod - Payout methods
- Notification - User notifications
- Favorite - User favorites
- SupportRequest - Support tickets
- Calendar - Availability calendar
- BlockedDate - Blocked dates
- Role - User roles
- Keystore - Authentication keys
- ApiKey - API keys
Installation
- Install dependencies:
npm install
- Configure environment variables:
cp env.example .env
# Edit .env and set your MONGODB_CONNECTION_STRING
- Build the TypeScript code:
npm run build
Usage
Running the Server
npm start
Or run directly:
node build/index.js
The server runs on stdio and communicates via the Model Context Protocol.
Testing the MCP Server
Quick Test
After building, test the server with a simple query:
cd /home/mrinal/Desktop/Drivio-Application/KONECT_MCP_Server
MONGODB_CONNECTION_STRING="your-connection-string" NODE_ENV=development SALT_ROUNDS=10 \
echo '{"jsonrpc":"2.0","id":1,"method":"tools/call","params":{"name":"query_database","arguments":{"model":"User","query":{},"limit":1}}}' | \
node build/index.js
You should see:
Connected to MongoDBModels loaded successfullyRegistered models: [ 'AddOn', 'ApiKey', 'BlockedDate', 'Booking', ... ]- A JSON response with query results
Step 1: Verify Build Success
After running npm run build, check that the build directory was created:
ls -la build/
You should see:
build/index.js(executable)build/loadModels.js
Step 2: Test Server Startup
Run the server and check for startup messages:
MONGODB_CONNECTION_STRING="your-connection-string" NODE_ENV=development SALT_ROUNDS=10 \
node build/index.js
Expected output:
Connected to MongoDB
Models loaded successfully
Registered models: [
'AddOn', 'ApiKey',
'BlockedDate', 'Booking',
'Calendar', 'Conversation',
'Document', 'Favorite',
'Keystore', 'Message',
'Notification', 'PaymentMethod',
'PayoutMethod', 'Review',
'Role', 'SupportRequest',
'Transaction', 'User',
'Vehicle'
]
Konect Database MCP Server running on stdio
Note: The server will wait for input on stdin. Press Ctrl+C to exit.
Step 3: Test Model Loading
Verify all 19 models are loaded:
MONGODB_CONNECTION_STRING="your-connection-string" NODE_ENV=development SALT_ROUNDS=10 \
node build/index.js 2>&1 | grep "Registered models"
You should see all 19 models listed.
Step 4: Test Database Query
Test a simple query using JSON-RPC:
MONGODB_CONNECTION_STRING="your-connection-string" NODE_ENV=development SALT_ROUNDS=10 \
echo '{"jsonrpc":"2.0","id":1,"method":"tools/call","params":{"name":"query_database","arguments":{"model":"User","query":{},"limit":1}}}' | \
node build/index.js 2>&1 | grep -A 20 '"success"'
Expected: JSON response with "success": true and query results.
Step 5: Test Different Models
Test various models to ensure they all work:
# Test User model
echo '{"jsonrpc":"2.0","id":1,"method":"tools/call","params":{"name":"query_database","arguments":{"model":"User","query":{"status":"active"},"limit":2}}}' | \
MONGODB_CONNECTION_STRING="your-connection-string" NODE_ENV=development SALT_ROUNDS=10 \
node build/index.js 2>&1 | tail -5
# Test Vehicle model
echo '{"jsonrpc":"2.0","id":2,"method":"tools/call","params":{"name":"query_database","arguments":{"model":"Vehicle","query":{"isActive":true},"limit":2}}}' | \
MONGODB_CONNECTION_STRING="your-connection-string" NODE_ENV=development SALT_ROUNDS=10 \
node build/index.js 2>&1 | tail -5
Step 6: Test with Filters and Sorting
Test advanced query features:
# Test with filter and sort
echo '{"jsonrpc":"2.0","id":3,"method":"tools/call","params":{"name":"query_database","arguments":{"model":"User","query":{"status":"active"},"sort":{"createdAt":-1},"limit":3}}}' | \
MONGODB_CONNECTION_STRING="your-connection-string" NODE_ENV=development SALT_ROUNDS=10 \
node build/index.js 2>&1 | grep -A 10 '"success"'
Step 7: Verify Database Connection
Before testing queries, ensure:
- MongoDB is accessible (local or Atlas)
- The connection string is correct
- The database contains data
Test MongoDB connection manually:
# For MongoDB Atlas
mongosh "mongodb+srv://user:password@cluster.mongodb.net/database"
# For local MongoDB
mongosh "mongodb://localhost:27017/database"
Step 8: Using with MCP Clients (Claude Desktop, etc.)
To use with an MCP client like Claude Desktop:
- Add the server to your MCP client configuration (usually in
~/.config/Claude/claude_desktop_config.json):
{
"mcpServers": {
"konect-database": {
"command": "/home/mrinal/.nvm/versions/node/v18.20.8/bin/node",
"args": [
"/home/mrinal/Desktop/Drivio-Application/KONECT_MCP_Server/build/index.js"
],
"env": {
"MONGODB_CONNECTION_STRING": "mongodb+srv://user:password@cluster.mongodb.net/database",
"NODE_ENV": "development",
"SALT_ROUNDS": "10"
}
}
}
}
Important:
- Use the full path to Node.js (or ensure
nodeis in PATH) - Use absolute path to
build/index.js - Include
NODE_ENVandSALT_ROUNDSfor model loading - Use your actual MongoDB connection string
- Restart Claude Desktop completely
- Verify the tool is available by asking: "List all available MCP tools"
- The
query_databasetool should now be available
Troubleshooting
Build Errors:
- Run
npm installto ensure all dependencies are installed - Check that TypeScript is installed:
npm list typescript - Verify Node.js version:
node --version(should be >= 18.0.0)
Runtime Errors:
MongoDB Connection Error:
- Check that MongoDB is running:
mongosh --versionormongo --version - Verify the connection string in
.env - Test connection manually:
mongosh "your-connection-string"
Model Not Found Error:
- Check that all 19 models are registered: Look for "Registered models:" in stderr output
- Ensure
drivio-web-service/database/mongoose/modelsdirectory exists - Verify
drivio-web-service/config.jsexists (models need it for saltRound) - Check that
NODE_ENVandSALT_ROUNDSenvironment variables are set
Models Not Loading:
- Models use CommonJS and require
config.jsfrom drivio-web-service - Ensure
drivio-web-servicedirectory is at the correct relative path:../../drivio-web-servicefrombuild/loadModels.js - Check that
keys/private.pemandkeys/public.pemexist in drivio-web-service (config.js reads them) - Verify MongoDB connection is established before models load
Tool: query_database
Query the database with MongoDB query syntax.
Parameters
- model (required): The model name to query (e.g., "User", "Vehicle", "Booking")
- query (required): MongoDB query object
- projection (optional): Fields to include/exclude
- sort (optional): Sort order
- limit (optional): Maximum number of results (default: 100, max: 1000)
- skip (optional): Number of documents to skip (for pagination)
- populate (optional): Array of field names to populate
Example Queries
Query active users:
{
"model": "User",
"query": {
"status": "active"
},
"limit": 10
}
Query vehicles by category:
{
"model": "Vehicle",
"query": {
"category": "SUV",
"isActive": true,
"status": "active"
},
"sort": {
"createdAt": -1
},
"limit": 20
}
Query bookings with date range:
{
"model": "Booking",
"query": {
"startDate": {
"$gte": "2024-01-01T00:00:00.000Z"
},
"status": "confirmed"
},
"populate": ["guest", "host", "vehicle"],
"sort": {
"startDate": 1
}
}
Query with field projection:
{
"model": "User",
"query": {
"status": "active"
},
"projection": {
"name": 1,
"emails": 1,
"status": 1
},
"limit": 50
}
Query with MongoDB operators:
{
"model": "Review",
"query": {
"rating": {
"$gte": 4
}
},
"sort": {
"rating": -1,
"createdAt": -1
}
}
Query with regex:
{
"model": "Vehicle",
"query": {
"make": {
"$regex": "Toyota",
"$options": "i"
}
}
}
Response Format
The server returns a JSON object with:
- success: Boolean indicating query success
- model: The model that was queried
- query: The query that was executed
- count: Number of results returned
- totalCount: Total number of matching documents
- skip: Number of documents skipped
- limit: Maximum number of results
- hasMore: Boolean indicating if there are more results
- results: Array of matching documents
Error Handling
The server handles various error cases:
- Invalid model names
- MongoDB connection errors
- Invalid query syntax
- Database operation errors
All errors are returned in the MCP error format with appropriate error codes.
Development
This server follows the same pattern as the weather MCP server, using the @modelcontextprotocol/sdk package for MCP protocol implementation.
License
MIT
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.