slack-ruby-client 0.16.0 → 1.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (234) hide show
  1. checksums.yaml +4 -4
  2. data/.github/workflows/danger.yml +19 -0
  3. data/.github/workflows/integtest.yml +25 -0
  4. data/.github/workflows/rubocop.yml +13 -0
  5. data/.github/workflows/test.yml +34 -0
  6. data/.gitignore +5 -3
  7. data/.rubocop.yml +6 -0
  8. data/.rubocop_todo.yml +137 -43
  9. data/CHANGELOG.md +34 -3
  10. data/CONTRIBUTING.md +4 -4
  11. data/Gemfile +18 -1
  12. data/Gemfile.danger +6 -0
  13. data/LICENSE.md +1 -1
  14. data/README.md +13 -12
  15. data/RELEASING.md +1 -1
  16. data/UPGRADING.md +42 -0
  17. data/bin/commands/admin_analytics.rb +2 -1
  18. data/bin/commands/admin_apps.rb +11 -0
  19. data/bin/commands/admin_apps_requests.rb +12 -0
  20. data/bin/commands/admin_auth_policy.rb +39 -0
  21. data/bin/commands/admin_conversations.rb +2 -1
  22. data/bin/commands/admin_conversations_restrictAccess.rb +1 -1
  23. data/bin/commands/admin_emoji.rb +2 -2
  24. data/bin/commands/admin_teams.rb +1 -1
  25. data/bin/commands/admin_users.rb +1 -0
  26. data/bin/commands/admin_users_session.rb +40 -0
  27. data/bin/commands/admin_users_unsupportedVersions.rb +15 -0
  28. data/bin/commands/apps_manifest.rb +52 -0
  29. data/bin/commands/bookmarks.rb +52 -0
  30. data/bin/commands/channels.rb +0 -157
  31. data/bin/commands/chat.rb +14 -9
  32. data/bin/commands/conversations.rb +61 -4
  33. data/bin/commands/dnd.rb +3 -1
  34. data/bin/commands/files.rb +2 -1
  35. data/bin/commands/groups.rb +0 -163
  36. data/bin/commands/im.rb +0 -62
  37. data/bin/commands/mpim.rb +0 -60
  38. data/bin/commands/oauth.rb +0 -13
  39. data/bin/commands/oauth_v2.rb +13 -1
  40. data/bin/commands/openid_connect.rb +27 -0
  41. data/bin/commands/pins.rb +2 -2
  42. data/bin/commands/reminders.rb +6 -0
  43. data/bin/commands/rtm.rb +2 -2
  44. data/bin/commands/search.rb +2 -1
  45. data/bin/commands/stars.rb +7 -6
  46. data/bin/commands/team.rb +1 -0
  47. data/bin/commands/team_billing.rb +13 -0
  48. data/bin/commands/team_preferences.rb +13 -0
  49. data/bin/commands/tooling_tokens.rb +14 -0
  50. data/bin/commands/usergroups.rb +1 -1
  51. data/bin/commands/users.rb +1 -1
  52. data/bin/commands/views.rb +1 -1
  53. data/bin/commands.rb +8 -9
  54. data/lib/slack/config.rb +1 -2
  55. data/lib/slack/events/request.rb +5 -3
  56. data/lib/slack/real_time/client.rb +6 -7
  57. data/lib/slack/real_time/concurrency/async.rb +6 -8
  58. data/lib/slack/real_time/config.rb +3 -13
  59. data/lib/slack/real_time/socket.rb +1 -2
  60. data/lib/slack/real_time/stores/base.rb +1 -6
  61. data/lib/slack/real_time/stores/starter.rb +6 -3
  62. data/lib/slack/real_time/stores/store.rb +5 -0
  63. data/lib/slack/version.rb +1 -1
  64. data/lib/slack/web/api/endpoints/admin_analytics.rb +5 -3
  65. data/lib/slack/web/api/endpoints/admin_apps.rb +21 -5
  66. data/lib/slack/web/api/endpoints/admin_apps_approved.rb +2 -2
  67. data/lib/slack/web/api/endpoints/admin_apps_requests.rb +20 -2
  68. data/lib/slack/web/api/endpoints/admin_apps_restricted.rb +2 -2
  69. data/lib/slack/web/api/endpoints/admin_auth_policy.rb +72 -0
  70. data/lib/slack/web/api/endpoints/admin_barriers.rb +6 -6
  71. data/lib/slack/web/api/endpoints/admin_conversations.rb +28 -26
  72. data/lib/slack/web/api/endpoints/admin_conversations_ekm.rb +4 -4
  73. data/lib/slack/web/api/endpoints/admin_emoji.rb +11 -11
  74. data/lib/slack/web/api/endpoints/admin_inviteRequests.rb +7 -7
  75. data/lib/slack/web/api/endpoints/admin_inviteRequests_approved.rb +3 -3
  76. data/lib/slack/web/api/endpoints/admin_inviteRequests_denied.rb +2 -2
  77. data/lib/slack/web/api/endpoints/admin_teams.rb +7 -7
  78. data/lib/slack/web/api/endpoints/admin_teams_admins.rb +2 -2
  79. data/lib/slack/web/api/endpoints/admin_teams_owners.rb +2 -2
  80. data/lib/slack/web/api/endpoints/admin_teams_settings.rb +5 -5
  81. data/lib/slack/web/api/endpoints/admin_usergroups.rb +10 -10
  82. data/lib/slack/web/api/endpoints/admin_users.rb +20 -18
  83. data/lib/slack/web/api/endpoints/admin_users_session.rb +65 -9
  84. data/lib/slack/web/api/endpoints/admin_users_unsupportedVersions.rb +25 -0
  85. data/lib/slack/web/api/endpoints/api.rb +1 -1
  86. data/lib/slack/web/api/endpoints/apps.rb +2 -2
  87. data/lib/slack/web/api/endpoints/apps_event_authorizations.rb +3 -3
  88. data/lib/slack/web/api/endpoints/apps_manifest.rb +77 -0
  89. data/lib/slack/web/api/endpoints/auth.rb +1 -1
  90. data/lib/slack/web/api/endpoints/auth_teams.rb +3 -3
  91. data/lib/slack/web/api/endpoints/bookmarks.rb +86 -0
  92. data/lib/slack/web/api/endpoints/bots.rb +2 -2
  93. data/lib/slack/web/api/endpoints/calls.rb +15 -15
  94. data/lib/slack/web/api/endpoints/calls_participants.rb +4 -4
  95. data/lib/slack/web/api/endpoints/channels.rb +0 -265
  96. data/lib/slack/web/api/endpoints/chat.rb +67 -57
  97. data/lib/slack/web/api/endpoints/chat_scheduledMessages.rb +3 -3
  98. data/lib/slack/web/api/endpoints/conversations.rb +117 -27
  99. data/lib/slack/web/api/endpoints/dialog.rb +2 -2
  100. data/lib/slack/web/api/endpoints/dnd.rb +6 -3
  101. data/lib/slack/web/api/endpoints/files.rb +16 -14
  102. data/lib/slack/web/api/endpoints/files_comments.rb +1 -1
  103. data/lib/slack/web/api/endpoints/files_remote.rb +20 -20
  104. data/lib/slack/web/api/endpoints/groups.rb +0 -273
  105. data/lib/slack/web/api/endpoints/im.rb +0 -107
  106. data/lib/slack/web/api/endpoints/migration.rb +3 -3
  107. data/lib/slack/web/api/endpoints/mpim.rb +0 -102
  108. data/lib/slack/web/api/endpoints/oauth.rb +5 -27
  109. data/lib/slack/web/api/endpoints/oauth_v2.rb +24 -6
  110. data/lib/slack/web/api/endpoints/openid_connect.rb +42 -0
  111. data/lib/slack/web/api/endpoints/pins.rb +4 -4
  112. data/lib/slack/web/api/endpoints/reactions.rb +12 -12
  113. data/lib/slack/web/api/endpoints/reminders.rb +17 -5
  114. data/lib/slack/web/api/endpoints/rtm.rb +10 -10
  115. data/lib/slack/web/api/endpoints/search.rb +24 -16
  116. data/lib/slack/web/api/endpoints/stars.rb +11 -9
  117. data/lib/slack/web/api/endpoints/team.rb +10 -8
  118. data/lib/slack/web/api/endpoints/team_billing.rb +21 -0
  119. data/lib/slack/web/api/endpoints/team_preferences.rb +21 -0
  120. data/lib/slack/web/api/endpoints/team_profile.rb +1 -1
  121. data/lib/slack/web/api/endpoints/tooling_tokens.rb +24 -0
  122. data/lib/slack/web/api/endpoints/usergroups.rb +19 -19
  123. data/lib/slack/web/api/endpoints/usergroups_users.rb +7 -7
  124. data/lib/slack/web/api/endpoints/users.rb +16 -16
  125. data/lib/slack/web/api/endpoints/users_profile.rb +4 -4
  126. data/lib/slack/web/api/endpoints/views.rb +12 -12
  127. data/lib/slack/web/api/endpoints/workflows.rb +9 -9
  128. data/lib/slack/web/api/endpoints.rb +16 -20
  129. data/lib/slack/web/api/errors/server_error.rb +37 -0
  130. data/lib/slack/web/api/errors/too_many_requests_error.rb +1 -4
  131. data/lib/slack/web/api/errors.rb +232 -16
  132. data/lib/slack/web/api/mixins.rb +0 -2
  133. data/lib/slack/web/api/patches/chat.1.patch +7 -9
  134. data/lib/slack/web/api/templates/endpoints.erb +0 -2
  135. data/lib/slack/web/faraday/connection.rb +5 -5
  136. data/lib/slack/web/faraday/request.rb +4 -1
  137. data/lib/slack/web/faraday/response/raise_error.rb +2 -14
  138. data/lib/slack/web/faraday/response/wrap_error.rb +11 -5
  139. data/lib/slack/web/pagination/cursor.rb +1 -5
  140. data/lib/slack-ruby-client.rb +3 -2
  141. data/lib/tasks/real_time.rake +1 -3
  142. data/lib/tasks/web.rake +4 -0
  143. data/slack-ruby-client.gemspec +5 -14
  144. data/spec/fixtures/slack/web/429_error.yml +50 -54
  145. data/spec/fixtures/slack/web/auth_test_error.yml +51 -18
  146. data/spec/fixtures/slack/web/auth_test_success.yml +50 -26
  147. data/spec/fixtures/slack/web/conversations_info.yml +167 -0
  148. data/spec/fixtures/slack/web/conversations_setTopic.yml +42 -27
  149. data/spec/fixtures/slack/web/conversations_setTopic_one_page.yml +89 -59
  150. data/spec/fixtures/slack/web/conversations_setTopic_paginated.yml +131 -86
  151. data/spec/fixtures/slack/web/paginated_users_list.yml +501 -69
  152. data/spec/fixtures/slack/web/rtm_connect.yml +267 -30
  153. data/spec/fixtures/slack/web/rtm_start.yml +771 -60
  154. data/spec/fixtures/slack/web/users_info.yml +153 -69
  155. data/spec/fixtures/slack/web/users_list.yml +102 -41
  156. data/spec/fixtures/slack/web/views_open_error.yml +49 -42
  157. data/spec/integration/integration_spec.rb +1 -1
  158. data/spec/slack/events/request_spec.rb +7 -6
  159. data/spec/slack/real_time/client_spec.rb +37 -39
  160. data/spec/slack/real_time/concurrency/with_concurrency_spec.rb +10 -0
  161. data/spec/slack/real_time/concurrency/without_concurrency_spec.rb +10 -0
  162. data/spec/slack/real_time/event_handlers/bot_spec.rb +1 -1
  163. data/spec/slack/real_time/event_handlers/channel_spec.rb +9 -9
  164. data/spec/slack/real_time/event_handlers/group_spec.rb +2 -2
  165. data/spec/slack/real_time/event_handlers/im_spec.rb +7 -7
  166. data/spec/slack/real_time/event_handlers/user_spec.rb +2 -2
  167. data/spec/slack/real_time/rtm_connect_spec.rb +1 -1
  168. data/spec/slack/real_time/rtm_start_spec.rb +1 -1
  169. data/spec/slack/real_time/store_spec.rb +2 -2
  170. data/spec/slack/slack_spec.rb +7 -5
  171. data/spec/slack/version_spec.rb +1 -1
  172. data/spec/slack/web/api/endpoints/admin_apps_requests_spec.rb +5 -0
  173. data/spec/slack/web/api/endpoints/admin_apps_spec.rb +5 -0
  174. data/spec/slack/web/api/endpoints/admin_auth_policy_spec.rb +35 -0
  175. data/spec/slack/web/api/endpoints/admin_conversations_spec.rb +9 -9
  176. data/spec/slack/web/api/endpoints/admin_teams_settings_spec.rb +1 -1
  177. data/spec/slack/web/api/endpoints/admin_usergroups_spec.rb +6 -6
  178. data/spec/slack/web/api/endpoints/admin_users_session_spec.rb +22 -2
  179. data/spec/slack/web/api/endpoints/admin_users_spec.rb +8 -8
  180. data/spec/slack/web/api/endpoints/admin_users_unsupportedVersions_spec.rb +8 -0
  181. data/spec/slack/web/api/endpoints/apps_manifest_spec.rb +36 -0
  182. data/spec/slack/web/api/endpoints/apps_spec.rb +2 -2
  183. data/spec/slack/web/api/endpoints/bookmarks_spec.rb +40 -0
  184. data/spec/slack/web/api/endpoints/calls_participants_spec.rb +4 -4
  185. data/spec/slack/web/api/endpoints/calls_spec.rb +2 -2
  186. data/spec/slack/web/api/endpoints/custom_specs/auth_spec.rb +4 -6
  187. data/spec/slack/web/api/endpoints/custom_specs/chat_spec.rb +28 -16
  188. data/spec/slack/web/api/endpoints/custom_specs/conversations_spec.rb +13 -0
  189. data/spec/slack/web/api/endpoints/custom_specs/dialog_spec.rb +4 -2
  190. data/spec/slack/web/api/endpoints/custom_specs/users_spec.rb +2 -2
  191. data/spec/slack/web/api/endpoints/custom_specs/views_spec.rb +22 -14
  192. data/spec/slack/web/api/endpoints/dnd_spec.rb +0 -5
  193. data/spec/slack/web/api/endpoints/files_comments_spec.rb +2 -2
  194. data/spec/slack/web/api/endpoints/files_remote_spec.rb +3 -3
  195. data/spec/slack/web/api/endpoints/oauth_spec.rb +0 -11
  196. data/spec/slack/web/api/endpoints/oauth_v2_spec.rb +6 -3
  197. data/spec/slack/web/api/endpoints/{apps_permissions_scopes_spec.rb → openid_connect_spec.rb} +1 -1
  198. data/spec/slack/web/api/endpoints/reactions_spec.rb +3 -3
  199. data/spec/slack/web/api/endpoints/reminders_spec.rb +2 -2
  200. data/spec/slack/web/api/endpoints/{apps_permissions_resources_spec.rb → team_billing_spec.rb} +1 -1
  201. data/spec/slack/web/api/endpoints/team_preferences_spec.rb +8 -0
  202. data/spec/slack/web/api/endpoints/tooling_tokens_spec.rb +13 -0
  203. data/spec/slack/web/api/endpoints/usergroups_users_spec.rb +2 -2
  204. data/spec/slack/web/api/error_spec.rb +5 -7
  205. data/spec/slack/web/api/errors/slack_error_spec.rb +21 -26
  206. data/spec/slack/web/api/mixins/conversations_list_spec.rb +1 -1
  207. data/spec/slack/web/api/pagination/cursor_spec.rb +8 -10
  208. data/spec/slack/web/client_spec.rb +46 -32
  209. data/spec/slack/web/faraday/request_spec.rb +80 -0
  210. data/spec/slack/web/faraday/response/raise_error_spec.rb +2 -1
  211. data/spec/spec_helper.rb +1 -1
  212. data/spec/support/real_time/connected_client.rb +2 -8
  213. data/spec/support/vcr.rb +33 -2
  214. metadata +50 -297
  215. data/.travis.yml +0 -28
  216. data/lib/slack/web/api/errors/internal_error.rb +0 -14
  217. data/lib/slack/web/api/mixins/channels.id.json +0 -20
  218. data/lib/slack/web/api/mixins/channels.id.rb +0 -25
  219. data/lib/slack/web/api/mixins/groups.id.json +0 -20
  220. data/lib/slack/web/api/mixins/groups.id.rb +0 -25
  221. data/spec/fixtures/slack/web/503_error.yml +0 -14
  222. data/spec/fixtures/slack/web/channels_info.yml +0 -139
  223. data/spec/fixtures/slack/web/groups_info.yml +0 -43
  224. data/spec/slack/web/api/endpoints/admin_conversations_whitelist_spec.rb +0 -32
  225. data/spec/slack/web/api/endpoints/apps_permissions_spec.rb +0 -16
  226. data/spec/slack/web/api/endpoints/apps_permissions_users_spec.rb +0 -19
  227. data/spec/slack/web/api/endpoints/conversations_spec.rb +0 -109
  228. data/spec/slack/web/api/endpoints/custom_specs/channels_spec.rb +0 -13
  229. data/spec/slack/web/api/endpoints/custom_specs/groups_spec.rb +0 -13
  230. data/spec/slack/web/api/endpoints/im_spec.rb +0 -39
  231. data/spec/slack/web/api/endpoints/mpim_spec.rb +0 -39
  232. data/spec/slack/web/api/endpoints/views_spec.rb +0 -29
  233. data/spec/slack/web/api/mixins/channels_spec.rb +0 -43
  234. data/spec/slack/web/api/mixins/groups_spec.rb +0 -43
