Sprinklr MCP Server
Enables AI assistants read-only access to Sprinklr data via MCP, allowing querying reports, searching cases, and calling Sprinklr API endpoints.
README
Sprinklr MCP Server
An open-source MCP server that gives AI assistants read-only access to your Sprinklr data. Works with Claude, ChatGPT, Copilot, Cursor, or any MCP-compatible client.
How it works: You deploy this server with your Sprinklr API credentials. Your AI assistant connects to it via MCP and can query reports, search cases, and call any read-only Sprinklr API endpoint --- using your existing permissions. No new access surface, no data leaves your infrastructure.
Table of Contents
- Quick Start
- What You Can Do
- Deployment
- Full Setup Guide
- Token Lifecycle
- Security
- Troubleshooting
- Contributing
- Links
Quick Start
Option A: npm package (fastest)
npm install -g sprinklr-mcp
Create a .env file in your working directory with your Sprinklr credentials (see .env.example for the template), then run:
sprinklr-mcp
Do not pass credentials as inline environment variables. They will be saved in your shell history.
Option B: Clone and configure
git clone https://github.com/daiict218/sprinklr-mcp.git
cd sprinklr-mcp
npm install
cp .env.example .env # fill in your Sprinklr credentials
npm test # verify connectivity
npm start # server runs on port 3000
Then connect your AI client:
| Client | How |
|---|---|
| Claude.ai | Settings > Connectors > Add custom connector > https://your-url/sse |
| Claude Desktop | Add to config: {"mcpServers":{"sprinklr":{"url":"http://localhost:3000/sse"}}} |
| Cursor / Others | Point to /sse (SSE) or /mcp (Streamable HTTP) |
Need Sprinklr API credentials? See Full Setup Guide below.
What You Can Do
| Tool | Description |
|---|---|
sprinklr_report |
Run any reporting dashboard query via API v2 payload |
sprinklr_search_cases |
Search CARE tickets by text, case number, or status |
sprinklr_raw_api |
GET any Sprinklr v2 endpoint (scoped by your token's permissions) |
sprinklr_me |
Check authenticated user profile / verify connectivity |
sprinklr_token_status |
Check connection status and tenant info |
Example: Open a Sprinklr dashboard > click three dots on a widget > "Generate API v2 Payload" > copy the JSON > ask your AI assistant: "Pull this reporting data: {paste payload}"
Deployment
Deploy to any Node.js host (Render, Railway, Fly.io, AWS, on-prem). Set all env vars from .env and run npm start.
For Render free tier, set SERVER_URL to your Render URL --- the server self-pings every 14 minutes to prevent spin-down.
Cost model: You deploy, you authenticate, you pay for your own LLM subscription. Zero cost on Sprinklr's side.
Note: This server has no built-in auth --- deploy on a private network or behind a reverse proxy. See Security.
Full Setup Guide
Prerequisites
- Node.js 18+
- Sprinklr account with API access
- Admin or platform-level role to create developer apps
Step 1: Find Your Sprinklr Environment
Each Sprinklr instance runs on a specific environment. Your API keys and tokens are tied to that environment and cannot be used across others.
- Log into Sprinklr in your browser
- Open browser DevTools (F12 or right-click > Inspect)
- Press Ctrl+F (Windows) or Cmd+F (Mac) to search
- Search for
sentry-environment - The value (e.g.,
prod4) is your environment
Common environments: prod, prod2, prod3, prod4, prod8.
Note: The prod environment has no path prefix in API URLs. All others include the environment name in the path.
Step 2: Create a Sprinklr Developer App
- Open Sprinklr > All Settings > Manage Customer > Developer Apps
- Click "+ Create App" and fill in the details
- Set the Callback URL to
https://www.google.com(or any URL you control)
Alternatively, use the Developer Portal: register, go to Apps > + New App > fill in the form.
Step 3: Generate API Key and Secret
- In Developer Apps, find your app > three dots > "Manage API Key/Token"
- Click "+ API Key"
- Copy both the API Key and Secret immediately --- the Secret is only shown once
If you lose the Secret, you must generate a new pair.
Step 4: Ensure Required Permissions
The authorizing user needs Generate Token and Generate API v2 Payload permissions. These are managed in All Settings > Platform Setup > Governance Console > Workspace/Global Roles.
Step 5: Generate OAuth Tokens
Step 5a: Get an Authorization Code
Open this URL in your browser (must be logged into Sprinklr):
https://api2.sprinklr.com/{ENV}/oauth/authorize?client_id={YOUR_API_KEY}&response_type=code&redirect_uri=https://www.google.com
For prod, omit {ENV}/. The redirect_uri must exactly match your app's Callback URL.
The browser redirects to https://www.google.com/?code=XXXXX. Copy the code value.
Codes expire in 10 minutes --- proceed immediately.
Step 5b: Exchange the Code for Tokens
curl -s -X POST "https://api2.sprinklr.com/{ENV}/oauth/token" \
-H "Content-Type: application/x-www-form-urlencoded" \
-d "client_id={YOUR_API_KEY}" \
-d "client_secret={YOUR_API_SECRET}" \
-d "code={YOUR_CODE}" \
-d "grant_type=authorization_code" \
-d "redirect_uri=https://www.google.com"
Returns access_token and refresh_token. Save both.
Alternative: Generate tokens directly from the Sprinklr UI via Developer Apps > Your App > Manage API Key/Token > Generate Token.
Step 6: Clone and Configure
git clone https://github.com/daiict218/sprinklr-mcp.git
cd sprinklr-mcp
npm install
cp .env.example .env
Fill in your .env with values from the previous steps. See .env.example for the template.
Step 7: Test and Start
npm test # verify Sprinklr connectivity
npm start # start the server on port 3000
Endpoints:
- SSE:
GET /sse+POST /messages(Claude.ai connectors) - Streamable HTTP:
POST/GET/DELETE /mcp - Health:
GET /health
Token Lifecycle
| Token | Expiry | Notes |
|---|---|---|
| Authorization code | 10 minutes | One-time use |
| Access token | ~30 days | Tied to environment |
| Refresh token | No expiry | Single-use --- each refresh invalidates the old one |
The server auto-refreshes on 401, but stores new tokens in memory only. If the server restarts, it re-reads from env vars. Update your env vars after a refresh, or re-run the OAuth flow if tokens go stale.
One token per API key. If multiple instances share an API key, one refreshing will invalidate the others. Use separate API keys per instance.
Security
Architecture
This MCP server is built entirely on top of Sprinklr's existing public REST APIs. It does not create any new access surface, bypass any Sprinklr access controls, or touch internal systems. Every request goes through Sprinklr's standard API gateway with the same authentication, authorization, and rate limiting that applies to any direct API consumer.
Because of this:
- No Sprinklr security review required. This is equivalent to a customer using Sprinklr APIs directly --- same endpoints, same credentials, same access controls.
- Customer security teams should review. As with any API integration, the deploying organization should review the connector as part of their standard security process.
Deployment Model
The intended deployment model keeps all sensitive data within the customer's own infrastructure:
- Customer deploys the server on their own infrastructure (Render, Railway, AWS, on-prem).
- Customer authenticates with their own Sprinklr credentials. No credentials are shared with or stored by Sprinklr.
- LLM costs sit with the customer --- they use their own Claude, ChatGPT, or Copilot subscription.
Sprinklr publishes the open-source connector code. Customers deploy, authenticate, and run it themselves. Zero infrastructure or AI cost on Sprinklr's side.
Important: No Built-in Authentication
This server does not authenticate incoming MCP client connections. Anyone who can reach the server URL can invoke all tools using the configured Sprinklr credentials. This is by design for simplicity --- the server is intended to run on private networks, localhost, or behind a reverse proxy with authentication.
Do not expose this server to the public internet without adding an authentication layer (e.g., reverse proxy with OAuth, VPN, or firewall rules).
Protections
- Read-only enforcement: PUT, DELETE, and PATCH are blocked at the API client level. POST is allowlisted only for
/reports/queryand/case/search. - SSRF prevention: All endpoints must start with
/and are validated against protocol injection (://) and path traversal (..). Requests always target the configured Sprinklr API domain. - Session expiry: Inactive MCP sessions are cleaned up after 30 minutes.
- No credentials in code: All secrets are loaded from environment variables.
.envis gitignored. - Token auto-refresh: On 401 responses, the server refreshes the access token and stores the new refresh token for subsequent rotations.
- Sanitized errors: Sprinklr API error details are logged server-side only. Clients receive only the HTTP status code, not internal response bodies.
sprinklr_raw_apiscope: This tool allows GET requests to any Sprinklr v2 endpoint. Access is intentionally broad to support diverse use cases. The Sprinklr token's own permission scope limits what data is accessible.
Token Storage
Tokens are stored in memory only. This is a deliberate design choice --- it avoids writing credentials to disk and keeps the attack surface minimal. The tradeoff: if the server restarts, it falls back to the tokens in your environment variables. Update your env vars after a refresh if needed, or re-run the OAuth flow.
See Token Lifecycle for details on expiry and single-use refresh tokens.
Troubleshooting
| Error | Cause | Fix |
|---|---|---|
| "Invalid APIKey/ClientID" (401) | API Key doesn't match environment | Verify key belongs to correct environment bundle |
| "Unauthorized" (401) | Access token expired | Server auto-refreshes, or re-run OAuth flow |
| "invalid_grant" | Auth code expired/used/redirect mismatch | Get a fresh code, exchange within 10 minutes |
| Refresh token fails | Already used (single-use) | Re-run full OAuth flow |
| "Developer Over Rate" (403) | Hit 1,000 calls/hour limit | Wait, or contact Sprinklr Success Manager |
Contributing
Contributions are welcome. Please open an issue first to discuss what you'd like to change.
- Fork the repo
- Create a branch (
git checkout -b feature/your-feature) - Make your changes
- Test locally (
npm test && npm start) - Open a PR against
main
Guidelines:
- Keep changes focused --- one concern per PR
- Follow the existing code style (ES modules, arrow functions)
- All PRs are reviewed before merge
- All PRs must target
main--- direct pushes are blocked
Adding new read-only endpoints: Add the POST path to ALLOWED_POST_ENDPOINTS in server.mjs. GET endpoints work automatically via sprinklr_raw_api.
Links
- Sprinklr Developer Portal
- OAuth 2.0 Guide
- API Key Generation
- Authorization Troubleshooting
- REST API Error Codes
License
ISC
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.