slack-ruby-client 0.7.2 → 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (383) hide show
  1. checksums.yaml +5 -5
  2. data/.github/FUNDING.yml +1 -0
  3. data/.gitignore +2 -0
  4. data/.gitmodules +1 -1
  5. data/.rubocop.yml +37 -1
  6. data/.rubocop_todo.yml +130 -47
  7. data/.travis.yml +17 -13
  8. data/CHANGELOG.md +254 -43
  9. data/CONTRIBUTING.md +26 -15
  10. data/Dangerfile +3 -0
  11. data/Gemfile +13 -2
  12. data/LICENSE.md +1 -1
  13. data/README.md +287 -63
  14. data/RELEASING.md +22 -14
  15. data/Rakefile +2 -1
  16. data/UPGRADING.md +129 -5
  17. data/bin/commands/admin_analytics.rb +16 -0
  18. data/bin/commands/admin_apps.rb +51 -0
  19. data/bin/commands/admin_apps_approved.rb +17 -0
  20. data/bin/commands/admin_apps_requests.rb +17 -0
  21. data/bin/commands/admin_apps_restricted.rb +17 -0
  22. data/bin/commands/admin_auth_policy.rb +39 -0
  23. data/bin/commands/admin_barriers.rb +47 -0
  24. data/bin/commands/admin_conversations.rb +169 -0
  25. data/bin/commands/admin_conversations_ekm.rb +17 -0
  26. data/bin/commands/admin_conversations_restrictAccess.rb +37 -0
  27. data/bin/commands/admin_conversations_whitelist.rb +37 -0
  28. data/bin/commands/admin_emoji.rb +54 -0
  29. data/bin/commands/admin_inviteRequests.rb +36 -0
  30. data/bin/commands/admin_inviteRequests_approved.rb +16 -0
  31. data/bin/commands/admin_inviteRequests_denied.rb +16 -0
  32. data/bin/commands/admin_teams.rb +27 -0
  33. data/bin/commands/admin_teams_admins.rb +16 -0
  34. data/bin/commands/admin_teams_owners.rb +16 -0
  35. data/bin/commands/admin_teams_settings.rb +64 -0
  36. data/bin/commands/admin_usergroups.rb +48 -0
  37. data/bin/commands/admin_users.rb +98 -0
  38. data/bin/commands/admin_users_session.rb +78 -0
  39. data/bin/commands/api.rb +3 -3
  40. data/bin/commands/apps.rb +15 -0
  41. data/bin/commands/apps_connections.rb +13 -0
  42. data/bin/commands/apps_event_authorizations.rb +16 -0
  43. data/bin/commands/apps_manifest.rb +51 -0
  44. data/bin/commands/apps_permissions.rb +23 -0
  45. data/bin/commands/apps_permissions_resources.rb +15 -0
  46. data/bin/commands/apps_permissions_scopes.rb +13 -0
  47. data/bin/commands/apps_permissions_users.rb +26 -0
  48. data/bin/commands/auth.rb +12 -2
  49. data/bin/commands/auth_teams.rb +16 -0
  50. data/bin/commands/bots.rb +15 -0
  51. data/bin/commands/calls.rb +52 -0
  52. data/bin/commands/calls_participants.rb +25 -0
  53. data/bin/commands/channels.rb +6 -132
  54. data/bin/commands/chat.rb +127 -20
  55. data/bin/commands/chat_scheduledMessages.rb +19 -0
  56. data/bin/commands/conversations.rb +253 -0
  57. data/bin/commands/dialog.rb +15 -0
  58. data/bin/commands/dnd.rb +12 -9
  59. data/bin/commands/emoji.rb +3 -2
  60. data/bin/commands/files.rb +47 -31
  61. data/bin/commands/files_comments.rb +3 -23
  62. data/bin/commands/files_remote.rb +78 -0
  63. data/bin/commands/groups.rb +1 -154
  64. data/bin/commands/im.rb +1 -48
  65. data/bin/commands/migration.rb +16 -0
  66. data/bin/commands/mpim.rb +1 -48
  67. data/bin/commands/oauth.rb +4 -2
  68. data/bin/commands/oauth_v2.rb +29 -0
  69. data/bin/commands/openid_connect.rb +27 -0
  70. data/bin/commands/pins.rb +9 -12
  71. data/bin/commands/reactions.rb +17 -15
  72. data/bin/commands/reminders.rb +17 -10
  73. data/bin/commands/rtm.rb +19 -4
  74. data/bin/commands/search.rb +17 -12
  75. data/bin/commands/stars.rb +12 -9
  76. data/bin/commands/team.rb +23 -8
  77. data/bin/commands/team_billing.rb +13 -0
  78. data/bin/commands/team_preferences.rb +13 -0
  79. data/bin/commands/team_profile.rb +14 -0
  80. data/bin/commands/tooling_tokens.rb +14 -0
  81. data/bin/commands/usergroups.rb +23 -17
  82. data/bin/commands/usergroups_users.rb +7 -4
  83. data/bin/commands/users.rb +83 -27
  84. data/bin/commands/users_admin.rb +29 -0
  85. data/bin/commands/users_prefs.rb +13 -0
  86. data/bin/commands/users_profile.rb +27 -0
  87. data/bin/commands/views.rb +48 -0
  88. data/bin/commands/workflows.rb +38 -0
  89. data/bin/commands.rb +47 -5
  90. data/bin/slack +3 -4
  91. data/examples/hi_real_time_and_web/Gemfile +1 -0
  92. data/examples/hi_real_time_and_web/hi.rb +8 -4
  93. data/examples/{hi_real_time_async_celluloid → hi_real_time_async_async}/Gemfile +2 -1
  94. data/examples/{hi_real_time_async_celluloid → hi_real_time_async_async}/Procfile +0 -0
  95. data/examples/{hi_real_time_async_celluloid → hi_real_time_async_async}/hi.rb +13 -8
  96. data/examples/hi_web/Gemfile +1 -0
  97. data/examples/hi_web/hi.rb +2 -1
  98. data/examples/new_ticket/Gemfile +1 -0
  99. data/examples/new_ticket/new_ticket.rb +3 -2
  100. data/lib/slack/config.rb +2 -2
  101. data/lib/slack/events/config.rb +32 -0
  102. data/lib/slack/events/request.rb +72 -0
  103. data/lib/slack/logger.rb +6 -5
  104. data/lib/slack/messages/formatting.rb +4 -4
  105. data/lib/slack/messages/message.rb +6 -4
  106. data/lib/slack/real_time/api/message.rb +3 -1
  107. data/lib/slack/real_time/api/message_id.rb +1 -0
  108. data/lib/slack/real_time/api/ping.rb +5 -2
  109. data/lib/slack/real_time/api/templates/event_handler.erb +1 -1
  110. data/lib/slack/real_time/api/typing.rb +3 -1
  111. data/lib/slack/real_time/client.rb +116 -36
  112. data/lib/slack/real_time/concurrency/async.rb +138 -0
  113. data/lib/slack/real_time/concurrency.rb +2 -2
  114. data/lib/slack/real_time/config.rb +17 -19
  115. data/lib/slack/real_time/models/base.rb +3 -3
  116. data/lib/slack/real_time/models/bot.rb +1 -0
  117. data/lib/slack/real_time/models/channel.rb +1 -0
  118. data/lib/slack/real_time/models/group.rb +1 -0
  119. data/lib/slack/real_time/models/im.rb +1 -0
  120. data/lib/slack/real_time/models/team.rb +1 -0
  121. data/lib/slack/real_time/models/user.rb +1 -0
  122. data/lib/slack/real_time/models.rb +8 -7
  123. data/lib/slack/real_time/socket.rb +51 -23
  124. data/lib/slack/real_time/stores/base.rb +6 -9
  125. data/lib/slack/real_time/stores/starter.rb +143 -69
  126. data/lib/slack/real_time/stores/store.rb +160 -82
  127. data/lib/slack/real_time/stores.rb +4 -3
  128. data/lib/slack/version.rb +2 -1
  129. data/lib/slack/web/api/endpoints/admin_analytics.rb +28 -0
  130. data/lib/slack/web/api/endpoints/admin_apps.rb +78 -0
  131. data/lib/slack/web/api/endpoints/admin_apps_approved.rb +35 -0
  132. data/lib/slack/web/api/endpoints/admin_apps_requests.rb +35 -0
  133. data/lib/slack/web/api/endpoints/admin_apps_restricted.rb +35 -0
  134. data/lib/slack/web/api/endpoints/admin_auth_policy.rb +72 -0
  135. data/lib/slack/web/api/endpoints/admin_barriers.rb +82 -0
  136. data/lib/slack/web/api/endpoints/admin_conversations.rb +260 -0
  137. data/lib/slack/web/api/endpoints/admin_conversations_ekm.rb +35 -0
  138. data/lib/slack/web/api/endpoints/admin_conversations_restrictAccess.rb +61 -0
  139. data/lib/slack/web/api/endpoints/admin_conversations_whitelist.rb +64 -0
  140. data/lib/slack/web/api/endpoints/admin_emoji.rb +88 -0
  141. data/lib/slack/web/api/endpoints/admin_inviteRequests.rb +61 -0
  142. data/lib/slack/web/api/endpoints/admin_inviteRequests_approved.rb +33 -0
  143. data/lib/slack/web/api/endpoints/admin_inviteRequests_denied.rb +33 -0
  144. data/lib/slack/web/api/endpoints/admin_teams.rb +50 -0
  145. data/lib/slack/web/api/endpoints/admin_teams_admins.rb +34 -0
  146. data/lib/slack/web/api/endpoints/admin_teams_owners.rb +34 -0
  147. data/lib/slack/web/api/endpoints/admin_teams_settings.rb +99 -0
  148. data/lib/slack/web/api/endpoints/admin_usergroups.rb +77 -0
  149. data/lib/slack/web/api/endpoints/admin_users.rb +163 -0
  150. data/lib/slack/web/api/endpoints/admin_users_session.rb +122 -0
  151. data/lib/slack/web/api/endpoints/api.rb +4 -5
  152. data/lib/slack/web/api/endpoints/apps.rb +27 -0
  153. data/lib/slack/web/api/endpoints/apps_connections.rb +21 -0
  154. data/lib/slack/web/api/endpoints/apps_event_authorizations.rb +34 -0
  155. data/lib/slack/web/api/endpoints/apps_manifest.rb +75 -0
  156. data/lib/slack/web/api/endpoints/apps_permissions.rb +36 -0
  157. data/lib/slack/web/api/endpoints/apps_permissions_resources.rb +31 -0
  158. data/lib/slack/web/api/endpoints/apps_permissions_scopes.rb +21 -0
  159. data/lib/slack/web/api/endpoints/apps_permissions_users.rb +50 -0
  160. data/lib/slack/web/api/endpoints/auth.rb +14 -2
  161. data/lib/slack/web/api/endpoints/auth_teams.rb +33 -0
  162. data/lib/slack/web/api/endpoints/bots.rb +25 -0
  163. data/lib/slack/web/api/endpoints/calls.rb +83 -0
  164. data/lib/slack/web/api/endpoints/calls_participants.rb +42 -0
  165. data/lib/slack/web/api/endpoints/channels.rb +8 -201
  166. data/lib/slack/web/api/endpoints/chat.rb +252 -42
  167. data/lib/slack/web/api/endpoints/chat_scheduledMessages.rb +40 -0
  168. data/lib/slack/web/api/endpoints/conversations.rb +422 -0
  169. data/lib/slack/web/api/endpoints/dialog.rb +33 -0
  170. data/lib/slack/web/api/endpoints/dnd.rb +17 -12
  171. data/lib/slack/web/api/endpoints/emoji.rb +3 -2
  172. data/lib/slack/web/api/endpoints/files.rb +82 -43
  173. data/lib/slack/web/api/endpoints/files_comments.rb +4 -36
  174. data/lib/slack/web/api/endpoints/files_remote.rb +127 -0
  175. data/lib/slack/web/api/endpoints/groups.rb +1 -235
  176. data/lib/slack/web/api/endpoints/im.rb +1 -73
  177. data/lib/slack/web/api/endpoints/migration.rb +28 -0
  178. data/lib/slack/web/api/endpoints/mpim.rb +1 -72
  179. data/lib/slack/web/api/endpoints/oauth.rb +9 -10
  180. data/lib/slack/web/api/endpoints/oauth_v2.rb +48 -0
  181. data/lib/slack/web/api/endpoints/openid_connect.rb +42 -0
  182. data/lib/slack/web/api/endpoints/pins.rb +14 -23
  183. data/lib/slack/web/api/endpoints/presence.rb +1 -1
  184. data/lib/slack/web/api/endpoints/reactions.rb +43 -34
  185. data/lib/slack/web/api/endpoints/reminders.rb +28 -15
  186. data/lib/slack/web/api/endpoints/rtm.rb +29 -8
  187. data/lib/slack/web/api/endpoints/search.rb +39 -24
  188. data/lib/slack/web/api/endpoints/stars.rb +30 -22
  189. data/lib/slack/web/api/endpoints/team.rb +34 -11
  190. data/lib/slack/web/api/endpoints/team_billing.rb +21 -0
  191. data/lib/slack/web/api/endpoints/team_preferences.rb +21 -0
  192. data/lib/slack/web/api/endpoints/team_profile.rb +23 -0
  193. data/lib/slack/web/api/endpoints/tooling_tokens.rb +24 -0
  194. data/lib/slack/web/api/endpoints/usergroups.rb +43 -32
  195. data/lib/slack/web/api/endpoints/usergroups_users.rb +14 -9
  196. data/lib/slack/web/api/endpoints/users.rb +104 -19
  197. data/lib/slack/web/api/endpoints/users_admin.rb +49 -0
  198. data/lib/slack/web/api/endpoints/users_prefs.rb +21 -0
  199. data/lib/slack/web/api/endpoints/users_profile.rb +44 -0
  200. data/lib/slack/web/api/endpoints/views.rb +97 -0
  201. data/lib/slack/web/api/endpoints/workflows.rb +61 -0
  202. data/lib/slack/web/api/endpoints.rb +111 -29
  203. data/lib/slack/web/api/error.rb +2 -8
  204. data/lib/slack/web/api/errors/server_error.rb +37 -0
  205. data/lib/slack/web/api/errors/slack_error.rb +29 -0
  206. data/lib/slack/web/api/errors/too_many_requests_error.rb +21 -0
  207. data/lib/slack/web/api/errors.rb +1040 -0
  208. data/lib/slack/web/api/mixins/conversations.id.rb +25 -0
  209. data/lib/slack/web/api/mixins/ids.id.rb +24 -0
  210. data/lib/slack/web/api/mixins/users.id.rb +6 -7
  211. data/lib/slack/web/api/mixins/users.search.rb +39 -36
  212. data/lib/slack/web/api/mixins.rb +4 -4
  213. data/lib/slack/web/api/patches/chat.1.patch +70 -0
  214. data/lib/slack/web/api/patches/dialog.1.open-json-support.patch +17 -0
  215. data/lib/slack/web/api/patches/views.1.view-json.patch +40 -0
  216. data/lib/slack/web/api/patches/views.1.views-published.patch +16 -0
  217. data/lib/slack/web/api/templates/command.erb +5 -3
  218. data/lib/slack/web/api/templates/commands.erb +2 -1
  219. data/lib/slack/web/api/templates/endpoints.erb +5 -5
  220. data/lib/slack/web/api/templates/errors.erb +20 -0
  221. data/lib/slack/web/api/templates/method.erb +26 -4
  222. data/lib/slack/web/api/templates/method_spec.erb +3 -2
  223. data/lib/slack/web/client.rb +2 -1
  224. data/lib/slack/web/config.rb +21 -10
  225. data/lib/slack/web/faraday/connection.rb +25 -16
  226. data/lib/slack/web/faraday/request.rb +4 -1
  227. data/lib/slack/web/faraday/response/raise_error.rb +19 -1
  228. data/lib/slack/web/faraday/response/wrap_error.rb +24 -0
  229. data/lib/slack/web/pagination/cursor.rb +48 -0
  230. data/lib/slack-ruby-client.rb +40 -26
  231. data/lib/slack.rb +1 -0
  232. data/lib/slack_ruby_client.rb +1 -0
  233. data/lib/tasks/git.rake +2 -1
  234. data/lib/tasks/real_time.rake +16 -6
  235. data/lib/tasks/update.rake +1 -0
  236. data/lib/tasks/web.rake +42 -10
  237. data/screenshots/create-app.png +0 -0
  238. data/slack-ruby-client.gemspec +11 -9
  239. data/spec/fixtures/slack/web/429_error.yml +50 -52
  240. data/spec/fixtures/slack/web/auth_test_error.yml +51 -18
  241. data/spec/fixtures/slack/web/auth_test_success.yml +50 -26
  242. data/spec/fixtures/slack/web/conversations_info.yml +167 -0
  243. data/spec/fixtures/slack/web/conversations_setTopic.yml +84 -0
  244. data/spec/fixtures/slack/web/conversations_setTopic_one_page.yml +172 -0
  245. data/spec/fixtures/slack/web/conversations_setTopic_paginated.yml +253 -0
  246. data/spec/fixtures/slack/web/paginated_users_list.yml +613 -0
  247. data/spec/fixtures/slack/web/rtm_connect.yml +307 -0
  248. data/spec/fixtures/slack/web/rtm_start.yml +771 -60
  249. data/spec/fixtures/slack/web/users_info.yml +153 -69
  250. data/spec/fixtures/slack/web/users_list.yml +102 -41
  251. data/spec/fixtures/slack/web/views_open_error.yml +83 -0
  252. data/spec/integration/integration_spec.rb +116 -48
  253. data/spec/slack/config_spec.rb +2 -0
  254. data/spec/slack/events/config_spec.rb +33 -0
  255. data/spec/slack/events/request_spec.rb +184 -0
  256. data/spec/slack/messages/formatting_spec.rb +25 -14
  257. data/spec/slack/real_time/api/message_spec.rb +6 -1
  258. data/spec/slack/real_time/api/ping_spec.rb +2 -0
  259. data/spec/slack/real_time/api/typing_spec.rb +5 -1
  260. data/spec/slack/real_time/client_spec.rb +465 -141
  261. data/spec/slack/real_time/concurrency/it_behaves_like_a_realtime_socket.rb +21 -0
  262. data/spec/slack/real_time/concurrency/with_concurrency_spec.rb +10 -0
  263. data/spec/slack/real_time/concurrency/without_concurrency_spec.rb +10 -0
  264. data/spec/slack/real_time/event_handlers/bot_spec.rb +7 -4
  265. data/spec/slack/real_time/event_handlers/channel_spec.rb +10 -7
  266. data/spec/slack/real_time/event_handlers/event_handlers_spec.rb +3 -2
  267. data/spec/slack/real_time/event_handlers/group_spec.rb +5 -4
  268. data/spec/slack/real_time/event_handlers/im_spec.rb +9 -8
  269. data/spec/slack/real_time/event_handlers/team_spec.rb +8 -4
  270. data/spec/slack/real_time/event_handlers/user_spec.rb +7 -4
  271. data/spec/slack/real_time/rtm_connect_spec.rb +14 -0
  272. data/spec/slack/real_time/rtm_start_spec.rb +2 -1
  273. data/spec/slack/real_time/store_spec.rb +2 -1
  274. data/spec/slack/slack_spec.rb +42 -8
  275. data/spec/slack/version_spec.rb +2 -1
  276. data/spec/slack/web/api/endpoints/admin_analytics_spec.rb +13 -0
  277. data/spec/slack/web/api/endpoints/admin_apps_approved_spec.rb +8 -0
  278. data/spec/slack/web/api/endpoints/admin_apps_requests_spec.rb +8 -0
  279. data/spec/slack/web/api/endpoints/admin_apps_restricted_spec.rb +8 -0
  280. data/spec/slack/web/api/endpoints/admin_apps_spec.rb +18 -0
  281. data/spec/slack/web/api/endpoints/admin_auth_policy_spec.rb +35 -0
  282. data/spec/slack/web/api/endpoints/admin_barriers_spec.rb +38 -0
  283. data/spec/slack/web/api/endpoints/admin_conversations_ekm_spec.rb +8 -0
  284. data/spec/slack/web/api/endpoints/admin_conversations_restrictAccess_spec.rb +32 -0
  285. data/spec/slack/web/api/endpoints/admin_conversations_spec.rb +98 -0
  286. data/spec/slack/web/api/endpoints/admin_emoji_spec.rb +37 -0
  287. data/spec/slack/web/api/endpoints/admin_inviteRequests_approved_spec.rb +8 -0
  288. data/spec/slack/web/api/endpoints/admin_inviteRequests_denied_spec.rb +8 -0
  289. data/spec/slack/web/api/endpoints/admin_inviteRequests_spec.rb +18 -0
  290. data/spec/slack/web/api/endpoints/admin_teams_admins_spec.rb +13 -0
  291. data/spec/slack/web/api/endpoints/admin_teams_owners_spec.rb +13 -0
  292. data/spec/slack/web/api/endpoints/admin_teams_settings_spec.rb +53 -0
  293. data/spec/slack/web/api/endpoints/admin_teams_spec.rb +16 -0
  294. data/spec/slack/web/api/endpoints/admin_usergroups_spec.rb +37 -0
  295. data/spec/slack/web/api/endpoints/admin_users_session_spec.rb +41 -0
  296. data/spec/slack/web/api/endpoints/admin_users_spec.rb +67 -0
  297. data/spec/slack/web/api/endpoints/api_spec.rb +1 -0
  298. data/spec/slack/web/api/endpoints/apps_connections_spec.rb +8 -0
  299. data/spec/slack/web/api/endpoints/apps_event_authorizations_spec.rb +13 -0
  300. data/spec/slack/web/api/endpoints/apps_manifest_spec.rb +36 -0
  301. data/spec/slack/web/api/endpoints/apps_spec.rb +16 -0
  302. data/spec/slack/web/api/endpoints/auth_teams_spec.rb +8 -0
  303. data/spec/slack/web/api/endpoints/bots_spec.rb +8 -0
  304. data/spec/slack/web/api/endpoints/calls_participants_spec.rb +24 -0
  305. data/spec/slack/web/api/endpoints/calls_spec.rb +31 -0
  306. data/spec/slack/web/api/endpoints/chat_scheduledMessages_spec.rb +8 -0
  307. data/spec/slack/web/api/endpoints/custom_specs/auth_spec.rb +11 -4
  308. data/spec/slack/web/api/endpoints/custom_specs/chat_spec.rb +140 -24
  309. data/spec/slack/web/api/endpoints/custom_specs/conversations_spec.rb +13 -0
  310. data/spec/slack/web/api/endpoints/custom_specs/dialog_spec.rb +36 -0
  311. data/spec/slack/web/api/endpoints/custom_specs/users_spec.rb +22 -7
  312. data/spec/slack/web/api/endpoints/custom_specs/views_spec.rb +95 -0
  313. data/spec/slack/web/api/endpoints/dnd_spec.rb +4 -3
  314. data/spec/slack/web/api/endpoints/emoji_spec.rb +1 -0
  315. data/spec/slack/web/api/endpoints/files_comments_spec.rb +3 -21
  316. data/spec/slack/web/api/endpoints/files_remote_spec.rb +24 -0
  317. data/spec/slack/web/api/endpoints/files_spec.rb +17 -5
  318. data/spec/slack/web/api/endpoints/migration_spec.rb +13 -0
  319. data/spec/slack/web/api/endpoints/oauth_spec.rb +1 -11
  320. data/spec/slack/web/api/endpoints/oauth_v2_spec.rb +16 -0
  321. data/spec/slack/web/api/endpoints/openid_connect_spec.rb +8 -0
  322. data/spec/slack/web/api/endpoints/pins_spec.rb +1 -0
  323. data/spec/slack/web/api/endpoints/reactions_spec.rb +8 -1
  324. data/spec/slack/web/api/endpoints/reminders_spec.rb +3 -2
  325. data/spec/slack/web/api/endpoints/rtm_spec.rb +1 -0
  326. data/spec/slack/web/api/endpoints/search_spec.rb +1 -0
  327. data/spec/slack/web/api/endpoints/stars_spec.rb +1 -0
  328. data/spec/slack/web/api/endpoints/team_billing_spec.rb +8 -0
  329. data/spec/slack/web/api/endpoints/team_preferences_spec.rb +8 -0
  330. data/spec/slack/web/api/endpoints/team_profile_spec.rb +8 -0
  331. data/spec/slack/web/api/endpoints/team_spec.rb +1 -0
  332. data/spec/slack/web/api/endpoints/tooling_tokens_spec.rb +13 -0
  333. data/spec/slack/web/api/endpoints/usergroups_spec.rb +1 -0
  334. data/spec/slack/web/api/endpoints/usergroups_users_spec.rb +3 -2
  335. data/spec/slack/web/api/endpoints/users_admin_spec.rb +18 -0
  336. data/spec/slack/web/api/endpoints/users_prefs_spec.rb +8 -0
  337. data/spec/slack/web/api/endpoints/users_profile_spec.rb +8 -0
  338. data/spec/slack/web/api/endpoints/workflows_spec.rb +26 -0
  339. data/spec/slack/web/api/error_spec.rb +7 -7
  340. data/spec/slack/web/api/errors/slack_error_spec.rb +33 -0
  341. data/spec/slack/web/api/mixins/conversations_list_spec.rb +21 -0
  342. data/spec/slack/web/api/mixins/conversations_spec.rb +43 -0
  343. data/spec/slack/web/api/mixins/users_spec.rb +30 -17
  344. data/spec/slack/web/api/pagination/cursor_spec.rb +98 -0
  345. data/spec/slack/web/client_spec.rb +211 -14
  346. data/spec/slack/web/faraday/request_spec.rb +80 -0
  347. data/spec/slack/web/faraday/response/raise_error_spec.rb +86 -0
  348. data/spec/spec_helper.rb +9 -2
  349. data/spec/support/queue_with_timeout.rb +6 -5
  350. data/spec/support/real_time/concurrency/mock.rb +2 -2
  351. data/spec/support/real_time/connected_client.rb +7 -2
  352. data/spec/support/real_time/event.rb +1 -0
  353. data/spec/support/token.rb +1 -0
  354. data/spec/support/vcr.rb +37 -1
  355. metadata +250 -130
  356. data/examples/hi_real_time/Gemfile +0 -5
  357. data/examples/hi_real_time/hi.gif +0 -0
  358. data/examples/hi_real_time/hi.rb +0 -37
  359. data/examples/hi_real_time_async/Gemfile +0 -5
  360. data/examples/hi_real_time_async/hi.rb +0 -29
  361. data/examples/hi_real_time_async_eventmachine/Gemfile +0 -6
  362. data/examples/hi_real_time_async_eventmachine/Procfile +0 -2
  363. data/examples/hi_real_time_async_eventmachine/hi.rb +0 -36
  364. data/lib/slack/real_time/concurrency/celluloid.rb +0 -100
  365. data/lib/slack/real_time/concurrency/eventmachine.rb +0 -60
  366. data/lib/slack/web/api/mixins/channels.id.json +0 -20
  367. data/lib/slack/web/api/mixins/channels.id.rb +0 -26
  368. data/lib/slack/web/api/mixins/groups.id.json +0 -20
  369. data/lib/slack/web/api/mixins/groups.id.rb +0 -26
  370. data/lib/slack/web/api/patches/chat.1.text-attachments-required.patch +0 -13
  371. data/lib/slack/web/api/patches/chat.2.attachments-json.patch +0 -17
  372. data/lib/slack/web/api/patches/chat.3.update-attachments-support.patch +0 -20
  373. data/screenshots/register-bot.png +0 -0
  374. data/spec/fixtures/slack/web/channels_info.yml +0 -46
  375. data/spec/fixtures/slack/web/groups_info.yml +0 -43
  376. data/spec/slack/real_time/concurrency/celluloid_spec.rb +0 -35
  377. data/spec/slack/real_time/concurrency/eventmachine_spec.rb +0 -50
  378. data/spec/slack/web/api/endpoints/custom_specs/channels_spec.rb +0 -11
  379. data/spec/slack/web/api/endpoints/custom_specs/groups_spec.rb +0 -11
  380. data/spec/slack/web/api/endpoints/im_spec.rb +0 -30
  381. data/spec/slack/web/api/endpoints/mpim_spec.rb +0 -30
  382. data/spec/slack/web/api/mixins/channels_spec.rb +0 -31
  383. data/spec/slack/web/api/mixins/groups_spec.rb +0 -31