@@ -1,6 +1,4 @@
1
1
  # frozen_string_literal: true
2
- require_relative 'mixins/channels.id'
3
2
  require_relative 'mixins/conversations.id'
4
3
  require_relative 'mixins/users.id'
5
4
  require_relative 'mixins/users.search'
6
- require_relative 'mixins/groups.id'
@@ -1,12 +1,11 @@
1
1
  diff --git a/lib/slack/web/api/endpoints/chat.rb b/lib/slack/web/api/endpoints/chat.rb
2
- index 9de4aa9..8ed5625 100644
2
+ index d090ae2..50186d5 100644
3
3
  --- a/lib/slack/web/api/endpoints/chat.rb
4
4
  +++ b/lib/slack/web/api/endpoints/chat.rb
5
- @@ -121,11 +121,22 @@ module Slack
5
+ @@ -121,10 +121,22 @@ module Slack
6
6
  # @see https://api.slack.com/methods/chat.postEphemeral
7
7
  # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/chat/chat.postEphemeral.json
8
8
  def chat_postEphemeral(options = {})
9
- - throw ArgumentError.new('Required arguments :attachments missing') if options[:attachments].nil?
10
9
  throw ArgumentError.new('Required arguments :channel missing') if options[:channel].nil?
11
10
  - throw ArgumentError.new('Required arguments :text missing') if options[:text].nil?
