slack-ruby-client 0.14.4 → 0.16.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (352) hide show
  1. checksums.yaml +4 -4
  2. data/.github/FUNDING.yml +1 -0
  3. data/.rubocop.yml +23 -7
  4. data/.rubocop_todo.yml +104 -47
  5. data/.travis.yml +1 -5
  6. data/CHANGELOG.md +41 -2
  7. data/CONTRIBUTING.md +17 -6
  8. data/Dangerfile +2 -1
  9. data/Gemfile +2 -2
  10. data/README.md +94 -53
  11. data/Rakefile +1 -0
  12. data/UPGRADING.md +20 -2
  13. data/bin/commands.rb +30 -0
  14. data/bin/commands/admin_analytics.rb +15 -0
  15. data/bin/commands/admin_apps.rb +40 -0
  16. data/bin/commands/admin_apps_approved.rb +17 -0
  17. data/bin/commands/admin_apps_requests.rb +16 -0
  18. data/bin/commands/admin_apps_restricted.rb +17 -0
  19. data/bin/commands/admin_barriers.rb +47 -0
  20. data/bin/commands/admin_conversations.rb +169 -0
  21. data/bin/commands/admin_conversations_ekm.rb +17 -0
  22. data/bin/commands/admin_conversations_restrictAccess.rb +37 -0
  23. data/bin/commands/admin_conversations_whitelist.rb +37 -0
  24. data/bin/commands/admin_emoji.rb +54 -0
  25. data/bin/commands/admin_inviteRequests.rb +36 -0
  26. data/bin/commands/admin_inviteRequests_approved.rb +16 -0
  27. data/bin/commands/admin_inviteRequests_denied.rb +16 -0
  28. data/bin/commands/admin_teams.rb +27 -0
  29. data/bin/commands/admin_teams_admins.rb +16 -0
  30. data/bin/commands/admin_teams_owners.rb +16 -0
  31. data/bin/commands/admin_teams_settings.rb +64 -0
  32. data/bin/commands/admin_usergroups.rb +48 -0
  33. data/bin/commands/admin_users.rb +97 -0
  34. data/bin/commands/admin_users_session.rb +25 -2
  35. data/bin/commands/api.rb +3 -3
  36. data/bin/commands/apps.rb +3 -2
  37. data/bin/commands/apps_connections.rb +13 -0
  38. data/bin/commands/apps_event_authorizations.rb +16 -0
  39. data/bin/commands/apps_permissions.rb +5 -4
  40. data/bin/commands/apps_permissions_resources.rb +3 -2
  41. data/bin/commands/apps_permissions_scopes.rb +3 -2
  42. data/bin/commands/apps_permissions_users.rb +5 -4
  43. data/bin/commands/auth.rb +5 -4
  44. data/bin/commands/auth_teams.rb +16 -0
  45. data/bin/commands/bots.rb +4 -2
  46. data/bin/commands/calls.rb +52 -0
  47. data/bin/commands/calls_participants.rb +25 -0
  48. data/bin/commands/channels.rb +37 -33
  49. data/bin/commands/chat.rb +34 -33
  50. data/bin/commands/chat_scheduledMessages.rb +4 -2
  51. data/bin/commands/conversations.rb +50 -38
  52. data/bin/commands/dialog.rb +3 -2
  53. data/bin/commands/dnd.rb +10 -9
  54. data/bin/commands/emoji.rb +3 -2
  55. data/bin/commands/files.rb +16 -13
  56. data/bin/commands/files_comments.rb +3 -2
  57. data/bin/commands/files_remote.rb +78 -0
  58. data/bin/commands/groups.rb +38 -35
  59. data/bin/commands/im.rb +14 -13
  60. data/bin/commands/migration.rb +4 -2
  61. data/bin/commands/mpim.rb +14 -13
  62. data/bin/commands/oauth.rb +6 -5
  63. data/bin/commands/oauth_v2.rb +17 -0
  64. data/bin/commands/pins.rb +7 -10
  65. data/bin/commands/reactions.rb +11 -11
  66. data/bin/commands/reminders.rb +11 -10
  67. data/bin/commands/rtm.rb +5 -4
  68. data/bin/commands/search.rb +11 -7
  69. data/bin/commands/stars.rb +7 -6
  70. data/bin/commands/team.rb +12 -8
  71. data/bin/commands/team_profile.rb +3 -2
  72. data/bin/commands/usergroups.rb +17 -11
  73. data/bin/commands/usergroups_users.rb +7 -4
  74. data/bin/commands/users.rb +26 -23
  75. data/bin/commands/users_admin.rb +1 -0
  76. data/bin/commands/users_prefs.rb +1 -0
  77. data/bin/commands/users_profile.rb +6 -5
  78. data/bin/commands/views.rb +48 -0
  79. data/bin/commands/workflows.rb +38 -0
  80. data/bin/slack +1 -2
  81. data/examples/hi_real_time_and_web/Gemfile +1 -0
  82. data/examples/hi_real_time_and_web/hi.rb +7 -3
  83. data/examples/hi_real_time_async_async/Gemfile +1 -0
  84. data/examples/hi_real_time_async_async/hi.rb +6 -2
  85. data/examples/hi_web/Gemfile +1 -0
  86. data/examples/hi_web/hi.rb +1 -0
  87. data/examples/new_ticket/Gemfile +1 -0
  88. data/examples/new_ticket/new_ticket.rb +1 -0
  89. data/lib/slack-ruby-client.rb +6 -4
  90. data/lib/slack.rb +1 -0
  91. data/lib/slack/config.rb +1 -0
  92. data/lib/slack/events/config.rb +1 -0
  93. data/lib/slack/events/request.rb +8 -2
  94. data/lib/slack/logger.rb +6 -5
  95. data/lib/slack/messages/formatting.rb +1 -0
  96. data/lib/slack/messages/message.rb +1 -4
  97. data/lib/slack/real_time/api/message.rb +3 -1
  98. data/lib/slack/real_time/api/message_id.rb +1 -0
  99. data/lib/slack/real_time/api/ping.rb +5 -2
  100. data/lib/slack/real_time/api/typing.rb +3 -1
  101. data/lib/slack/real_time/client.rb +21 -13
  102. data/lib/slack/real_time/concurrency.rb +1 -2
  103. data/lib/slack/real_time/concurrency/async.rb +12 -6
  104. data/lib/slack/real_time/config.rb +9 -3
  105. data/lib/slack/real_time/models.rb +1 -0
  106. data/lib/slack/real_time/models/base.rb +1 -4
  107. data/lib/slack/real_time/models/bot.rb +1 -0
  108. data/lib/slack/real_time/models/channel.rb +1 -0
  109. data/lib/slack/real_time/models/group.rb +1 -0
  110. data/lib/slack/real_time/models/im.rb +1 -0
  111. data/lib/slack/real_time/models/team.rb +1 -0
  112. data/lib/slack/real_time/models/user.rb +1 -0
  113. data/lib/slack/real_time/socket.rb +16 -13
  114. data/lib/slack/real_time/stores.rb +1 -0
  115. data/lib/slack/real_time/stores/base.rb +4 -1
  116. data/lib/slack/real_time/stores/starter.rb +1 -0
  117. data/lib/slack/real_time/stores/store.rb +16 -25
  118. data/lib/slack/version.rb +2 -1
  119. data/lib/slack/web/api/endpoints.rb +60 -0
  120. data/lib/slack/web/api/endpoints/admin_analytics.rb +26 -0
  121. data/lib/slack/web/api/endpoints/admin_apps.rb +62 -0
  122. data/lib/slack/web/api/endpoints/admin_apps_approved.rb +35 -0
  123. data/lib/slack/web/api/endpoints/admin_apps_requests.rb +33 -0
  124. data/lib/slack/web/api/endpoints/admin_apps_restricted.rb +35 -0
  125. data/lib/slack/web/api/endpoints/admin_barriers.rb +82 -0
  126. data/lib/slack/web/api/endpoints/admin_conversations.rb +260 -0
  127. data/lib/slack/web/api/endpoints/admin_conversations_ekm.rb +35 -0
  128. data/lib/slack/web/api/endpoints/admin_conversations_restrictAccess.rb +61 -0
  129. data/lib/slack/web/api/endpoints/admin_conversations_whitelist.rb +64 -0
  130. data/lib/slack/web/api/endpoints/admin_emoji.rb +88 -0
  131. data/lib/slack/web/api/endpoints/admin_inviteRequests.rb +61 -0
  132. data/lib/slack/web/api/endpoints/admin_inviteRequests_approved.rb +33 -0
  133. data/lib/slack/web/api/endpoints/admin_inviteRequests_denied.rb +33 -0
  134. data/lib/slack/web/api/endpoints/admin_teams.rb +50 -0
  135. data/lib/slack/web/api/endpoints/admin_teams_admins.rb +34 -0
  136. data/lib/slack/web/api/endpoints/admin_teams_owners.rb +34 -0
  137. data/lib/slack/web/api/endpoints/admin_teams_settings.rb +99 -0
  138. data/lib/slack/web/api/endpoints/admin_usergroups.rb +77 -0
  139. data/lib/slack/web/api/endpoints/admin_users.rb +161 -0
  140. data/lib/slack/web/api/endpoints/admin_users_session.rb +40 -1
  141. data/lib/slack/web/api/endpoints/api.rb +2 -3
  142. data/lib/slack/web/api/endpoints/apps.rb +2 -1
  143. data/lib/slack/web/api/endpoints/apps_connections.rb +21 -0
  144. data/lib/slack/web/api/endpoints/apps_event_authorizations.rb +34 -0
  145. data/lib/slack/web/api/endpoints/apps_permissions.rb +3 -2
  146. data/lib/slack/web/api/endpoints/apps_permissions_resources.rb +2 -1
  147. data/lib/slack/web/api/endpoints/apps_permissions_scopes.rb +2 -1
  148. data/lib/slack/web/api/endpoints/apps_permissions_users.rb +3 -2
  149. data/lib/slack/web/api/endpoints/auth.rb +3 -2
  150. data/lib/slack/web/api/endpoints/auth_teams.rb +33 -0
  151. data/lib/slack/web/api/endpoints/bots.rb +4 -1
  152. data/lib/slack/web/api/endpoints/calls.rb +83 -0
  153. data/lib/slack/web/api/endpoints/calls_participants.rb +42 -0
  154. data/lib/slack/web/api/endpoints/channels.rb +52 -31
  155. data/lib/slack/web/api/endpoints/chat.rb +31 -30
  156. data/lib/slack/web/api/endpoints/chat_scheduledMessages.rb +5 -2
  157. data/lib/slack/web/api/endpoints/conversations.rb +55 -36
  158. data/lib/slack/web/api/endpoints/dialog.rb +2 -1
  159. data/lib/slack/web/api/endpoints/dnd.rb +5 -4
  160. data/lib/slack/web/api/endpoints/emoji.rb +2 -1
  161. data/lib/slack/web/api/endpoints/files.rb +13 -8
  162. data/lib/slack/web/api/endpoints/files_comments.rb +2 -1
  163. data/lib/slack/web/api/endpoints/files_remote.rb +127 -0
  164. data/lib/slack/web/api/endpoints/groups.rb +39 -24
  165. data/lib/slack/web/api/endpoints/im.rb +17 -12
  166. data/lib/slack/web/api/endpoints/migration.rb +4 -1
  167. data/lib/slack/web/api/endpoints/mpim.rb +18 -13
  168. data/lib/slack/web/api/endpoints/oauth.rb +4 -6
  169. data/lib/slack/web/api/endpoints/oauth_v2.rb +30 -0
  170. data/lib/slack/web/api/endpoints/pins.rb +7 -16
  171. data/lib/slack/web/api/endpoints/reactions.rb +14 -15
  172. data/lib/slack/web/api/endpoints/reminders.rb +6 -5
  173. data/lib/slack/web/api/endpoints/rtm.rb +3 -2
  174. data/lib/slack/web/api/endpoints/search.rb +10 -3
  175. data/lib/slack/web/api/endpoints/stars.rb +6 -7
  176. data/lib/slack/web/api/endpoints/team.rb +11 -5
  177. data/lib/slack/web/api/endpoints/team_profile.rb +2 -1
  178. data/lib/slack/web/api/endpoints/usergroups.rb +16 -5
  179. data/lib/slack/web/api/endpoints/usergroups_users.rb +7 -2
  180. data/lib/slack/web/api/endpoints/users.rb +18 -21
  181. data/lib/slack/web/api/endpoints/users_admin.rb +1 -0
  182. data/lib/slack/web/api/endpoints/users_prefs.rb +1 -0
  183. data/lib/slack/web/api/endpoints/users_profile.rb +4 -3
  184. data/lib/slack/web/api/endpoints/views.rb +97 -0
  185. data/lib/slack/web/api/endpoints/workflows.rb +61 -0
  186. data/lib/slack/web/api/error.rb +1 -0
  187. data/lib/slack/web/api/errors.rb +850 -0
  188. data/lib/slack/web/api/errors/internal_error.rb +14 -0
  189. data/lib/slack/web/api/errors/slack_error.rb +14 -1
  190. data/lib/slack/web/api/errors/too_many_requests_error.rb +1 -0
  191. data/lib/slack/web/api/mixins.rb +2 -0
  192. data/lib/slack/web/api/mixins/channels.id.rb +2 -3
  193. data/lib/slack/web/api/mixins/conversations.id.rb +25 -0
  194. data/lib/slack/web/api/mixins/groups.id.rb +2 -3
  195. data/lib/slack/web/api/mixins/ids.id.rb +3 -2
  196. data/lib/slack/web/api/mixins/users.id.rb +2 -3
  197. data/lib/slack/web/api/mixins/users.search.rb +1 -0
  198. data/lib/slack/web/api/patches/{chat.6.block-kit-support.patch → chat.1.patch} +29 -26
  199. data/lib/slack/web/api/patches/views.1.view-json.patch +40 -0
  200. data/lib/slack/web/api/patches/views.1.views-published.patch +16 -0
  201. data/lib/slack/web/api/templates/command.erb +1 -0
  202. data/lib/slack/web/api/templates/commands.erb +1 -0
  203. data/lib/slack/web/api/templates/endpoints.erb +2 -0
  204. data/lib/slack/web/api/templates/errors.erb +20 -0
  205. data/lib/slack/web/api/templates/method.erb +5 -1
  206. data/lib/slack/web/api/templates/method_spec.erb +2 -1
  207. data/lib/slack/web/client.rb +2 -1
  208. data/lib/slack/web/config.rb +3 -0
  209. data/lib/slack/web/faraday/connection.rb +24 -20
  210. data/lib/slack/web/faraday/request.rb +1 -0
  211. data/lib/slack/web/faraday/response/raise_error.rb +25 -6
  212. data/lib/slack/web/faraday/response/wrap_error.rb +18 -0
  213. data/lib/slack/web/pagination/cursor.rb +3 -2
  214. data/lib/slack_ruby_client.rb +1 -0
  215. data/lib/tasks/git.rake +1 -0
  216. data/lib/tasks/real_time.rake +13 -5
  217. data/lib/tasks/update.rake +1 -0
  218. data/lib/tasks/web.rake +34 -10
  219. data/screenshots/create-app.png +0 -0
  220. data/slack-ruby-client.gemspec +6 -3
  221. data/spec/fixtures/slack/web/channels_info.yml +108 -15
  222. data/spec/fixtures/slack/web/conversations_setTopic.yml +69 -0
  223. data/spec/fixtures/slack/web/conversations_setTopic_one_page.yml +142 -0
  224. data/spec/fixtures/slack/web/conversations_setTopic_paginated.yml +208 -0
  225. data/spec/fixtures/slack/web/views_open_error.yml +76 -0
  226. data/spec/integration/integration_spec.rb +16 -17
  227. data/spec/slack/config_spec.rb +2 -0
  228. data/spec/slack/events/config_spec.rb +8 -4
  229. data/spec/slack/events/request_spec.rb +74 -40
  230. data/spec/slack/messages/formatting_spec.rb +25 -13
  231. data/spec/slack/real_time/api/message_spec.rb +6 -1
  232. data/spec/slack/real_time/api/ping_spec.rb +2 -0
  233. data/spec/slack/real_time/api/typing_spec.rb +5 -1
  234. data/spec/slack/real_time/client_spec.rb +153 -38
  235. data/spec/slack/real_time/concurrency/it_behaves_like_a_realtime_socket.rb +2 -0
  236. data/spec/slack/real_time/event_handlers/bot_spec.rb +2 -1
  237. data/spec/slack/real_time/event_handlers/channel_spec.rb +9 -6
  238. data/spec/slack/real_time/event_handlers/event_handlers_spec.rb +2 -1
  239. data/spec/slack/real_time/event_handlers/group_spec.rb +5 -4
  240. data/spec/slack/real_time/event_handlers/im_spec.rb +4 -3
  241. data/spec/slack/real_time/event_handlers/team_spec.rb +3 -1
  242. data/spec/slack/real_time/event_handlers/user_spec.rb +1 -0
  243. data/spec/slack/real_time/rtm_connect_spec.rb +1 -0
  244. data/spec/slack/real_time/rtm_start_spec.rb +1 -0
  245. data/spec/slack/real_time/store_spec.rb +2 -1
  246. data/spec/slack/slack_spec.rb +37 -5
  247. data/spec/slack/version_spec.rb +2 -1
  248. data/spec/slack/web/api/endpoints/admin_analytics_spec.rb +13 -0
  249. data/spec/slack/web/api/endpoints/admin_apps_approved_spec.rb +8 -0
  250. data/spec/slack/web/api/endpoints/admin_apps_requests_spec.rb +8 -0
  251. data/spec/slack/web/api/endpoints/admin_apps_restricted_spec.rb +8 -0
  252. data/spec/slack/web/api/endpoints/admin_apps_spec.rb +13 -0
  253. data/spec/slack/web/api/endpoints/admin_barriers_spec.rb +38 -0
  254. data/spec/slack/web/api/endpoints/admin_conversations_ekm_spec.rb +8 -0
  255. data/spec/slack/web/api/endpoints/admin_conversations_restrictAccess_spec.rb +32 -0
  256. data/spec/slack/web/api/endpoints/admin_conversations_spec.rb +98 -0
  257. data/spec/slack/web/api/endpoints/admin_conversations_whitelist_spec.rb +32 -0
  258. data/spec/slack/web/api/endpoints/admin_emoji_spec.rb +37 -0
  259. data/spec/slack/web/api/endpoints/admin_inviteRequests_approved_spec.rb +8 -0
  260. data/spec/slack/web/api/endpoints/admin_inviteRequests_denied_spec.rb +8 -0
  261. data/spec/slack/web/api/endpoints/admin_inviteRequests_spec.rb +18 -0
  262. data/spec/slack/web/api/endpoints/admin_teams_admins_spec.rb +13 -0
  263. data/spec/slack/web/api/endpoints/admin_teams_owners_spec.rb +13 -0
  264. data/spec/slack/web/api/endpoints/admin_teams_settings_spec.rb +53 -0
  265. data/spec/slack/web/api/endpoints/admin_teams_spec.rb +16 -0
  266. data/spec/slack/web/api/endpoints/admin_usergroups_spec.rb +37 -0
  267. data/spec/slack/web/api/endpoints/admin_users_session_spec.rb +9 -0
  268. data/spec/slack/web/api/endpoints/admin_users_spec.rb +67 -0
  269. data/spec/slack/web/api/endpoints/api_spec.rb +1 -0
  270. data/spec/slack/web/api/endpoints/apps_connections_spec.rb +8 -0
  271. data/spec/slack/web/api/endpoints/apps_event_authorizations_spec.rb +13 -0
  272. data/spec/slack/web/api/endpoints/apps_permissions_resources_spec.rb +1 -0
  273. data/spec/slack/web/api/endpoints/apps_permissions_scopes_spec.rb +1 -0
  274. data/spec/slack/web/api/endpoints/apps_permissions_spec.rb +3 -2
  275. data/spec/slack/web/api/endpoints/apps_permissions_users_spec.rb +4 -3
  276. data/spec/slack/web/api/endpoints/apps_spec.rb +3 -2
  277. data/spec/slack/web/api/endpoints/auth_teams_spec.rb +8 -0
  278. data/spec/slack/web/api/endpoints/bots_spec.rb +1 -0
  279. data/spec/slack/web/api/endpoints/calls_participants_spec.rb +24 -0
  280. data/spec/slack/web/api/endpoints/calls_spec.rb +31 -0
  281. data/spec/slack/web/api/endpoints/chat_scheduledMessages_spec.rb +1 -0
  282. data/spec/slack/web/api/endpoints/conversations_spec.rb +21 -12
  283. data/spec/slack/web/api/endpoints/custom_specs/auth_spec.rb +5 -1
  284. data/spec/slack/web/api/endpoints/custom_specs/channels_spec.rb +5 -3
  285. data/spec/slack/web/api/endpoints/custom_specs/chat_spec.rb +80 -25
  286. data/spec/slack/web/api/endpoints/custom_specs/dialog_spec.rb +12 -4
  287. data/spec/slack/web/api/endpoints/custom_specs/groups_spec.rb +2 -0
  288. data/spec/slack/web/api/endpoints/custom_specs/users_spec.rb +6 -1
  289. data/spec/slack/web/api/endpoints/custom_specs/views_spec.rb +95 -0
  290. data/spec/slack/web/api/endpoints/dnd_spec.rb +1 -0
  291. data/spec/slack/web/api/endpoints/emoji_spec.rb +1 -0
  292. data/spec/slack/web/api/endpoints/files_comments_spec.rb +3 -2
  293. data/spec/slack/web/api/endpoints/files_remote_spec.rb +24 -0
  294. data/spec/slack/web/api/endpoints/files_spec.rb +5 -4
  295. data/spec/slack/web/api/endpoints/im_spec.rb +5 -4
  296. data/spec/slack/web/api/endpoints/migration_spec.rb +1 -0
  297. data/spec/slack/web/api/endpoints/mpim_spec.rb +5 -4
  298. data/spec/slack/web/api/endpoints/oauth_spec.rb +4 -14
  299. data/spec/slack/web/api/endpoints/oauth_v2_spec.rb +13 -0
  300. data/spec/slack/web/api/endpoints/pins_spec.rb +1 -0
  301. data/spec/slack/web/api/endpoints/reactions_spec.rb +8 -1
  302. data/spec/slack/web/api/endpoints/reminders_spec.rb +3 -2
  303. data/spec/slack/web/api/endpoints/rtm_spec.rb +1 -0
  304. data/spec/slack/web/api/endpoints/search_spec.rb +1 -0
  305. data/spec/slack/web/api/endpoints/stars_spec.rb +1 -0
  306. data/spec/slack/web/api/endpoints/team_profile_spec.rb +1 -0
  307. data/spec/slack/web/api/endpoints/team_spec.rb +1 -0
  308. data/spec/slack/web/api/endpoints/usergroups_spec.rb +1 -0
  309. data/spec/slack/web/api/endpoints/usergroups_users_spec.rb +3 -2
  310. data/spec/slack/web/api/endpoints/users_admin_spec.rb +1 -0
  311. data/spec/slack/web/api/endpoints/users_prefs_spec.rb +1 -0
  312. data/spec/slack/web/api/endpoints/users_profile_spec.rb +1 -0
  313. data/spec/slack/web/api/endpoints/views_spec.rb +29 -0
  314. data/spec/slack/web/api/endpoints/workflows_spec.rb +26 -0
  315. data/spec/slack/web/api/error_spec.rb +4 -2
  316. data/spec/slack/web/api/errors/slack_error_spec.rb +26 -2
  317. data/spec/slack/web/api/mixins/channels_spec.rb +17 -7
  318. data/spec/slack/web/api/mixins/conversations_list_spec.rb +21 -0
  319. data/spec/slack/web/api/mixins/conversations_spec.rb +43 -0
  320. data/spec/slack/web/api/mixins/groups_spec.rb +17 -7
  321. data/spec/slack/web/api/mixins/users_spec.rb +17 -8
  322. data/spec/slack/web/api/pagination/cursor_spec.rb +40 -10
  323. data/spec/slack/web/client_spec.rb +171 -18
  324. data/spec/slack/web/faraday/response/raise_error_spec.rb +47 -12
  325. data/spec/spec_helper.rb +2 -1
  326. data/spec/support/queue_with_timeout.rb +1 -0
  327. data/spec/support/real_time/concurrency/mock.rb +1 -0
  328. data/spec/support/real_time/connected_client.rb +9 -3
  329. data/spec/support/real_time/event.rb +1 -0
  330. data/spec/support/token.rb +1 -0
  331. data/spec/support/vcr.rb +5 -0
  332. metadata +190 -46
  333. data/examples/hi_real_time/Gemfile +0 -5
  334. data/examples/hi_real_time/hi.gif +0 -0
  335. data/examples/hi_real_time/hi.rb +0 -37
  336. data/examples/hi_real_time_async_celluloid/Gemfile +0 -6
  337. data/examples/hi_real_time_async_celluloid/Procfile +0 -2
  338. data/examples/hi_real_time_async_celluloid/hi.rb +0 -35
  339. data/examples/hi_real_time_async_eventmachine/Gemfile +0 -6
  340. data/examples/hi_real_time_async_eventmachine/Procfile +0 -2
  341. data/examples/hi_real_time_async_eventmachine/hi.rb +0 -35
  342. data/lib/slack/real_time/concurrency/celluloid.rb +0 -136
  343. data/lib/slack/real_time/concurrency/eventmachine.rb +0 -82
  344. data/lib/slack/web/api/patches/chat.1.text-attachments-required.patch +0 -13
  345. data/lib/slack/web/api/patches/chat.2.attachments-json.patch +0 -17
  346. data/lib/slack/web/api/patches/chat.3.update-attachments-support.patch +0 -21
  347. data/lib/slack/web/api/patches/chat.4.postEphemeral-attachments-support.patch +0 -17
  348. data/lib/slack/web/api/patches/chat.5.postEphemeral-text-or-attachments.patch +0 -15
  349. data/screenshots/register-bot.png +0 -0
  350. data/spec/slack/real_time/concurrency/celluloid_spec.rb +0 -111
  351. data/spec/slack/real_time/concurrency/eventmachine_spec.rb +0 -49
  352. data/spec/slack/web/api/errors/service_unavailable_spec.rb +0 -14
