mcp-interaction-studio
Provides tools to manage datasets, campaigns, segments, templates, recipes, and campaign performance stats for Salesforce Interaction Studio / Marketing Cloud Personalization via its internal admin APIs.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@mcp-interaction-studiolist my datasets"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
mcp-interaction-studio
MCP (Model Context Protocol) server for Salesforce Interaction Studio / Marketing Cloud Personalization admin APIs.
Connect Cursor, Claude Desktop, or any MCP client to your Interaction Studio instance to list datasets, campaigns, segments, templates, recipes, and campaign performance stats through natural language.
How it works
Interaction Studio’s admin UI uses undocumented internal APIs under /internal/.... This server authenticates the same way your browser does: with a session cookie (JSESSIONID) from an active UI login.
Auth method | Used for |
| All tools in this package ( |
API token (Basic auth) | Public |
Related MCP server: Salesforce MCP Server
Prerequisites
Node.js 18+
Access to Interaction Studio admin UI (Gears) for your org
An MCP host (e.g. Cursor, Claude Desktop)
Step 1 — Find your IS_BASE_URL
Log into Interaction Studio. The URL in your browser looks like:
https://{accountName}.{instance}.evergage.com/ui/...Your base URL is everything before /ui:
https://{accountName}.{instance}.evergage.comExample: if you seehttps://demo.us-1.evergage.com/ui/
then:
IS_BASE_URL=https://demo.us-1.evergage.comDo not include a trailing slash.
You can also find this from any Network request to *.evergage.com — use the scheme + host only.
Step 2 — Get your IS_SESSION_ID (JSESSIONID)
The session ID is a cookie set when you log into the admin UI. It expires when you log out or after idle timeout.
Chrome / Edge
Log into Interaction Studio at
{IS_BASE_URL}/ui/Open DevTools → Network tab
Reload the page (or click any screen that loads data)
Click any request to your
*.evergage.comhostUnder Request Headers, find the
CookieheaderCopy the value after
JSESSIONID=up to the next;
Example cookie header:
Cookie: JSESSIONID=274fb681-ebf1-4dbb-8e4d-5b03bb8a1752; AWSALBTG=...Copy only:
274fb681-ebf1-4dbb-8e4d-5b03bb8a1752Firefox
Log into the UI
DevTools → Network → select a request → Headers → Cookie
Copy the
JSESSIONIDvalue the same way
Verify with curl
curl -k "https://YOUR_ACCOUNT.us-4.evergage.com/internal/datasetSummaries/" \
-H "Cookie: JSESSIONID=YOUR_SESSION_ID_HERE" \
-H "X-Requested-With: XMLHttpRequest"If you get a JSON array of datasets, the session is valid. If you get 401 or "Bad Credentials", log in again and copy a fresh JSESSIONID.
Security: Treat
JSESSIONIDlike a password. Do not commit it to git or share it in chat. Refresh it when it expires.
Step 3 — Install the MCP server
Option A — Run with npx (recommended)
No global install needed:
npx mcp-interaction-studioOption B — Global install
npm install -g mcp-interaction-studio
mcp-interaction-studioOption C — Clone and run locally
git clone <your-repo-url>
cd mcp-interaction-studio
npm install
npm startStep 4 — Configure your MCP host
Cursor
Open Cursor Settings → MCP (or edit ~/.cursor/mcp.json):
{
"mcpServers": {
"interaction-studio": {
"command": "npx",
"args": ["-y", "mcp-interaction-studio"],
"env": {
"IS_BASE_URL": "https://YOUR_ACCOUNT.us-4.evergage.com",
"IS_SESSION_ID": "paste-your-JSESSIONID-here",
"IS_DEFAULT_DATASET": "my-dataset",
"IS_TLS_INSECURE": "true"
}
}
}
}If installed globally:
{
"mcpServers": {
"interaction-studio": {
"command": "mcp-interaction-studio",
"env": {
"IS_BASE_URL": "https://YOUR_ACCOUNT.us-4.evergage.com",
"IS_SESSION_ID": "paste-your-JSESSIONID-here",
"IS_DEFAULT_DATASET": "my-dataset",
"IS_TLS_INSECURE": "true"
}
}
}
}Restart MCP in Cursor Settings after changing config.
Claude Desktop
Add to claude_desktop_config.json:
{
"mcpServers": {
"interaction-studio": {
"command": "npx",
"args": ["-y", "mcp-interaction-studio"],
"env": {
"IS_BASE_URL": "https://YOUR_ACCOUNT.us-4.evergage.com",
"IS_SESSION_ID": "paste-your-JSESSIONID-here",
"IS_DEFAULT_DATASET": "my-dataset",
"IS_TLS_INSECURE": "true"
}
}
}
}Environment variables
Variable | Required | Description |
| Yes | Interaction Studio host, e.g. |
| Yes |
|
| No | Default dataset name when a tool omits the |
| No | Set to |
| No | Set to |
| No | Path to your corporate root CA |
Copy .env.example to .env when running locally:
cp .env.example .env
# edit .env, then:
npm startCorporate SSL (Zscaler / proxy)
If you see:
SSL certificate problem: unable to get local issuer certificateQuick fix (dev): set IS_TLS_INSECURE=true
Proper fix: export your org’s Zscaler/corporate root CA and set:
export NODE_EXTRA_CA_CERTS=/path/to/corporate-root.pemThen remove IS_TLS_INSECURE.
Session expiration
When JSESSIONID expires, tools return:
Session expired or invalid (401). Log into Interaction Studio, copy a fresh JSESSIONID...Fix: log into the UI again → copy new JSESSIONID → update IS_SESSION_ID in MCP config → restart MCP.
There is no API token alternative for /internal/* admin routes today.
Available tools
Tool | Description |
| Validate |
| All datasets in the account |
| Dataset metadata and content zones |
| Campaigns in a dataset |
| Campaign details: state, targeting, experiences |
| Impressions, clicks, goals, orders, revenue |
| Segments in a dataset |
| Segment details and targeting rules |
| Segments across all datasets (or filter one) |
| Item/message templates |
| Recommendation recipes |
| Campaign experiences, messages, and runtime context |
| Surveys in a dataset |
| Content zone activity logs |
| Extended segment info including membership counts |
| Dataset audit report (markdown or JSON); optional file output |
| Executive-ready orchestrated audit: narrative, health score, governance, consumption, settings; markdown + DOCX |
| Side-by-side comparison of two datasets |
| Map recipes to campaigns (resolves inUse vs actual linkage) |
| Batch segment membership counts and calc status |
| Publish or disable a campaign (write; gated) |
| Enable or disable a segment (write; gated) |
Set IS_DEFAULT_DATASET to skip passing dataset on every call.
Write tools (v1.0)
Write operations are disabled by default. To enable:
Set
IS_WRITES_ENABLED=truein MCP configCall with
dry_run=falseandconfirm=true
Always preview first with dry_run=true (default):
"Dry run: publish campaign Q07yv in eharper"
"Disable segment uvoSx in eharper — dry run only"
Execute only when intentional:
"Set campaign qDArI to Disabled in eharper with dry_run false and confirm true"
Endpoint | Method | Operation |
| PUT | Publish / disable campaign (full object, |
| POST | Enable / disable segment ( |
Executive audit (audit_mcp_dataset)
Board-ready assessment with health rating, strengths/gaps narrative, domain assessments, and prioritized recommendations. Writes markdown and DOCX when output_path is set.
Parameter | Description |
|
|
|
|
| When saving |
|
|
Example:
"Full MCP audit of eharper — save to audit/eharper-audit.md"
"audit_mcp_dataset dataset=eharper report_style=executive output_path=audit/report.md"
Example prompts
"Check my Interaction Studio session"
"List my Interaction Studio datasets"
"Audit the eharper dataset and save to audit/eharper-audit.md"
"Full executive MCP audit of eharper with markdown and docx"
"Compare mathes and eharper datasets"
"Which campaigns use recipe 4RhQk in eharper?"
"List segment stats for all segments in eharper"
"Get stats for campaign ABC123 in my-dataset"
"List all segments across every dataset"
"Get segment XYZ789 from my-dataset"
Campaign stats time ranges
For get_campaign_stats and list_campaigns, use time_range:
pastDay,pastWeek(default),pastMonth,pastQuarter,TodayCustom:
YYYY-MM-DD..YYYY-MM-DD(max range limits apply per IS API)
CLI audit script
After building locally, run a full audit from the command line:
npm run build
node dist/scripts/audit-dataset.js eharper --output ../audit/eharper-audit.mdOr use the npm script:
npm run audit -- eharper --output ../audit/eharper-audit.mdTroubleshooting
Problem | Solution |
| Refresh |
SSL certificate error |
|
Tool not found in Cursor | Restart MCP after upgrading the package |
| Set env in MCP config |
Zero campaign stats | Campaign may have no traffic in the selected time window; try a wider custom range |
| Use a valid |
License
MIT
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/matheswarwan/mcp-interaction-studio'
If you have feedback or need assistance with the MCP directory API, please join our Discord server