12
11
  + throw ArgumentError.new('Required arguments :text, :attachments or :blocks missing') if options[:text].nil? && options[:attachments].nil? && options[:blocks].nil?
@@ -26,12 +25,11 @@ index 9de4aa9..8ed5625 100644
26
25
  + end
27
26
  post('chat.postEphemeral', options)
28
27
  end
29
-
30
- @@ -166,7 +177,19 @@ module Slack
28
+
29
+ @@ -168,6 +179,19 @@ module Slack
31
30
  # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/chat/chat.postMessage.json
32
31
  def chat_postMessage(options = {})
33
32
  throw ArgumentError.new('Required arguments :channel missing') if options[:channel].nil?
34
- - throw ArgumentError.new('Required arguments :text missing') if options[:text].nil?
35
33
  + throw ArgumentError.new('Required arguments :text, :attachments or :blocks missing') if options[:text].nil? && options[:attachments].nil? && options[:blocks].nil?
36
34
  + # attachments must be passed as an encoded JSON string
37
35
  + if options.key?(:attachments)
@@ -47,12 +45,12 @@ index 9de4aa9..8ed5625 100644
47
45
  + end
48
46
  post('chat.postMessage', options)
49
47
  end
50
-
51
- @@ -254,8 +277,21 @@ module Slack
48
+
49
+ @@ -257,8 +281,21 @@ module Slack
52
50
  # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/chat/chat.update.json
