Salesforce MCP Server
Enables AI assistants to interact with Salesforce data by listing objects, describing fields, and executing SOQL queries.
README
Salesforce MCP Server
An MCP (Model Context Protocol) server implementation for Salesforce integration, enabling AI assistants to interact with Salesforce data through standardized tools.
Features
This MCP server provides three powerful tools for Salesforce integration:
- list_objects: List all available Salesforce objects with their metadata
- describe_object: Get detailed field information for a specific Salesforce object
- execute_soql_query: Execute SOQL queries against your Salesforce instance
Prerequisites
- Python 3.13+
- A Salesforce account with API access
- Salesforce security token (see setup instructions below)
Installation
- Clone this repository:
git clone <repository-url>
cd mcp-salesforce
- Create and activate a virtual environment using uv:
uv venv
source .venv/bin/activate # On Unix/macOS
# or
.venv\Scripts\activate # On Windows
- Install dependencies:
uv pip install -e .
Configuration
- Copy the example environment file:
cp .env.example .env
- Edit
.envand add your Salesforce credentials:
SALESFORCE_USERNAME=your_username@example.com
SALESFORCE_PASSWORD=your_password
SALESFORCE_SECURITY_TOKEN=your_security_token
Getting Your Salesforce Security Token
- Log in to Salesforce
- Go to Setup > Personal Setup > My Personal Information > Reset My Security Token
- Click Reset Security Token
- Check your email for the new security token
Usage
Running the Server
Start the MCP server using one of the following methods:
# Method 1: Run directly with Python
python main.py
# Method 2: Use the installed command
mcp-salesforce
# Method 3: Run with uv (recommended)
uv run mcp-salesforce
Testing with MCP Inspector
The MCP Inspector is a powerful tool for testing and debugging your MCP server. It provides an interactive interface to explore available tools and test them with different parameters.
Method 1: Using uv run with mcp-salesforce command (recommended)
npx @modelcontextprotocol/inspector uv run mcp-salesforce
Method 2: Using uv run with Python directly
npx @modelcontextprotocol/inspector uv run python main.py
This will:
- Start the MCP Inspector web interface
- Launch your Salesforce MCP server
- Open a browser window where you can:
- View all available tools
- Test each tool with custom parameters
- See the JSON responses
- Debug any issues
Note: Make sure your .env file is configured with valid Salesforce credentials before running the inspector.
Available Tools
1. list_objects
Lists all available Salesforce objects in your org.
Returns:
- Dictionary containing:
objects: Array of object metadata, each with:name: API name of the objectlabel: Display labelcustom: Whether it's a custom objectqueryable: Whether it can be queried via SOQLsearchable: Whether it's searchablecreateable: Whether new records can be createdupdateable: Whether records can be updateddeletable: Whether records can be deleted
2. describe_object
Get all fields for a specific Salesforce object.
Parameters:
object_name(string): The API name of the Salesforce object (e.g., 'Account', 'Contact', 'CustomObject__c')
Returns:
- Dictionary containing:
name: Object API namefields: Array of field definitions with:name: Field API namelabel: Field display labeltype: Data type (string, number, date, picklist, etc.)length,precision,scale: Size constraintsrequired: Whether the field is requiredunique: Whether values must be uniquecreateable,updateable: Field permissionscalculated: Whether it's a formula fielddefaultValue: Default value for the fieldpicklistValues: Available values (for picklist fields)referenceTo: Referenced object (for lookup/master-detail fields)
3. execute_soql_query
Execute SOQL (Salesforce Object Query Language) queries.
Parameters:
query(string): The SOQL query string (e.g., 'SELECT Id, Name FROM Account LIMIT 10')
Returns:
- Dictionary containing:
query: The executed SOQL query stringrows: Array of records with queried fieldsrow_count: Total number of records returnedcolumns: Array of column names in the result set
Important SOQL Rules:
- CANNOT use SELECT * - You MUST specify column names explicitly
- Aggregate queries CANNOT use LIMIT - Queries using COUNT, SUM, AVG, MIN, MAX cannot have LIMIT clause
Example Queries:
-- Get first 10 accounts
SELECT Id, Name, Industry FROM Account LIMIT 10
-- Get contacts with filters
SELECT Id, FirstName, LastName, Email FROM Contact WHERE Email != null LIMIT 20
-- Join query (using relationship)
SELECT Id, Name, Owner.Name FROM Account WHERE CreatedDate = TODAY
Development
Project Structure
mcp-salesforce/
├── main.py # Main MCP server implementation
├── pyproject.toml # Project configuration and dependencies
├── .env.example # Example environment variables
├── .env # Your actual credentials (git-ignored)
└── README.md # This file
Dependencies
- fastmcp: Framework for building MCP servers
- simple-salesforce: Python client for Salesforce REST API
- python-dotenv: Load environment variables from .env files
Adding to Claude Desktop
To use this MCP server with Claude Desktop, add the following to your Claude Desktop configuration:
MacOS: ~/Library/Application Support/Claude/claude_desktop_config.json
Windows: %APPDATA%/Claude/claude_desktop_config.json
{
"mcpServers": {
"salesforce": {
"command": "uv",
"args": [
"--directory",
"/absolute/path/to/mcp-salesforce",
"run",
"mcp-salesforce"
]
}
}
}
Replace /absolute/path/to/mcp-salesforce with the actual path to your project directory.
Alternative configuration using Python directly:
{
"mcpServers": {
"salesforce": {
"command": "uv",
"args": [
"--directory",
"/absolute/path/to/mcp-salesforce",
"run",
"python",
"main.py"
]
}
}
}
Error Handling
The server includes comprehensive error handling:
- Missing Credentials: Clear error message if environment variables are not set
- Authentication Errors: Salesforce API authentication failures are reported
- Invalid Queries: SOQL syntax errors are returned with helpful messages
- API Limits: Respects Salesforce API rate limits
Security Notes
- Never commit your
.envfile to version control - Keep your Salesforce security token secure
- Consider using OAuth 2.0 for production deployments
- Regularly rotate your security token
License
[Add your license here]
Contributing
[Add contribution guidelines here]
Support
For issues and questions:
- Check the simple-salesforce documentation
- Review Salesforce API documentation
- Open an issue in this repository
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.