@@ -1,6 +1,7 @@
1
+ # frozen_string_literal: true
1
2
  # This file was auto-generated by lib/tasks/web.rake
2
3
 
3
- desc 'Chat methods.'
4
+ desc 'Post chat messages to Slack.'
4
5
  command 'chat' do |g|
5
6
  g.desc 'Execute a slash command in a public channel (undocumented)'
6
7
  g.long_desc %( Execute a slash command in a public channel )
@@ -13,8 +14,8 @@ command 'chat' do |g|
13
14
  end
14
15
  end
15
16
 
16
- g.desc 'This method deletes a message from a channel.'
17
- g.long_desc %( This method deletes a message from a channel. )
17
+ g.desc 'Deletes a message.'
18
+ g.long_desc %( Deletes a message. )
18
19
  g.command 'delete' do |c|
19
20
  c.flag 'channel', desc: 'Channel containing the message to be deleted.'
20
21
  c.flag 'ts', desc: 'Timestamp of the message to be deleted.'
@@ -24,8 +25,8 @@ command 'chat' do |g|
24
25
  end
25
26
  end
26
27
 
27
- g.desc 'This method deletes a pending scheduled message before it is sent.'
28
- g.long_desc %( This method deletes a pending scheduled message before it is sent. )
28
+ g.desc 'Deletes a pending scheduled message from the queue.'
29
+ g.long_desc %( Deletes a pending scheduled message from the queue. )
29
30
  g.command 'deleteScheduledMessage' do |c|