53
51
  def chat_update(options = {})
54
52
  throw ArgumentError.new('Required arguments :channel missing') if options[:channel].nil?
55
- + throw ArgumentError.new('Required arguments :text, :attachments or :blocks missing') if options[:text].nil? && options[:attachments].nil? && options[:blocks].nil?
53
+ + throw ArgumentError.new('Required arguments :text, :attachments, :blocks or :reply_broadcast missing') if options[:text].nil? && options[:attachments].nil? && options[:blocks].nil? && options[:reply_broadcast].nil?
56
54
  throw ArgumentError.new('Required arguments :ts missing') if options[:ts].nil?
57
55
  options = options.merge(channel: conversations_id(options)['channel']['id']) if options[:channel]
58
56
  + # attachments must be passed as an encoded JSON string
@@ -10,9 +10,7 @@ module Slack
10
10
  module Api
11
11
  module Endpoints
12
12
  include Slack::Web::Api::Mixins::Conversations
13
- include Slack::Web::Api::Mixins::Channels
14
13
  include Slack::Web::Api::Mixins::Users
15
- include Slack::Web::Api::Mixins::Groups
16
14
 
17
15
  <% files.sort.each do |f| %>
18
16
  include <%= f.camelize %>
@@ -22,12 +22,12 @@ module Slack
22
22
  options[:request] = request_options if request_options.any?