@@ -1,3 +1,4 @@
1
+ # frozen_string_literal: true
1
2
  # This file was auto-generated by lib/tasks/web.rake
2
3
 
3
4
  module Slack
@@ -6,92 +7,301 @@ module Slack
6
7
  module Endpoints
7
8
  module Chat
8
9
  #
9
- # This method deletes a message from a channel.
10
+ # Execute a slash command in a public channel (undocumented)
11
+ #
12
+ # @option options [channel] :channel
13
+ # Channel to execute the command in.
14
+ # @option options [Object] :command
15
+ # Slash command to be executed. Leading backslash is required.
16
+ # @option options [Object] :text
17
+ # Additional parameters provided to the slash command.
18
+ # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/undocumented/chat/chat.command.json
19
+ def chat_command(options = {})
20
+ throw ArgumentError.new('Required arguments :channel missing') if options[:channel].nil?
21
+ throw ArgumentError.new('Required arguments :command missing') if options[:command].nil?
22
+ options = options.merge(channel: conversations_id(options)['channel']['id']) if options[:channel]
23
+ logger.warn('The chat.command method is undocumented.')
24
+ post('chat.command', options)
25
+ end
26
+
27
+ #
28
+ # Deletes a message.
10
29
  #
11
- # @option options [timestamp] :ts
12
- # Timestamp of the message to be deleted.
13
30
  # @option options [channel] :channel
