slack-ruby-client 0.14.5 → 0.17.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (231) hide show
  1. checksums.yaml +4 -4
  2. data/.github/FUNDING.yml +1 -0
  3. data/.rubocop.yml +11 -3
  4. data/.rubocop_todo.yml +61 -23
  5. data/.travis.yml +1 -5
  6. data/CHANGELOG.md +43 -4
  7. data/CONTRIBUTING.md +17 -6
  8. data/Dangerfile +1 -1
  9. data/Gemfile +1 -2
  10. data/LICENSE.md +1 -1
  11. data/README.md +86 -52
  12. data/UPGRADING.md +20 -2
  13. data/bin/commands.rb +23 -0
  14. data/bin/commands/admin_analytics.rb +16 -0
  15. data/bin/commands/admin_apps.rb +15 -2
  16. data/bin/commands/admin_apps_approved.rb +17 -0
  17. data/bin/commands/admin_apps_restricted.rb +17 -0
  18. data/bin/commands/admin_barriers.rb +47 -0
  19. data/bin/commands/admin_conversations.rb +159 -0
  20. data/bin/commands/admin_conversations_ekm.rb +17 -0
  21. data/bin/commands/admin_conversations_restrictAccess.rb +37 -0
  22. data/bin/commands/admin_conversations_whitelist.rb +37 -0
  23. data/bin/commands/admin_emoji.rb +54 -0
  24. data/bin/commands/admin_inviteRequests.rb +36 -0
  25. data/bin/commands/admin_inviteRequests_approved.rb +16 -0
  26. data/bin/commands/admin_inviteRequests_denied.rb +16 -0
  27. data/bin/commands/admin_teams.rb +27 -0
  28. data/bin/commands/admin_teams_admins.rb +16 -0
  29. data/bin/commands/admin_teams_owners.rb +16 -0
  30. data/bin/commands/admin_teams_settings.rb +64 -0
  31. data/bin/commands/admin_usergroups.rb +48 -0
  32. data/bin/commands/admin_users.rb +97 -0
  33. data/bin/commands/admin_users_session.rb +22 -0
  34. data/bin/commands/api.rb +0 -1
  35. data/bin/commands/apps_connections.rb +13 -0
  36. data/bin/commands/apps_event_authorizations.rb +16 -0
  37. data/bin/commands/auth_teams.rb +16 -0
  38. data/bin/commands/bots.rb +1 -0
  39. data/bin/commands/calls.rb +52 -0
  40. data/bin/commands/calls_participants.rb +25 -0
  41. data/bin/commands/channels.rb +1 -155
  42. data/bin/commands/chat.rb +14 -12
  43. data/bin/commands/chat_scheduledMessages.rb +1 -0
  44. data/bin/commands/conversations.rb +15 -4
  45. data/bin/commands/dnd.rb +3 -1
  46. data/bin/commands/files.rb +7 -5
  47. data/bin/commands/files_remote.rb +3 -3
  48. data/bin/commands/groups.rb +1 -162
  49. data/bin/commands/im.rb +1 -63
  50. data/bin/commands/migration.rb +1 -0
  51. data/bin/commands/mpim.rb +1 -61
  52. data/bin/commands/oauth.rb +1 -1
  53. data/bin/commands/pins.rb +0 -2
  54. data/bin/commands/reactions.rb +1 -0
  55. data/bin/commands/search.rb +4 -1
  56. data/bin/commands/team.rb +3 -0
  57. data/bin/commands/usergroups.rb +6 -1
  58. data/bin/commands/usergroups_users.rb +2 -0
  59. data/bin/commands/users.rb +5 -3
  60. data/bin/commands/users_profile.rb +5 -5
  61. data/bin/commands/views.rb +1 -1
  62. data/bin/commands/workflows.rb +38 -0
  63. data/lib/slack-ruby-client.rb +5 -4
  64. data/lib/slack/events/request.rb +7 -3
  65. data/lib/slack/messages/message.rb +0 -4
  66. data/lib/slack/real_time/client.rb +2 -1
  67. data/lib/slack/real_time/concurrency.rb +0 -2
  68. data/lib/slack/real_time/concurrency/async.rb +1 -3
  69. data/lib/slack/real_time/config.rb +5 -14
  70. data/lib/slack/real_time/models/base.rb +0 -4
  71. data/lib/slack/real_time/socket.rb +2 -2
  72. data/lib/slack/real_time/stores/base.rb +3 -1
  73. data/lib/slack/version.rb +1 -1
  74. data/lib/slack/web/api/endpoints.rb +47 -0
  75. data/lib/slack/web/api/endpoints/admin_analytics.rb +28 -0
  76. data/lib/slack/web/api/endpoints/admin_apps.rb +22 -2
  77. data/lib/slack/web/api/endpoints/admin_apps_approved.rb +35 -0
  78. data/lib/slack/web/api/endpoints/admin_apps_restricted.rb +35 -0
  79. data/lib/slack/web/api/endpoints/admin_barriers.rb +82 -0
  80. data/lib/slack/web/api/endpoints/admin_conversations.rb +246 -0
  81. data/lib/slack/web/api/endpoints/admin_conversations_ekm.rb +35 -0
  82. data/lib/slack/web/api/endpoints/admin_conversations_restrictAccess.rb +61 -0
  83. data/lib/slack/web/api/endpoints/admin_conversations_whitelist.rb +64 -0
  84. data/lib/slack/web/api/endpoints/admin_emoji.rb +88 -0
  85. data/lib/slack/web/api/endpoints/admin_inviteRequests.rb +61 -0
  86. data/lib/slack/web/api/endpoints/admin_inviteRequests_approved.rb +33 -0
  87. data/lib/slack/web/api/endpoints/admin_inviteRequests_denied.rb +33 -0
  88. data/lib/slack/web/api/endpoints/admin_teams.rb +50 -0
  89. data/lib/slack/web/api/endpoints/admin_teams_admins.rb +34 -0
  90. data/lib/slack/web/api/endpoints/admin_teams_owners.rb +34 -0
  91. data/lib/slack/web/api/endpoints/admin_teams_settings.rb +99 -0
  92. data/lib/slack/web/api/endpoints/admin_usergroups.rb +77 -0
  93. data/lib/slack/web/api/endpoints/admin_users.rb +161 -0
  94. data/lib/slack/web/api/endpoints/admin_users_session.rb +38 -0
  95. data/lib/slack/web/api/endpoints/api.rb +0 -2
  96. data/lib/slack/web/api/endpoints/apps_connections.rb +21 -0
  97. data/lib/slack/web/api/endpoints/apps_event_authorizations.rb +34 -0
  98. data/lib/slack/web/api/endpoints/auth_teams.rb +33 -0
  99. data/lib/slack/web/api/endpoints/bots.rb +2 -0
  100. data/lib/slack/web/api/endpoints/calls.rb +83 -0
  101. data/lib/slack/web/api/endpoints/calls_participants.rb +42 -0
  102. data/lib/slack/web/api/endpoints/channels.rb +1 -245
  103. data/lib/slack/web/api/endpoints/chat.rb +23 -19
  104. data/lib/slack/web/api/endpoints/chat_scheduledMessages.rb +3 -1
  105. data/lib/slack/web/api/endpoints/conversations.rb +37 -19
  106. data/lib/slack/web/api/endpoints/dnd.rb +4 -0
  107. data/lib/slack/web/api/endpoints/files.rb +8 -4
  108. data/lib/slack/web/api/endpoints/files_remote.rb +4 -4
  109. data/lib/slack/web/api/endpoints/groups.rb +0 -253
  110. data/lib/slack/web/api/endpoints/im.rb +0 -101
  111. data/lib/slack/web/api/endpoints/migration.rb +2 -0
  112. data/lib/slack/web/api/endpoints/mpim.rb +0 -96
  113. data/lib/slack/web/api/endpoints/oauth.rb +1 -4
  114. data/lib/slack/web/api/endpoints/pins.rb +3 -8
  115. data/lib/slack/web/api/endpoints/reactions.rb +5 -3
  116. data/lib/slack/web/api/endpoints/search.rb +6 -0
  117. data/lib/slack/web/api/endpoints/stars.rb +2 -2
  118. data/lib/slack/web/api/endpoints/team.rb +6 -0
  119. data/lib/slack/web/api/endpoints/usergroups.rb +10 -0
  120. data/lib/slack/web/api/endpoints/usergroups_users.rb +4 -0
  121. data/lib/slack/web/api/endpoints/users.rb +7 -5
  122. data/lib/slack/web/api/endpoints/users_profile.rb +3 -3
  123. data/lib/slack/web/api/endpoints/views.rb +1 -1
  124. data/lib/slack/web/api/endpoints/workflows.rb +61 -0
  125. data/lib/slack/web/api/errors.rb +848 -0
  126. data/lib/slack/web/api/errors/internal_error.rb +14 -0
  127. data/lib/slack/web/api/errors/slack_error.rb +12 -0
  128. data/lib/slack/web/api/mixins.rb +1 -0
  129. data/lib/slack/web/api/mixins/channels.id.rb +1 -3
  130. data/lib/slack/web/api/mixins/conversations.id.rb +25 -0
  131. data/lib/slack/web/api/mixins/groups.id.rb +1 -3
  132. data/lib/slack/web/api/mixins/ids.id.rb +3 -5
  133. data/lib/slack/web/api/mixins/users.id.rb +1 -3
  134. data/lib/slack/web/api/patches/{chat.6.block-kit-support.patch → chat.1.patch} +26 -24
  135. data/lib/slack/web/api/templates/endpoints.erb +1 -0
  136. data/lib/slack/web/api/templates/errors.erb +20 -0
  137. data/lib/slack/web/api/templates/method.erb +4 -1
  138. data/lib/slack/web/api/templates/method_spec.erb +1 -1
  139. data/lib/slack/web/client.rb +1 -1
  140. data/lib/slack/web/config.rb +2 -0
  141. data/lib/slack/web/faraday/connection.rb +23 -20
  142. data/lib/slack/web/faraday/response/raise_error.rb +16 -2
  143. data/lib/slack/web/faraday/response/wrap_error.rb +24 -0
  144. data/lib/slack/web/pagination/cursor.rb +2 -2
  145. data/lib/tasks/real_time.rake +1 -1
  146. data/lib/tasks/web.rake +21 -4
  147. data/slack-ruby-client.gemspec +5 -5
  148. data/spec/fixtures/slack/web/channels_info.yml +108 -15
  149. data/spec/fixtures/slack/web/{groups_info.yml → conversations_info.yml} +4 -4
  150. data/spec/fixtures/slack/web/conversations_setTopic.yml +69 -0
  151. data/spec/fixtures/slack/web/conversations_setTopic_one_page.yml +142 -0
  152. data/spec/fixtures/slack/web/conversations_setTopic_paginated.yml +208 -0
  153. data/spec/fixtures/slack/web/views_open_error.yml +76 -0
  154. data/spec/slack/events/request_spec.rb +13 -8
  155. data/spec/slack/real_time/client_spec.rb +18 -1
  156. data/spec/slack/real_time/concurrency/with_concurrency_spec.rb +10 -0
  157. data/spec/slack/real_time/concurrency/without_concurrency_spec.rb +10 -0
  158. data/spec/slack/real_time/rtm_connect_spec.rb +1 -1
  159. data/spec/slack/real_time/rtm_start_spec.rb +1 -1
  160. data/spec/slack/web/api/endpoints/admin_analytics_spec.rb +13 -0
  161. data/spec/slack/web/api/endpoints/admin_apps_approved_spec.rb +8 -0
  162. data/spec/slack/web/api/endpoints/admin_apps_restricted_spec.rb +8 -0
  163. data/spec/slack/web/api/endpoints/admin_apps_spec.rb +5 -0
  164. data/spec/slack/web/api/endpoints/admin_barriers_spec.rb +38 -0
  165. data/spec/slack/web/api/endpoints/admin_conversations_ekm_spec.rb +8 -0
  166. data/spec/slack/web/api/endpoints/admin_conversations_restrictAccess_spec.rb +32 -0
  167. data/spec/slack/web/api/endpoints/admin_conversations_spec.rb +93 -0
  168. data/spec/slack/web/api/endpoints/admin_emoji_spec.rb +37 -0
  169. data/spec/slack/web/api/endpoints/admin_inviteRequests_approved_spec.rb +8 -0
  170. data/spec/slack/web/api/endpoints/admin_inviteRequests_denied_spec.rb +8 -0
  171. data/spec/slack/web/api/endpoints/admin_inviteRequests_spec.rb +18 -0
  172. data/spec/slack/web/api/endpoints/admin_teams_admins_spec.rb +13 -0
  173. data/spec/slack/web/api/endpoints/admin_teams_owners_spec.rb +13 -0
  174. data/spec/slack/web/api/endpoints/admin_teams_settings_spec.rb +53 -0
  175. data/spec/slack/web/api/endpoints/admin_teams_spec.rb +16 -0
  176. data/spec/slack/web/api/endpoints/admin_usergroups_spec.rb +37 -0
  177. data/spec/slack/web/api/endpoints/admin_users_session_spec.rb +8 -0
  178. data/spec/slack/web/api/endpoints/admin_users_spec.rb +67 -0
  179. data/spec/slack/web/api/endpoints/apps_connections_spec.rb +8 -0
  180. data/spec/slack/web/api/endpoints/apps_event_authorizations_spec.rb +13 -0
  181. data/spec/slack/web/api/endpoints/apps_permissions_spec.rb +2 -2
  182. data/spec/slack/web/api/endpoints/apps_permissions_users_spec.rb +3 -3
  183. data/spec/slack/web/api/endpoints/apps_spec.rb +2 -2
  184. data/spec/slack/web/api/endpoints/auth_teams_spec.rb +8 -0
  185. data/spec/slack/web/api/endpoints/calls_participants_spec.rb +24 -0
  186. data/spec/slack/web/api/endpoints/calls_spec.rb +31 -0
  187. data/spec/slack/web/api/endpoints/conversations_spec.rb +20 -12
  188. data/spec/slack/web/api/endpoints/custom_specs/conversations_spec.rb +13 -0
  189. data/spec/slack/web/api/endpoints/files_comments_spec.rb +2 -2
  190. data/spec/slack/web/api/endpoints/files_remote_spec.rb +3 -3
  191. data/spec/slack/web/api/endpoints/files_spec.rb +4 -4
  192. data/spec/slack/web/api/endpoints/im_spec.rb +0 -31
  193. data/spec/slack/web/api/endpoints/mpim_spec.rb +0 -31
  194. data/spec/slack/web/api/endpoints/oauth_spec.rb +3 -14
  195. data/spec/slack/web/api/endpoints/pins_spec.rb +1 -4
  196. data/spec/slack/web/api/endpoints/reactions_spec.rb +3 -3
  197. data/spec/slack/web/api/endpoints/reminders_spec.rb +2 -2
  198. data/spec/slack/web/api/endpoints/usergroups_users_spec.rb +2 -2
  199. data/spec/slack/web/api/endpoints/workflows_spec.rb +26 -0
  200. data/spec/slack/web/api/errors/slack_error_spec.rb +22 -0
  201. data/spec/slack/web/api/mixins/channels_spec.rb +1 -1
  202. data/spec/slack/web/api/mixins/conversations_list_spec.rb +21 -0
  203. data/spec/slack/web/api/mixins/conversations_spec.rb +43 -0
  204. data/spec/slack/web/api/mixins/groups_spec.rb +1 -1
  205. data/spec/slack/web/api/mixins/users_spec.rb +1 -1
  206. data/spec/slack/web/client_spec.rb +121 -0
  207. data/spec/slack/web/faraday/response/raise_error_spec.rb +33 -9
  208. data/spec/support/vcr.rb +4 -0
  209. metadata +145 -55
  210. data/examples/hi_real_time/Gemfile +0 -6
  211. data/examples/hi_real_time/hi.gif +0 -0
  212. data/examples/hi_real_time/hi.rb +0 -41
  213. data/examples/hi_real_time_async_celluloid/Gemfile +0 -7
  214. data/examples/hi_real_time_async_celluloid/Procfile +0 -2
  215. data/examples/hi_real_time_async_celluloid/hi.rb +0 -39
  216. data/examples/hi_real_time_async_eventmachine/Gemfile +0 -7
  217. data/examples/hi_real_time_async_eventmachine/Procfile +0 -2
  218. data/examples/hi_real_time_async_eventmachine/hi.rb +0 -39
  219. data/lib/slack/real_time/concurrency/celluloid.rb +0 -142
  220. data/lib/slack/real_time/concurrency/eventmachine.rb +0 -85
  221. data/lib/slack/web/api/patches/chat.1.text-attachments-required.patch +0 -13
  222. data/lib/slack/web/api/patches/chat.2.attachments-json.patch +0 -17
  223. data/lib/slack/web/api/patches/chat.3.update-attachments-support.patch +0 -21
  224. data/lib/slack/web/api/patches/chat.4.postEphemeral-attachments-support.patch +0 -17
  225. data/lib/slack/web/api/patches/chat.5.postEphemeral-text-or-attachments.patch +0 -15
  226. data/spec/slack/real_time/concurrency/celluloid_spec.rb +0 -116
  227. data/spec/slack/real_time/concurrency/eventmachine_spec.rb +0 -57
  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/views_spec.rb +0 -29
  231. data/spec/slack/web/api/errors/service_unavailable_spec.rb +0 -17