30
31
  c.flag 'channel', desc: 'The channel the scheduled_message is posting to.'
31
32
  c.flag 'scheduled_message_id', desc: 'scheduled_message_id returned from call to chat.scheduleMessage.'
@@ -35,8 +36,8 @@ command 'chat' do |g|
35
36
  end
36
37
  end
37
38
 
38
- g.desc 'Easily exchange a message timestamp and a channel ID for a friendly HTTP-based permalink to that message. Handles message threads and all conversation types.'
39
- g.long_desc %( Easily exchange a message timestamp and a channel ID for a friendly HTTP-based permalink to that message. Handles message threads and all conversation types. )
39
+ g.desc 'Retrieve a permalink URL for a specific extant message'
40
+ g.long_desc %( Retrieve a permalink URL for a specific extant message )
40
41
  g.command 'getPermalink' do |c|
41
42
  c.flag 'channel', desc: 'The ID of the conversation or channel containing the message.'
42
43
  c.flag 'message_ts', desc: "A message's ts value, uniquely identifying it within a channel."
@@ -45,8 +46,8 @@ command 'chat' do |g|
45
46
  end
46
47
  end
47
48
 
48
- g.desc 'This method sends a me message to a channel from the calling user.'
49
- g.long_desc %( This method sends a me message to a channel from the calling user. )
49
+ g.desc 'Share a me message into a channel.'
50
+ g.long_desc %( Share a me message into a channel. )
50
51
  g.command 'meMessage' do |c|