14
31
  # Channel containing the message to be deleted.
15
- # @option options [Object] :as_user
16
- # Pass true to delete the message as the authed user. Bot users in this context are considered authed users.
32
+ # @option options [timestamp] :ts
33
+ # Timestamp of the message to be deleted.
34
+ # @option options [boolean] :as_user
35
+ # Pass true to delete the message as the authed user with chat:write:user scope. Bot users in this context are considered authed users. If unused or false, the message will be deleted with chat:write:bot scope.
17
36
  # @see https://api.slack.com/methods/chat.delete
18
- # @see https://github.com/dblock/slack-api-ref/blob/master/methods/chat/chat.delete.json
37
+ # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/chat/chat.delete.json
19
38
  def chat_delete(options = {})
20
- throw ArgumentError.new('Required arguments :ts missing') if options[:ts].nil?
21
39
  throw ArgumentError.new('Required arguments :channel missing') if options[:channel].nil?
22
- options = options.merge(channel: channels_id(options)['channel']['id']) if options[:channel]
40
+ throw ArgumentError.new('Required arguments :ts missing') if options[:ts].nil?
41
+ options = options.merge(channel: conversations_id(options)['channel']['id']) if options[:channel]
23
42
  post('chat.delete', options)
24
43
  end
25
44
 
