Dakota Marketplace MCP Server
Enables AI clients to query Dakota Marketplace data by integrating directly with Salesforce via OAuth and PKCE. Users can search and retrieve detailed profiles for fund managers, allocators, and funds while maintaining native Salesforce security and sharing rules.
README
Dakota Marketplace MCP Server
External-facing MCP (Model Context Protocol) server that allows customers to query Dakota Marketplace data from any MCP-compatible AI client. Every query runs as the authenticated customer using their Salesforce OAuth token — Salesforce sharing rules and field-level security are enforced natively.
Architecture
AI Client (Claude/ChatGPT/Cursor)
↓ MCP Protocol
Dakota MCP Server (Node.js + Express)
├─ OAuth 2.0 + PKCE → Salesforce Connected App
├─ Redis → Session storage, cache, rate limiting
└─ Salesforce REST/Composite API → Per-user queries
MCP Tools
| Tool | Description |
|---|---|
search_fund_managers |
Search by name, AUM, strategy, geography |
get_fund_manager |
Full profile + funds + contacts (Composite API) |
search_allocators |
Search by type, AUM, location |
get_allocator |
Full allocator profile + contacts |
search_funds |
Search by strategy, vintage year, status, manager |
get_fund |
Full fund details + manager info |
get_contacts |
Contacts for a manager or allocator |
search_marketplace |
Free-text search across all entities (SOSL) |
Setup
1. Salesforce Connected App
- In Salesforce Setup → App Manager → New Connected App
- Enable OAuth Settings:
- Callback URL:
https://your-app.herokuapp.com/auth/callback - OAuth Scopes:
api,refresh_token
- Callback URL:
- Enable PKCE: check "Require Proof Key for Code Exchange (PKCE)"
- Set "Permitted Users" to "All users may self-authorize"
- Note the Consumer Key and Consumer Secret
2. Environment Variables
Copy .env.example to .env and fill in:
cp .env.example .env
| Variable | Description |
|---|---|
SALESFORCE_CLIENT_ID |
Connected App Consumer Key |
SALESFORCE_CLIENT_SECRET |
Connected App Consumer Secret |
SALESFORCE_INSTANCE_URL |
e.g., https://dakota.my.salesforce.com |
SALESFORCE_REDIRECT_URI |
e.g., https://your-app.herokuapp.com/auth/callback |
REDIS_URL |
Redis connection string |
SESSION_SECRET |
Random secret for session signing |
PORT |
Server port (Heroku sets automatically) |
3. Install & Run
npm install
npm start
4. Deploy to Heroku
heroku create dakota-mcp-server
heroku addons:create heroku-redis:mini
heroku config:set SALESFORCE_CLIENT_ID=... SALESFORCE_CLIENT_SECRET=... ...
git push heroku main
Authentication Flow
- Customer opens
GET /auth/login— redirects to Salesforce OAuth - After login, Salesforce redirects to
/auth/callbackwith authorization code - Server exchanges code for access + refresh tokens (PKCE verified)
- Tokens stored in Redis keyed by session ID
- Session ID returned to client for use in MCP tool calls
- Token refresh happens automatically before expiry
Rate Limits
- Standard tier: 100 requests/hour
- Premium tier: 500 requests/hour
- Sliding window tracked in Redis
- Clear error with retry guidance when exceeded
Cache Strategy
- Search results: 120s TTL
- Profile lookups: 300s TTL
- Strictly isolated by user ID — no cross-customer data leakage
- Key format:
cache:{user_id}:{tool_name}:{query_hash}
Customizing SOQL Queries
All Salesforce field names are centralized in the tool files under src/tools/. Update the SOQL queries there to match your actual Salesforce object and field API names. The Composite API request builders are in src/salesforce/composite.js.
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.