51
52
  c.flag 'channel', desc: 'Channel to send message to. Can be a public channel, private group or IM channel. Can be an encoded ID, or a name.'
52
53
  c.flag 'text', desc: 'Text of the message to send.'
@@ -55,12 +56,12 @@ command 'chat' do |g|
55
56
  end
56
57
  end
57
58
 
58
- g.desc 'This method posts an ephemeral message, which is visible only to the assigned user in a specific public channel, private channel, or private conversation.'
59
- g.long_desc %( This method posts an ephemeral message, which is visible only to the assigned user in a specific public channel, private channel, or private conversation. )
59
+ g.desc 'Sends an ephemeral message to a user in a channel.'
60
+ g.long_desc %( Sends an ephemeral message to a user in a channel. )
60
61
  g.command 'postEphemeral' do |c|
61
62
  c.flag 'attachments', desc: 'A JSON-based array of structured attachments, presented as a URL-encoded string.'
62
63
  c.flag 'channel', desc: 'Channel, private group, or IM channel to send message to. Can be an encoded ID, or a name.'
63
- c.flag 'text', desc: "Text of the message to send. See below for an explanation of formatting. This field is usually required, unless you're providing only attachments instead."
64
+ c.flag 'text', desc: 'How this field works and whether it is required depends on other fields you use in your API call. See below for more detail.'
64
65
  c.flag 'user', desc: 'id of the user who will receive the ephemeral message. The user should be in the channel specified by the channel argument.'