26
45
  #
27
- # This method posts a message to a public channel, private group, or IM channel.
46
+ # Deletes a pending scheduled message from the queue.
28
47
  #
29
48
  # @option options [channel] :channel
30
- # Channel, private group, or IM channel to send message to. Can be an encoded ID, or a name. See below for more details.
31
- # @option options [Object] :text
32
- # Text of the message to send. See below for an explanation of formatting.
33
- # @option options [Object] :parse
49
+ # The channel the scheduled_message is posting to.
50
+ # @option options [string] :scheduled_message_id
51
+ # scheduled_message_id returned from call to chat.scheduleMessage.
52
+ # @option options [boolean] :as_user
53
+ # Pass true to delete the message as the authed user with chat:write:user scope. Bot users in this context are considered authed users. If unused or false, the message will be deleted with chat:write:bot scope.
54
+ # @see https://api.slack.com/methods/chat.deleteScheduledMessage
55
+ # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/chat/chat.deleteScheduledMessage.json
56
+ def chat_deleteScheduledMessage(options = {})
57
+ throw ArgumentError.new('Required arguments :channel missing') if options[:channel].nil?
58
+ throw ArgumentError.new('Required arguments :scheduled_message_id missing') if options[:scheduled_message_id].nil?
59
+ options = options.merge(channel: conversations_id(options)['channel']['id']) if options[:channel]
60
+ post('chat.deleteScheduledMessage', options)
61
+ end
62
+
63
+ #
64
+ # Retrieve a permalink URL for a specific extant message
65
+ #
66
+ # @option options [channel] :channel
67
+ # The ID of the conversation or channel containing the message.
68
+ # @option options [string] :message_ts
69
+ # A message's ts value, uniquely identifying it within a channel.
70
+ # @see https://api.slack.com/methods/chat.getPermalink
71
+ # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/chat/chat.getPermalink.json
72
+ def chat_getPermalink(options = {})
73
+ throw ArgumentError.new('Required arguments :channel missing') if options[:channel].nil?
74
+ throw ArgumentError.new('Required arguments :message_ts missing') if options[:message_ts].nil?
75
+ options = options.merge(channel: conversations_id(options)['channel']['id']) if options[:channel]
76
+ post('chat.getPermalink', options)
77
+ end
78
+
79
+ #
80
+ # Share a me message into a channel.
81
+ #
82
+ # @option options [channel] :channel
83
+ # Channel to send message to. Can be a public channel, private group or IM channel. Can be an encoded ID, or a name.
84
+ # @option options [string] :text
85
+ # Text of the message to send.
86
+ # @see https://api.slack.com/methods/chat.meMessage
87
+ # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/chat/chat.meMessage.json
88
+ def chat_meMessage(options = {})
89
+ throw ArgumentError.new('Required arguments :channel missing') if options[:channel].nil?
90
+ throw ArgumentError.new('Required arguments :text missing') if options[:text].nil?
91
+ post('chat.meMessage', options)
92
+ end
93
+
94
+ #
95
+ # Sends an ephemeral message to a user in a channel.
96
+ #
97
+ # @option options [channel] :channel
98
+ # Channel, private group, or IM channel to send message to. Can be an encoded ID, or a name.
99
+ # @option options [string] :text
100
+ # How this field works and whether it is required depends on other fields you use in your API call. See below for more detail.
101
+ # @option options [user] :user
102
+ # id of the user who will receive the ephemeral message. The user should be in the channel specified by the channel argument.
103
+ # @option options [boolean] :as_user
104
+ # 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.
105
+ # @option options [string] :attachments
106
+ # A JSON-based array of structured attachments, presented as a URL-encoded string.
107
+ # @option options [blocks[] as string] :blocks
108
+ # A JSON-based array of structured blocks, presented as a URL-encoded string.
109
+ # @option options [string] :icon_emoji
110
+ # 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.
111
+ # @option options [string] :icon_url
112
+ # 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.
113
+ # @option options [boolean] :link_names
114
+ # Find and link channel names and usernames.
115
+ # @option options [string] :parse
34
116
  # Change how messages are treated. Defaults to none. See below.
