slack-ruby-client 0.7.9 → 0.16.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (358) hide show
  1. checksums.yaml +5 -5
  2. data/.github/FUNDING.yml +1 -0
  3. data/.gitignore +2 -0
  4. data/.rubocop.yml +32 -1
  5. data/.rubocop_todo.yml +98 -49
  6. data/.travis.yml +10 -14
  7. data/CHANGELOG.md +172 -24
  8. data/CONTRIBUTING.md +17 -6
  9. data/Dangerfile +2 -0
  10. data/Gemfile +10 -4
  11. data/LICENSE.md +1 -1
  12. data/README.md +276 -54
  13. data/RELEASING.md +19 -11
  14. data/Rakefile +2 -1
  15. data/UPGRADING.md +84 -2
  16. data/bin/commands.rb +43 -1
  17. data/bin/commands/admin_analytics.rb +15 -0
  18. data/bin/commands/admin_apps.rb +40 -0
  19. data/bin/commands/admin_apps_approved.rb +17 -0
  20. data/bin/commands/admin_apps_requests.rb +16 -0
  21. data/bin/commands/admin_apps_restricted.rb +17 -0
  22. data/bin/commands/admin_barriers.rb +47 -0
  23. data/bin/commands/admin_conversations.rb +169 -0
  24. data/bin/commands/admin_conversations_ekm.rb +17 -0
  25. data/bin/commands/admin_conversations_restrictAccess.rb +37 -0
  26. data/bin/commands/admin_conversations_whitelist.rb +37 -0
  27. data/bin/commands/admin_emoji.rb +54 -0
  28. data/bin/commands/admin_inviteRequests.rb +36 -0
  29. data/bin/commands/admin_inviteRequests_approved.rb +16 -0
  30. data/bin/commands/admin_inviteRequests_denied.rb +16 -0
  31. data/bin/commands/admin_teams.rb +27 -0
  32. data/bin/commands/admin_teams_admins.rb +16 -0
  33. data/bin/commands/admin_teams_owners.rb +16 -0
  34. data/bin/commands/admin_teams_settings.rb +64 -0
  35. data/bin/commands/admin_usergroups.rb +48 -0
  36. data/bin/commands/admin_users.rb +97 -0
  37. data/bin/commands/admin_users_session.rb +38 -0
  38. data/bin/commands/api.rb +3 -3
  39. data/bin/commands/apps.rb +15 -0
  40. data/bin/commands/apps_connections.rb +13 -0
  41. data/bin/commands/apps_event_authorizations.rb +16 -0
  42. data/bin/commands/apps_permissions.rb +23 -0
  43. data/bin/commands/apps_permissions_resources.rb +15 -0
  44. data/bin/commands/apps_permissions_scopes.rb +13 -0
  45. data/bin/commands/apps_permissions_users.rb +26 -0
  46. data/bin/commands/auth.rb +5 -4
  47. data/bin/commands/auth_teams.rb +16 -0
  48. data/bin/commands/bots.rb +4 -2
  49. data/bin/commands/calls.rb +52 -0
  50. data/bin/commands/calls_participants.rb +25 -0
  51. data/bin/commands/channels.rb +64 -43
  52. data/bin/commands/chat.rb +114 -24
  53. data/bin/commands/chat_scheduledMessages.rb +19 -0
  54. data/bin/commands/conversations.rb +196 -0
  55. data/bin/commands/dialog.rb +15 -0
  56. data/bin/commands/dnd.rb +9 -8
  57. data/bin/commands/emoji.rb +3 -2
  58. data/bin/commands/files.rb +45 -30
  59. data/bin/commands/files_comments.rb +3 -24
  60. data/bin/commands/files_remote.rb +78 -0
  61. data/bin/commands/groups.rb +53 -53
  62. data/bin/commands/im.rb +17 -13
  63. data/bin/commands/migration.rb +16 -0
  64. data/bin/commands/mpim.rb +16 -13
  65. data/bin/commands/oauth.rb +17 -2
  66. data/bin/commands/oauth_v2.rb +17 -0
  67. data/bin/commands/pins.rb +7 -10
  68. data/bin/commands/reactions.rb +17 -15
  69. data/bin/commands/reminders.rb +11 -10
  70. data/bin/commands/rtm.rb +19 -4
  71. data/bin/commands/search.rb +15 -11
  72. data/bin/commands/stars.rb +11 -8
  73. data/bin/commands/team.rb +15 -10
  74. data/bin/commands/team_profile.rb +3 -2
  75. data/bin/commands/usergroups.rb +22 -16
  76. data/bin/commands/usergroups_users.rb +7 -4
  77. data/bin/commands/users.rb +65 -37
  78. data/bin/commands/users_admin.rb +29 -0
  79. data/bin/commands/users_prefs.rb +13 -0
  80. data/bin/commands/users_profile.rb +8 -7
  81. data/bin/commands/views.rb +48 -0
  82. data/bin/commands/workflows.rb +38 -0
  83. data/bin/slack +3 -4
  84. data/examples/hi_real_time_and_web/Gemfile +1 -0
  85. data/examples/hi_real_time_and_web/hi.rb +8 -4
  86. data/examples/{hi_real_time_async_eventmachine → hi_real_time_async_async}/Gemfile +2 -1
  87. data/examples/{hi_real_time_async_celluloid → hi_real_time_async_async}/Procfile +0 -0
  88. data/examples/{hi_real_time_async_celluloid → hi_real_time_async_async}/hi.rb +13 -8
  89. data/examples/hi_web/Gemfile +1 -0
  90. data/examples/hi_web/hi.rb +2 -1
  91. data/examples/new_ticket/Gemfile +1 -0
  92. data/examples/new_ticket/new_ticket.rb +2 -1
  93. data/lib/slack-ruby-client.rb +40 -26
  94. data/lib/slack.rb +1 -0
  95. data/lib/slack/config.rb +1 -0
  96. data/lib/slack/events/config.rb +32 -0
  97. data/lib/slack/events/request.rb +70 -0
  98. data/lib/slack/logger.rb +6 -5
  99. data/lib/slack/messages/formatting.rb +4 -4
  100. data/lib/slack/messages/message.rb +2 -6
  101. data/lib/slack/real_time/api/message.rb +3 -1
  102. data/lib/slack/real_time/api/message_id.rb +1 -0
  103. data/lib/slack/real_time/api/ping.rb +5 -2
  104. data/lib/slack/real_time/api/templates/event_handler.erb +1 -1
  105. data/lib/slack/real_time/api/typing.rb +3 -1
  106. data/lib/slack/real_time/client.rb +113 -32
  107. data/lib/slack/real_time/concurrency.rb +2 -2
  108. data/lib/slack/real_time/concurrency/async.rb +140 -0
  109. data/lib/slack/real_time/config.rb +20 -12
  110. data/lib/slack/real_time/models.rb +8 -7
  111. data/lib/slack/real_time/models/base.rb +2 -6
  112. data/lib/slack/real_time/models/bot.rb +1 -0
  113. data/lib/slack/real_time/models/channel.rb +1 -0
  114. data/lib/slack/real_time/models/group.rb +1 -0
  115. data/lib/slack/real_time/models/im.rb +1 -0
  116. data/lib/slack/real_time/models/team.rb +1 -0
  117. data/lib/slack/real_time/models/user.rb +1 -0
  118. data/lib/slack/real_time/socket.rb +46 -17
  119. data/lib/slack/real_time/stores.rb +4 -3
  120. data/lib/slack/real_time/stores/base.rb +5 -3
  121. data/lib/slack/real_time/stores/starter.rb +113 -72
  122. data/lib/slack/real_time/stores/store.rb +131 -88
  123. data/lib/slack/version.rb +2 -1
  124. data/lib/slack/web/api/endpoints.rb +110 -26
  125. data/lib/slack/web/api/endpoints/admin_analytics.rb +26 -0
  126. data/lib/slack/web/api/endpoints/admin_apps.rb +62 -0
  127. data/lib/slack/web/api/endpoints/admin_apps_approved.rb +35 -0
  128. data/lib/slack/web/api/endpoints/admin_apps_requests.rb +33 -0
  129. data/lib/slack/web/api/endpoints/admin_apps_restricted.rb +35 -0
  130. data/lib/slack/web/api/endpoints/admin_barriers.rb +82 -0
  131. data/lib/slack/web/api/endpoints/admin_conversations.rb +260 -0
  132. data/lib/slack/web/api/endpoints/admin_conversations_ekm.rb +35 -0
  133. data/lib/slack/web/api/endpoints/admin_conversations_restrictAccess.rb +61 -0
  134. data/lib/slack/web/api/endpoints/admin_conversations_whitelist.rb +64 -0
  135. data/lib/slack/web/api/endpoints/admin_emoji.rb +88 -0
  136. data/lib/slack/web/api/endpoints/admin_inviteRequests.rb +61 -0
  137. data/lib/slack/web/api/endpoints/admin_inviteRequests_approved.rb +33 -0
  138. data/lib/slack/web/api/endpoints/admin_inviteRequests_denied.rb +33 -0
  139. data/lib/slack/web/api/endpoints/admin_teams.rb +50 -0
  140. data/lib/slack/web/api/endpoints/admin_teams_admins.rb +34 -0
  141. data/lib/slack/web/api/endpoints/admin_teams_owners.rb +34 -0
  142. data/lib/slack/web/api/endpoints/admin_teams_settings.rb +99 -0
  143. data/lib/slack/web/api/endpoints/admin_usergroups.rb +77 -0
  144. data/lib/slack/web/api/endpoints/admin_users.rb +161 -0
  145. data/lib/slack/web/api/endpoints/admin_users_session.rb +66 -0
  146. data/lib/slack/web/api/endpoints/api.rb +3 -4
  147. data/lib/slack/web/api/endpoints/apps.rb +27 -0
  148. data/lib/slack/web/api/endpoints/apps_connections.rb +21 -0
  149. data/lib/slack/web/api/endpoints/apps_event_authorizations.rb +34 -0
  150. data/lib/slack/web/api/endpoints/apps_permissions.rb +36 -0
  151. data/lib/slack/web/api/endpoints/apps_permissions_resources.rb +31 -0
  152. data/lib/slack/web/api/endpoints/apps_permissions_scopes.rb +21 -0
  153. data/lib/slack/web/api/endpoints/apps_permissions_users.rb +50 -0
  154. data/lib/slack/web/api/endpoints/auth.rb +5 -4
  155. data/lib/slack/web/api/endpoints/auth_teams.rb +33 -0
  156. data/lib/slack/web/api/endpoints/bots.rb +5 -2
  157. data/lib/slack/web/api/endpoints/calls.rb +83 -0
  158. data/lib/slack/web/api/endpoints/calls_participants.rb +42 -0
  159. data/lib/slack/web/api/endpoints/channels.rb +105 -49
  160. data/lib/slack/web/api/endpoints/chat.rb +221 -40
  161. data/lib/slack/web/api/endpoints/chat_scheduledMessages.rb +40 -0
  162. data/lib/slack/web/api/endpoints/conversations.rb +332 -0
  163. data/lib/slack/web/api/endpoints/dialog.rb +33 -0
  164. data/lib/slack/web/api/endpoints/dnd.rb +11 -9
  165. data/lib/slack/web/api/endpoints/emoji.rb +3 -2
  166. data/lib/slack/web/api/endpoints/files.rb +75 -38
  167. data/lib/slack/web/api/endpoints/files_comments.rb +3 -38
  168. data/lib/slack/web/api/endpoints/files_remote.rb +127 -0
  169. data/lib/slack/web/api/endpoints/groups.rb +76 -53
  170. data/lib/slack/web/api/endpoints/im.rb +38 -21
  171. data/lib/slack/web/api/endpoints/migration.rb +28 -0
  172. data/lib/slack/web/api/endpoints/mpim.rb +37 -22
  173. data/lib/slack/web/api/endpoints/oauth.rb +25 -4
  174. data/lib/slack/web/api/endpoints/oauth_v2.rb +30 -0
  175. data/lib/slack/web/api/endpoints/pins.rb +10 -19
  176. data/lib/slack/web/api/endpoints/presence.rb +1 -1
  177. data/lib/slack/web/api/endpoints/reactions.rb +37 -28
  178. data/lib/slack/web/api/endpoints/reminders.rb +11 -10
  179. data/lib/slack/web/api/endpoints/rtm.rb +28 -7
  180. data/lib/slack/web/api/endpoints/search.rb +21 -14
  181. data/lib/slack/web/api/endpoints/stars.rb +24 -15
  182. data/lib/slack/web/api/endpoints/team.rb +21 -13
  183. data/lib/slack/web/api/endpoints/team_profile.rb +3 -2
  184. data/lib/slack/web/api/endpoints/usergroups.rb +33 -22
  185. data/lib/slack/web/api/endpoints/usergroups_users.rb +9 -4
  186. data/lib/slack/web/api/endpoints/users.rb +78 -29
  187. data/lib/slack/web/api/endpoints/users_admin.rb +49 -0
  188. data/lib/slack/web/api/endpoints/users_prefs.rb +21 -0
  189. data/lib/slack/web/api/endpoints/users_profile.rb +11 -10
  190. data/lib/slack/web/api/endpoints/views.rb +97 -0
  191. data/lib/slack/web/api/endpoints/workflows.rb +61 -0
  192. data/lib/slack/web/api/error.rb +2 -8
  193. data/lib/slack/web/api/errors.rb +850 -0
  194. data/lib/slack/web/api/errors/internal_error.rb +14 -0
  195. data/lib/slack/web/api/errors/slack_error.rb +29 -0
  196. data/lib/slack/web/api/errors/too_many_requests_error.rb +24 -0
  197. data/lib/slack/web/api/mixins.rb +6 -4
  198. data/lib/slack/web/api/mixins/channels.id.rb +6 -7
  199. data/lib/slack/web/api/mixins/conversations.id.rb +25 -0
  200. data/lib/slack/web/api/mixins/groups.id.rb +6 -7
  201. data/lib/slack/web/api/mixins/ids.id.rb +24 -0
  202. data/lib/slack/web/api/mixins/users.id.rb +6 -7
  203. data/lib/slack/web/api/mixins/users.search.rb +39 -36
  204. data/lib/slack/web/api/patches/chat.1.patch +72 -0
  205. data/lib/slack/web/api/patches/dialog.1.open-json-support.patch +17 -0
  206. data/lib/slack/web/api/patches/views.1.view-json.patch +40 -0
  207. data/lib/slack/web/api/patches/views.1.views-published.patch +16 -0
  208. data/lib/slack/web/api/templates/command.erb +5 -3
  209. data/lib/slack/web/api/templates/commands.erb +2 -1
  210. data/lib/slack/web/api/templates/endpoints.erb +5 -3
  211. data/lib/slack/web/api/templates/errors.erb +20 -0
  212. data/lib/slack/web/api/templates/method.erb +26 -4
  213. data/lib/slack/web/api/templates/method_spec.erb +3 -2
  214. data/lib/slack/web/client.rb +2 -1
  215. data/lib/slack/web/config.rb +21 -10
  216. data/lib/slack/web/faraday/connection.rb +25 -16
  217. data/lib/slack/web/faraday/request.rb +2 -0
  218. data/lib/slack/web/faraday/response/raise_error.rb +23 -1
  219. data/lib/slack/web/faraday/response/wrap_error.rb +18 -0
  220. data/lib/slack/web/pagination/cursor.rb +52 -0
  221. data/lib/slack_ruby_client.rb +1 -0
  222. data/lib/tasks/git.rake +2 -1
  223. data/lib/tasks/real_time.rake +16 -6
  224. data/lib/tasks/update.rake +1 -0
  225. data/lib/tasks/web.rake +38 -10
  226. data/screenshots/create-app.png +0 -0
  227. data/slack-ruby-client.gemspec +9 -6
  228. data/spec/fixtures/slack/web/429_error.yml +2 -0
  229. data/spec/fixtures/slack/web/503_error.yml +14 -0
  230. data/spec/fixtures/slack/web/channels_info.yml +108 -15
  231. data/spec/fixtures/slack/web/conversations_setTopic.yml +69 -0
  232. data/spec/fixtures/slack/web/conversations_setTopic_one_page.yml +142 -0
  233. data/spec/fixtures/slack/web/conversations_setTopic_paginated.yml +208 -0
  234. data/spec/fixtures/slack/web/paginated_users_list.yml +181 -0
  235. data/spec/fixtures/slack/web/rtm_connect.yml +70 -0
  236. data/spec/fixtures/slack/web/rtm_start.yml +1 -1
  237. data/spec/fixtures/slack/web/views_open_error.yml +76 -0
  238. data/spec/integration/integration_spec.rb +116 -48
  239. data/spec/slack/config_spec.rb +2 -0
  240. data/spec/slack/events/config_spec.rb +33 -0
  241. data/spec/slack/events/request_spec.rb +183 -0
  242. data/spec/slack/messages/formatting_spec.rb +25 -14
  243. data/spec/slack/real_time/api/message_spec.rb +6 -1
  244. data/spec/slack/real_time/api/ping_spec.rb +2 -0
  245. data/spec/slack/real_time/api/typing_spec.rb +5 -1
  246. data/spec/slack/real_time/client_spec.rb +462 -134
  247. data/spec/slack/real_time/concurrency/it_behaves_like_a_realtime_socket.rb +3 -1
  248. data/spec/slack/real_time/event_handlers/bot_spec.rb +6 -3
  249. data/spec/slack/real_time/event_handlers/channel_spec.rb +9 -6
  250. data/spec/slack/real_time/event_handlers/event_handlers_spec.rb +3 -2
  251. data/spec/slack/real_time/event_handlers/group_spec.rb +5 -4
  252. data/spec/slack/real_time/event_handlers/im_spec.rb +4 -3
  253. data/spec/slack/real_time/event_handlers/team_spec.rb +8 -4
  254. data/spec/slack/real_time/event_handlers/user_spec.rb +5 -2
  255. data/spec/slack/real_time/rtm_connect_spec.rb +14 -0
  256. data/spec/slack/real_time/rtm_start_spec.rb +1 -0
  257. data/spec/slack/real_time/store_spec.rb +2 -1
  258. data/spec/slack/slack_spec.rb +39 -7
  259. data/spec/slack/version_spec.rb +2 -1
  260. data/spec/slack/web/api/endpoints/admin_analytics_spec.rb +13 -0
  261. data/spec/slack/web/api/endpoints/admin_apps_approved_spec.rb +8 -0
  262. data/spec/slack/web/api/endpoints/admin_apps_requests_spec.rb +8 -0
  263. data/spec/slack/web/api/endpoints/admin_apps_restricted_spec.rb +8 -0
  264. data/spec/slack/web/api/endpoints/admin_apps_spec.rb +13 -0
  265. data/spec/slack/web/api/endpoints/admin_barriers_spec.rb +38 -0
  266. data/spec/slack/web/api/endpoints/admin_conversations_ekm_spec.rb +8 -0
  267. data/spec/slack/web/api/endpoints/admin_conversations_restrictAccess_spec.rb +32 -0
  268. data/spec/slack/web/api/endpoints/admin_conversations_spec.rb +98 -0
  269. data/spec/slack/web/api/endpoints/admin_conversations_whitelist_spec.rb +32 -0
  270. data/spec/slack/web/api/endpoints/admin_emoji_spec.rb +37 -0
  271. data/spec/slack/web/api/endpoints/admin_inviteRequests_approved_spec.rb +8 -0
  272. data/spec/slack/web/api/endpoints/admin_inviteRequests_denied_spec.rb +8 -0
  273. data/spec/slack/web/api/endpoints/admin_inviteRequests_spec.rb +18 -0
  274. data/spec/slack/web/api/endpoints/admin_teams_admins_spec.rb +13 -0
  275. data/spec/slack/web/api/endpoints/admin_teams_owners_spec.rb +13 -0
  276. data/spec/slack/web/api/endpoints/admin_teams_settings_spec.rb +53 -0
  277. data/spec/slack/web/api/endpoints/admin_teams_spec.rb +16 -0
  278. data/spec/slack/web/api/endpoints/admin_usergroups_spec.rb +37 -0
  279. data/spec/slack/web/api/endpoints/admin_users_session_spec.rb +21 -0
  280. data/spec/slack/web/api/endpoints/admin_users_spec.rb +67 -0
  281. data/spec/slack/web/api/endpoints/api_spec.rb +1 -0
  282. data/spec/slack/web/api/endpoints/apps_connections_spec.rb +8 -0
  283. data/spec/slack/web/api/endpoints/apps_event_authorizations_spec.rb +13 -0
  284. data/spec/slack/web/api/endpoints/apps_permissions_resources_spec.rb +8 -0
  285. data/spec/slack/web/api/endpoints/apps_permissions_scopes_spec.rb +8 -0
  286. data/spec/slack/web/api/endpoints/apps_permissions_spec.rb +16 -0
  287. data/spec/slack/web/api/endpoints/apps_permissions_users_spec.rb +19 -0
  288. data/spec/slack/web/api/endpoints/apps_spec.rb +16 -0
  289. data/spec/slack/web/api/endpoints/auth_teams_spec.rb +8 -0
  290. data/spec/slack/web/api/endpoints/bots_spec.rb +1 -0
  291. data/spec/slack/web/api/endpoints/calls_participants_spec.rb +24 -0
  292. data/spec/slack/web/api/endpoints/calls_spec.rb +31 -0
  293. data/spec/slack/web/api/endpoints/chat_scheduledMessages_spec.rb +8 -0
  294. data/spec/slack/web/api/endpoints/conversations_spec.rb +109 -0
  295. data/spec/slack/web/api/endpoints/custom_specs/auth_spec.rb +13 -4
  296. data/spec/slack/web/api/endpoints/custom_specs/channels_spec.rb +5 -3
  297. data/spec/slack/web/api/endpoints/custom_specs/chat_spec.rb +140 -24
  298. data/spec/slack/web/api/endpoints/custom_specs/dialog_spec.rb +36 -0
  299. data/spec/slack/web/api/endpoints/custom_specs/groups_spec.rb +2 -0
  300. data/spec/slack/web/api/endpoints/custom_specs/users_spec.rb +21 -6
  301. data/spec/slack/web/api/endpoints/custom_specs/views_spec.rb +95 -0
  302. data/spec/slack/web/api/endpoints/dnd_spec.rb +6 -0
  303. data/spec/slack/web/api/endpoints/emoji_spec.rb +1 -0
  304. data/spec/slack/web/api/endpoints/files_comments_spec.rb +3 -21
  305. data/spec/slack/web/api/endpoints/files_remote_spec.rb +24 -0
  306. data/spec/slack/web/api/endpoints/files_spec.rb +17 -5
  307. data/spec/slack/web/api/endpoints/im_spec.rb +5 -4
  308. data/spec/slack/web/api/endpoints/migration_spec.rb +13 -0
  309. data/spec/slack/web/api/endpoints/mpim_spec.rb +5 -4
  310. data/spec/slack/web/api/endpoints/oauth_spec.rb +5 -4
  311. data/spec/slack/web/api/endpoints/oauth_v2_spec.rb +13 -0
  312. data/spec/slack/web/api/endpoints/pins_spec.rb +1 -0
  313. data/spec/slack/web/api/endpoints/reactions_spec.rb +8 -1
  314. data/spec/slack/web/api/endpoints/reminders_spec.rb +3 -2
  315. data/spec/slack/web/api/endpoints/rtm_spec.rb +1 -0
  316. data/spec/slack/web/api/endpoints/search_spec.rb +1 -0
  317. data/spec/slack/web/api/endpoints/stars_spec.rb +1 -0
  318. data/spec/slack/web/api/endpoints/team_profile_spec.rb +1 -0
  319. data/spec/slack/web/api/endpoints/team_spec.rb +1 -0
  320. data/spec/slack/web/api/endpoints/usergroups_spec.rb +1 -0
  321. data/spec/slack/web/api/endpoints/usergroups_users_spec.rb +3 -2
  322. data/spec/slack/web/api/endpoints/users_admin_spec.rb +18 -0
  323. data/spec/slack/web/api/endpoints/users_prefs_spec.rb +8 -0
  324. data/spec/slack/web/api/endpoints/users_profile_spec.rb +1 -0
  325. data/spec/slack/web/api/endpoints/views_spec.rb +29 -0
  326. data/spec/slack/web/api/endpoints/workflows_spec.rb +26 -0
  327. data/spec/slack/web/api/error_spec.rb +5 -3
  328. data/spec/slack/web/api/errors/slack_error_spec.rb +38 -0
  329. data/spec/slack/web/api/mixins/channels_spec.rb +24 -12
  330. data/spec/slack/web/api/mixins/conversations_list_spec.rb +21 -0
  331. data/spec/slack/web/api/mixins/conversations_spec.rb +43 -0
  332. data/spec/slack/web/api/mixins/groups_spec.rb +24 -12
  333. data/spec/slack/web/api/mixins/users_spec.rb +30 -17
  334. data/spec/slack/web/api/pagination/cursor_spec.rb +100 -0
  335. data/spec/slack/web/client_spec.rb +215 -14
  336. data/spec/slack/web/faraday/response/raise_error_spec.rb +85 -0
  337. data/spec/spec_helper.rb +8 -1
  338. data/spec/support/queue_with_timeout.rb +6 -5
  339. data/spec/support/real_time/concurrency/mock.rb +2 -2
  340. data/spec/support/real_time/connected_client.rb +13 -2
  341. data/spec/support/real_time/event.rb +1 -0
  342. data/spec/support/token.rb +1 -0
  343. data/spec/support/vcr.rb +6 -1
  344. metadata +280 -55
  345. data/examples/hi_real_time/Gemfile +0 -5
  346. data/examples/hi_real_time/hi.gif +0 -0
  347. data/examples/hi_real_time/hi.rb +0 -37
  348. data/examples/hi_real_time_async_celluloid/Gemfile +0 -6
  349. data/examples/hi_real_time_async_eventmachine/Procfile +0 -2
  350. data/examples/hi_real_time_async_eventmachine/hi.rb +0 -36
  351. data/lib/slack/real_time/concurrency/celluloid.rb +0 -113
  352. data/lib/slack/real_time/concurrency/eventmachine.rb +0 -60
  353. data/lib/slack/web/api/patches/chat.1.text-attachments-required.patch +0 -13
  354. data/lib/slack/web/api/patches/chat.2.attachments-json.patch +0 -17
  355. data/lib/slack/web/api/patches/chat.3.update-attachments-support.patch +0 -20
  356. data/screenshots/register-bot.png +0 -0
  357. data/spec/slack/real_time/concurrency/celluloid_spec.rb +0 -31
  358. data/spec/slack/real_time/concurrency/eventmachine_spec.rb +0 -47