@@ -0,0 +1,35 @@
1
+ # frozen_string_literal: true
2
+ # This file was auto-generated by lib/tasks/web.rake
3
+
4
+ module Slack
5
+ module Web
6
+ module Api
7
+ module Endpoints
8
+ module AdminConversationsEkm
9
+ #
10
+ # List all disconnected channels—i.e., channels that were once connected to other workspaces and then disconnected—and the corresponding original channel IDs for key revocation with EKM.
11
+ #
12
+ # @option options [Object] :channel_ids
13
+ # A comma-separated list of channels to filter to.
14
+ # @option options [Object] :cursor
15
+ # Set cursor to next_cursor returned by the previous call to list items in the next page.
16
+ # @option options [Object] :limit
17
+ # The maximum number of items to return. Must be between 1 - 1000 both inclusive.
18
+ # @option options [Object] :team_ids
19
+ # A comma-separated list of the workspaces to which the channels you would like returned belong.
20
+ # @see https://api.slack.com/methods/admin.conversations.ekm.listOriginalConnectedChannelInfo
21
+ # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/admin.conversations.ekm/admin.conversations.ekm.listOriginalConnectedChannelInfo.json
22
+ def admin_conversations_ekm_listOriginalConnectedChannelInfo(options = {})
23
+ if block_given?
24
+ Pagination::Cursor.new(self, :admin_conversations_ekm_listOriginalConnectedChannelInfo, options).each do |page|
25
+ yield page
26
+ end
27
+ else
28
+ post('admin.conversations.ekm.listOriginalConnectedChannelInfo', options)
29
+ end
30
+ end
31
+ end
32
+ end
33
+ end
34
+ end
35
+ end
@@ -0,0 +1,61 @@
1
+ # frozen_string_literal: true
2
+ # This file was auto-generated by lib/tasks/web.rake
3
+
4
+ module Slack
5
+ module Web
6
+ module Api
7
+ module Endpoints
8
+ module AdminConversationsRestrictaccess
9
+ #
10
+ # Add an allowlist of IDP groups for accessing a channel
11
+ #
12
+ # @option options [Object] :channel_id
13
+ # The channel to link this group to.
14
+ # @option options [Object] :group_id
15
+ # The IDP Group ID to be an allowlist for the private channel.
16
+ # @option options [Object] :team_id
17
+ # The workspace where the channel exists. This argument is required for channels only tied to one workspace, and optional for channels that are shared across an organization.
18
+ # @see https://api.slack.com/methods/admin.conversations.restrictAccess.addGroup
19
+ # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/admin.conversations.restrictAccess/admin.conversations.restrictAccess.addGroup.json
20
+ def admin_conversations_restrictAccess_addGroup(options = {})
21
+ throw ArgumentError.new('Required arguments :channel_id missing') if options[:channel_id].nil?
22
+ throw ArgumentError.new('Required arguments :group_id missing') if options[:group_id].nil?
23
+ post('admin.conversations.restrictAccess.addGroup', options)
24
+ end
25
+
26
+ #
27
+ # List all IDP Groups linked to a channel
28
+ #
29
+ # @option options [Object] :channel_id
30
+ # .
31
+ # @option options [Object] :team_id
32
+ # The workspace where the channel exists. This argument is required for channels only tied to one workspace, and optional for channels that are shared across an organization.
33
+ # @see https://api.slack.com/methods/admin.conversations.restrictAccess.listGroups
34
+ # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/admin.conversations.restrictAccess/admin.conversations.restrictAccess.listGroups.json
35
+ def admin_conversations_restrictAccess_listGroups(options = {})
36
+ throw ArgumentError.new('Required arguments :channel_id missing') if options[:channel_id].nil?
37
+ post('admin.conversations.restrictAccess.listGroups', options)
38
+ end
39
+
40
+ #
41
+ # Remove a linked IDP group linked from a private channel
42
+ #
43
+ # @option options [Object] :channel_id
44
+ # The channel to remove the linked group from.
45
+ # @option options [Object] :group_id
46
+ # The IDP Group ID to remove from the private channel.
47
+ # @option options [Object] :team_id
48
+ # The workspace where the channel exists. This argument is required for channels only tied to one workspace, and optional for channels that are shared across an organization.
49
+ # @see https://api.slack.com/methods/admin.conversations.restrictAccess.removeGroup
50
+ # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/admin.conversations.restrictAccess/admin.conversations.restrictAccess.removeGroup.json
51
+ def admin_conversations_restrictAccess_removeGroup(options = {})
52
+ throw ArgumentError.new('Required arguments :channel_id missing') if options[:channel_id].nil?
53
+ throw ArgumentError.new('Required arguments :group_id missing') if options[:group_id].nil?
54
+ throw ArgumentError.new('Required arguments :team_id missing') if options[:team_id].nil?
55
+ post('admin.conversations.restrictAccess.removeGroup', options)
56
+ end
57
+ end
58
+ end
59
+ end
60
+ end
61
+ end
@@ -0,0 +1,64 @@
1
+ # frozen_string_literal: true
2
+ # This file was auto-generated by lib/tasks/web.rake
3
+
4
+ module Slack
5
+ module Web
6
+ module Api
7
+ module Endpoints
8
+ module AdminConversationsWhitelist
9
+ #
10
+ # Add an allowlist of IDP groups for accessing a channel
11
+ #
12
+ # @option options [Object] :channel_id
13
+ # The channel to whitelist a group for.
14
+ # @option options [Object] :group_id
15
+ # The IDP Group ID to whitelist for the private channel.
16
+ # @option options [Object] :team_id
17
+ # The workspace where the IDP Group and channel exist.
18
+ # @see https://api.slack.com/methods/admin.conversations.whitelist.add
19
+ # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/admin.conversations.whitelist/admin.conversations.whitelist.add.json
20
+ def admin_conversations_whitelist_add(options = {})
21
+ throw ArgumentError.new('Required arguments :channel_id missing') if options[:channel_id].nil?
22
+ throw ArgumentError.new('Required arguments :group_id missing') if options[:group_id].nil?
23
+ logger.warn('admin.conversations.whitelist.add: This method is deprecated Alternative methods: .')
24
+ post('admin.conversations.whitelist.add', options)
25
+ end
26
+
27
+ #
28
+ # List all IDP Groups linked to a channel
29
+ #
30
+ # @option options [Object] :channel_id
31
+ # .
32
+ # @option options [Object] :team_id
33
+ # The workspace where the channele exists. This argument is required for channels only tied to one workspace, and optional for channels that are shared across an organization.
34
+ # @see https://api.slack.com/methods/admin.conversations.whitelist.listGroupsLinkedToChannel
35
+ # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/admin.conversations.whitelist/admin.conversations.whitelist.listGroupsLinkedToChannel.json
36
+ def admin_conversations_whitelist_listGroupsLinkedToChannel(options = {})
37
+ throw ArgumentError.new('Required arguments :channel_id missing') if options[:channel_id].nil?
38
+ logger.warn('admin.conversations.whitelist.listGroupsLinkedToChannel: This method is deprecated Alternative methods: .')
39
+ post('admin.conversations.whitelist.listGroupsLinkedToChannel', options)
40
+ end
41
+
42
+ #
43
+ # Remove an allowlisted IDP group linked to a private channel
44
+ #
45
+ # @option options [Object] :channel_id
46
+ # The channel to remove a whitelisted group for.
47
+ # @option options [Object] :group_id
48
+ # The IDP Group ID to remove from the private channel whitelist.
49
+ # @option options [Object] :team_id
50
+ # The workspace where the IDP Group and channel exist.
51
+ # @see https://api.slack.com/methods/admin.conversations.whitelist.remove
52
+ # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/admin.conversations.whitelist/admin.conversations.whitelist.remove.json
53
+ def admin_conversations_whitelist_remove(options = {})
54
+ throw ArgumentError.new('Required arguments :channel_id missing') if options[:channel_id].nil?
55
+ throw ArgumentError.new('Required arguments :group_id missing') if options[:group_id].nil?
56
+ throw ArgumentError.new('Required arguments :team_id missing') if options[:team_id].nil?
57
+ logger.warn('admin.conversations.whitelist.remove: This method is deprecated Alternative methods: .')
58
+ post('admin.conversations.whitelist.remove', options)
59
+ end
60
+ end
61
+ end
62
+ end
63
+ end
64
+ end
@@ -0,0 +1,88 @@
1
+ # frozen_string_literal: true
2
+ # This file was auto-generated by lib/tasks/web.rake
3
+
4
+ module Slack
5
+ module Web
6
+ module Api
7
+ module Endpoints
8
+ module AdminEmoji
9
+ #
10
+ # Add an emoji.
11
+ #
12
+ # @option options [Object] :name
13
+ # The name of the emoji to be added. Colons (:myemoji:) around the value are not required, although they may be included.
14
+ # @option options [Object] :url
15
+ # The URL of a file to use as an image for the emoji. Square images under 128KB and with transparent backgrounds work best.
16
+ # @see https://api.slack.com/methods/admin.emoji.add
17
+ # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/admin.emoji/admin.emoji.add.json
18
+ def admin_emoji_add(options = {})
19
+ throw ArgumentError.new('Required arguments :name missing') if options[:name].nil?
20
+ throw ArgumentError.new('Required arguments :url missing') if options[:url].nil?
21
+ post('admin.emoji.add', options)
22
+ end
23
+
24
+ #
25
+ # Add an emoji alias.
26
+ #
27
+ # @option options [Object] :alias_for
28
+ # The alias of the emoji.
29
+ # @option options [Object] :name
30
+ # The name of the emoji to be aliased. Colons (:myemoji:) around the value are not required, although they may be included.
31
+ # @see https://api.slack.com/methods/admin.emoji.addAlias
32
+ # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/admin.emoji/admin.emoji.addAlias.json
33
+ def admin_emoji_addAlias(options = {})
34
+ throw ArgumentError.new('Required arguments :alias_for missing') if options[:alias_for].nil?
35
+ throw ArgumentError.new('Required arguments :name missing') if options[:name].nil?
36
+ post('admin.emoji.addAlias', options)
37
+ end
38
+
39
+ #
40
+ # List emoji for an Enterprise Grid organization.
41
+ #
42
+ # @option options [Object] :cursor
43
+ # Set cursor to next_cursor returned by the previous call to list items in the next page.
44
+ # @option options [Object] :limit
45
+ # The maximum number of items to return. Must be between 1 - 1000 both inclusive.
46
+ # @see https://api.slack.com/methods/admin.emoji.list
47
+ # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/admin.emoji/admin.emoji.list.json
48
+ def admin_emoji_list(options = {})
49
+ if block_given?
50
+ Pagination::Cursor.new(self, :admin_emoji_list, options).each do |page|
51
+ yield page
52
+ end
53
+ else
54
+ post('admin.emoji.list', options)
55
+ end
56
+ end
57
+
58
+ #
59
+ # Remove an emoji across an Enterprise Grid organization
60
+ #
61
+ # @option options [Object] :name
62
+ # The name of the emoji to be removed. Colons (:myemoji:) around the value are not required, although they may be included.
63
+ # @see https://api.slack.com/methods/admin.emoji.remove
64
+ # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/admin.emoji/admin.emoji.remove.json
65
+ def admin_emoji_remove(options = {})
66
+ throw ArgumentError.new('Required arguments :name missing') if options[:name].nil?
67
+ post('admin.emoji.remove', options)
68
+ end
69
+
70
+ #
71
+ # Rename an emoji.
72
+ #
73
+ # @option options [Object] :name
74
+ # The name of the emoji to be renamed. Colons (:myemoji:) around the value are not required, although they may be included.
75
+ # @option options [Object] :new_name
76
+ # The new name of the emoji.
77
+ # @see https://api.slack.com/methods/admin.emoji.rename
78
+ # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/admin.emoji/admin.emoji.rename.json
79
+ def admin_emoji_rename(options = {})
80
+ throw ArgumentError.new('Required arguments :name missing') if options[:name].nil?
81
+ throw ArgumentError.new('Required arguments :new_name missing') if options[:new_name].nil?
82
+ post('admin.emoji.rename', options)
83
+ end
84
+ end
85
+ end
86
+ end
87
+ end
88
+ end
@@ -0,0 +1,61 @@
1
+ # frozen_string_literal: true
2
+ # This file was auto-generated by lib/tasks/web.rake
3
+
4
+ module Slack
5
+ module Web
6
+ module Api
7
+ module Endpoints
8
+ module AdminInviterequests
9
+ #
10
+ # Approve a workspace invite request.
11
+ #
12
+ # @option options [Object] :invite_request_id
13
+ # ID of the request to invite.
14
+ # @option options [Object] :team_id
15
+ # ID for the workspace where the invite request was made.
16
+ # @see https://api.slack.com/methods/admin.inviteRequests.approve
17
+ # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/admin.inviteRequests/admin.inviteRequests.approve.json
18
+ def admin_inviteRequests_approve(options = {})
19
+ throw ArgumentError.new('Required arguments :invite_request_id missing') if options[:invite_request_id].nil?
20
+ post('admin.inviteRequests.approve', options)
21
+ end
22
+
23
+ #
24
+ # Deny a workspace invite request.
25
+ #
26
+ # @option options [Object] :invite_request_id
27
+ # ID of the request to invite.
28
+ # @option options [Object] :team_id
29
+ # ID for the workspace where the invite request was made.
30
+ # @see https://api.slack.com/methods/admin.inviteRequests.deny
31
+ # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/admin.inviteRequests/admin.inviteRequests.deny.json
32
+ def admin_inviteRequests_deny(options = {})
33
+ throw ArgumentError.new('Required arguments :invite_request_id missing') if options[:invite_request_id].nil?
34
+ post('admin.inviteRequests.deny', options)
35
+ end
36
+
37
+ #
38
+ # List all pending workspace invite requests.
39
+ #
40
+ # @option options [Object] :cursor
41
+ # Value of the next_cursor field sent as part of the previous API response.
42
+ # @option options [Object] :limit
43
+ # The number of results that will be returned by the API on each invocation. Must be between 1 - 1000, both inclusive.
44
+ # @option options [Object] :team_id
45
+ # ID for the workspace where the invite requests were made.
46
+ # @see https://api.slack.com/methods/admin.inviteRequests.list
47
+ # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/admin.inviteRequests/admin.inviteRequests.list.json
48
+ def admin_inviteRequests_list(options = {})
49
+ if block_given?
50
+ Pagination::Cursor.new(self, :admin_inviteRequests_list, options).each do |page|
51
+ yield page
52
+ end
53
+ else
54
+ post('admin.inviteRequests.list', options)
55
+ end
56
+ end
57
+ end
58
+ end
59
+ end
60
+ end
61
+ end
@@ -0,0 +1,33 @@
1
+ # frozen_string_literal: true
2
+ # This file was auto-generated by lib/tasks/web.rake
3
+
4
+ module Slack
5
+ module Web
6
+ module Api
7
+ module Endpoints
8
+ module AdminInviterequestsApproved
9
+ #
10
+ # List all approved workspace invite requests.
11
+ #
12
+ # @option options [Object] :cursor
13
+ # Value of the next_cursor field sent as part of the previous API response.
14
+ # @option options [Object] :limit
15
+ # The number of results that will be returned by the API on each invocation. Must be between 1 - 1000, both inclusive.
16
+ # @option options [Object] :team_id
17
+ # ID for the workspace where the invite requests were made.
18
+ # @see https://api.slack.com/methods/admin.inviteRequests.approved.list
19
+ # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/admin.inviteRequests.approved/admin.inviteRequests.approved.list.json
20
+ def admin_inviteRequests_approved_list(options = {})
21
+ if block_given?
22
+ Pagination::Cursor.new(self, :admin_inviteRequests_approved_list, options).each do |page|
23
+ yield page
24
+ end
25
+ else
26
+ post('admin.inviteRequests.approved.list', options)
27
+ end
28
+ end
29
+ end
30
+ end
31
+ end
32
+ end
33
+ end
@@ -0,0 +1,33 @@
1
+ # frozen_string_literal: true
2
+ # This file was auto-generated by lib/tasks/web.rake
3
+
4
+ module Slack
5
+ module Web
6
+ module Api
7
+ module Endpoints
8
+ module AdminInviterequestsDenied
9
+ #
10
+ # List all denied workspace invite requests.
11
+ #
12
+ # @option options [Object] :cursor
13
+ # Value of the next_cursor field sent as part of the previous api response.
14
+ # @option options [Object] :limit
15
+ # The number of results that will be returned by the API on each invocation. Must be between 1 - 1000 both inclusive.
16
+ # @option options [Object] :team_id
17
+ # ID for the workspace where the invite requests were made.
18
+ # @see https://api.slack.com/methods/admin.inviteRequests.denied.list
19
+ # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/admin.inviteRequests.denied/admin.inviteRequests.denied.list.json
20
+ def admin_inviteRequests_denied_list(options = {})
21
+ if block_given?
22
+ Pagination::Cursor.new(self, :admin_inviteRequests_denied_list, options).each do |page|
23
+ yield page
24
+ end
25
+ else
26
+ post('admin.inviteRequests.denied.list', options)
27
+ end
28
+ end
29
+ end
30
+ end
31
+ end
32
+ end
33
+ end
@@ -0,0 +1,50 @@
1
+ # frozen_string_literal: true
2
+ # This file was auto-generated by lib/tasks/web.rake
3
+
4
+ module Slack
5
+ module Web
6
+ module Api
7
+ module Endpoints
8
+ module AdminTeams
9
+ #
10
+ # Create an Enterprise team.
11
+ #
12
+ # @option options [Object] :team_domain
13
+ # Team domain (for example, slacksoftballteam). Domains are limited to 21 characters.
14
+ # @option options [Object] :team_name
15
+ # Team name (for example, Slack Softball Team).
16
+ # @option options [Object] :team_description
17
+ # Description for the team.
18
+ # @option options [Object] :team_discoverability
19
+ # Who can join the team. A team's discoverability can be open, closed, invite_only, or unlisted.
20
+ # @see https://api.slack.com/methods/admin.teams.create
21
+ # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/admin.teams/admin.teams.create.json
22
+ def admin_teams_create(options = {})
23
+ throw ArgumentError.new('Required arguments :team_domain missing') if options[:team_domain].nil?
24
+ throw ArgumentError.new('Required arguments :team_name missing') if options[:team_name].nil?
25
+ post('admin.teams.create', options)
26
+ end
27
+
28
+ #
29
+ # List all teams on an Enterprise organization
30
+ #
31
+ # @option options [Object] :cursor
32
+ # Set cursor to next_cursor returned by the previous call to list items in the next page.
33
+ # @option options [Object] :limit
34
+ # The maximum number of items to return. Must be between 1 - 100 both inclusive.
35
+ # @see https://api.slack.com/methods/admin.teams.list
36
+ # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/admin.teams/admin.teams.list.json
37
+ def admin_teams_list(options = {})
38
+ if block_given?
39
+ Pagination::Cursor.new(self, :admin_teams_list, options).each do |page|
40
+ yield page
41
+ end
42
+ else
43
+ post('admin.teams.list', options)
44
+ end
45
+ end
46
+ end
47
+ end
48
+ end
49
+ end
50
+ end
@@ -0,0 +1,34 @@
1
+ # frozen_string_literal: true
2
+ # This file was auto-generated by lib/tasks/web.rake
3
+
4
+ module Slack
5
+ module Web
6
+ module Api
7
+ module Endpoints
8
+ module AdminTeamsAdmins
9
+ #
10
+ # List all of the admins on a given workspace.
11
+ #
12
+ # @option options [Object] :team_id
13
+ # .
14
+ # @option options [Object] :cursor
15
+ # Set cursor to next_cursor returned by the previous call to list items in the next page.
16
+ # @option options [Object] :limit
17
+ # The maximum number of items to return.
18
+ # @see https://api.slack.com/methods/admin.teams.admins.list
19
+ # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/admin.teams.admins/admin.teams.admins.list.json
20
+ def admin_teams_admins_list(options = {})
21
+ throw ArgumentError.new('Required arguments :team_id missing') if options[:team_id].nil?
22
+ if block_given?
23
+ Pagination::Cursor.new(self, :admin_teams_admins_list, options).each do |page|
24
+ yield page
25
+ end
26
+ else
27
+ post('admin.teams.admins.list', options)
28
+ end
29
+ end
30
+ end
31
+ end
32
+ end
33
+ end
34
+ end