slack-cr

A Crystal shard for making Slack Web API calls. Most (but not all) API calls have been implemented. If there are calls missing for what you want to do, either send a request to the contributors or (ideally) submit a pull request.

Installation

Add this to your application's shard.yml:

dependencies:
  slack-api:
    github: crystal-bits/slack-api

Usage

In order to make any Slack API call you need to set up a Slack app, and create an OAuth user token and optionally a Bot user token. These tokens are described here. The user token needs to be set in environment variable SLACK_OAUTH_TOKEN. If you are using the Bot user token (for example to send messages as the Bot user rather than the user that installed the app), you need to set it in environment variable SLACK_BOT_TOKEN.

From there it is pretty straight forward. A class has been defined for each of the supported Slack API calls. The instance variables of the class correspond to the parameters defined for the Slack API method being called. You simply instantiate the class and call the #submit method on that object.

For example:

  require "slack-api"

  req = Slack::Request::APITest.new
  resp = req.submit

The response object will contain all the fields as defined in the Slack API docs.

For examples of specific calls, refer to spec tests.

Checking OAuth scopes

As you will be aware, access to individual Slack API methods is controlled by OAuth scope. This shard can optionally check whether or not the current OAuth token has been granted the required OAuth scope prior to making the call. In order for this checking to occur simply do the following:

  Slack::Request.check_scope = true

Throttling (aka Rate Limits)

Slack imposes rate limits on most of the API requests. This shard handles any response from Slack as per Slack docs and resubmits requests (after sleeping for the directed duration) automatically as necessary.

Logging

The shard has been set up to log various events in case you're interested. I mainly used it during development but you may find it useful. There are two options for logging. Either you provide your own Log instance as follows:

  Slack::Request.logger = my_logger

or have the shard create a 'default' logger for you:

  Slack::Request.set_default_logger

The following messages will be logged. The examples are from the default logger:

Submitting a Slack API http request

Dump request parameters before POST

Response from Slack API http request

Rate Limit response

Class to API mapping

Here is a list of the supported Slack API method calls and the corresponding slack-api class.

Channels Methods

Chat Methods

Conversations Methods

Groups Methods

IM Methods

MPIM Methods

Misc Methods

Pins Methods

User Groups Methods

User Methods

Contributing

  1. Fork it (https://github.com/crystal-bits/slack-api/fork)
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Commit your changes (git commit -am 'Add some feature')
  4. Push to the branch (git push origin my-new-feature)
  5. Create a new Pull Request

Contributors