23
23
 
24
24
  ::Faraday::Connection.new(endpoint, options) do |connection|
25
- connection.use ::Faraday::Request::Multipart
26
- connection.use ::Faraday::Request::UrlEncoded
27
- connection.use ::Slack::Web::Faraday::Response::WrapError
25
+ connection.request :multipart
26
+ connection.request :url_encoded
28
27
  connection.use ::Slack::Web::Faraday::Response::RaiseError
29
- connection.use ::FaradayMiddleware::Mashify, mash_class: Slack::Messages::Message
30
- connection.use ::FaradayMiddleware::ParseJson
28
+ connection.response :mashify, mash_class: Slack::Messages::Message
29
+ connection.response :json, content_type: /\b*$/
30
+ connection.use ::Slack::Web::Faraday::Response::WrapError
31
31
  connection.response :logger, logger if logger
32
32
  connection.adapter adapter
33
33
  end
@@ -22,18 +22,21 @@ module Slack
22
22
  private
23
23
 
24
24
  def request(method, path, options)
25
- options = options.merge(token: token)
26
25
  response = connection.send(method) do |request|
27
26
  case method
28
27
  when :get, :delete
29
28
  request.url(path, options)
30
29
  when :post, :put
31
30
  request.path = path
31
+ options.compact!
32
32
  request.body = options unless options.empty?
33
33
  end
34
+ request.headers['Authorization'] = "Bearer #{token}" if token
34
35
  request.options.merge!(options.delete(:request)) if options.key?(:request)
35
36
  end
36
37
  response.body
38
+ rescue ::Faraday::ParsingError => e
39
+ raise Slack::Web::Api::Errors::ParsingError, e.response
37
40
  end
38
41
  end
39
42
  end
@@ -3,7 +3,7 @@ module Slack
3
3
  module Web
4
4
  module Faraday
5
5
  module Response
6
- class RaiseError < ::Faraday::Response::Middleware
6
+ class RaiseError < ::Faraday::Middleware
7
7
  def on_complete(env)
8
8
  raise Slack::Web::Api::Errors::TooManyRequestsError, env.response if env.status == 429
9
9
 
@@ -13,23 +13,11 @@ module Slack
13
13
  return unless body
14
14
  return if body['ok']
15
15
 
16
- error_message =
17
- body['error'] || body['errors'].map { |message| message['error'] }.join(',')
18
-
16
+ error_message = body['error'] || body['errors'].map { |message| message['error'] }.join(',')
19
17
  error_class = Slack::Web::Api::Errors::ERROR_CLASSES[error_message]
20
18
  error_class ||= Slack::Web::Api::Errors::SlackError
21
19
  raise error_class.new(error_message, env.response)
22
20
  end
23
-
24
- def call(env)
25
- super
26
- rescue Slack::Web::Api::Errors::SlackError, Slack::Web::Api::Errors::TooManyRequestsError
27
- raise
28
- rescue ::Faraday::ParsingError
29
- raise Slack::Web::Api::Errors::ParsingError.new('parsing_error', env.response)
30
- rescue ::Faraday::TimeoutError, ::Faraday::ConnectionFailed
31
- raise Slack::Web::Api::Errors::TimeoutError.new('timeout_error', env.response)
32
- end
33
21
  end
34
22
  end
35
23
  end
@@ -3,13 +3,19 @@ module Slack
3
3
  module Web
4
4
  module Faraday
5
5
  module Response
6
- class WrapError < ::Faraday::Response::RaiseError
6
+ class WrapError < ::Faraday::Middleware
7
+ UNAVAILABLE_ERROR_STATUSES = (500..599).freeze
8
+
7
9
  def on_complete(env)
10
+ return unless UNAVAILABLE_ERROR_STATUSES.cover?(env.status)
11
+
12
+ raise Slack::Web::Api::Errors::UnavailableError, env.response
13
+ end
14
+
15
+ def call(env)
8
16
  super
9
- rescue Slack::Web::Api::Errors::SlackError
10
- raise
11
- rescue ::Faraday::ServerError
12
- raise Slack::Web::Api::Errors::UnavailableError.new('unavailable_error', env.response)
17
+ rescue ::Faraday::TimeoutError, ::Faraday::ConnectionFailed
18
+ raise Slack::Web::Api::Errors::TimeoutError, env.response
13
19
  end
14
20
  end
15
21
  end
@@ -6,11 +6,7 @@ module Slack
6
6
  class Cursor
7
7
  include Enumerable
8
8
 
9
- attr_reader :client
10
- attr_reader :verb
11
- attr_reader :sleep_interval
12
- attr_reader :max_retries
13
- attr_reader :params
9
+ attr_reader :client, :verb, :sleep_interval, :max_retries, :params
14
10
 
15
11
  def initialize(client, verb, params = {})
16
12
  @client = client
@@ -10,7 +10,8 @@ require_relative 'slack/messages/formatting'
10
10
 
11
11
  # Web API
12
12
  require 'faraday'
13
- require 'faraday_middleware'
13
+ require 'faraday/mashify'
14
+ require 'faraday/multipart'
14
15
  require 'json'
15
16
  require 'logger'
16
17
  begin
@@ -28,7 +29,7 @@ require_relative 'slack/web/api/errors/slack_error'
28
29
  require_relative 'slack/web/api/errors/too_many_requests_error'
29
30
  require_relative 'slack/web/api/error'
30
31
  require_relative 'slack/web/api/errors'
31
- require_relative 'slack/web/api/errors/internal_error'
32
+ require_relative 'slack/web/api/errors/server_error'
32
33
  require_relative 'slack/web/faraday/response/raise_error'
33
34
  require_relative 'slack/web/faraday/response/wrap_error'
34
35
  require_relative 'slack/web/faraday/connection'
@@ -49,9 +49,7 @@ namespace :slack do
49
49
  end
50
50
  end
51
51
 
52
- File.open store_file, 'w' do |f|
53
- f.write store_file_contents
54
- end
52
+ File.write(store_file, store_file_contents)
55
53
 
56
54
  puts ' done.'
57
55
  end
data/lib/tasks/web.rake CHANGED
@@ -32,6 +32,10 @@ namespace :slack do
32
32
  parsed = JSON.parse(File.read(path))
33
33
  parsed['undocumented'] = true if path =~ /undocumented/
34
34
  JSON::Validator.validate(method_schema, parsed, insert_defaults: true)
35
+ if parsed['deprecated'] && parsed['deprecation']['deprecation_warning'] =~ /It will stop functioning in February 2021/
36
+ next
37
+ end
38
+
35
39
  result[prefix][name] = parsed
36
40
  end
37
41
 
@@ -10,27 +10,18 @@ Gem::Specification.new do |s|
10
10
  s.authors = ['Daniel Doubrovkine']
11
11
  s.email = 'dblock@dblock.org'
12
12
  s.platform = Gem::Platform::RUBY
13
+ s.required_ruby_version = '>= 2.7'
13
14
  s.required_rubygems_version = '>= 1.3.6'
14
15
  s.files = `git ls-files`.split("\n")
15
- s.test_files = `git ls-files -- spec/*`.split("\n")
16
16
  s.require_paths = ['lib']
17
17
  s.homepage = 'http://github.com/slack-ruby/slack-ruby-client'
18
18
  s.licenses = ['MIT']
19
19
  s.summary = 'Slack Web and RealTime API client.'
20
- s.add_dependency 'faraday', '>= 1.0'
21
- s.add_dependency 'faraday_middleware'
20
+ s.add_dependency 'faraday', '>= 2.0'
21
+ s.add_dependency 'faraday-mashify'
22
+ s.add_dependency 'faraday-multipart'
22
23
  s.add_dependency 'gli'
23
24
  s.add_dependency 'hashie'
24
25
  s.add_dependency 'websocket-driver'
25
- s.add_development_dependency 'activesupport'
26
- s.add_development_dependency 'erubis'
27
- s.add_development_dependency 'json-schema'
28
- s.add_development_dependency 'rake', '~> 10'
29
- s.add_development_dependency 'rspec'
30
- s.add_development_dependency 'rubocop', '~> 0.82.0'
31
- s.add_development_dependency 'rubocop-performance', '~> 1.5.2'
32
- s.add_development_dependency 'rubocop-rspec', '~> 1.39.0'
33
- s.add_development_dependency 'timecop'
34
- s.add_development_dependency 'vcr'
35
- s.add_development_dependency 'webmock'
26
+ s.metadata['rubygems_mfa_required'] = 'true'
36
27
  end
@@ -5,47 +5,14 @@ http_interactions:
5
5
  uri: https://slack.com/api/auth.test
6
6
  body:
7
7
  encoding: UTF-8
8
- string: token=
9
- headers:
10
- Accept:
11
- - application/json; charset=utf-8
12
- User-Agent:
13
- - Slack Ruby Client 0.1.0
14
- Content-Type:
15
- - application/x-www-form-urlencoded
16
- Accept-Encoding:
17
- - gzip;q=1.0,deflate;q=0.6,identity;q=0.3
18
- response:
19
- status:
20
- code: 429
21
- message: OK
22
- headers:
23
- Access-Control-Allow-Origin:
24
- - '*'
25
- Retry-After:
26
- - 3600
27
- Date:
28
- - Sat, 25 Jul 2015 14:42:07 GMT
29
- Server:
30
- - Apache
31
- Connection:
32
- - keep-alive
33
- body:
34
- encoding: US-ASCII
35
8
  string: ''
36
- http_version:
37
- recorded_at: Sat, 25 Jul 2015 14:42:08 GMT
38
- - request:
39
- method: post
40
- uri: https://slack.com/api/auth.test
41
- body:
42
- encoding: UTF-8
43
- string: token
44
9
  headers:
45
10
  Accept:
46
11
  - application/json; charset=utf-8
47
12
  User-Agent:
48
- - Slack Ruby Client/0.5.0
13
+ - Slack Ruby Client/0.18.0
14
+ Authorization:
15
+ - Bearer <SLACK_API_TOKEN>
49
16
  Content-Type:
50
17
  - application/x-www-form-urlencoded
51
18
  Accept-Encoding:
@@ -55,31 +22,60 @@ http_interactions:
55
22
  code: 200
56
23
  message: OK
57
24
  headers:
58
- Access-Control-Allow-Origin:
59
- - '*'
60
- Content-Security-Policy:
61
- - referrer no-referrer;
62
- Content-Type:
63
- - application/json; charset=utf-8
64
25
  Date:
65
- - Tue, 24 Nov 2015 20:03:05 GMT
26
+ - Sat, 04 Dec 2021 20:13:19 GMT
66
27
  Server:
67
28
  - Apache
29
+ Access-Control-Allow-Origin:
30
+ - "*"
31
+ Referrer-Policy:
32
+ - no-referrer
33
+ X-Slack-Backend:
34
+ - r
68
35
  Strict-Transport-Security:
69
36
  - max-age=31536000; includeSubDomains; preload
70
- X-Accepted-Oauth-Scopes:
71
- - identify
72
- X-Content-Type-Options:
73
- - nosniff
37
+ Access-Control-Allow-Headers:
38
+ - slack-route, x-slack-version-ts, x-b3-traceid, x-b3-spanid, x-b3-parentspanid,
39
+ x-b3-sampled, x-b3-flags
40
+ Access-Control-Expose-Headers:
41
+ - x-slack-req-id, retry-after
42
+ X-Oauth-Scopes:
43
+ - identify,read,post,client,apps
44
+ Expires:
45
+ - Mon, 26 Jul 1997 05:00:00 GMT
46
+ Cache-Control:
47
+ - private, no-cache, no-store, must-revalidate
48
+ Pragma:
49
+ - no-cache
74
50
  X-Xss-Protection:
75
51
  - '0'
52
+ X-Content-Type-Options:
53
+ - nosniff
54
+ X-Slack-Req-Id:
55
+ - 19b143ea43a655dcdc6c3debd59c41c0
56
+ Vary:
57
+ - Accept-Encoding
76
58
  Content-Length:
77
- - '33'
78
- Connection:
79
- - keep-alive
59
+ - '165'
60
+ Content-Type:
61
+ - application/json; charset=utf-8
62
+ X-Envoy-Upstream-Service-Time:
63
+ - '18'
64
+ X-Backend:
65
+ - main_normal main_bedrock_normal_with_overflow main_canary_with_overflow main_bedrock_canary_with_overflow
66
+ main_control_with_overflow main_bedrock_control_with_overflow
67
+ X-Server:
68
+ - slack-www-hhvm-main-iad-d5j5
69
+ X-Slack-Shared-Secret-Outcome:
70
+ - no-match
71
+ Via:
72
+ - envoy-www-iad-tdcc, envoy-edge-iad-olsk
73
+ X-Edge-Backend:
74
+ - envoy-www
75
+ X-Slack-Edge-Shared-Secret-Outcome:
76
+ - no-match
80
77
  body:
81
78
  encoding: UTF-8
82
- string: '{"ok":false,"error":"not_authed"}'
83
- http_version:
84
- recorded_at: Tue, 24 Nov 2015 20:03:05 GMT
85
- recorded_with: VCR 2.9.3
79
+ string: '{"ok":true,"url":"https:\/\/dblockdotorg.slack.com\/","team":"dblock","user":"travis-ci","team_id":"T04KB5WQH","user_id":"U0J1GAHN1","bot_id":"B0J1L75DY","is_enterprise_install":false}'
80
+ recorded_at: Sat, 19 Jan 2019 21:25:48 GMT
81
+ recorded_with: VCR 6.0.0
@@ -5,14 +5,16 @@ http_interactions:
5
5
  uri: https://slack.com/api/auth.test
6
6
  body:
7
7
  encoding: UTF-8
8
- string: token=
8
+ string: ''
9
9
  headers:
10
10
  Accept:
11
11
  - application/json; charset=utf-8
12
12
  User-Agent:
13
- - Slack Ruby Client 0.1.0
14
- Content-Type:
15
- - application/x-www-form-urlencoded
13
+ - Slack Ruby Client/0.18.0
14
+ Authorization:
15
+ - Bearer <SLACK_API_TOKEN>
16
+ Content-Length:
17
+ - '0'
16
18
  Accept-Encoding:
17
19
  - gzip;q=1.0,deflate;q=0.6,identity;q=0.3
18
20
  response:
@@ -20,29 +22,60 @@ http_interactions:
20
22
  code: 200
21
23
  message: OK
22
24
  headers:
23
- Access-Control-Allow-Origin:
24
- - "*"
25
- Content-Type:
26
- - application/json; charset=utf-8
27
25
  Date:
28
- - Sat, 25 Jul 2015 14:42:07 GMT
26
+ - Sat, 04 Dec 2021 20:13:18 GMT
29
27
  Server:
30
28
  - Apache
29
+ Access-Control-Allow-Origin:
30
+ - "*"
31
+ Referrer-Policy:
32
+ - no-referrer
33
+ X-Slack-Backend:
34
+ - r
31
35
  Strict-Transport-Security:
32
36
  - max-age=31536000; includeSubDomains; preload
33
- Vary:
34
- - Accept-Encoding
35
- X-Content-Type-Options:
36
- - nosniff
37
+ Access-Control-Allow-Headers:
38
+ - slack-route, x-slack-version-ts, x-b3-traceid, x-b3-spanid, x-b3-parentspanid,
39
+ x-b3-sampled, x-b3-flags
40
+ Access-Control-Expose-Headers:
41
+ - x-slack-req-id, retry-after
42
+ Expires:
43
+ - Mon, 26 Jul 1997 05:00:00 GMT
44
+ Cache-Control:
45
+ - private, no-cache, no-store, must-revalidate
46
+ Pragma:
47
+ - no-cache
48
+ X-Robots-Tag:
49
+ - noindex,nofollow
37
50
  X-Xss-Protection:
38
51
  - '0'
52
+ X-Content-Type-Options:
53
+ - nosniff
54
+ X-Slack-Req-Id:
55
+ - ad5ac4ccd453f8d6e46e1cc41d6d8a7a
56
+ Vary:
57
+ - Accept-Encoding
39
58
  Content-Length:
40
59
  - '53'
41
- Connection:
42
- - keep-alive
60
+ Content-Type:
61
+ - application/json; charset=utf-8
62
+ X-Envoy-Upstream-Service-Time:
63
+ - '5'
64
+ X-Backend:
65
+ - main_normal main_bedrock_normal_with_overflow main_canary_with_overflow main_bedrock_canary_with_overflow
66
+ main_control_with_overflow main_bedrock_control_with_overflow
67
+ X-Server:
68
+ - slack-www-hhvm-main-iad-6qbu
69
+ X-Slack-Shared-Secret-Outcome:
70
+ - no-match
71
+ Via:
72
+ - envoy-www-iad-fsrl, envoy-edge-iad-m7rj
73
+ X-Edge-Backend:
74
+ - envoy-www
75
+ X-Slack-Edge-Shared-Secret-Outcome:
76
+ - no-match
43
77
  body:
44
78
  encoding: UTF-8
45
79
  string: '{"ok":false,"error":"not_authed"}'
46
- http_version:
47
- recorded_at: Sat, 25 Jul 2015 14:42:08 GMT
48
- recorded_with: VCR 2.9.3
80
+ recorded_at: Sat, 19 Jan 2019 21:25:48 GMT
81
+ recorded_with: VCR 6.0.0
@@ -5,12 +5,14 @@ http_interactions:
5
5
  uri: https://slack.com/api/auth.test
6
6
  body:
7
7
  encoding: UTF-8
8
- string: token=token
8
+ string: ''
9
9
  headers:
10
10
  Accept:
11
11
  - application/json; charset=utf-8
12
12
  User-Agent:
13
- - Slack Ruby Gem 1.1.1
13
+ - Slack Ruby Client/0.18.0
14
+ Authorization:
15
+ - Bearer <SLACK_API_TOKEN>
14
16
  Content-Type:
15
17
  - application/x-www-form-urlencoded
16
18
  Accept-Encoding:
@@ -20,38 +22,60 @@ http_interactions:
20
22
  code: 200
21
23
  message: OK
22
24
  headers:
23
- Access-Control-Allow-Origin:
24
- - '*'
25
- Cache-Control:
26
- - private, no-cache, no-store, must-revalidate
27
- Content-Type:
28
- - application/json; charset=utf-8
29
25
  Date:
30
- - Tue, 28 Apr 2015 12:55:23 GMT
31
- Expires:
32
- - Mon, 26 Jul 1997 05:00:00 GMT
33
- Pragma:
34
- - no-cache
26
+ - Sat, 04 Dec 2021 20:13:19 GMT
35
27
  Server:
36
28
  - Apache
29
+ Access-Control-Allow-Origin:
30
+ - "*"
31
+ Referrer-Policy:
32
+ - no-referrer
33
+ X-Slack-Backend:
34
+ - r
37
35
  Strict-Transport-Security:
38
36
  - max-age=31536000; includeSubDomains; preload
39
- Vary:
40
- - Accept-Encoding
41
- X-Accepted-Oauth-Scopes:
42
- - identify
43
- X-Content-Type-Options:
44
- - nosniff
37
+ Access-Control-Allow-Headers:
38
+ - slack-route, x-slack-version-ts, x-b3-traceid, x-b3-spanid, x-b3-parentspanid,
39
+ x-b3-sampled, x-b3-flags
40
+ Access-Control-Expose-Headers:
41
+ - x-slack-req-id, retry-after
45
42
  X-Oauth-Scopes:
46
- - identify,read,post,client
43
+ - identify,read,post,client,apps
44
+ Expires:
45
+ - Mon, 26 Jul 1997 05:00:00 GMT
46
+ Cache-Control:
47
+ - private, no-cache, no-store, must-revalidate
48
+ Pragma:
49
+ - no-cache
47
50
  X-Xss-Protection:
48
51
  - '0'
52
+ X-Content-Type-Options:
53
+ - nosniff
54
+ X-Slack-Req-Id:
55
+ - cf2877c6fab8f3aa7747f2e07d0b5fd5
56
+ Vary:
57
+ - Accept-Encoding
49
58
  Content-Length:
50
- - '128'
51
- Connection:
52
- - keep-alive
59
+ - '165'
60
+ Content-Type:
61
+ - application/json; charset=utf-8
62
+ X-Envoy-Upstream-Service-Time:
63
+ - '18'
64
+ X-Backend:
65
+ - main_normal main_bedrock_normal_with_overflow main_canary_with_overflow main_bedrock_canary_with_overflow
66
+ main_control_with_overflow main_bedrock_control_with_overflow
67
+ X-Server:
68
+ - slack-www-hhvm-main-iad-i2dg
69
+ X-Slack-Shared-Secret-Outcome:
70
+ - no-match
71
+ Via:
72
+ - envoy-www-iad-pwei, envoy-edge-iad-p7fn
73
+ X-Edge-Backend:
74
+ - envoy-www
75
+ X-Slack-Edge-Shared-Secret-Outcome:
76
+ - no-match
53
77
  body:
54
78
  encoding: UTF-8
55
- string: '{"ok":true,"url":"https:\/\/rubybot.slack.com\/","team":"team_name","user":"user_name","team_id":"TDEADBEEF","user_id":"UBAADFOOD"}'
56
- http_version:
57
- recorded_at: Tue, 28 Apr 2015 12:55:22 GMT
79
+ string: '{"ok":true,"url":"https:\/\/rubybot.slack.com\/","team":"team_name","user":"user_name","team_id":"TDEADBEEF","user_id":"UBAADFOOD","bot_id":"B0J1L75DY","is_enterprise_install":false}'
80
+ recorded_at: Sat, 19 Jan 2019 21:25:48 GMT
81
+ recorded_with: VCR 6.0.0