io.github.SalesforgeAI/forge-mcp
MCP server for Salesforge, Primeforge, Leadsforge, Infraforge, Warmforge, and Mailforge
Ask AI about io.github.SalesforgeAI/forge-mcp
Powered by Claude Β· Grounded in docs
I know everything about io.github.SalesforgeAI/forge-mcp. Ask me about installation, configuration, usage, or troubleshooting.
0/500
Reviews
Documentation
Forge MCP Server
A remote MCP server that connects AI assistants to the full Salesforge product suite: Salesforge, Primeforge, Leadsforge, Infraforge, Warmforge, and Mailforge.
Built on the Model Context Protocol, works with Claude Desktop, Claude Code, Cursor, Windsurf, and any MCP-compatible client.
Supported Products
Salesforge (48 tools) - Workspaces, contacts, sequences, mailboxes, sender profiles, enrollments, webhooks, email validation, do-not-contact lists
Primeforge (22 tools) - Workspaces, domains, mailboxes, DNS management, prewarmed mailboxes
Leadsforge (12 tools) - Contact search, email/phone/LinkedIn enrichment, lookalike search
Infraforge (24 tools) - Workspaces, domains, mailboxes, DNS, domain availability, credits
Warmforge (12 tools) - Mailboxes, warmup stats, placement tests
Mailforge (23 tools) - Workspaces, domains, mailboxes, DNS management, domain availability, auto-renewal, domain masking, forwarding
Only provide API keys for the products you use. Tools for unconfigured products won't appear.
Quick Start
Claude Desktop
Add to your claude_desktop_config.json:
{
"mcpServers": {
"salesforge": {
"url": "https://mcp.salesforge.ai/mcp",
"headers": {
"X-Salesforge-Key": "YOUR_SALESFORGE_API_KEY",
"X-Primeforge-Key": "YOUR_PRIMEFORGE_API_KEY",
"X-Leadsforge-Key": "YOUR_LEADSFORGE_API_KEY",
"X-Infraforge-Key": "YOUR_INFRAFORGE_API_KEY",
"X-Warmforge-Key": "YOUR_WARMFORGE_API_KEY",
"X-Mailforge-Key": "YOUR_MAILFORGE_API_KEY"
}
}
}
}
Remove header lines for products you don't use. Restart Claude Desktop after saving.
Claude Code
claude mcp add salesforge \
--transport streamable-http \
--url https://mcp.salesforge.ai/mcp \
--header "X-Salesforge-Key: YOUR_SALESFORGE_API_KEY" \
--header "X-Primeforge-Key: YOUR_PRIMEFORGE_API_KEY" \
--header "X-Leadsforge-Key: YOUR_LEADSFORGE_API_KEY" \
--header "X-Infraforge-Key: YOUR_INFRAFORGE_API_KEY" \
--header "X-Warmforge-Key: YOUR_WARMFORGE_API_KEY" \
--header "X-Mailforge-Key: YOUR_MAILFORGE_API_KEY"
Cursor
Go to Settings > MCP and add a new server:
- Name: salesforge
- Type: streamable-http
- URL: https://mcp.salesforge.ai/mcp
- Headers: same as above
Getting API Keys
| Product | Where to get it |
|---|---|
| Salesforge | app.salesforge.ai > Settings > API |
| Primeforge | app.primeforge.ai > Settings > API |
| Leadsforge | app.leadsforge.ai > Settings > API |
| Infraforge | app.infraforge.ai > Settings > API |
| Warmforge | app.warmforge.ai > Settings > API |
| Mailforge | app.mailforge.ai > Settings > API |
Authentication Headers
| Product | Header | Format |
|---|---|---|
| Salesforge | X-Salesforge-Key | YOUR_API_KEY |
| Primeforge | X-Primeforge-Key | YOUR_API_KEY |
| Leadsforge | X-Leadsforge-Key | YOUR_API_KEY |
| Infraforge | X-Infraforge-Key | YOUR_API_KEY |
| Warmforge | X-Warmforge-Key | YOUR_API_KEY |
| Mailforge | X-Mailforge-Key | YOUR_API_KEY |
Multiple Accounts
If you manage multiple accounts (for example, different clients), add separate server entries:
{
"mcpServers": {
"salesforge-client-a": {
"url": "https://mcp.salesforge.ai/mcp",
"headers": {
"Authorization": "Bearer CLIENT_A_KEY"
}
},
"salesforge-client-b": {
"url": "https://mcp.salesforge.ai/mcp",
"headers": {
"Authorization": "Bearer CLIENT_B_KEY"
}
}
}
}
Each entry gets its own name and API keys. Your AI assistant sees tools from both and you specify which client to work with in your prompts.
Usage Examples
After setup, try asking your AI assistant:
- "List my Salesforge workspaces"
- "Show contacts tagged with 'enterprise' in workspace X"
- "Create a new sequence called 'Q2 Outreach'"
- "Enroll these contacts into the sequence"
- "Show my Primeforge domains"
- "Search Leadsforge for CTOs at SaaS companies in New York"
- "Check my Infraforge credit balance"
- "Show warmup stats for my mailboxes"
- "List my Mailforge domains"
- "Check if example.com is available on Mailforge"
Project Structure
src/
βββ index.ts # stdio entry point
βββ http.ts # HTTP/SSE transport entry point
βββ server.ts # MCP server setup, tool registration
βββ api-client.ts # HTTP client for upstream APIs
βββ client.ts # legacy client
βββ helpers.ts # shared utilities
βββ tools/
βββ identity.ts # API key validation
βββ workspaces.ts # workspace management
βββ contacts.ts # contact CRUD
βββ mailboxes.ts # mailbox and email operations
βββ sequences.ts # sequence lifecycle
βββ nodes.ts # sequence node management
βββ branches.ts # sequence branches
βββ enrollments.ts # contact enrollment
βββ sender-profiles.ts# sender profile management
βββ validations.ts # email validation
βββ webhooks.ts # webhook management
βββ dnc.ts # do-not-contact lists
βββ custom-vars.ts # custom variables
βββ reference.ts # action/condition type lookups
βββ primeforge/ # domain, mailbox, workspace tools
βββ leadsforge/ # search, enrichment, lookalike tools
βββ infraforge/ # domain, mailbox, credit tools
βββ warmforge/ # mailbox, placement test tools
βββ mailforge/ # workspace, domain, mailbox tools
Self-Hosting
If you prefer to run your own instance:
npm install
npm run build
npm run start:http
The server listens on port 3000 by default. API keys are passed as headers per request, not as environment variables.
License
MIT
