Slack
Interact with Slack workspaces using the Slack API.
Slack MCP Server
A Model Context Protocol (MCP) server that enables LLMs to interact with Slack workspaces through OAuth 2.0 authentication.
Features
- š OAuth 2.0 Authentication: Secure Slack OAuth flow with automatic token management
- š FastMCP Framework: Built with the official MCP SDK's FastMCP framework
- š¾ Token Persistence: Tokens are saved locally or in DynamoDB for cloud deployments
- š± Slack Integration: Post messages and list channels in Slack workspaces
- š Dynamic Client Registration: Supports VSCode MCP extension and other clients
- āļø GitHub + App Runner: Deploy directly from GitHub with AWS App Runner
Prerequisites
- Python 3.11+
- Slack App with OAuth 2.0 configured
- uv (Python package manager)
Quick Start
1. Slack App Configuration
- Create a new Slack App at https://api.slack.com/apps
- Add OAuth Scopes in "OAuth & Permissions":
chat:write- Post messageschannels:read- List channels
- Add Redirect URLs:
- Local:
http://localhost:8080/slack/callback - Production:
https://your-domain.com/slack/callback
- Local:
- Copy the Client ID and Client Secret
2. Installation
# Clone the repository
git clone https://github.com/miyatsuki/study-slack-remote-mcp.git
cd study-slack-remote-mcp
# Install dependencies using uv
uv sync
3. Configuration
Create a .env file:
# Required: Slack OAuth credentials
SLACK_CLIENT_ID=your_client_id
SLACK_CLIENT_SECRET=your_client_secret
# Optional: Service base URL (for production deployments)
# SERVICE_BASE_URL=https://your-apprunner-url.awsapprunner.com
4. Run the Server
# Start the server
uv run python server.py
# Or run in background
nohup uv run python server.py > server.log 2>&1 &
Usage
With VSCode MCP Extension
- Install the MCP extension for VSCode
- Connect to the server URL:
http://localhost:8080/mcp/ - The OAuth flow will start automatically when you first use a tool
With Claude Desktop
Add to your Claude Desktop configuration:
macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
Windows: %APPDATA%\Claude\claude_desktop_config.json
{
"mcpServers": {
"slack": {
"command": "uv",
"args": [
"--directory",
"/path/to/slack-mcp-server",
"run",
"python",
"server.py"
]
}
}
}
Available Tools
-
list_channels: Get a list of Slack channels
Returns: Dictionary mapping channel names to IDs -
post_message: Post a message to a Slack channel
Args: - channel_id: Channel ID (required) - text: Message text (required) Returns: Success/failure message -
get_auth_status: Check authentication status
Returns: Current authentication state and session info
Authentication Flow
- When a tool is first used, the OAuth flow automatically starts
- A browser window opens for Slack authorization
- After authorization, the token is saved for future use
- Subsequent requests use the cached token
Authentication
The server uses FastMCP's built-in OAuth 2.0 support with dynamic client registration. This allows compatibility with various MCP clients including VSCode's MCP extension.
Token Management
- OAuth tokens are mapped between MCP tokens and Slack tokens internally
- Tokens are persisted locally in memory (or DynamoDB in cloud)
- OAuth flow starts automatically when tools are first used
- Dynamic client registration supported for VSCode and other clients
Port Configuration
The server uses a single port:
- 8080: MCP server endpoint (includes health check and OAuth callback routes)
AWS App Runner Deployment (ECR-based)
The project uses ECR-based deployment with AWS App Runner for production:
# First, set up AWS Systems Manager parameters:
aws ssm put-parameter --name "/slack-mcp/dev/client-id" --value "your-client-id" --type "String"
aws ssm put-parameter --name "/slack-mcp/dev/client-secret" --value "your-secret" --type "SecureString"
aws ssm put-parameter --name "/slack-mcp/dev/service-base-url" --value "https://your-apprunner-url.awsapprunner.com" --type "String"
# Build and push Docker image to ECR:
./build-and-push.sh
# Create App Runner service (if not exists) or update existing service
aws apprunner update-service --service-arn <your-service-arn> --source-configuration '...'
App Runner provides:
- Deployment from ECR with pre-built Docker images
- Built-in HTTPS with automatic certificates
- Manual deployment control (auto-deploy disabled by default)
- Auto-scaling and simplified management
- Avoids Python 3.11 build issues with App Runner's source code deployment
Project Structure
study-slack-remote-mcp/
āāā server.py # Main MCP server using FastMCP framework
āāā slack_oauth_provider.py # Slack OAuth provider implementation
āāā storage_interface.py # Storage abstraction (local/cloud)
āāā storage_dynamodb.py # DynamoDB storage for AWS
āāā token_storage.py # Local file-based token storage
āāā Dockerfile # Docker container configuration
āāā build-and-push.sh # ECR deployment script
āāā requirements.txt # Python dependencies for Docker
āāā pyproject.toml # Project dependencies
āāā uv.lock # Locked dependencies
āāā tests/ # Unit tests
āāā infrastructure/ # AWS CDK deployment code
āāā CLAUDE.md # Development guidelines
āāā .env # Environment variables (create from .env.example)
Development
Testing
# Check server health
curl http://localhost:8080/health
# Test with MCP client
mcp run uv --directory /path/to/study-slack-remote-mcp run python server.py
Debugging
Enable debug logging by checking server.log:
tail -f server.log
Troubleshooting
Port Already in Use
# Check what's using port 8080
lsof -i :8080
# Kill process using port 8080 if needed
kill -9 $(lsof -ti:8080)
OAuth Errors
-
bad_redirect_uri: Ensure the redirect URL in Slack app matches exactly:
- Must include the full path:
http://localhost:8080/slack/callback - Port must be 8080 (MCP server port)
- Must include the full path:
-
invalid_client_id: Verify SLACK_CLIENT_ID in .env
-
Token not found: Complete OAuth by authorizing in browser
Security Considerations
- OAuth tokens are mapped between MCP tokens and Slack tokens
- Tokens stored in memory locally, DynamoDB in production
- Dynamic client registration supports various MCP clients
- OAuth callbacks use HTTPS in production (App Runner)
Contributing
- Fork the repository
- Create a feature branch
- Follow the guidelines in CLAUDE.md
- Submit a pull request
License
MIT License - see LICENSE file for details
References
Related Servers
Voice MCP
Enables voice interactions with Claude and other LLMs using an OpenAI API key for STT/TTS services.
Fast Intercom
A high-performance MCP server for analyzing Intercom conversations, offering speeds up to 100x faster than the REST API.
Claude Code Notification
Sends notifications from Claude Code with customizable sounds and cross-platform support.
MCP Server SSH Client
A local MCP server that securely connects to remote servers over SSH, acting as a proxy for MCP commands.
mcp-bitrix24
MCP server for Bitrix24 Tasks, Workgroups, and Users. Implements MCP/JSON-RPC over STDIO.
Slack
Interact with Slack workspaces to read and send messages directly through your AI assistant.
Telegram MCP
An MCP server for interacting with the Telegram messaging service using the mtcute library.
Africa's Talking Airtime MCP
Interact with Africa's Talking airtime service and store transaction data in a local SQLite database.
Slack MCP Server
Access Slack DMs, channels, and messages from Claude. Browser token auth - no OAuth needed.
any-chat-completions-mcp
Chat with any other OpenAI SDK Compatible Chat Completions API, like Perplexity, Groq, xAI and more