
Security News
Deno 2.2 Improves Dependency Management and Expands Node.js Compatibility
Deno 2.2 enhances Node.js compatibility, improves dependency management, adds OpenTelemetry support, and expands linting and task automation for developers.
@slack/client
Advanced tools
This is a wrapper around the Slack RTM and Web APIs.
This library will provide the low level functionality you need to build reliable apps and projects on top of Slack's APIs. It:
This library does not attempt to provide application level support, e.g. regex matching and filtering of the conversation stream. If you're looking for those kinds of features, you should check out one of the great libraries built on top of this.
npm install @slack/client --save
IMPORTANT We're moving to NPM organizations, so going forwards the client will be published as a scoped module under the Slack organization.
We'll dual-publish both @slack/client
and slack-client
until at least 2.1.0
is released, and possibly past that, but please switch over before then.
The Real Time Messaging client connects to Slack's RTM API over a websocket.
It allows you to listen for activity in the Slack team you've connected to and push simple messages back to that team over the websocket.
var RtmClient = require('@slack/client').RtmClient;
var token = process.env.SLACK_API_TOKEN || '';
var rtm = new RtmClient(token, {logLevel: 'debug'});
rtm.start();
rtm.start
payloadThe RTM client will emit a RTM.AUTHENTICATED
event, with the rtm.start
payload.
var CLIENT_EVENTS = require('@slack/client').CLIENT_EVENTS;
rtm.on(CLIENT_EVENTS.RTM.AUTHENTICATED, function (rtmStartData) {
});
var RTM_EVENTS = require('@slack/client').RTM_EVENTS;
rtm.on(RTM_EVENTS.MESSAGE, function (message) {
// Listens to all `message` events from the team
});
rtm.on(RTM_EVENTS.CHANNEL_CREATED, function (message) {
// Listens to all `channel_created` events from the team
});
var RTM_CLIENT_EVENTS = require('@slack/client').CLIENT_EVENTS.RTM;
// you need to wait for the client to fully connect before you can send messages
rtm.on(RTM_CLIENT_EVENTS.RTM_CONNECTION_OPENED, function () {
// This will send the message 'this is a test message' to the channel identified by id 'C0CHZA86Q'
rtm.sendMessage('this is a test message', 'C0CHZA86Q', function messageSent() {
// optionally, you can supply a callback to execute once the message has been sent
});
});
The RTM client has its own lifecycle events. These reflect the different states the RTM client can be in as it connects to Slack's RTM API.
The full details of the client lifecyle are in the RTM client events file
The most important events are:
RTM_CONNECTION_OPENED
: the remote server has acked the socket and sent a hello
message, the connection is now live and can be used to send messagesDISCONNECT
: the RTM client has disconnected and will not try to reconnect again automaticallyThis is an incomplete list of items to consider when you migrate from earlier versions. As issues and PRs are raised for things that don't work as expected we'll fill this out.
The model objects no longer provide utility functions for working with the API. This is to decouple them from the client implementation. There should be functions on each of the clients that allow you to take the same actions you took from the model via the clients instead. The most common of these are below.
channel.sendMessage('test message');
becomes
rtmClient.sendMessage('test message', channel.id);
channel.postMessage({
attachments: [...]
});
becomes
var data = {
attachments: [...]
};
webClient.chat.postMessage(channelId, 'test message', data, function() {});
Copyright © Slack Technologies, Inc. MIT License; see LICENSE for further details.
FAQs
Legacy wrapper for official Slack Platform's Web API, RTM API, and Incoming Webhook libraries. Use @slack/web-api, @slack/rtm-api, or @slack/webhook instead.
The npm package @slack/client receives a total of 66,501 weekly downloads. As such, @slack/client popularity was classified as popular.
We found that @slack/client demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 4 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Deno 2.2 enhances Node.js compatibility, improves dependency management, adds OpenTelemetry support, and expands linting and task automation for developers.
Security News
React's CRA deprecation announcement sparked community criticism over framework recommendations, leading to quick updates acknowledging build tools like Vite as valid alternatives.
Security News
Ransomware payment rates hit an all-time low in 2024 as law enforcement crackdowns, stronger defenses, and shifting policies make attacks riskier and less profitable.