35
- # @option options [Object] :link_names
117
+ # @option options [string] :thread_ts
118
+ # Provide another message's ts value to post this message in a thread. Avoid using a reply's ts value; use its parent's value instead. Ephemeral messages in threads are only shown if there is already an active thread.
119
+ # @option options [string] :username
120
+ # Set your bot's user name. Must be used in conjunction with as_user set to false, otherwise ignored. See authorship below.
121
+ # @see https://api.slack.com/methods/chat.postEphemeral
122
+ # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/chat/chat.postEphemeral.json
123
+ def chat_postEphemeral(options = {})
124
+ throw ArgumentError.new('Required arguments :channel missing') if options[:channel].nil?
125
+ throw ArgumentError.new('Required arguments :text, :attachments or :blocks missing') if options[:text].nil? && options[:attachments].nil? && options[:blocks].nil?
126
+ throw ArgumentError.new('Required arguments :user missing') if options[:user].nil?
127
+ options = options.merge(user: users_id(options)['user']['id']) if options[:user]
128
+ # attachments must be passed as an encoded JSON string
129
+ if options.key?(:attachments)
130
+ attachments = options[:attachments]
131
+ attachments = JSON.dump(attachments) unless attachments.is_a?(String)
132
+ options = options.merge(attachments: attachments)
133
+ end
134
+ # blocks must be passed as an encoded JSON string
135
+ if options.key?(:blocks)
136
+ blocks = options[:blocks]
137
+ blocks = JSON.dump(blocks) unless blocks.is_a?(String)
138
+ options = options.merge(blocks: blocks)
139
+ end
140
+ post('chat.postEphemeral', options)
141
+ end
142
+
143
+ #
144
+ # Sends a message to a channel.
145
+ #
146
+ # @option options [channel] :channel
147
+ # Channel, private group, or IM channel to send message to. Can be an encoded ID, or a name. See below for more details.
148
+ # @option options [string] :attachments
149
+ # A JSON-based array of structured attachments, presented as a URL-encoded string.
150
+ # @option options [blocks[] as string] :blocks
151
+ # A JSON-based array of structured blocks, presented as a URL-encoded string.
152
+ # @option options [string] :text
153
+ # The formatted text of the message to be published. If blocks are included, this will become the fallback text used in notifications.
154
+ # @option options [boolean] :as_user
155
+ # Pass true to post the message as the authed user, instead of as a bot. Defaults to false. See authorship below.
156
+ # @option options [string] :icon_emoji
157
+ # 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.
158
+ # @option options [string] :icon_url
159
+ # 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.
160
+ # @option options [boolean] :link_names
36
161
  # Find and link channel names and usernames.
