README.md in slack-ruby-bot-server-events-0.1.0 vs README.md in slack-ruby-bot-server-events-0.2.0
- old
+ new
@@ -1,12 +1,12 @@
-Slack Ruby Bot Server Slack Extensions
+Slack Ruby Bot Server Events Extension
======================================
[data:image/s3,"s3://crabby-images/cec90/cec90dd39029cdd8aef04d62d90bff6f3ef66d8c" alt="Gem Version"](https://badge.fury.io/rb/slack-ruby-bot-server-events)
[data:image/s3,"s3://crabby-images/5b979/5b97966b14eeeecfb44ebb8562d257fe81b4432b" alt="Build Status"](https://travis-ci.org/slack-ruby/slack-ruby-bot-server-events)
-An extension to [slack-ruby-bot-server](https://github.com/slack-ruby/slack-ruby-bot-server) that enables handling of Slack slash commands, interactive buttons and events.
+An extension to [slack-ruby-bot-server](https://github.com/slack-ruby/slack-ruby-bot-server) that makes it easy to handle Slack slash commands, interactive buttons and events.
### Sample
See [slack-ruby/slack-ruby-bot-server-events-sample](https://github.com/slack-ruby/slack-ruby-bot-server-events-sample) for a working sample.
@@ -41,17 +41,19 @@
This library supports events, actions and commands. When implementing multiple callbacks for each type, the response from the first callback to return a non `nil` value will be used and no further callbacks will be invoked. Callbacks receive subclasses of [SlackRubyBotServer::Events::Requests::Request](lib/slack-ruby-bot-server-events/requests/request.rb).
#### Events
-Respond to [Slack Events](https://api.slack.com/events-api) by implementing `SlackRubyBotServer::Events::Config#on :event`. The following example unfurls URLs and fails any other event type.
+Respond to [Slack Events](https://api.slack.com/events-api) by implementing `SlackRubyBotServer::Events::Config#on :event`.
+The following example unfurls URLs.
+
```ruby
SlackRubyBotServer::Events.configure do |config|
- config.on :event, ['event_callback', 'link_shared'] do |event|
+ config.on :event, 'event_callback', 'link_shared' do |event|
event[:event][:links].each do |link|
- Slack::Web::Client.new(token: '...').chat_unfurl(
+ Slack::Web::Client.new(token: ...).chat_unfurl(
channel: event[:event][:channel],
ts: event[:event][:message_ts],
unfurls: {
link[:url] => { text: 'Unfurled URL.' }
}.to_json
@@ -60,48 +62,63 @@
true # return true to avoid invoking further callbacks
end
config.on :event, 'event_callback' do |event|
- raise "I don't know how to handle #{event[:event][:type]}."
+ # handle any event callback
+ false
end
config.on :event do |event|
- raise "I don't know how to handle #{event[:type]}."
+ # handle any event[:event][:type]
+ false
end
end
```
#### Actions
-Respond to [Interactive Message Buttons](https://api.slack.com/legacy/message-buttons) by implementing `SlackRubyBotServer::Events::Config#on :action`.
+Respond to [Shortcuts](https://api.slack.com/interactivity/shortcuts) and [Interactive Message Buttons](https://api.slack.com/legacy/message-buttons) by implementing `SlackRubyBotServer::Events::Config#on :action`.
+The following example posts an ephemeral message that counts the letters in a message shortcut.
+
```ruby
SlackRubyBotServer::Events.configure do |config|
- config.on :action, 'action_id' do |action|
- # action[:payload][:callback_id] is 'action_id'
- { text: 'Success!' }
+ config.on :action, 'interactive_message', 'action_id' do |action|
+ payload = action[:payload]
+ message = payload[:message]
+
+ Faraday.post(payload[:response_url], {
+ text: "The text \"#{message[:text]}\" has #{message[:text].size} letter(s).",
+ response_type: 'ephemeral'
+ }.to_json, 'Content-Type' => 'application/json')
+
+ true
end
config.on :action do |action|
- { text: "I don't know how to handle #{action[:payload][:callback_id]}." }
+ # handle any other action
+ false
end
end
```
#### Commands
Respond to [Slash Commands](https://api.slack.com/interactivity/slash-commands) by implementing `SlackRubyBotServer::Events::Config#on :command`.
+The following example responds to `/ping` with `pong`.
+
```ruby
SlackRubyBotServer::Events.configure do |config|
- config.on :command, '/test' do
- { text: 'Success!' }
+ config.on :command, '/ping' do
+ { text: 'pong' }
end
config.on :command do |command|
- { text: "I don't know how to handle #{command[:command]}." }
+ # handle any other command
+ false
end
end
```
### Copyright & License