Slack MCP Server
A read-only MCP server that enables AI assistants to access Slack workspace data, including channels, messages, threads, and user information.
README
Slack MCP Server
A read-only Model Context Protocol (MCP) server for accessing Slack workspace data. This server enables AI assistants like Claude to read channels, messages, threads, and user information from your Slack workspace.
Features
| Tool | Description | Auth Required |
|---|---|---|
list_channels |
List all accessible public channels with pagination | Bot or User |
get_channel_history |
Retrieve message history from a specific channel | Bot or User |
get_thread_replies |
Get all replies in a message thread (including parent) | Bot or User |
list_users |
List all workspace users with pagination | Bot or User |
get_user_profile |
Get detailed profile information for a specific user | Bot or User |
search_messages |
Search messages across all channels | User only |
refresh_credentials |
Manually trigger credential refresh | User only |
All read tools support cursor-based pagination. The refresh_credentials tool enables automatic credential management for user token authentication.
Installation
Prerequisites
- Node.js 20+
- pnpm (or npm/yarn)
- A Slack workspace with appropriate access
Setup
# Clone the repository
git clone https://github.com/your-username/slack-mcp-server.git
cd slack-mcp-server
# Install dependencies
pnpm install
# Build the project
pnpm run build
Authentication
The server supports two authentication methods:
Option 1: Bot Token (Recommended)
Use a standard Slack Bot User OAuth token for most use cases.
- Create a Slack App at api.slack.com/apps
- Add the following Bot Token Scopes under OAuth & Permissions:
channels:read- List public channelschannels:history- Read channel messagesusers:read- List workspace usersusers.profile:read- Read user profiles
- Install the app to your workspace
- Copy the Bot User OAuth Token (starts with
xoxb-)
export SLACK_BOT_TOKEN=xoxb-your-token-here
Option 2: User Token (Unofficial - Required for Search)
Use a user token to enable the search_messages tool. This method uses browser session credentials.
Warning: This authentication method uses unofficial session credentials extracted from your browser. It may violate Slack's Terms of Service. Session tokens expire and require manual re-extraction. Use at your own risk and only with workspaces where you have appropriate authorization.
- Open your Slack workspace in a browser
- Open Developer Tools (F12) → Application → Cookies
- Find and copy the
dcookie value (starts withxoxd-) - In the Network tab, find any API request and copy the token from the Authorization header (starts with
xoxc-)
export SLACK_USER_TOKEN=xoxc-your-token-here
export SLACK_COOKIE_D=xoxd-your-cookie-here
Note: If both bot token and user token are configured, the bot token takes precedence.
Token Auto-Refresh (User Token Only)
User tokens expire periodically. The server can automatically refresh credentials to maintain uninterrupted access.
Required for auto-refresh:
export SLACK_USER_TOKEN=xoxc-your-token-here
export SLACK_COOKIE_D=xoxd-your-cookie-here
export SLACK_WORKSPACE=your-workspace-name # e.g., "mycompany" from mycompany.slack.com
Optional configuration:
# Credential storage location (default: ~/.slack-mcp-server/credentials.json)
export SLACK_CREDENTIALS_PATH=/custom/path/credentials.json
# Refresh interval in days (default: 7)
export SLACK_REFRESH_INTERVAL_DAYS=7
# Enable/disable auto-refresh (default: true)
export SLACK_REFRESH_ENABLED=true
How it works:
- On startup, credentials are loaded from storage (if available) or saved from environment variables
- Every hour, the system checks if refresh is due based on the configured interval
- When due, both xoxc token and d cookie are refreshed via a request to your workspace
- New credentials are persisted to the credentials file with secure permissions (0600)
- If refresh fails, retries occur with exponential backoff (max 3 attempts)
- You can also manually trigger refresh using the
refresh_credentialstool
Usage
Running the Server
# With bot token
SLACK_BOT_TOKEN=xoxb-... pnpm start
# With user token (enables search)
SLACK_USER_TOKEN=xoxc-... SLACK_COOKIE_D=xoxd-... pnpm start
Claude Code Configuration
Add this MCP server to Claude Code:
# With bot token
claude mcp add slack -- node /absolute/path/to/slack-mcp-server/build/index.js \
-e SLACK_BOT_TOKEN=xoxb-your-token-here
# With user token (enables search)
claude mcp add slack -- node /absolute/path/to/slack-mcp-server/build/index.js \
-e SLACK_USER_TOKEN=xoxc-your-token-here \
-e SLACK_COOKIE_D=xoxd-your-cookie-here
To verify the server is configured:
claude mcp list
Tool Reference
list_channels
List all accessible public channels in the workspace.
Parameters:
limit(optional): Maximum channels to return (1-1000, default: 100)cursor(optional): Pagination cursor from previous responseexclude_archived(optional): Exclude archived channels (default: true)
get_channel_history
Retrieve message history from a specific channel.
Parameters:
channel_id(required): Channel ID (e.g., C1234567890)limit(optional): Maximum messages to return (1-1000, default: 50)cursor(optional): Pagination cursoroldest(optional): Only messages after this timestamplatest(optional): Only messages before this timestamp
get_thread_replies
Retrieve all replies in a message thread.
Parameters:
channel_id(required): Channel ID containing the threadthread_ts(required): Timestamp of the parent messagelimit(optional): Maximum replies to return (1-1000, default: 50)cursor(optional): Pagination cursor
list_users
List all users in the workspace.
Parameters:
limit(optional): Maximum users to return (1-1000, default: 200)cursor(optional): Pagination cursor
get_user_profile
Get detailed profile information for a specific user.
Parameters:
user_id(required): User ID (e.g., U1234567890)
search_messages
Search for messages across all accessible channels. Requires user token authentication.
Parameters:
query(required): Search query (supports Slack modifiers:from:,in:,before:,after:)sort(optional): Sort byscoreortimestamp(default: score)sort_dir(optional): Sort directionascordesc(default: desc)count(optional): Results per page (1-100, default: 20)page(optional): Page number (default: 1)
refresh_credentials
Manually trigger a refresh of Slack user credentials. Requires user token authentication with SLACK_WORKSPACE configured.
Parameters: None
Returns:
- On success:
{ success: true, message, refreshedAt, totalRefreshes } - On failure:
{ success: false, error: { code, message, retryable } }
Error codes:
REFRESH_NOT_AVAILABLE- Bot token auth or workspace not configuredREFRESH_IN_PROGRESS- Another refresh is already runningSESSION_REVOKED- Credentials invalidated, manual re-auth requiredNETWORK_ERROR- Connectivity issue (retryable)
Disclaimer
This project is not affiliated with Slack Technologies, LLC.
User token authentication is unofficial and may not comply with Slack's Terms of Service. Bot token authentication is the recommended approach.
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.