37
- # @option options [Object] :attachments
38
- # Structured message attachments.
39
- # @option options [Object] :unfurl_links
162
+ # @option options [boolean] :mrkdwn
163
+ # Disable Slack markup parsing by setting to false. Enabled by default.
164
+ # @option options [string] :parse
165
+ # Change how messages are treated. Defaults to none. See below.
166
+ # @option options [boolean] :reply_broadcast
167
+ # Used in conjunction with thread_ts and indicates whether reply should be made visible to everyone in the channel or conversation. Defaults to false.
168
+ # @option options [string] :thread_ts
169
+ # Provide another message's ts value to make this message a reply. Avoid using a reply's ts value; use its parent instead.
170
+ # @option options [boolean] :unfurl_links
40
171
  # Pass true to enable unfurling of primarily text-based content.
41
- # @option options [Object] :unfurl_media
172
+ # @option options [boolean] :unfurl_media
42
173
  # Pass false to disable unfurling of media content.
43
- # @option options [Object] :username
174
+ # @option options [string] :username
44
175
  # Set your bot's user name. Must be used in conjunction with as_user set to false, otherwise ignored. See authorship below.
45
- # @option options [Object] :as_user
46
- # Pass true to post the message as the authed user, instead of as a bot. Defaults to false. See authorship below.
47
- # @option options [Object] :icon_url
48
- # 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.
49
- # @option options [Object] :icon_emoji
50
- # 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.
51
176
  # @see https://api.slack.com/methods/chat.postMessage