65
66
  c.flag 'as_user', desc: 'Pass true to post the message as the authed user. Defaults to true if the chat:write:bot scope is not included. Otherwise, defaults to false.'
66
67
  c.flag 'blocks', desc: 'A JSON-based array of structured blocks, presented as a URL-encoded string.'
@@ -75,16 +76,16 @@ command 'chat' do |g|
75
76
  end
76
77
  end
77
78
 
78
- g.desc 'This method posts a message to a public channel, private channel, or direct message/IM channel.'
79
- g.long_desc %( This method posts a message to a public channel, private channel, or direct message/IM channel. )
79
+ g.desc 'Sends a message to a channel.'
80
+ g.long_desc %( Sends a message to a channel. )
80
81
  g.command 'postMessage' do |c|
81
82
  c.flag 'channel', desc: 'Channel, private group, or IM channel to send message to. Can be an encoded ID, or a name. See below for more details.'
82
- c.flag 'text', desc: "Text of the message to send. See below for an explanation of formatting. This field is usually required, unless you're providing only attachments instead. Provide no more than 40,000 characters or risk truncation."
83
- c.flag 'as_user', desc: 'Pass true to post the message as the authed user, instead of as a bot. Defaults to false. See authorship below.'
83
+ c.flag 'text', desc: 'How this field works and whether it is required depends on other fields you use in your API call. See below for more detail.'
84
+ c.flag 'as_user', desc: 'Pass true to post the message as the authed user, instead of as a bot. Defaults to false. See authorship below. This argument may not be used with newer bot tokens.'
84
85
  c.flag 'attachments', desc: 'A JSON-based array of structured attachments, presented as a URL-encoded string.'
85
86
  c.flag 'blocks', desc: 'A JSON-based array of structured blocks, presented as a URL-encoded string.'
86
- c.flag 'icon_emoji', desc: 'Emoji to use as the icon for this message. Overrides icon_url. Must be used in conjunction with as_user set to false, otherwise ignored. See authorship below.'
87
- c.flag 'icon_url', desc: 'URL to an image to use as the icon for this message. Must be used in conjunction with as_user set to false, otherwise ignored. See authorship below.'
87
+ c.flag 'icon_emoji', desc: 'Emoji to use as the icon for this message. Overrides icon_url. See authorship below. Use with bot tokens requires chat:write.customize.'
88
+ c.flag 'icon_url', desc: 'URL to an image to use as the icon for this message. See authorship below. Use with bot tokens requires chat:write.customize.'
88
89
  c.flag 'link_names', desc: 'Find and link channel names and usernames.'
89
90
  c.flag 'mrkdwn', desc: 'Disable Slack markup parsing by setting to false. Enabled by default.'
90
91
  c.flag 'parse', desc: 'Change how messages are treated. Defaults to none. See below.'
@@ -92,23 +93,23 @@ command 'chat' do |g|
92
93
  c.flag 'thread_ts', desc: "Provide another message's ts value to make this message a reply. Avoid using a reply's ts value; use its parent instead."
93
94
  c.flag 'unfurl_links', desc: 'Pass true to enable unfurling of primarily text-based content.'
94
95
  c.flag 'unfurl_media', desc: 'Pass false to disable unfurling of media content.'
95
- c.flag 'username', desc: "Set your bot's user name. Must be used in conjunction with as_user set to false, otherwise ignored. See authorship below."
96
+ c.flag 'username', desc: "Set your bot's user name. See authorship below. Use with bot tokens requires chat:write.customize."
96
97
  c.action do |_global_options, options, _args|
97
98
  puts JSON.dump($client.chat_postMessage(options))
98
99
  end
99
100
  end
100
101
 
101
- g.desc 'This method schedules a message for delivery to a public channel, private channel, or direct message/IM channel at a specified time in the future.'
102
- g.long_desc %( This method schedules a message for delivery to a public channel, private channel, or direct message/IM channel at a specified time in the future. )
102
+ g.desc 'Schedules a message to be sent to a channel.'
103
+ g.long_desc %( Schedules a message to be sent to a channel. )
103
104
  g.command 'scheduleMessage' do |c|
104
105
  c.flag 'channel', desc: 'Channel, private group, or DM channel to send message to. Can be an encoded ID, or a name. See below for more details.'
105
106
  c.flag 'post_at', desc: 'Unix EPOCH timestamp of time in future to send the message.'
106
- c.flag 'text', desc: "Text of the message to send. See below for an explanation of formatting. This field is usually required, unless you're providing only attachments instead. Provide no more than 40,000 characters or risk truncation."
107
- c.flag 'as_user', desc: 'Pass true to post the message as the authed user, instead of as a bot. Defaults to false. See authorship below.'
107
+ c.flag 'text', desc: 'How this field works and whether it is required depends on other fields you use in your API call. See below for more detail.'
108
+ c.flag 'as_user', desc: 'Pass true to post the message as the authed user, instead of as a bot. Defaults to false. See chat.postMessage.'
108
109
  c.flag 'attachments', desc: 'A JSON-based array of structured attachments, presented as a URL-encoded string.'
109
110
  c.flag 'blocks', desc: 'A JSON-based array of structured blocks, presented as a URL-encoded string.'
110
111
  c.flag 'link_names', desc: 'Find and link channel names and usernames.'
111
- c.flag 'parse', desc: 'Change how messages are treated. Defaults to none. See below.'
112
+ c.flag 'parse', desc: 'Change how messages are treated. Defaults to none. See chat.postMessage.'
112
113
  c.flag 'reply_broadcast', desc: 'Used in conjunction with thread_ts and indicates whether reply should be made visible to everyone in the channel or conversation. Defaults to false.'
113
114
  c.flag 'thread_ts', desc: "Provide another message's ts value to make this message a reply. Avoid using a reply's ts value; use its parent instead."
114
115
  c.flag 'unfurl_links', desc: 'Pass true to enable unfurling of primarily text-based content.'
@@ -118,8 +119,8 @@ command 'chat' do |g|
118
119
  end
119
120
  end
120
121
 
121
- g.desc 'This method attaches Slack app unfurl behavior to a specified and relevant message. A user token is required as this method does not support bot user tokens.'
122
- g.long_desc %( This method attaches Slack app unfurl behavior to a specified and relevant message. A user token is required as this method does not support bot user tokens. )
122
+ g.desc 'Provide custom unfurl behavior for user-posted URLs'
123
+ g.long_desc %( Provide custom unfurl behavior for user-posted URLs )
123
124
  g.command 'unfurl' do |c|
