Human-in-the-Loop Slack MCP Server
Allows AI assistants to request information and receive responses from humans via Slack.
Human-in-the-Loop Slack MCP Server
A Model Context Protocol (MCP) server that enables AI assistants to request information from humans via Slack. This server acts as a bridge between AI systems and human experts, allowing AI to ask questions and receive responses through Slack when it needs human knowledge or clarification.
Quick Start with npx
Run directly from GitHub without installation:
npx github:trtd56/AskOnSlackMCP \
--slack-bot-token "xoxb-your-bot-token" \
--slack-app-token "xapp-your-app-token" \
--slack-channel-id "C1234567890" \
--slack-user-id "U1234567890"
Example with Claude Desktop
Add to your Claude Desktop configuration (~/Library/Application Support/Claude/claude_desktop_config.json):
{
"mcpServers": {
"slack-human": {
"command": "npx",
"args": [
"github:trtd56/AskOnSlackMCP",
"--slack-bot-token", "xoxb-your-actual-token",
"--slack-app-token", "xapp-your-actual-token",
"--slack-channel-id", "C1234567890",
"--slack-user-id", "U1234567890"
]
}
}
}
Features
- 🤖 MCP-compliant server for AI assistant integration
- 💬 Real-time Slack integration via Socket Mode WebSocket connection
- 🧵 Thread-based conversations for maintaining context
- ⏱️ 60-second timeout for human responses
- 📢 User mentions (
@username) for notifications - 🔍 Comprehensive debugging and logging capabilities
- 🔐 Secure token handling
- 🚀 Dynamic handler initialization for faster startup
- ⚡ Optimized for instant response detection with event-driven architecture
Prerequisites
-
Slack App Setup
- Create a new Slack app at https://api.slack.com/apps
- Enable Socket Mode in your app settings
- Generate an App-Level Token with
connections:writescope - Install the app to your workspace
-
Bot Token Scopes
chat:write- Send messageschannels:read- Access channel informationusers:read- Access user information
-
Socket Mode
- Enable Socket Mode in your app settings
- This is required for the app to receive events in real-time
-
Event Subscriptions
- Enable Events API
- Subscribe to bot events:
message.channels- Messages in public channelsmessage.groups- Messages in private channelsmessage.im- Direct messages (optional)
- Save changes and reinstall the app to your workspace
Installation (Optional)
If you want to install locally instead of using npx:
- Clone the repository:
git clone https://github.com/trtd56/AskOnSlackMCP.git
cd AskOnSlackMCP
- Install dependencies:
npm install
- Build the TypeScript code:
npm run build
Configuration
All configuration is passed via command-line arguments:
--slack-bot-token- Bot User OAuth Token (xoxb-...)--slack-app-token- App-Level Token for Socket Mode (xapp-...)--slack-channel-id- Channel ID where the bot will operate--slack-user-id- User ID to mention when asking questions--log-level- (Optional) Logging level (default: INFO)
Usage
Development Mode
Run with hot-reloading:
npm run dev
Production Mode
Build and run:
npm run build
npm start
With MCP Client (Using npx)
Configure your MCP client to use this server directly from GitHub:
{
"mcpServers": {
"human-in-the-loop-slack": {
"command": "npx",
"args": [
"github:trtd56/AskOnSlackMCP",
"--slack-bot-token", "xoxb-your-token",
"--slack-app-token", "xapp-your-token",
"--slack-channel-id", "C1234567890",
"--slack-user-id", "U1234567890"
]
}
}
}
With MCP Client (Local Installation)
If you've installed locally:
{
"mcpServers": {
"human-in-the-loop-slack": {
"command": "node",
"args": [
"/path/to/AskOnSlackMCP/dist/index.js",
"--slack-bot-token", "xoxb-your-token",
"--slack-app-token", "xapp-your-token",
"--slack-channel-id", "C1234567890",
"--slack-user-id", "U1234567890"
]
}
}
}
Available Tools
ask_on_slack
Main tool for asking questions to humans via Slack.
Parameters:
question(string): The question to ask the human. Be specific and provide context.
Example:
{
"tool": "ask_on_slack",
"arguments": {
"question": "What is the API endpoint for the production server?"
}
}
Usage Notes:
- The bot will mention the specified user in the Slack channel
- The human has 60 seconds to respond in a thread
- The tool will return the human's response or timeout after 60 seconds
Development
Scripts
npm run build- Compile TypeScriptnpm run dev- Run with hot-reloadingnpm start- Run compiled codenpm test- Run tests with Vitestnpm run test:ci- Run tests with coveragenpm run lint- Run ESLintnpm run format- Format code with Prettiernpm run clean- Clean build artifacts
Project Structure
src/
├── index.ts # Main MCP server implementation
├── bin.ts # Binary entry point for npx execution
├── human.ts # Abstract Human interface
├── slack-client.ts # Socket Mode Slack implementation
└── types.ts # TypeScript type definitions
tests/
├── human.test.ts # Human abstract class tests
├── index.test.ts # CLI argument parsing tests
├── slack-client.test.ts # Slack client tests
└── types.test.ts # Type definition tests
Testing
The project uses Vitest for testing. Tests are located in the tests/ directory.
To run tests:
npm test # Run tests in watch mode
npm run test:ci # Run tests once with coverage
CI/CD
The project uses GitHub Actions for continuous integration and deployment.
-
CI Workflow (
ci.yml): Runs on every push and pull request- Tests on Node.js 18.x, 20.x, and 22.x
- Runs linting and type checking
- Generates code coverage reports
- Builds the project
-
Release Workflow (
release.yml): Runs on version tags- Builds and tests the project
- Creates GitHub releases
- Publishes to npm (requires NPM_TOKEN secret)
Troubleshooting
-
Connection Issues
- Verify all tokens are correct
- Check that the bot is invited to the channel
- Ensure Socket Mode is enabled in your Slack app
-
No Response Received
- Verify the user ID is correct (format: U1234567890)
- Ensure the user responds in the message thread, not the main channel
- Check that the bot has permission to read messages in the channel
-
Authentication Errors
- Bot token should start with
xoxb- - App token should start with
xapp- - Regenerate tokens if needed
- Verify bot has required scopes:
chat:write,channels:read,users:read
- Bot token should start with
-
Performance Optimization
- The server uses event-driven architecture for instant response detection
- WebSocket connection ensures real-time message delivery
- Detailed timing logs available with
[TIMING]prefix for debugging
License
MIT
相關伺服器
MCP Telegram
Control Telegram using LLMs through the Model Context Protocol (MCP).
MCP Email Server
Provides IMAP and SMTP access for sending and receiving emails.
Gossiper Shopify Admin MCP Server
Control Shopify Admin tasks with agents or via prompt. Ultra slim integration, fast and secure.
Gmail MCP Server
Send emails with attachments through Gmail's SMTP server using AI agents.
Gmail MCP Server
An MCP server that integrates with the Gmail API for intelligent email management, including search, categorization, and archiving.
Reddit
Access Reddit's public API to browse frontpage posts, subreddit information, and read post comments.
Bouyomi-chan MCP Server (Node.js)
A Node.js MCP server for the Japanese text-to-speech software Bouyomi-chan.
Email
This server enables users to send emails through various email providers, including Gmail, Outlook, Yahoo, Sina, Sohu, 126, 163, and QQ Mail. It also supports attaching files from specified directories, making it easy to upload attachments along with the email content.
Tldv
Connect your AI agents to Google-Meet, Zoom & Microsoft Teams through tl;dv
WaliChat WhatsApp API
Automate WhatsApp by sending messages, summarizing conversations, and managing chats using natural language with AI assistants.