52
- # @see https://github.com/dblock/slack-api-ref/blob/master/methods/chat/chat.postMessage.json
177
+ # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/chat/chat.postMessage.json
53
178
  def chat_postMessage(options = {})
54
179
  throw ArgumentError.new('Required arguments :channel missing') if options[:channel].nil?
55
- throw ArgumentError.new('Required arguments :text or :attachments missing') if options[:text].nil? && options[:attachments].nil?
180
+ throw ArgumentError.new('Required arguments :text, :attachments or :blocks missing') if options[:text].nil? && options[:attachments].nil? && options[:blocks].nil?
56
181
  # attachments must be passed as an encoded JSON string
57
182
  if options.key?(:attachments)
58
183
  attachments = options[:attachments]
59
184
  attachments = JSON.dump(attachments) unless attachments.is_a?(String)
60
185
  options = options.merge(attachments: attachments)
61
186
  end
187
+ # blocks must be passed as an encoded JSON string
188
+ if options.key?(:blocks)
189
+ blocks = options[:blocks]
190
+ blocks = JSON.dump(blocks) unless blocks.is_a?(String)
191
+ options = options.merge(blocks: blocks)
192
+ end
62
193
  post('chat.postMessage', options)
63
194
  end
64
195
 
65
196
  #
66
- # This method updates a message in a channel. Though related to chat.postMessage, some parameters of chat.update are handled differently.
197
+ # Schedules a message to be sent to a channel.
67
198
  #
199
+ # @option options [channel] :channel
200
+ # Channel, private group, or DM channel to send message to. Can be an encoded ID, or a name. See below for more details.
201
+ # @option options [integer] :post_at
202
+ # Unix EPOCH timestamp of time in future to send the message.
203
+ # @option options [string] :text
204
+ # How this field works and whether it is required depends on other fields you use in your API call. See below for more detail.
205
+ # @option options [boolean] :as_user
206
+ # Pass true to post the message as the authed user, instead of as a bot. Defaults to false. See chat.postMessage.
207
+ # @option options [string] :attachments
208
+ # A JSON-based array of structured attachments, presented as a URL-encoded string.
209
+ # @option options [blocks[] as string] :blocks
210
+ # A JSON-based array of structured blocks, presented as a URL-encoded string.
211
+ # @option options [boolean] :link_names
212
+ # Find and link channel names and usernames.
213
+ # @option options [string] :parse
214
+ # Change how messages are treated. Defaults to none. See chat.postMessage.
215
+ # @option options [boolean] :reply_broadcast
216
+ # Used in conjunction with thread_ts and indicates whether reply should be made visible to everyone in the channel or conversation. Defaults to false.
217
+ # @option options [string] :thread_ts
218
+ # Provide another message's ts value to make this message a reply. Avoid using a reply's ts value; use its parent instead.
219
+ # @option options [boolean] :unfurl_links
220
+ # Pass true to enable unfurling of primarily text-based content.
221
+ # @option options [boolean] :unfurl_media
222
+ # Pass false to disable unfurling of media content.
223
+ # @see https://api.slack.com/methods/chat.scheduleMessage
224
+ # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/chat/chat.scheduleMessage.json
225
+ def chat_scheduleMessage(options = {})
226
+ throw ArgumentError.new('Required arguments :channel missing') if options[:channel].nil?
227
+ throw ArgumentError.new('Required arguments :post_at missing') if options[:post_at].nil?
228
+ throw ArgumentError.new('Required arguments :text missing') if options[:text].nil?
229
+ post('chat.scheduleMessage', options)
230
+ end
231
+
232
+ #
233
+ # Provide custom unfurl behavior for user-posted URLs
234
+ #
235
+ # @option options [channel] :channel
236
+ # Channel ID of the message. Both channel and ts must be provided together, or unfurl_id and source must be provided together.
68
237
  # @option options [timestamp] :ts
69
- # Timestamp of the message to be updated.
238
+ # Timestamp of the message to add unfurl behavior to.
239
+ # @option options [string] :unfurls
240
+ # URL-encoded JSON map with keys set to URLs featured in the the message, pointing to their unfurl blocks or message attachments.
241
+ # @option options [string] :source
242
+ # The source of the link to unfurl. The source may either be composer, when the link is inside the message composer, or conversations_history, when the link has been posted to a conversation.
243
+ # @option options [string] :unfurl_id
244
+ # The ID of the link to unfurl. Both unfurl_id and source must be provided together, or channel and ts must be provided together.
245
+ # @option options [Object] :user_auth_blocks
246
+ # Provide a JSON based array of structured blocks presented as URL-encoded string to send as an ephemeral message to the user as invitation to authenticate further and enable full unfurling behavior.
247
+ # @option options [Object] :user_auth_message
248
+ # Provide a simply-formatted string to send as an ephemeral message to the user as invitation to authenticate further and enable full unfurling behavior. Provides two buttons, Not now or Never ask me again.
249
+ # @option options [boolean] :user_auth_required
250
+ # Set to true or 1 to indicate the user must install your Slack app to trigger unfurls for this domain.
251
+ # @option options [Object] :user_auth_url
252
+ # Send users to this custom URL where they will complete authentication in your app to fully trigger unfurling. Value should be properly URL-encoded.
253
+ # @see https://api.slack.com/methods/chat.unfurl
254
+ # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/chat/chat.unfurl.json
255
+ def chat_unfurl(options = {})
256
+ throw ArgumentError.new('Required arguments :channel missing') if options[:channel].nil?
257
+ throw ArgumentError.new('Required arguments :ts missing') if options[:ts].nil?
258
+ throw ArgumentError.new('Required arguments :unfurls missing') if options[:unfurls].nil?
259
+ options = options.merge(channel: conversations_id(options)['channel']['id']) if options[:channel]
260
+ post('chat.unfurl', options)
261
+ end
262
+
263
+ #
264
+ # Updates a message.
265
+ #
70
266
  # @option options [channel] :channel
71
267
  # Channel containing the message to be updated.
72
- # @option options [Object] :text
73
- # New text for the message, using the default formatting rules.
74
- # @option options [Object] :attachments
75
- # Structured message attachments.
76
- # @option options [Object] :parse
77
- # Change how messages are treated. Defaults to client, unlike chat.postMessage. See below.
78
- # @option options [Object] :link_names
79
- # Find and link channel names and usernames. Defaults to none. This parameter should be used in conjunction with parse. To set link_names to 1, specify a parse mode of full.
80
- # @option options [Object] :as_user
268
+ # @option options [timestamp] :ts
269
+ # Timestamp of the message to be updated.
270
+ # @option options [boolean] :as_user
81
271
  # Pass true to update the message as the authed user. Bot users in this context are considered authed users.
272
+ # @option options [string] :attachments
273
+ # 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.
274
+ # @option options [blocks[] as string] :blocks
275
+ # 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.
276
+ # @option options [array] :file_ids
277
+ # Array of new file ids that will be sent with this message.
278
+ # @option options [boolean] :link_names
279
+ # 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.
280
+ # @option options [string] :parse
281
+ # 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.
282
+ # @option options [boolean] :reply_broadcast
283
+ # Broadcast an existing thread reply to make it visible to everyone in the channel or conversation.
284
+ # @option options [string] :text
285
+ # New text for the message, using the default formatting rules. It's not required when presenting blocks or attachments.
82
286
  # @see https://api.slack.com/methods/chat.update
83
- # @see https://github.com/dblock/slack-api-ref/blob/master/methods/chat/chat.update.json
287
+ # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/chat/chat.update.json
84
288
  def chat_update(options = {})
85
- throw ArgumentError.new('Required arguments :ts missing') if options[:ts].nil?
86
289
  throw ArgumentError.new('Required arguments :channel missing') if options[:channel].nil?
87
- throw ArgumentError.new('Required arguments :text or :attachments missing') if options[:text].nil? && options[:attachments].nil?
88
- options = options.merge(channel: channels_id(options)['channel']['id']) if options[:channel]
290
+ throw ArgumentError.new('Required arguments :text, :attachments or :blocks missing') if options[:text].nil? && options[:attachments].nil? && options[:blocks].nil?
291
+ throw ArgumentError.new('Required arguments :ts missing') if options[:ts].nil?
292
+ options = options.merge(channel: conversations_id(options)['channel']['id']) if options[:channel]
89
293
  # attachments must be passed as an encoded JSON string
90
294
  if options.key?(:attachments)
91
295
  attachments = options[:attachments]
92
296
  attachments = JSON.dump(attachments) unless attachments.is_a?(String)
93
297
  options = options.merge(attachments: attachments)
94
298
  end
299
+ # blocks must be passed as an encoded JSON string
300
+ if options.key?(:blocks)
301
+ blocks = options[:blocks]
302
+ blocks = JSON.dump(blocks) unless blocks.is_a?(String)
303
+ options = options.merge(blocks: blocks)
304
+ end
95
305
  post('chat.update', options)
96
306
  end
97
307
  end
@@ -0,0 +1,40 @@
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 ChatScheduledmessages
9
+ #
10
+ # Returns a list of scheduled messages.
11
+ #
12
+ # @option options [channel] :channel
13
+ # The channel of the scheduled messages.
14
+ # @option options [string] :cursor
15
+ # 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.
16
+ # @option options [timestamp] :latest
17
+ # A UNIX timestamp of the latest value in the time range.
18
+ # @option options [integer] :limit
19
+ # Maximum number of original entries to return.
20
+ # @option options [timestamp] :oldest
21
+ # A UNIX timestamp of the oldest value in the time range.
22
+ # @option options [string] :team_id
23
+ # encoded team id to list channels in, required if org token is used.
24
+ # @see https://api.slack.com/methods/chat.scheduledMessages.list
25
+ # @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/chat.scheduledMessages/chat.scheduledMessages.list.json
26
+ def chat_scheduledMessages_list(options = {})
27
+ options = options.merge(channel: conversations_id(options)['channel']['id']) if options[:channel]
28
+ if block_given?
29
+ Pagination::Cursor.new(self, :chat_scheduledMessages_list, options).each do |page|
30
+ yield page
31
+ end
32
+ else
33
+ post('chat.scheduledMessages.list', options)
34
+ end
35
+ end
36
+ end
37
+ end
38
+ end
39
+ end
40
+ end