124
125
  c.flag 'channel', desc: 'Channel ID of the message.'
125
126
  c.flag 'ts', desc: 'Timestamp of the message to add unfurl behavior to.'
@@ -132,17 +133,17 @@ command 'chat' do |g|
132
133
  end
133
134
  end
134
135
 
135
- g.desc 'This method updates a message in a channel. Though related to chat.postMessage, some parameters of chat.update are handled differently.'
136
- g.long_desc %( This method updates a message in a channel. Though related to chat.postMessage, some parameters of chat.update are handled differently. )
136
+ g.desc 'Updates a message.'
137
+ g.long_desc %( Updates a message. )
137
138
  g.command 'update' do |c|
138
139
  c.flag 'channel', desc: 'Channel containing the message to be updated.'
139
- c.flag 'text', desc: "New text for the message, using the default formatting rules. It's not required when presenting attachments."
140
140
  c.flag 'ts', desc: 'Timestamp of the message to be updated.'
141
141
  c.flag 'as_user', desc: 'Pass true to update the message as the authed user. Bot users in this context are considered authed users.'
142
- c.flag 'attachments', desc: 'A JSON-based array of structured attachments, presented as a URL-encoded string. This field is required when not presenting text.'
143
- c.flag 'blocks', desc: 'A JSON-based array of structured blocks, presented as a URL-encoded string.'
144
- c.flag 'link_names', desc: 'Find and link channel names and usernames. Defaults to none. See below.'
145
- c.flag 'parse', desc: 'Change how messages are treated. Defaults to client, unlike chat.postMessage. See below.'
142
+ c.flag 'attachments', desc: "A JSON-based array of structured attachments, presented as a URL-encoded string. This field is required when not presenting text. If you don't include this field, the message's previous attachments will be retained. To remove previous attachments, include an empty array for this field."
143
+ c.flag 'blocks', desc: "A JSON-based array of structured blocks, presented as a URL-encoded string. If you don't include this field, the message's previous blocks will be retained. To remove previous blocks, include an empty array for this field."
144
+ c.flag 'link_names', desc: 'Find and link channel names and usernames. Defaults to none. If you do not specify a value for this field, the original value set for the message will be overwritten with the default, none.'
145
+ c.flag 'parse', desc: 'Change how messages are treated. Defaults to client, unlike chat.postMessage. Accepts either none or full. If you do not specify a value for this field, the original value set for the message will be overwritten with the default, client.'
146
+ c.flag 'text', desc: "New text for the message, using the default formatting rules. It's not required when presenting blocks or attachments."
146
147
  c.action do |_global_options, options, _args|
147
148
  puts JSON.dump($client.chat_update(options))
148
149
  end
@@ -1,15 +1,17 @@
1
+ # frozen_string_literal: true
1
2
  # This file was auto-generated by lib/tasks/web.rake
2
3
 
3
4
  desc 'ChatScheduledmessages methods.'
4
5
  command 'chat_scheduledMessages' do |g|
5
- g.desc 'This method returns a list of pending scheduled messages.'
6
- g.long_desc %( This method returns a list of pending scheduled messages. )
6
+ g.desc 'Returns a list of scheduled messages.'
7
+ g.long_desc %( Returns a list of scheduled messages. )
7
8
  g.command 'list' do |c|
8
9
  c.flag 'channel', desc: 'The channel of the scheduled messages.'
9
10
  c.flag 'cursor', desc: 'For pagination purposes, this is the cursor value returned from a previous call to chat.scheduledmessages.list indicating where you want to start this call from.'
10
11
  c.flag 'latest', desc: 'A UNIX timestamp of the latest value in the time range.'
11
12
  c.flag 'limit', desc: 'Maximum number of original entries to return.'
12
13
  c.flag 'oldest', desc: 'A UNIX timestamp of the oldest value in the time range.'
14
+ c.flag 'team_id', desc: 'encoded team id to list channels in, required if org token is used.'
13
15
  c.action do |_global_options, options, _args|
14
16
  puts JSON.dump($client.chat_scheduledMessages_list(options))
15
17
  end
@@ -1,9 +1,10 @@
1
+ # frozen_string_literal: true
1
2
  # This file was auto-generated by lib/tasks/web.rake
2
3
 
3
- desc 'Conversations methods.'
4
+ desc "Interface with all kinds of conversations the same way, whether they're public or private channels, direct messages, or otherwise."
4
5
  command 'conversations' do |g|
5
- g.desc 'This method archives a conversation. Not all types of conversations can be archived.'
6
- g.long_desc %( This method archives a conversation. Not all types of conversations can be archived. )
6
+ g.desc 'Archives a conversation.'
7
+ g.long_desc %( Archives a conversation. )
7
8
  g.command 'archive' do |c|
8
9
  c.flag 'channel', desc: 'ID of conversation to archive.'
9
10
  c.action do |_global_options, options, _args|
@@ -11,8 +12,8 @@ command 'conversations' do |g|
11
12
  end
12
13
  end
13
14
 
14
- g.desc 'This Conversations API method closes direct messages, multi-person or 1:1 or otherwise.'
15
- g.long_desc %( This Conversations API method closes direct messages, multi-person or 1:1 or otherwise. )
15
+ g.desc 'Closes a direct message or multi-person direct message.'
16
+ g.long_desc %( Closes a direct message or multi-person direct message. )
16
17
  g.command 'close' do |c|
17
18
  c.flag 'channel', desc: 'Conversation to close.'
18
19
  c.action do |_global_options, options, _args|
@@ -20,19 +21,19 @@ command 'conversations' do |g|
20
21
  end
21
22
  end
22
23
 
23
- g.desc 'Create a public or private channel using this Conversations API method.'
24
- g.long_desc %( Create a public or private channel using this Conversations API method. )
24
+ g.desc 'Initiates a public or private channel-based conversation'
25
+ g.long_desc %( Initiates a public or private channel-based conversation )
25
26
  g.command 'create' do |c|
26
27
  c.flag 'name', desc: 'Name of the public or private channel to create.'
27
28
  c.flag 'is_private', desc: 'Create a private channel instead of a public one.'
28
- c.flag 'user_ids', desc: 'Required for workspace apps. A list of between 1 and 30 human users that will be added to the newly-created conversation. This argument has no effect when used by classic Slack apps.'
29
+ c.flag 'team_id', desc: 'encoded team id to create the channel in, required if org token is used.'
29
30
  c.action do |_global_options, options, _args|
30
31
  puts JSON.dump($client.conversations_create(options))
31
32
  end
32
33
  end
33
34
 
