Slack MCP Server

Slack MCP Server

A read-only MCP server that enables AI assistants to access Slack workspace data, including channels, messages, threads, and user information.

Category
Visit Server

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.

  1. Create a Slack App at api.slack.com/apps
  2. Add the following Bot Token Scopes under OAuth & Permissions:
    • channels:read - List public channels
    • channels:history - Read channel messages
    • users:read - List workspace users
    • users.profile:read - Read user profiles
  3. Install the app to your workspace
  4. 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.

  1. Open your Slack workspace in a browser
  2. Open Developer Tools (F12) → Application → Cookies
  3. Find and copy the d cookie value (starts with xoxd-)
  4. 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:

  1. On startup, credentials are loaded from storage (if available) or saved from environment variables
  2. Every hour, the system checks if refresh is due based on the configured interval
  3. When due, both xoxc token and d cookie are refreshed via a request to your workspace
  4. New credentials are persisted to the credentials file with secure permissions (0600)
  5. If refresh fails, retries occur with exponential backoff (max 3 attempts)
  6. You can also manually trigger refresh using the refresh_credentials tool

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 response
  • exclude_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 cursor
  • oldest (optional): Only messages after this timestamp
  • latest (optional): Only messages before this timestamp

get_thread_replies

Retrieve all replies in a message thread.

Parameters:

  • channel_id (required): Channel ID containing the thread
  • thread_ts (required): Timestamp of the parent message
  • limit (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 by score or timestamp (default: score)
  • sort_dir (optional): Sort direction asc or desc (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 configured
  • REFRESH_IN_PROGRESS - Another refresh is already running
  • SESSION_REVOKED - Credentials invalidated, manual re-auth required
  • NETWORK_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

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.

Official
Featured
TypeScript
Magic Component Platform (MCP)

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.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

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.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

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.

Official
Featured
TypeScript
Kagi MCP Server

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.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

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.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured