Dakota Marketplace MCP Server

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.

Category
Visit Server

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

  1. In Salesforce Setup → App Manager → New Connected App
  2. Enable OAuth Settings:
    • Callback URL: https://your-app.herokuapp.com/auth/callback
    • OAuth Scopes: api, refresh_token
  3. Enable PKCE: check "Require Proof Key for Code Exchange (PKCE)"
  4. Set "Permitted Users" to "All users may self-authorize"
  5. 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

  1. Customer opens GET /auth/login — redirects to Salesforce OAuth
  2. After login, Salesforce redirects to /auth/callback with authorization code
  3. Server exchanges code for access + refresh tokens (PKCE verified)
  4. Tokens stored in Redis keyed by session ID
  5. Session ID returned to client for use in MCP tool calls
  6. 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

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.

Official
Featured
TypeScript
Magic Component Platform (MCP)

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.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

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.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

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.

Official
Featured
TypeScript
Kagi MCP Server

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.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

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.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured