slack-ruby-client 0.16.0 → 1.1.0

Sign up to get free protection for your applications and to get access to all the features.
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