A Model Context Protocol (MCP) server for Slack built with FastMCP. This server provides read-only access to Slack data, including messages, channels, and users, and secures all API endpoints with bearer token authentication.
- List all channels in a workspace
- Get detailed information about a specific channel
- Read messages from channels
- List all users in a workspace
- Get detailed information about a specific user
- Secure API access via bearer token authentication
-
Install dependencies:
pip install -r requirements.txt
-
Create a
.env
file with your Slack bot token:cp sample.env .env
-
Edit the
.env
file and add your Slack Bot User OAuth Token:SLACK_BOT_TOKEN=xoxb-your-token-here
The server uses JWT (JSON Web Tokens) for authentication. You must also add your RSA keypair as base64-encoded PEM strings:
RSA_PRIVATE_KEY="<base64-encoded-PEM-private-key>" RSA_PUBLIC_KEY="<base64-encoded-PEM-public-key>"
- If you do not have these values, run the server or
python generate_client_token.py
once; it will print out the base64-encoded keys to add to your.env
file. - The keys must be base64-encoded (not raw PEM).
- If you do not have these values, run the server or
- Go to https://api.slack.com/apps
- Create a new app (or use an existing one)
- Navigate to "OAuth & Permissions"
- Add the following scopes to your bot:
channels:read
channels:history
groups:read
groups:history
users:read
- Install the app to your workspace
- Copy the "Bot User OAuth Token" that starts with
xoxb-
Start the server with:
python main.py
The server will run at http://localhost:8000
. By default, all API endpoints are protected with bearer token authentication.
The server exposes the following MCP tools:
Lists all channels in the workspace.
Gets detailed information about a specific channel.
Gets messages from a channel with pagination support.
Lists all users in the workspace.
Gets detailed information about a specific user.
All requests to the MCP server require JWT bearer token authentication. When you start the server, it will display a JWT token that can be used for authentication.
To authenticate your requests, include the following header with the token provided by the server:
Authorization: Bearer eyJhbGciOiJS...your-jwt-token...XwQ
This applies to both HTTP API endpoints and the Server-Sent Events (SSE) connection.
curl -H "Authorization: Bearer eyJhbGciOiJS...your-jwt-token...XwQ" http://localhost:8000/mcp/list
const eventSource = new EventSource('http://localhost:8000/sse', {
headers: {
'Authorization': 'Bearer eyJhbGciOiJS...your-jwt-token...XwQ'
}
});
Note: The JWT token is generated when the server starts. If you restart the server, it will use the same keypair (stored in
jwt_keys.json
), but you may need to get a new token from the server output.
This MCP server can be integrated with LLMs to provide them with read-only access to Slack data. The LLM can query channels, users, and messages but cannot send messages or modify any data. When integrating with LLMs, ensure you securely pass the API token to the client code that establishes the connection.