N8Maynard91/sailpoint-iiq-mcp-server
If you are the rightful owner of sailpoint-iiq-mcp-server and would like to certify it and/or have it hosted online, please leave a comment on the right or send an email to henry@mcphub.com.
This document provides a comprehensive guide to setting up and using a SailPoint IdentityIQ MCP server, which is designed to work with Model Context Provider (MCP) clients.
SailPoint IdentityIQ MCP Server
Welcome to your SailPoint IdentityIQ MCP server! 🚀 This project provides a Model Context Provider (MCP) server for SailPoint IdentityIQ, configured to work with Model Context Provider (MCP) clients. It provides you with:
- ✅ An MCP-compatible server (
mcpServer.js
) - ✅ Automatically generated JavaScript tools for SailPoint IdentityIQ SCIM API endpoints
Let's set things up!
🚦 Getting Started
⚙️ Prerequisites
Before starting, please ensure you have:
- Node.js (v18+ required, v20+ recommended)
- npm (included with Node)
Warning: if you run with a lower version of Node, fetch
won't be present. Tools use fetch
to make HTTP calls. To work around this, you can modify the tools to use node-fetch
instead. Make sure that node-fetch
is installed as a dependency and then import it as fetch
into each tool file.
📥 Installation & Setup
1. Install dependencies
Run from your project's root directory:
npm install
🔐 Set tool environment variables
Create a .env
file in the root directory with your SailPoint IdentityIQ API configuration. You can use the config.example.js
file as a reference for the available configuration options:
# Copy the example configuration
cp config.example.js config.js
# Create your .env file with your actual credentials
touch .env
Add the following environment variables to your .env
file:
# IdentityIQ API Configuration
SAILPOINT_BASE_URL=http://your-identityiq-server:8080/identityiq
SAILPOINT_SCIM_BASE_URL=http://your-identityiq-server:8080/identityiq/scim/v2
SAILPOINT_USERNAME=your_username
SAILPOINT_PASSWORD=your_password
SAILPOINT_API_KEY=your_api_key
# Server Configuration
PORT=3001
NODE_ENV=development
These environment variables are used inside of the generated tools to set the API authentication for each request. You can inspect a file in the tools
directory to see how it works.
// environment variables are used inside of each tool file
const apiKey = process.env.SAILPOINT_API_KEY;
🌐 Test the MCP Server with Postman
The MCP Server (mcpServer.js
) exposes your automated SailPoint IdentityIQ API tools to MCP-compatible clients, such as Claude Desktop or the Postman Desktop Application. We recommend that you test the server with Postman first and then move on to using it with an LLM.
The Postman Desktop Application is the easiest way to run and test MCP servers. Testing the downloaded server first is optional but recommended.
Step 1: Download the latest Postman Desktop Application from https://www.postman.com/downloads/.
Step 2: Read out the documentation article here and see how to create an MCP request inside the Postman app.
Step 3: Set the type of the MCP request to STDIO
and set the command to node </absolute/path/to/mcpServer.js>
. If you have issues with using only node
(e.g. an old version is used), supply an absolute path instead to a node version 18+. You can get the full path to node by running:
which node
To check the node version, run:
node --version
To get the absolute path to mcpServer.js
, run:
realpath mcpServer.js
Use the node command followed by the full path to mcpServer.js
as the command for your new Postman MCP Request. Then click the Connect button. You should see a list of tools that you selected before generating the server. You can test that each tool works here before connecting the MCP server to an LLM.
👩💻 Connect the MCP Server to Claude
You can connect your MCP server to any MCP client. Here we provide instructions for connecting it to Claude Desktop.
Step 1: Note the full path to node and the mcpServer.js
from the previous step.
Step 2. Open Claude Desktop → Settings → Developers → Edit Config and add a new MCP server:
{
"mcpServers": {
"sailpoint-iiq-mcp-server": {
"command": "<absolute/path/to/node>",
"args": ["<absolute/path/to/mcpServer.js>"]
}
}
}
Restart Claude Desktop to activate this change. Make sure the new MCP is turned on and has a green circle next to it. If so, you're ready to begin a chat session that can use the SailPoint IdentityIQ tools you've connected.
Warning: If you don't supply an absolute path to a node
version that is v18+, Claude (and other MCP clients) may fall back to another node
version on the system of a previous version. In this case, the fetch
API won't be present and tool calls will not work. If that happens, you can a) install a newer version of node and point to it in the command, or b) import node-fetch
into each tool as fetch
, making sure to also add the node-fetch
dependency to your package.json.
Additional Options
🐳 Docker Deployment (Production)
For production deployments, you can use Docker:
1. Build Docker image
docker build -t <your_server_name> .
2. Claude Desktop Integration
Add Docker server configuration to Claude Desktop (Settings → Developers → Edit Config):
{
"mcpServers": {
"<your_server_name>": {
"command": "docker",
"args": ["run", "-i", "--rm", "--env-file=.env", "<your_server_name>"]
}
}
}
Add your environment variables (API keys, etc.) inside the
.env
file.
The project comes bundled with the following minimal Docker setup:
FROM node:22.12-alpine AS builder
WORKDIR /app
COPY package.json package-lock.json ./
RUN npm install
COPY . .
ENTRYPOINT ["node", "mcpServer.js"]
🌐 Server-Sent Events (SSE)
To run the server with Server-Sent Events (SSE) support, use the --sse
flag:
node mcpServer.js --sse
🛠️ Additional CLI commands
List tools
List descriptions and parameters from all SailPoint IdentityIQ tools with:
node index.js tools
Example:
Available Tools:
Workspace: identityiq
Collection: scim-api
returns_all_user_resources
Description: Retrieve a list of all user resources.
Parameters:
- startIndex: Starting index for pagination
- count: Number of results returned
[...additional parameters...]
➕ Adding New Tools
Extend your SailPoint IdentityIQ MCP server with more tools easily:
- Add new SailPoint IdentityIQ SCIM API endpoints to your tools directory.
- Update your
tools/paths.js
file to include new tool references. - Ensure proper authentication and error handling for new endpoints.
💬 Questions & Support
For SailPoint IdentityIQ specific questions, refer to the SailPoint IdentityIQ Documentation.
For MCP-related questions, join the MCP community discussions and check the Model Context Protocol documentation.