Skip to main content

Slack integration plugin for elizaOS agents with Socket Mode support

Project description

@elizaos/plugin-slack

Slack integration plugin for elizaOS agents with Socket Mode support.

Features

  • Socket Mode: Real-time event handling via Slack Socket Mode
  • Message Operations: Send, edit, delete, read messages
  • Reactions: Add and remove emoji reactions
  • Pins: Pin and unpin messages, list pinned items
  • Channels: List channels, read channel history
  • User Info: Get user profile information
  • Threads: Full thread support with reply tracking
  • Media: Handle file uploads and attachments
  • Custom Emoji: List workspace custom emoji

Installation

npm install @elizaos/plugin-slack
# or
bun add @elizaos/plugin-slack

Configuration

Required Environment Variables

# Bot Token (starts with xoxb-)
SLACK_BOT_TOKEN=xoxb-your-bot-token

# App Token for Socket Mode (starts with xapp-)
SLACK_APP_TOKEN=xapp-your-app-token

Optional Environment Variables

# Signing Secret for request verification
SLACK_SIGNING_SECRET=your-signing-secret

# User Token for enhanced permissions (starts with xoxp-)
SLACK_USER_TOKEN=xoxp-your-user-token

# Comma-separated list of channel IDs to restrict bot to
SLACK_CHANNEL_IDS=C123456789,C987654321

# Ignore messages from other bots
SLACK_SHOULD_IGNORE_BOT_MESSAGES=false

# Only respond when mentioned
SLACK_SHOULD_RESPOND_ONLY_TO_MENTIONS=false

Slack App Setup

  1. Create a new Slack App at https://api.slack.com/apps

  2. Enable Socket Mode in your app settings

  3. Generate an App-Level Token with connections:write scope

  4. Add the following Bot Token Scopes:

    • channels:history - Read messages in public channels
    • channels:read - View basic channel information
    • chat:write - Send messages
    • emoji:read - View custom emoji
    • files:read - View files
    • groups:history - Read messages in private channels
    • groups:read - View basic private channel information
    • im:history - Read direct messages
    • im:read - View basic direct message information
    • mpim:history - Read group direct messages
    • mpim:read - View basic group direct message information
    • pins:read - View pinned items
    • pins:write - Add and remove pinned items
    • reactions:read - View reactions
    • reactions:write - Add and remove reactions
    • team:read - View workspace information
    • users:read - View basic user information
    • users:read.email - View user email addresses
  5. Enable Events and subscribe to:

    • message.channels - Messages in public channels
    • message.groups - Messages in private channels
    • message.im - Direct messages
    • message.mpim - Group direct messages
    • app_mention - When the app is mentioned
    • member_joined_channel - When a user joins a channel
    • member_left_channel - When a user leaves a channel
    • reaction_added - When a reaction is added
    • reaction_removed - When a reaction is removed
  6. Install the app to your workspace

Usage

Add to your agent configuration

import slackPlugin from "@elizaos/plugin-slack";

const agent = {
  // ... other configuration
  plugins: [slackPlugin],
};

Character file configuration

{
  "name": "MyAgent",
  "clients": ["slack"],
  "settings": {
    "slack": {
      "shouldIgnoreBotMessages": true,
      "shouldRespondOnlyToMentions": false
    }
  }
}

Actions

Action Description
SLACK_SEND_MESSAGE Send a message to a channel or thread
SLACK_REACT_TO_MESSAGE Add or remove emoji reactions
SLACK_READ_CHANNEL Read message history from a channel
SLACK_EDIT_MESSAGE Edit an existing message
SLACK_DELETE_MESSAGE Delete a message
SLACK_PIN_MESSAGE Pin a message to a channel
SLACK_UNPIN_MESSAGE Unpin a message from a channel
SLACK_LIST_PINS List pinned messages in a channel
SLACK_LIST_CHANNELS List available channels
SLACK_GET_USER_INFO Get information about a user
SLACK_EMOJI_LIST List custom emoji in the workspace

Providers

Provider Description
slackChannelState Current channel context and metadata
slackWorkspaceInfo Workspace-level information
slackMemberList Members in the current channel

Events

The plugin emits the following events:

  • SLACK_MESSAGE_RECEIVED - When a message is received
  • SLACK_MESSAGE_SENT - When a message is sent
  • SLACK_REACTION_ADDED - When a reaction is added
  • SLACK_REACTION_REMOVED - When a reaction is removed
  • SLACK_APP_MENTION - When the bot is mentioned
  • SLACK_MEMBER_JOINED_CHANNEL - When a member joins a channel
  • SLACK_MEMBER_LEFT_CHANNEL - When a member leaves a channel
  • SLACK_FILE_SHARED - When a file is shared

API Reference

SlackService

The main service class providing direct access to Slack functionality:

import { SlackService, SLACK_SERVICE_NAME } from "@elizaos/plugin-slack";

// Get service from runtime
const slackService = runtime.getService(SLACK_SERVICE_NAME) as SlackService;

// Send a message
await slackService.sendMessage(channelId, "Hello!", { threadTs: "..." });

// Add a reaction
await slackService.sendReaction(channelId, messageTs, "thumbsup");

// Get user info
const user = await slackService.getUser(userId);

// List channels
const channels = await slackService.listChannels();

Troubleshooting

Bot not responding to messages

  1. Verify your SLACK_BOT_TOKEN and SLACK_APP_TOKEN are correct
  2. Check that Socket Mode is enabled in your Slack app
  3. Ensure the bot has been invited to the channel
  4. Check if SLACK_SHOULD_RESPOND_ONLY_TO_MENTIONS is enabled

Permission errors

  1. Verify the bot has all required OAuth scopes
  2. Reinstall the app to your workspace after adding new scopes
  3. Check if the channel is private and the bot is a member

Socket Mode connection issues

  1. Verify your SLACK_APP_TOKEN starts with xapp-
  2. Check that the app-level token has connections:write scope
  3. Ensure only one instance of the bot is running per token

License

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

elizaos_plugin_slack-2.0.0a5.tar.gz (28.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

elizaos_plugin_slack-2.0.0a5-py3-none-any.whl (30.0 kB view details)

Uploaded Python 3

File details

Details for the file elizaos_plugin_slack-2.0.0a5.tar.gz.

File metadata

  • Download URL: elizaos_plugin_slack-2.0.0a5.tar.gz
  • Upload date:
  • Size: 28.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.10

File hashes

Hashes for elizaos_plugin_slack-2.0.0a5.tar.gz
Algorithm Hash digest
SHA256 5c030d54a0b7516185663f4b864b46dc1e0780aaa7f8d7f74156c8f66a112a83
MD5 1571a22cff8921624e4d798fc00bfb31
BLAKE2b-256 96e377add105eaa68e4a58ebbbdd0bb2863115cb4ad049c10d0c1d74bc07b8c9

See more details on using hashes here.

File details

Details for the file elizaos_plugin_slack-2.0.0a5-py3-none-any.whl.

File metadata

File hashes

Hashes for elizaos_plugin_slack-2.0.0a5-py3-none-any.whl
Algorithm Hash digest
SHA256 2261b91cacb13c5ebc46690c75c433a904c6b016f6c7f732a2bd7f759f560282
MD5 6f6c96d4b6e79db911f795b24c95e458
BLAKE2b-256 b0446c71a8624a813650f969353fef51b3848445a6daab641d1c114a9ffab847

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page