@@ -0,0 +1,260 @@
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 AdminConversations
9
+ #
10
+ # Archive a public or private channel.
11
+ #
12
+ # @option options [Object] :channel_id
13
+ # The channel to archive.
14
+ # @see https://api.slack.com/methods/admin.conversations.archive
15
+ # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/admin.conversations/admin.conversations.archive.json
16
+ def admin_conversations_archive(options = {})
17
+ throw ArgumentError.new('Required arguments :channel_id missing') if options[:channel_id].nil?
18
+ post('admin.conversations.archive', options)
19
+ end
20
+
21
+ #
22
+ # Convert a public channel to a private channel.
23
+ #
24
+ # @option options [Object] :channel_id
25
+ # The channel to convert to private.
26
+ # @see https://api.slack.com/methods/admin.conversations.convertToPrivate
27
+ # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/admin.conversations/admin.conversations.convertToPrivate.json
28
+ def admin_conversations_convertToPrivate(options = {})
29
+ throw ArgumentError.new('Required arguments :channel_id missing') if options[:channel_id].nil?
30
+ post('admin.conversations.convertToPrivate', options)
31
+ end
32
+
33
+ #
34
+ # Create a public or private channel-based conversation.
35
+ #
36
+ # @option options [Object] :is_private
37
+ # When true, creates a private channel instead of a public channel.
38
+ # @option options [Object] :name
39
+ # Name of the public or private channel to create.
40
+ # @option options [Object] :description
41
+ # Description of the public or private channel to create.
42
+ # @option options [Object] :org_wide
43
+ # When true, the channel will be available org-wide. Note: if the channel is not org_wide=true, you must specify a team_id for this channel.
44
+ # @option options [Object] :team_id
45
+ # The workspace to create the channel in. Note: this argument is required unless you set org_wide=true.
46
+ # @see https://api.slack.com/methods/admin.conversations.create
47
+ # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/admin.conversations/admin.conversations.create.json
48
+ def admin_conversations_create(options = {})
49
+ throw ArgumentError.new('Required arguments :is_private missing') if options[:is_private].nil?
50
+ throw ArgumentError.new('Required arguments :name missing') if options[:name].nil?
51
+ post('admin.conversations.create', options)
52
+ end
53
+
54
+ #
55
+ # Delete a public or private channel.
56
+ #
57
+ # @option options [Object] :channel_id
58
+ # The channel to delete.
59
+ # @see https://api.slack.com/methods/admin.conversations.delete
60
+ # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/admin.conversations/admin.conversations.delete.json
61
+ def admin_conversations_delete(options = {})
62
+ throw ArgumentError.new('Required arguments :channel_id missing') if options[:channel_id].nil?
63
+ post('admin.conversations.delete', options)
64
+ end
65
+
66
+ #
67
+ # Disconnect a connected channel from one or more workspaces.
68
+ #
69
+ # @option options [Object] :channel_id
70
+ # The channel to be disconnected from some workspaces.
71
+ # @option options [Object] :leaving_team_ids
72
+ # The team to be removed from the channel. Currently only a single team id can be specified.
73
+ # @see https://api.slack.com/methods/admin.conversations.disconnectShared
74
+ # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/admin.conversations/admin.conversations.disconnectShared.json
75
+ def admin_conversations_disconnectShared(options = {})
76
+ throw ArgumentError.new('Required arguments :channel_id missing') if options[:channel_id].nil?
77
+ post('admin.conversations.disconnectShared', options)
78
+ end
79
+
80
+ #
81
+ # Get conversation preferences for a public or private channel.
82
+ #
83
+ # @option options [Object] :channel_id
84
+ # The channel to get preferences for.
85
+ # @see https://api.slack.com/methods/admin.conversations.getConversationPrefs
86
+ # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/admin.conversations/admin.conversations.getConversationPrefs.json
87
+ def admin_conversations_getConversationPrefs(options = {})
88
+ throw ArgumentError.new('Required arguments :channel_id missing') if options[:channel_id].nil?
89
+ post('admin.conversations.getConversationPrefs', options)
90
+ end
91
+
92
+ #
93
+ # This API endpoint can be used by any admin to get a channel's retention policy.
94
+ #
95
+ # @option options [Object] :channel_id
96
+ # The channel to get the retention policy for.
97
+ # @see https://api.slack.com/methods/admin.conversations.getCustomRetention
98
+ # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/admin.conversations/admin.conversations.getCustomRetention.json
99
+ def admin_conversations_getCustomRetention(options = {})
100
+ throw ArgumentError.new('Required arguments :channel_id missing') if options[:channel_id].nil?
101
+ post('admin.conversations.getCustomRetention', options)
102
+ end
103
+
104
+ #
105
+ # Get all the workspaces a given public or private channel is connected to within this Enterprise org.
106
+ #
107
+ # @option options [Object] :channel_id
108
+ # The channel to determine connected workspaces within the organization for.
109
+ # @option options [Object] :cursor
110
+ # Set cursor to next_cursor returned by the previous call to list items in the next page.
111
+ # @option options [Object] :limit
112
+ # The maximum number of items to return. Must be between 1 - 1000 both inclusive.
113
+ # @see https://api.slack.com/methods/admin.conversations.getTeams
114
+ # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/admin.conversations/admin.conversations.getTeams.json
115
+ def admin_conversations_getTeams(options = {})
116
+ throw ArgumentError.new('Required arguments :channel_id missing') if options[:channel_id].nil?
117
+ if block_given?
118
+ Pagination::Cursor.new(self, :admin_conversations_getTeams, options).each do |page|
119
+ yield page
120
+ end
121
+ else
122
+ post('admin.conversations.getTeams', options)
123
+ end
124
+ end
125
+
126
+ #
127
+ # Invite a user to a public or private channel.
128
+ #
129
+ # @option options [Object] :channel_id
130
+ # The channel that the users will be invited to.
131
+ # @option options [Object] :user_ids
132
+ # The users to invite.
133
+ # @see https://api.slack.com/methods/admin.conversations.invite
134
+ # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/admin.conversations/admin.conversations.invite.json
135
+ def admin_conversations_invite(options = {})
136
+ throw ArgumentError.new('Required arguments :channel_id missing') if options[:channel_id].nil?
137
+ throw ArgumentError.new('Required arguments :user_ids missing') if options[:user_ids].nil?
138
+ post('admin.conversations.invite', options)
139
+ end
140
+
141
+ #
142
+ # This API endpoint can be used by any admin to remove a channel's retention policy.
143
+ #
144
+ # @option options [Object] :channel_id
145
+ # The channel to set the retention policy for.
146
+ # @see https://api.slack.com/methods/admin.conversations.removeCustomRetention
147
+ # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/admin.conversations/admin.conversations.removeCustomRetention.json
148
+ def admin_conversations_removeCustomRetention(options = {})
149
+ throw ArgumentError.new('Required arguments :channel_id missing') if options[:channel_id].nil?
150
+ post('admin.conversations.removeCustomRetention', options)
151
+ end
152
+
153
+ #
154
+ # Rename a public or private channel.
155
+ #
156
+ # @option options [Object] :channel_id
157
+ # The channel to rename.
158
+ # @option options [Object] :name
159
+ # .
160
+ # @see https://api.slack.com/methods/admin.conversations.rename
161
+ # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/admin.conversations/admin.conversations.rename.json
162
+ def admin_conversations_rename(options = {})
163
+ throw ArgumentError.new('Required arguments :channel_id missing') if options[:channel_id].nil?
164
+ throw ArgumentError.new('Required arguments :name missing') if options[:name].nil?
165
+ post('admin.conversations.rename', options)
166
+ end
167
+
168
+ #
169
+ # Search for public or private channels in an Enterprise organization.
170
+ #
171
+ # @option options [Object] :cursor
172
+ # Set cursor to next_cursor returned by the previous call to list items in the next page.
173
+ # @option options [Object] :limit
174
+ # Maximum number of items to be returned. Must be between 1 - 20 both inclusive. Default is 10.
175
+ # @option options [Object] :query
176
+ # Name of the the channel to query by.
177
+ # @option options [Object] :search_channel_types
178
+ # The type of channel to include or exclude in the search. For example private will search private channels, while private_exclude will exclude them. For a full list of types, check the Types section.
179
+ # @option options [Object] :sort
180
+ # Possible values are relevant (search ranking based on what we think is closest), name (alphabetical), member_count (number of users in the channel), and created (date channel was created). You can optionally pair this with the sort_dir arg to change how it is sorted.
181
+ # @option options [Object] :sort_dir
182
+ # Sort direction. Possible values are asc for ascending order like (1, 2, 3) or (a, b, c), and desc for descending order like (3, 2, 1) or (c, b, a).
183
+ # @option options [Object] :team_ids
184
+ # Comma separated string of team IDs, signifying the workspaces to search through.
185
+ # @see https://api.slack.com/methods/admin.conversations.search
186
+ # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/admin.conversations/admin.conversations.search.json
187
+ def admin_conversations_search(options = {})
188
+ if block_given?
189
+ Pagination::Cursor.new(self, :admin_conversations_search, options).each do |page|
190
+ yield page
191
+ end
192
+ else
193
+ post('admin.conversations.search', options)
194
+ end
195
+ end
196
+
197
+ #
198
+ # Set the posting permissions for a public or private channel.
199
+ #
200
+ # @option options [Object] :channel_id
201
+ # The channel to set the prefs for.
202
+ # @option options [Object] :prefs
203
+ # The prefs for this channel in a stringified JSON format.
204
+ # @see https://api.slack.com/methods/admin.conversations.setConversationPrefs
205
+ # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/admin.conversations/admin.conversations.setConversationPrefs.json
206
+ def admin_conversations_setConversationPrefs(options = {})
207
+ throw ArgumentError.new('Required arguments :channel_id missing') if options[:channel_id].nil?
208
+ throw ArgumentError.new('Required arguments :prefs missing') if options[:prefs].nil?
209
+ post('admin.conversations.setConversationPrefs', options)
210
+ end
211
+
212
+ #
213
+ # This API endpoint can be used by any admin to set a channel's retention policy.
214
+ #
215
+ # @option options [Object] :channel_id
216
+ # The channel to set the retention policy for.
217
+ # @option options [Object] :duration_days
218
+ # The message retention duration in days to set for this channel.
219
+ # @see https://api.slack.com/methods/admin.conversations.setCustomRetention
220
+ # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/admin.conversations/admin.conversations.setCustomRetention.json
221
+ def admin_conversations_setCustomRetention(options = {})
222
+ throw ArgumentError.new('Required arguments :channel_id missing') if options[:channel_id].nil?
223
+ throw ArgumentError.new('Required arguments :duration_days missing') if options[:duration_days].nil?
224
+ post('admin.conversations.setCustomRetention', options)
225
+ end
226
+
227
+ #
228
+ # Set the workspaces in an Enterprise grid org that connect to a public or private channel.
229
+ #
230
+ # @option options [Object] :channel_id
231
+ # The encoded channel_id to add or remove to workspaces.
232
+ # @option options [Object] :org_channel
233
+ # True if channel has to be converted to an org channel.
234
+ # @option options [Object] :target_team_ids
235
+ # A comma-separated list of workspaces to which the channel should be shared. Not required if the channel is being shared org-wide.
236
+ # @option options [Object] :team_id
237
+ # The workspace to which the channel belongs. Omit this argument if the channel is a cross-workspace shared channel.
238
+ # @see https://api.slack.com/methods/admin.conversations.setTeams
239
+ # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/admin.conversations/admin.conversations.setTeams.json
240
+ def admin_conversations_setTeams(options = {})
241
+ throw ArgumentError.new('Required arguments :channel_id missing') if options[:channel_id].nil?
242
+ post('admin.conversations.setTeams', options)
243
+ end
244
+
245
+ #
246
+ # Unarchive a public or private channel.
247
+ #
248
+ # @option options [Object] :channel_id
249
+ # The channel to unarchive.
250
+ # @see https://api.slack.com/methods/admin.conversations.unarchive
251
+ # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/admin.conversations/admin.conversations.unarchive.json
252
+ def admin_conversations_unarchive(options = {})
253
+ throw ArgumentError.new('Required arguments :channel_id missing') if options[:channel_id].nil?
254
+ post('admin.conversations.unarchive', options)
255
+ end
256
+ end
257
+ end
258
+ end
259
+ end
260
+ end
@@ -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