34
- g.desc 'This method returns a portion of message events from the specified conversation.'
35
- g.long_desc %( This method returns a portion of message events from the specified conversation. )
35
+ g.desc "Fetches a conversation's history of messages and events."
36
+ g.long_desc %( Fetches a conversation's history of messages and events. )
36
37
  g.command 'history' do |c|
37
38
  c.flag 'channel', desc: 'Conversation ID to fetch history for.'
38
39
  c.flag 'cursor', desc: "Paginate through collections of data by setting the cursor parameter to a next_cursor attribute returned by a previous request's response_metadata. Default value fetches the first 'page' of the collection. See pagination for more detail."
@@ -45,8 +46,8 @@ command 'conversations' do |g|
45
46
  end
46
47
  end
47
48
 
48
- g.desc 'This Conversations API method returns information about a workspace conversation.'
49
- g.long_desc %( This Conversations API method returns information about a workspace conversation. )
49
+ g.desc 'Retrieve information about a conversation.'
50
+ g.long_desc %( Retrieve information about a conversation. )
50
51
  g.command 'info' do |c|
51
52
  c.flag 'channel', desc: 'Conversation ID to learn more about.'
52
53
  c.flag 'include_locale', desc: 'Set this to true to receive the locale for this conversation. Defaults to false.'
@@ -56,18 +57,18 @@ command 'conversations' do |g|
56
57
  end
57
58
  end
58
59
 
59
- g.desc 'This Conversations API method invites 1-30 users to a public or private channel. The calling user must be a member of the channel.'
60
- g.long_desc %( This Conversations API method invites 1-30 users to a public or private channel. The calling user must be a member of the channel. )
60
+ g.desc 'Invites users to a channel.'
61
+ g.long_desc %( Invites users to a channel. )
61
62
  g.command 'invite' do |c|
62
63
  c.flag 'channel', desc: 'The ID of the public or private channel to invite user(s) to.'
63
- c.flag 'users', desc: 'A comma separated list of user IDs. Up to 30 users may be listed.'
64
+ c.flag 'users', desc: 'A comma separated list of user IDs. Up to 1000 users may be listed.'
64
65
  c.action do |_global_options, options, _args|
65
66
  puts JSON.dump($client.conversations_invite(options))
66
67
  end
67
68
  end
68
69
 
69
- g.desc 'This Conversations API method joins a user to an existing conversation.'
70
- g.long_desc %( This Conversations API method joins a user to an existing conversation. )
70
+ g.desc 'Joins an existing conversation.'
71
+ g.long_desc %( Joins an existing conversation. )
71
72
  g.command 'join' do |c|
72
73
  c.flag 'channel', desc: 'ID of conversation to join.'
73
74
  c.action do |_global_options, options, _args|
@@ -75,8 +76,8 @@ command 'conversations' do |g|
75
76
  end
76
77
  end
77
78
 
78
- g.desc 'This Conversations API method allows a user to remove another member from a channel.'
79
- g.long_desc %( This Conversations API method allows a user to remove another member from a channel. )
79
+ g.desc 'Removes a user from a conversation.'
80
+ g.long_desc %( Removes a user from a conversation. )
80
81
  g.command 'kick' do |c|
81
82
  c.flag 'channel', desc: 'ID of conversation to remove user from.'
82
83
  c.flag 'user', desc: 'User ID to be removed.'
@@ -85,8 +86,8 @@ command 'conversations' do |g|
85
86
  end
86
87
  end
87
88
 
88
- g.desc 'This Conversations API method makes like a tree and leaves a conversation.'
89
- g.long_desc %( This Conversations API method makes like a tree and leaves a conversation. )
89
+ g.desc 'Leaves a conversation.'
90
+ g.long_desc %( Leaves a conversation. )
90
91
  g.command 'leave' do |c|
91
92
  c.flag 'channel', desc: 'Conversation to leave.'
92
93
  c.action do |_global_options, options, _args|
@@ -94,20 +95,31 @@ command 'conversations' do |g|
94
95
  end
95
96
  end
96
97
 
97
- g.desc 'This Conversations API method returns a list of all channel-like conversations in a workspace. The "channels" returned depend on what the calling token has access to and the directives placed in the types parameter.'
98
- g.long_desc %( This Conversations API method returns a list of all channel-like conversations in a workspace. The "channels" returned depend on what the calling token has access to and the directives placed in the types parameter. )
98
+ g.desc 'Lists all channels in a Slack team.'
99
+ g.long_desc %( Lists all channels in a Slack team. )
99
100
  g.command 'list' do |c|
100
101
  c.flag 'cursor', desc: "Paginate through collections of data by setting the cursor parameter to a next_cursor attribute returned by a previous request's response_metadata. Default value fetches the first 'page' of the collection. See pagination for more detail."
101
102
  c.flag 'exclude_archived', desc: 'Set to true to exclude archived channels from the list.'
102
103
  c.flag 'limit', desc: "The maximum number of items to return. Fewer than the requested number of items may be returned, even if the end of the list hasn't been reached. Must be an integer no larger than 1000."
104
+ c.flag 'team_id', desc: 'encoded team id to list channels in, required if org token is used.'
103
105
  c.flag 'types', desc: 'Mix and match channel types by providing a comma-separated list of any combination of public_channel, private_channel, mpim, im.'
104
106
  c.action do |_global_options, options, _args|
105
107
  puts JSON.dump($client.conversations_list(options))
106
108
  end
107
109
  end
108
110
 
109
- g.desc 'This Conversations API method returns a paginated list of members party to a conversation.'
110
- g.long_desc %( This Conversations API method returns a paginated list of members party to a conversation. )
111
+ g.desc 'Sets the read cursor in a channel.'
112
+ g.long_desc %( Sets the read cursor in a channel. )
113
+ g.command 'mark' do |c|
114
+ c.flag 'channel', desc: 'Channel or conversation to set the read cursor for.'
115
+ c.flag 'ts', desc: 'Unique identifier of message you want marked as most recently seen in this conversation.'
116
+ c.action do |_global_options, options, _args|
117
+ puts JSON.dump($client.conversations_mark(options))
118
+ end
119
+ end
120
+
121
+ g.desc 'Retrieve members of a conversation.'
122
+ g.long_desc %( Retrieve members of a conversation. )
111
123
  g.command 'members' do |c|
112
124
  c.flag 'channel', desc: 'ID of the conversation to retrieve members for.'
113
125
  c.flag 'cursor', desc: "Paginate through collections of data by setting the cursor parameter to a next_cursor attribute returned by a previous request's response_metadata. Default value fetches the first 'page' of the collection. See pagination for more detail."
@@ -117,8 +129,8 @@ command 'conversations' do |g|
117
129
  end
118
130
  end
119
131
 
120
- g.desc 'This Conversations API method opens a multi-person direct message or just a 1:1 direct message.'
121
- g.long_desc %( This Conversations API method opens a multi-person direct message or just a 1:1 direct message. )
132
+ g.desc 'Opens or resumes a direct message or multi-person direct message.'
133
+ g.long_desc %( Opens or resumes a direct message or multi-person direct message. )
122
134
  g.command 'open' do |c|
123
135
  c.flag 'channel', desc: "Resume a conversation by supplying an im or mpim's ID. Or provide the users field instead."
124
136
  c.flag 'return_im', desc: 'Boolean, indicates you want the full IM channel definition in the response.'
@@ -128,8 +140,8 @@ command 'conversations' do |g|
128
140
  end
129
141
  end
130
142
 
131
- g.desc 'This method renames a conversation. Some types of conversations cannot be renamed.'
132
- g.long_desc %( This method renames a conversation. Some types of conversations cannot be renamed. )
143
+ g.desc 'Renames a conversation.'
144
+ g.long_desc %( Renames a conversation. )
133
145
  g.command 'rename' do |c|
134
146
  c.flag 'channel', desc: 'ID of conversation to rename.'
135
147
  c.flag 'name', desc: 'New name for conversation.'
@@ -138,11 +150,11 @@ command 'conversations' do |g|
138
150
  end
139
151
  end
140
152
 
141
- g.desc 'This Conversations API method returns an entire thread (a message plus all the messages in reply to it), while conversations.history method returns only parent messages.'
142
- g.long_desc %( This Conversations API method returns an entire thread (a message plus all the messages in reply to it), while conversations.history method returns only parent messages. )
153
+ g.desc 'Retrieve a thread of messages posted to a conversation'
154
+ g.long_desc %( Retrieve a thread of messages posted to a conversation )
143
155
  g.command 'replies' do |c|
144
156
  c.flag 'channel', desc: 'Conversation ID to fetch thread from.'
145
- c.flag 'ts', desc: "Unique identifier of a thread's parent message."
157
+ c.flag 'ts', desc: "Unique identifier of a thread's parent message. ts must be the timestamp of an existing message with 0 or more replies. If there are no replies then just the single message referenced by ts will return - it is just an ordinary, unthreaded message."
146
158
  c.flag 'cursor', desc: "Paginate through collections of data by setting the cursor parameter to a next_cursor attribute returned by a previous request's response_metadata. Default value fetches the first 'page' of the collection. See pagination for more detail."
147
159
  c.flag 'inclusive', desc: 'Include messages with latest or oldest timestamp in results only when either timestamp is specified.'
148
160
  c.flag 'latest', desc: 'End of time range of messages to include in results.'
@@ -153,8 +165,8 @@ command 'conversations' do |g|
153
165
  end
154
166
  end
155
167
 
156
- g.desc 'This method is used to change the purpose of a conversation. The calling user must be a member of the conversation. Not all conversation types may have a purpose set.'
157
- g.long_desc %( This method is used to change the purpose of a conversation. The calling user must be a member of the conversation. Not all conversation types may have a purpose set. )
168
+ g.desc 'Sets the purpose for a conversation.'
169
+ g.long_desc %( Sets the purpose for a conversation. )
158
170
  g.command 'setPurpose' do |c|
159
171
  c.flag 'channel', desc: 'Conversation to set the purpose of.'
160
172
  c.flag 'purpose', desc: 'A new, specialer purpose.'
@@ -163,8 +175,8 @@ command 'conversations' do |g|
163
175
  end
164
176
  end
165
177
 
166
- g.desc 'This method is used to change the topic of a conversation. The calling user must be a member of the conversation. Not all conversation types support a new topic.'
167
- g.long_desc %( This method is used to change the topic of a conversation. The calling user must be a member of the conversation. Not all conversation types support a new topic. )
178
+ g.desc 'Sets the topic for a conversation.'
179
+ g.long_desc %( Sets the topic for a conversation. )
168
180
  g.command 'setTopic' do |c|
169
181
  c.flag 'channel', desc: 'Conversation to set the topic of.'
170
182
  c.flag 'topic', desc: 'The new topic string. Does not support formatting or linkification.'
@@ -173,8 +185,8 @@ command 'conversations' do |g|
173
185
  end
174
186
  end
175
187
 
176
- g.desc 'This method unarchives a conversation. The calling user is added to the conversation.'
177
- g.long_desc %( This method unarchives a conversation. The calling user is added to the conversation. )
188
+ g.desc 'Reverses conversation archival.'
189
+ g.long_desc %( Reverses conversation archival. )
178
190
  g.command 'unarchive' do |c|
179
191
  c.flag 'channel', desc: 'ID of conversation to unarchive.'
180
192
  c.action do |_global_options, options, _args|
@@ -1,9 +1,10 @@
1
+ # frozen_string_literal: true
1
2
  # This file was auto-generated by lib/tasks/web.rake
2
3
 
3
4
  desc 'Dialog methods.'
4
5
  command 'dialog' do |g|
5
- g.desc 'Open a dialog with a user by exchanging a trigger_id received from another interaction. See the dialogs documentation to learn how to obtain triggers define form elements.'
6
- g.long_desc %( Open a dialog with a user by exchanging a trigger_id received from another interaction. See the dialogs documentation to learn how to obtain triggers define form elements. )
6
+ g.desc 'Open a dialog with a user'
7
+ g.long_desc %( Open a dialog with a user )
7
8
  g.command 'open' do |c|
8
9
  c.flag 'dialog', desc: 'The dialog definition. This must be a JSON-encoded string.'
9
10
  c.flag 'trigger_id', desc: 'Exchange a trigger to post to the user.'
@@ -1,9 +1,10 @@
1
+ # frozen_string_literal: true
1
2
  # This file was auto-generated by lib/tasks/web.rake
2
3
 
3
- desc 'Dnd methods.'
4
+ desc 'Adjust and view Do Not Disturb settings for team members.'
4
5
  command 'dnd' do |g|
5
- g.desc "Ends the user's currently scheduled Do Not Disturb session immediately."
6
- g.long_desc %( Ends the user's currently scheduled Do Not Disturb session immediately. )
6
+ g.desc "Ends the current user's Do Not Disturb session immediately."
7
+ g.long_desc %( Ends the current user's Do Not Disturb session immediately. )
7
8
  g.command 'endDnd' do |c|
8
9
  c.action do |_global_options, options, _args|
9
10
  puts JSON.dump($client.dnd_endDnd(options))
@@ -18,8 +19,8 @@ command 'dnd' do |g|
18
19
  end
19
20
  end
20
21
 
21
- g.desc "Provides information about a user's current Do Not Disturb settings."
22
- g.long_desc %( Provides information about a user's current Do Not Disturb settings. )
22
+ g.desc "Retrieves a user's current Do Not Disturb status."
23
+ g.long_desc %( Retrieves a user's current Do Not Disturb status. )
23
24
  g.command 'info' do |c|
24
25
  c.flag 'user', desc: 'User to fetch status for (defaults to current user).'
25
26
  c.action do |_global_options, options, _args|
@@ -27,8 +28,8 @@ command 'dnd' do |g|
27
28
  end
28
29
  end
29
30
 
30
- g.desc "Adjusts the snooze duration for a user's Do Not Disturb settings. If a snooze session is not already active for the user, invoking this method will begin one for the specified duration."
31
- g.long_desc %( Adjusts the snooze duration for a user's Do Not Disturb settings. If a snooze session is not already active for the user, invoking this method will begin one for the specified duration. )
31
+ g.desc 'Turns on Do Not Disturb mode for the current user, or changes its duration.'
32
+ g.long_desc %( Turns on Do Not Disturb mode for the current user, or changes its duration. )
32
33
  g.command 'setSnooze' do |c|
33
34
  c.flag 'num_minutes', desc: 'Number of minutes, from now, to snooze until.'
34
35
  c.action do |_global_options, options, _args|
@@ -36,8 +37,8 @@ command 'dnd' do |g|
36
37
  end
37
38
  end
38
39
 
39
- g.desc 'Provides information about the current Do Not Disturb settings for a list of users in a Slack team.'
40
- g.long_desc %( Provides information about the current Do Not Disturb settings for a list of users in a Slack team. )
40
+ g.desc 'Retrieves the Do Not Disturb status for up to 50 users on a team.'
41
+ g.long_desc %( Retrieves the Do Not Disturb status for up to 50 users on a team. )
41
42
  g.command 'teamInfo' do |c|
42
43
  c.flag 'users', desc: 'Comma-separated list of users to fetch Do Not Disturb status for.'
43
44
  c.action do |_global_options, options, _args|
@@ -1,9 +1,10 @@
1
+ # frozen_string_literal: true
1
2
  # This file was auto-generated by lib/tasks/web.rake
2
3
 
3
4
  desc 'Emoji methods.'
4
5
  command 'emoji' do |g|
5
- g.desc 'This method lists the custom emoji for a team.'
6
- g.long_desc %( This method lists the custom emoji for a team. )
6
+ g.desc 'Lists custom emoji for a team.'
7
+ g.long_desc %( Lists custom emoji for a team. )
7
8
  g.command 'list' do |c|
8
9
  c.action do |_global_options, options, _args|
9
10
  puts JSON.dump($client.emoji_list(options))