slack-ruby-client 0.15.0 → 1.0.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (264) hide show
  1. checksums.yaml +4 -4
  2. data/.rubocop.yml +6 -1
  3. data/.rubocop_todo.yml +75 -43
  4. data/.travis.yml +2 -4
  5. data/CHANGELOG.md +32 -0
  6. data/CONTRIBUTING.md +6 -13
  7. data/LICENSE.md +1 -1
  8. data/README.md +19 -36
  9. data/RELEASING.md +1 -1
  10. data/UPGRADING.md +56 -2
  11. data/bin/commands/admin_analytics.rb +16 -0
  12. data/bin/commands/admin_apps.rb +26 -2
  13. data/bin/commands/admin_apps_requests.rb +1 -0
  14. data/bin/commands/admin_auth_policy.rb +39 -0
  15. data/bin/commands/admin_barriers.rb +47 -0
  16. data/bin/commands/admin_conversations.rb +154 -2
  17. data/bin/commands/admin_conversations_ekm.rb +17 -0
  18. data/bin/commands/admin_conversations_restrictAccess.rb +3 -3
  19. data/bin/commands/admin_conversations_whitelist.rb +1 -1
  20. data/bin/commands/admin_emoji.rb +1 -1
  21. data/bin/commands/admin_teams.rb +1 -1
  22. data/bin/commands/admin_usergroups.rb +2 -2
  23. data/bin/commands/admin_users.rb +3 -2
  24. data/bin/commands/admin_users_session.rb +62 -0
  25. data/bin/commands/api.rb +0 -1
  26. data/bin/commands/apps_connections.rb +13 -0
  27. data/bin/commands/apps_event_authorizations.rb +16 -0
  28. data/bin/commands/apps_manifest.rb +51 -0
  29. data/bin/commands/auth_teams.rb +16 -0
  30. data/bin/commands/bots.rb +1 -0
  31. data/bin/commands/channels.rb +1 -155
  32. data/bin/commands/chat.rb +12 -7
  33. data/bin/commands/chat_scheduledMessages.rb +1 -0
  34. data/bin/commands/conversations.rb +71 -2
  35. data/bin/commands/dnd.rb +2 -0
  36. data/bin/commands/files.rb +6 -4
  37. data/bin/commands/files_remote.rb +2 -2
  38. data/bin/commands/groups.rb +1 -162
  39. data/bin/commands/im.rb +1 -63
  40. data/bin/commands/migration.rb +1 -0
  41. data/bin/commands/mpim.rb +1 -61
  42. data/bin/commands/oauth.rb +0 -13
  43. data/bin/commands/oauth_v2.rb +13 -1
  44. data/bin/commands/openid_connect.rb +27 -0
  45. data/bin/commands/pins.rb +2 -4
  46. data/bin/commands/reactions.rb +1 -0
  47. data/bin/commands/reminders.rb +6 -0
  48. data/bin/commands/rtm.rb +2 -2
  49. data/bin/commands/search.rb +4 -0
  50. data/bin/commands/stars.rb +7 -6
  51. data/bin/commands/team.rb +3 -0
  52. data/bin/commands/team_billing.rb +13 -0
  53. data/bin/commands/team_preferences.rb +13 -0
  54. data/bin/commands/tooling_tokens.rb +14 -0
  55. data/bin/commands/usergroups.rb +5 -0
  56. data/bin/commands/usergroups_users.rb +2 -0
  57. data/bin/commands/users.rb +4 -2
  58. data/bin/commands/users_profile.rb +5 -5
  59. data/bin/commands/views.rb +2 -2
  60. data/bin/commands/workflows.rb +38 -0
  61. data/bin/commands.rb +13 -9
  62. data/lib/slack/config.rb +1 -2
  63. data/lib/slack/events/request.rb +10 -4
  64. data/lib/slack/real_time/client.rb +6 -6
  65. data/lib/slack/real_time/concurrency/async.rb +6 -8
  66. data/lib/slack/real_time/concurrency.rb +0 -2
  67. data/lib/slack/real_time/config.rb +5 -14
  68. data/lib/slack/real_time/socket.rb +1 -2
  69. data/lib/slack/real_time/stores/base.rb +1 -6
  70. data/lib/slack/real_time/stores/starter.rb +6 -3
  71. data/lib/slack/real_time/stores/store.rb +5 -0
  72. data/lib/slack/version.rb +1 -1
  73. data/lib/slack/web/api/endpoints/admin_analytics.rb +28 -0
  74. data/lib/slack/web/api/endpoints/admin_apps.rb +42 -6
  75. data/lib/slack/web/api/endpoints/admin_apps_approved.rb +2 -2
  76. data/lib/slack/web/api/endpoints/admin_apps_requests.rb +4 -2
  77. data/lib/slack/web/api/endpoints/admin_apps_restricted.rb +2 -2
  78. data/lib/slack/web/api/endpoints/admin_auth_policy.rb +72 -0
  79. data/lib/slack/web/api/endpoints/admin_barriers.rb +82 -0
  80. data/lib/slack/web/api/endpoints/admin_conversations.rb +233 -3
  81. data/lib/slack/web/api/endpoints/admin_conversations_ekm.rb +35 -0
  82. data/lib/slack/web/api/endpoints/admin_conversations_restrictAccess.rb +3 -3
  83. data/lib/slack/web/api/endpoints/admin_conversations_whitelist.rb +3 -3
  84. data/lib/slack/web/api/endpoints/admin_emoji.rb +10 -10
  85. data/lib/slack/web/api/endpoints/admin_inviteRequests.rb +7 -7
  86. data/lib/slack/web/api/endpoints/admin_inviteRequests_approved.rb +3 -3
  87. data/lib/slack/web/api/endpoints/admin_inviteRequests_denied.rb +2 -2
  88. data/lib/slack/web/api/endpoints/admin_teams.rb +7 -7
  89. data/lib/slack/web/api/endpoints/admin_teams_admins.rb +2 -2
  90. data/lib/slack/web/api/endpoints/admin_teams_owners.rb +2 -2
  91. data/lib/slack/web/api/endpoints/admin_teams_settings.rb +5 -5
  92. data/lib/slack/web/api/endpoints/admin_usergroups.rb +11 -11
  93. data/lib/slack/web/api/endpoints/admin_users.rb +23 -23
  94. data/lib/slack/web/api/endpoints/admin_users_session.rb +97 -3
  95. data/lib/slack/web/api/endpoints/api.rb +1 -3
  96. data/lib/slack/web/api/endpoints/apps.rb +2 -2
  97. data/lib/slack/web/api/endpoints/apps_connections.rb +21 -0
  98. data/lib/slack/web/api/endpoints/apps_event_authorizations.rb +34 -0
  99. data/lib/slack/web/api/endpoints/apps_manifest.rb +75 -0
  100. data/lib/slack/web/api/endpoints/auth.rb +1 -1
  101. data/lib/slack/web/api/endpoints/auth_teams.rb +33 -0
  102. data/lib/slack/web/api/endpoints/bots.rb +3 -1
  103. data/lib/slack/web/api/endpoints/calls.rb +15 -15
  104. data/lib/slack/web/api/endpoints/calls_participants.rb +4 -4
  105. data/lib/slack/web/api/endpoints/channels.rb +0 -259
  106. data/lib/slack/web/api/endpoints/chat.rb +65 -55
  107. data/lib/slack/web/api/endpoints/chat_scheduledMessages.rb +4 -2
  108. data/lib/slack/web/api/endpoints/conversations.rb +134 -24
  109. data/lib/slack/web/api/endpoints/dialog.rb +2 -2
  110. data/lib/slack/web/api/endpoints/dnd.rb +6 -3
  111. data/lib/slack/web/api/endpoints/files.rb +19 -15
  112. data/lib/slack/web/api/endpoints/files_comments.rb +1 -1
  113. data/lib/slack/web/api/endpoints/files_remote.rb +22 -22
  114. data/lib/slack/web/api/endpoints/groups.rb +0 -269
  115. data/lib/slack/web/api/endpoints/im.rb +0 -107
  116. data/lib/slack/web/api/endpoints/migration.rb +4 -2
  117. data/lib/slack/web/api/endpoints/mpim.rb +0 -102
  118. data/lib/slack/web/api/endpoints/oauth.rb +5 -27
  119. data/lib/slack/web/api/endpoints/oauth_v2.rb +24 -6
  120. data/lib/slack/web/api/endpoints/openid_connect.rb +42 -0
  121. data/lib/slack/web/api/endpoints/pins.rb +4 -9
  122. data/lib/slack/web/api/endpoints/reactions.rb +13 -11
  123. data/lib/slack/web/api/endpoints/reminders.rb +17 -5
  124. data/lib/slack/web/api/endpoints/rtm.rb +10 -10
  125. data/lib/slack/web/api/endpoints/search.rb +27 -13
  126. data/lib/slack/web/api/endpoints/stars.rb +11 -9
  127. data/lib/slack/web/api/endpoints/team.rb +11 -5
  128. data/lib/slack/web/api/endpoints/team_billing.rb +21 -0
  129. data/lib/slack/web/api/endpoints/team_preferences.rb +21 -0
  130. data/lib/slack/web/api/endpoints/team_profile.rb +1 -1
  131. data/lib/slack/web/api/endpoints/tooling_tokens.rb +24 -0
  132. data/lib/slack/web/api/endpoints/usergroups.rb +26 -16
  133. data/lib/slack/web/api/endpoints/usergroups_users.rb +9 -5
  134. data/lib/slack/web/api/endpoints/users.rb +20 -18
  135. data/lib/slack/web/api/endpoints/users_profile.rb +7 -7
  136. data/lib/slack/web/api/endpoints/views.rb +13 -13
  137. data/lib/slack/web/api/endpoints/workflows.rb +61 -0
  138. data/lib/slack/web/api/endpoints.rb +26 -20
  139. data/lib/slack/web/api/errors/server_error.rb +37 -0
  140. data/lib/slack/web/api/errors/too_many_requests_error.rb +1 -4
  141. data/lib/slack/web/api/errors.rb +394 -10
  142. data/lib/slack/web/api/mixins/conversations.id.rb +1 -3
  143. data/lib/slack/web/api/mixins/ids.id.rb +2 -2
  144. data/lib/slack/web/api/mixins/users.id.rb +1 -3
  145. data/lib/slack/web/api/mixins.rb +0 -2
  146. data/lib/slack/web/api/patches/chat.1.patch +6 -8
  147. data/lib/slack/web/api/templates/endpoints.erb +1 -2
  148. data/lib/slack/web/api/templates/method_spec.erb +1 -1
  149. data/lib/slack/web/config.rb +2 -0
  150. data/lib/slack/web/faraday/connection.rb +2 -2
  151. data/lib/slack/web/faraday/request.rb +2 -1
  152. data/lib/slack/web/faraday/response/raise_error.rb +12 -1
  153. data/lib/slack/web/faraday/response/wrap_error.rb +24 -0
  154. data/lib/slack/web/pagination/cursor.rb +1 -5
  155. data/lib/slack-ruby-client.rb +2 -0
  156. data/lib/tasks/web.rake +11 -3
  157. data/slack-ruby-client.gemspec +2 -3
  158. data/spec/fixtures/slack/web/429_error.yml +50 -54
  159. data/spec/fixtures/slack/web/auth_test_error.yml +51 -18
  160. data/spec/fixtures/slack/web/auth_test_success.yml +50 -26
  161. data/spec/fixtures/slack/web/conversations_info.yml +167 -0
  162. data/spec/fixtures/slack/web/conversations_setTopic.yml +84 -0
  163. data/spec/fixtures/slack/web/conversations_setTopic_one_page.yml +172 -0
  164. data/spec/fixtures/slack/web/conversations_setTopic_paginated.yml +253 -0
  165. data/spec/fixtures/slack/web/paginated_users_list.yml +501 -69
  166. data/spec/fixtures/slack/web/rtm_connect.yml +267 -30
  167. data/spec/fixtures/slack/web/rtm_start.yml +771 -60
  168. data/spec/fixtures/slack/web/users_info.yml +153 -69
  169. data/spec/fixtures/slack/web/users_list.yml +102 -41
  170. data/spec/fixtures/slack/web/views_open_error.yml +49 -42
  171. data/spec/slack/events/request_spec.rb +13 -8
  172. data/spec/slack/real_time/client_spec.rb +35 -22
  173. data/spec/slack/real_time/concurrency/with_concurrency_spec.rb +10 -0
  174. data/spec/slack/real_time/concurrency/without_concurrency_spec.rb +10 -0
  175. data/spec/slack/real_time/event_handlers/bot_spec.rb +1 -1
  176. data/spec/slack/real_time/event_handlers/channel_spec.rb +1 -1
  177. data/spec/slack/real_time/event_handlers/im_spec.rb +5 -5
  178. data/spec/slack/real_time/event_handlers/user_spec.rb +2 -2
  179. data/spec/slack/real_time/rtm_connect_spec.rb +1 -1
  180. data/spec/slack/real_time/rtm_start_spec.rb +1 -1
  181. data/spec/slack/slack_spec.rb +3 -1
  182. data/spec/slack/web/api/endpoints/admin_analytics_spec.rb +13 -0
  183. data/spec/slack/web/api/endpoints/admin_apps_spec.rb +10 -0
  184. data/spec/slack/web/api/endpoints/admin_auth_policy_spec.rb +35 -0
  185. data/spec/slack/web/api/endpoints/admin_barriers_spec.rb +38 -0
  186. data/spec/slack/web/api/endpoints/{apps_permissions_scopes_spec.rb → admin_conversations_ekm_spec.rb} +1 -1
  187. data/spec/slack/web/api/endpoints/admin_conversations_restrictAccess_spec.rb +5 -5
  188. data/spec/slack/web/api/endpoints/admin_conversations_spec.rb +85 -0
  189. data/spec/slack/web/api/endpoints/admin_emoji_spec.rb +6 -6
  190. data/spec/slack/web/api/endpoints/admin_teams_settings_spec.rb +10 -10
  191. data/spec/slack/web/api/endpoints/admin_teams_spec.rb +2 -2
  192. data/spec/slack/web/api/endpoints/admin_usergroups_spec.rb +6 -6
  193. data/spec/slack/web/api/endpoints/admin_users_session_spec.rb +28 -0
  194. data/spec/slack/web/api/endpoints/admin_users_spec.rb +15 -23
  195. data/spec/slack/web/api/endpoints/{apps_permissions_resources_spec.rb → apps_connections_spec.rb} +1 -1
  196. data/spec/slack/web/api/endpoints/apps_event_authorizations_spec.rb +13 -0
  197. data/spec/slack/web/api/endpoints/apps_manifest_spec.rb +36 -0
  198. data/spec/slack/web/api/endpoints/apps_spec.rb +2 -2
  199. data/spec/slack/web/api/endpoints/auth_teams_spec.rb +8 -0
  200. data/spec/slack/web/api/endpoints/calls_participants_spec.rb +4 -4
  201. data/spec/slack/web/api/endpoints/calls_spec.rb +2 -2
  202. data/spec/slack/web/api/endpoints/custom_specs/auth_spec.rb +4 -6
  203. data/spec/slack/web/api/endpoints/custom_specs/conversations_spec.rb +13 -0
  204. data/spec/slack/web/api/endpoints/custom_specs/users_spec.rb +2 -2
  205. data/spec/slack/web/api/endpoints/dnd_spec.rb +0 -5
  206. data/spec/slack/web/api/endpoints/files_comments_spec.rb +2 -2
  207. data/spec/slack/web/api/endpoints/files_remote_spec.rb +3 -3
  208. data/spec/slack/web/api/endpoints/files_spec.rb +4 -4
  209. data/spec/slack/web/api/endpoints/oauth_spec.rb +0 -11
  210. data/spec/slack/web/api/endpoints/oauth_v2_spec.rb +6 -3
  211. data/spec/slack/web/api/endpoints/openid_connect_spec.rb +8 -0
  212. data/spec/slack/web/api/endpoints/pins_spec.rb +1 -4
  213. data/spec/slack/web/api/endpoints/reactions_spec.rb +3 -3
  214. data/spec/slack/web/api/endpoints/reminders_spec.rb +2 -2
  215. data/spec/slack/web/api/endpoints/team_billing_spec.rb +8 -0
  216. data/spec/slack/web/api/endpoints/team_preferences_spec.rb +8 -0
  217. data/spec/slack/web/api/endpoints/tooling_tokens_spec.rb +13 -0
  218. data/spec/slack/web/api/endpoints/usergroups_users_spec.rb +2 -2
  219. data/spec/slack/web/api/endpoints/workflows_spec.rb +26 -0
  220. data/spec/slack/web/api/error_spec.rb +5 -7
  221. data/spec/slack/web/api/errors/slack_error_spec.rb +21 -26
  222. data/spec/slack/web/api/mixins/conversations_list_spec.rb +21 -0
  223. data/spec/slack/web/api/mixins/conversations_spec.rb +11 -9
  224. data/spec/slack/web/api/mixins/users_spec.rb +1 -1
  225. data/spec/slack/web/api/pagination/cursor_spec.rb +1 -3
  226. data/spec/slack/web/client_spec.rb +112 -16
  227. data/spec/slack/web/faraday/request_spec.rb +80 -0
  228. data/spec/slack/web/faraday/response/raise_error_spec.rb +8 -6
  229. data/spec/spec_helper.rb +1 -1
  230. data/spec/support/real_time/connected_client.rb +1 -7
  231. data/spec/support/vcr.rb +36 -1
  232. metadata +58 -155
  233. data/examples/hi_real_time/Gemfile +0 -6
  234. data/examples/hi_real_time/hi.gif +0 -0
  235. data/examples/hi_real_time/hi.rb +0 -41
  236. data/examples/hi_real_time_async_celluloid/Gemfile +0 -7
  237. data/examples/hi_real_time_async_celluloid/Procfile +0 -2
  238. data/examples/hi_real_time_async_celluloid/hi.rb +0 -39
  239. data/examples/hi_real_time_async_eventmachine/Gemfile +0 -7
  240. data/examples/hi_real_time_async_eventmachine/Procfile +0 -2
  241. data/examples/hi_real_time_async_eventmachine/hi.rb +0 -39
  242. data/lib/slack/real_time/concurrency/celluloid.rb +0 -142
  243. data/lib/slack/real_time/concurrency/eventmachine.rb +0 -85
  244. data/lib/slack/web/api/mixins/channels.id.json +0 -20
  245. data/lib/slack/web/api/mixins/channels.id.rb +0 -27
  246. data/lib/slack/web/api/mixins/groups.id.json +0 -20
  247. data/lib/slack/web/api/mixins/groups.id.rb +0 -27
  248. data/spec/fixtures/slack/web/503_error.yml +0 -14
  249. data/spec/fixtures/slack/web/channels_info.yml +0 -139
  250. data/spec/fixtures/slack/web/groups_info.yml +0 -43
  251. data/spec/slack/real_time/concurrency/celluloid_spec.rb +0 -116
  252. data/spec/slack/real_time/concurrency/eventmachine_spec.rb +0 -57
  253. data/spec/slack/web/api/endpoints/admin_conversations_whitelist_spec.rb +0 -32
  254. data/spec/slack/web/api/endpoints/apps_permissions_spec.rb +0 -16
  255. data/spec/slack/web/api/endpoints/apps_permissions_users_spec.rb +0 -19
  256. data/spec/slack/web/api/endpoints/conversations_spec.rb +0 -101
  257. data/spec/slack/web/api/endpoints/custom_specs/channels_spec.rb +0 -13
  258. data/spec/slack/web/api/endpoints/custom_specs/groups_spec.rb +0 -13
  259. data/spec/slack/web/api/endpoints/im_spec.rb +0 -39
  260. data/spec/slack/web/api/endpoints/mpim_spec.rb +0 -39
  261. data/spec/slack/web/api/endpoints/views_spec.rb +0 -29
  262. data/spec/slack/web/api/errors/service_unavailable_spec.rb +0 -17
  263. data/spec/slack/web/api/mixins/channels_spec.rb +0 -43
  264. data/spec/slack/web/api/mixins/groups_spec.rb +0 -43
@@ -0,0 +1,39 @@
1
+ # frozen_string_literal: true
2
+ # This file was auto-generated by lib/tasks/web.rake
3
+
4
+ desc 'AdminAuthPolicy methods.'
5
+ command 'admin_auth_policy' do |g|
6
+ g.desc 'Assign entities to a particular authentication policy.'
7
+ g.long_desc %( Assign entities to a particular authentication policy. )
8
+ g.command 'assignEntities' do |c|
9
+ c.flag 'entity_ids', desc: 'Array of IDs to assign to the policy.'
10
+ c.flag 'entity_type', desc: 'The type of entity to assign to the policy. Currently, USER is supported.'
11
+ c.flag 'policy_name', desc: 'The name of the authentication policy to assign the entities to. Currently, email_password is the only policy that may be used with this method.'
12
+ c.action do |_global_options, options, _args|
13
+ puts JSON.dump($client.admin_auth_policy_assignEntities(options))
14
+ end
15
+ end
16
+
17
+ g.desc 'Fetch all the entities assigned to a particular authentication policy by name.'
18
+ g.long_desc %( Fetch all the entities assigned to a particular authentication policy by name. )
19
+ g.command 'getEntities' do |c|
20
+ c.flag 'policy_name', desc: 'The name of the policy to fetch entities for. Currently, email_password is the only policy that may be used with this method.'
21
+ c.flag 'cursor', desc: 'Set cursor to next_cursor returned by the previous call to list items in the next page.'
22
+ c.flag 'entity_type', desc: 'The type of entity to assign to the policy. Currently, USER is supported.'
23
+ c.flag 'limit', desc: 'The maximum number of items to return. Must be between 1 and 1000, both inclusive.'
24
+ c.action do |_global_options, options, _args|
25
+ puts JSON.dump($client.admin_auth_policy_getEntities(options))
26
+ end
27
+ end
28
+
29
+ g.desc 'Remove specified entities from a specified authentication policy.'
30
+ g.long_desc %( Remove specified entities from a specified authentication policy. )
31
+ g.command 'removeEntities' do |c|
32
+ c.flag 'entity_ids', desc: "Encoded IDs of the entities you'd like to remove from the policy."
33
+ c.flag 'entity_type', desc: 'The type of entity to assign to the policy. Currently, USER is supported.'
34
+ c.flag 'policy_name', desc: 'The name of the policy to remove entities from. Currently, email_password is the only policy that may be used with this method.'
35
+ c.action do |_global_options, options, _args|
36
+ puts JSON.dump($client.admin_auth_policy_removeEntities(options))
37
+ end
38
+ end
39
+ end
@@ -0,0 +1,47 @@
1
+ # frozen_string_literal: true
2
+ # This file was auto-generated by lib/tasks/web.rake
3
+
4
+ desc 'AdminBarriers methods.'
5
+ command 'admin_barriers' do |g|
6
+ g.desc 'Create an Information Barrier'
7
+ g.long_desc %( Create an Information Barrier )
8
+ g.command 'create' do |c|
9
+ c.flag 'barriered_from_usergroup_ids', desc: 'A list of IDP Groups ids that the primary usergroup is to be barriered from.'
10
+ c.flag 'primary_usergroup_id', desc: 'The id of the primary IDP Group.'
11
+ c.flag 'restricted_subjects', desc: 'What kind of interactions are blocked by this barrier? For v1, we only support a list of all 3, eg im, mpim, call.'
12
+ c.action do |_global_options, options, _args|
13
+ puts JSON.dump($client.admin_barriers_create(options))
14
+ end
15
+ end
16
+
17
+ g.desc 'Delete an existing Information Barrier'
18
+ g.long_desc %( Delete an existing Information Barrier )
19
+ g.command 'delete' do |c|
20
+ c.flag 'barrier_id', desc: "The ID of the barrier you're trying to delete."
21
+ c.action do |_global_options, options, _args|
22
+ puts JSON.dump($client.admin_barriers_delete(options))
23
+ end
24
+ end
25
+
26
+ g.desc 'Get all Information Barriers for your organization'
27
+ g.long_desc %( Get all Information Barriers for your organization )
28
+ g.command 'list' do |c|
29
+ c.flag 'cursor', desc: 'Set cursor to next_cursor returned by the previous call to list items in the next page.'
30
+ c.flag 'limit', desc: 'The maximum number of items to return. Must be between 1 - 1000 both inclusive.'
31
+ c.action do |_global_options, options, _args|
32
+ puts JSON.dump($client.admin_barriers_list(options))
33
+ end
34
+ end
35
+
36
+ g.desc 'Update an existing Information Barrier'
37
+ g.long_desc %( Update an existing Information Barrier )
38
+ g.command 'update' do |c|
39
+ c.flag 'barrier_id', desc: "The ID of the barrier you're trying to modify."
40
+ c.flag 'barriered_from_usergroup_ids', desc: 'A list of IDP Groups ids that the primary usergroup is to be barriered from.'
41
+ c.flag 'primary_usergroup_id', desc: 'The id of the primary IDP Group.'
42
+ c.flag 'restricted_subjects', desc: 'What kind of interactions are blocked by this barrier? For v1, we only support a list of all 3, eg im, mpim, call.'
43
+ c.action do |_global_options, options, _args|
44
+ puts JSON.dump($client.admin_barriers_update(options))
45
+ end
46
+ end
47
+ end
@@ -3,8 +3,151 @@
3
3
 
4
4
  desc 'AdminConversations methods.'
5
5
  command 'admin_conversations' do |g|
6
- g.desc 'Set the workspaces in an Enterprise grid org that connect to a channel.'
7
- g.long_desc %( Set the workspaces in an Enterprise grid org that connect to a channel. )
6
+ g.desc 'Archive a public or private channel.'
7
+ g.long_desc %( Archive a public or private channel. )
8
+ g.command 'archive' do |c|
9
+ c.flag 'channel_id', desc: 'The channel to archive.'
10
+ c.action do |_global_options, options, _args|
11
+ puts JSON.dump($client.admin_conversations_archive(options))
12
+ end
13
+ end
14
+
15
+ g.desc 'Convert a public channel to a private channel.'
16
+ g.long_desc %( Convert a public channel to a private channel. )
17
+ g.command 'convertToPrivate' do |c|
18
+ c.flag 'channel_id', desc: 'The channel to convert to private.'
19
+ c.action do |_global_options, options, _args|
20
+ puts JSON.dump($client.admin_conversations_convertToPrivate(options))
21
+ end
22
+ end
23
+
24
+ g.desc 'Create a public or private channel-based conversation.'
25
+ g.long_desc %( Create a public or private channel-based conversation. )
26
+ g.command 'create' do |c|
27
+ c.flag 'is_private', desc: 'When true, creates a private channel instead of a public channel.'
28
+ c.flag 'name', desc: 'Name of the public or private channel to create.'
29
+ c.flag 'description', desc: 'Description of the public or private channel to create.'
30
+ c.flag 'org_wide', desc: 'When true, the channel will be available org-wide. Note: if the channel is not org_wide=true, you must specify a team_id for this channel.'
31
+ c.flag 'team_id', desc: 'The workspace to create the channel in. Note: this argument is required unless you set org_wide=true.'
32
+ c.action do |_global_options, options, _args|
33
+ puts JSON.dump($client.admin_conversations_create(options))
34
+ end
35
+ end
36
+
37
+ g.desc 'Delete a public or private channel.'
38
+ g.long_desc %( Delete a public or private channel. )
39
+ g.command 'delete' do |c|
40
+ c.flag 'channel_id', desc: 'The channel to delete.'
41
+ c.action do |_global_options, options, _args|
42
+ puts JSON.dump($client.admin_conversations_delete(options))
43
+ end
44
+ end
45
+
46
+ g.desc 'Disconnect a connected channel from one or more workspaces.'
47
+ g.long_desc %( Disconnect a connected channel from one or more workspaces. )
48
+ g.command 'disconnectShared' do |c|
49
+ c.flag 'channel_id', desc: 'The channel to be disconnected from some workspaces.'
50
+ c.flag 'leaving_team_ids', desc: 'team IDs getting removed from the channel, optional if there are only two teams in the channel.'
51
+ c.action do |_global_options, options, _args|
52
+ puts JSON.dump($client.admin_conversations_disconnectShared(options))
53
+ end
54
+ end
55
+
56
+ g.desc 'Get conversation preferences for a public or private channel.'
57
+ g.long_desc %( Get conversation preferences for a public or private channel. )
58
+ g.command 'getConversationPrefs' do |c|
59
+ c.flag 'channel_id', desc: 'The channel to get preferences for.'
60
+ c.action do |_global_options, options, _args|
61
+ puts JSON.dump($client.admin_conversations_getConversationPrefs(options))
62
+ end
63
+ end
64
+
65
+ g.desc "This API endpoint can be used by any admin to get a channel's retention policy."
66
+ g.long_desc %( This API endpoint can be used by any admin to get a channel's retention policy. )
67
+ g.command 'getCustomRetention' do |c|
68
+ c.flag 'channel_id', desc: 'The channel to get the retention policy for.'
69
+ c.action do |_global_options, options, _args|
70
+ puts JSON.dump($client.admin_conversations_getCustomRetention(options))
71
+ end
72
+ end
73
+
74
+ g.desc 'Get all the workspaces a given public or private channel is connected to within this Enterprise org.'
75
+ g.long_desc %( Get all the workspaces a given public or private channel is connected to within this Enterprise org. )
76
+ g.command 'getTeams' do |c|
77
+ c.flag 'channel_id', desc: 'The channel to determine connected workspaces within the organization for.'
78
+ c.flag 'cursor', desc: 'Set cursor to next_cursor returned by the previous call to list items in the next page.'
79
+ c.flag 'limit', desc: 'The maximum number of items to return. Must be between 1 - 1000 both inclusive.'
80
+ c.action do |_global_options, options, _args|
81
+ puts JSON.dump($client.admin_conversations_getTeams(options))
82
+ end
83
+ end
84
+
85
+ g.desc 'Invite a user to a public or private channel.'
86
+ g.long_desc %( Invite a user to a public or private channel. )
87
+ g.command 'invite' do |c|
88
+ c.flag 'channel_id', desc: 'The channel that the users will be invited to.'
89
+ c.flag 'user_ids', desc: 'The users to invite.'
90
+ c.action do |_global_options, options, _args|
91
+ puts JSON.dump($client.admin_conversations_invite(options))
92
+ end
93
+ end
94
+
95
+ g.desc "This API endpoint can be used by any admin to remove a channel's retention policy."
96
+ g.long_desc %( This API endpoint can be used by any admin to remove a channel's retention policy. )
97
+ g.command 'removeCustomRetention' do |c|
98
+ c.flag 'channel_id', desc: 'The channel to set the retention policy for.'
99
+ c.action do |_global_options, options, _args|
100
+ puts JSON.dump($client.admin_conversations_removeCustomRetention(options))
101
+ end
102
+ end
103
+
104
+ g.desc 'Rename a public or private channel.'
105
+ g.long_desc %( Rename a public or private channel. )
106
+ g.command 'rename' do |c|
107
+ c.flag 'channel_id', desc: 'The channel to rename.'
108
+ c.flag 'name', desc: '.'
109
+ c.action do |_global_options, options, _args|
110
+ puts JSON.dump($client.admin_conversations_rename(options))
111
+ end
112
+ end
113
+
114
+ g.desc 'Search for public or private channels in an Enterprise organization.'
115
+ g.long_desc %( Search for public or private channels in an Enterprise organization. )
116
+ g.command 'search' do |c|
117
+ c.flag 'cursor', desc: 'Set cursor to next_cursor returned by the previous call to list items in the next page.'
118
+ c.flag 'limit', desc: 'Maximum number of items to be returned. Must be between 1 - 20 both inclusive. Default is 10.'
119
+ c.flag 'query', desc: 'Name of the the channel to query by.'
120
+ c.flag 'search_channel_types', desc: 'The type of channel to include or exclude in the search. For example private will search private channels, while private_exclude will exclude them. For a full list of types, check the Types section.'
121
+ c.flag 'sort', desc: 'Possible values are relevant (search ranking based on what we think is closest), name (alphabetical), member_count (number of users in the channel), and created (date channel was created). You can optionally pair this with the sort_dir arg to change how it is sorted.'
122
+ c.flag 'sort_dir', desc: 'Sort direction. Possible values are asc for ascending order like (1, 2, 3) or (a, b, c), and desc for descending order like (3, 2, 1) or (c, b, a).'
123
+ c.flag 'team_ids', desc: 'Comma separated string of team IDs, signifying the workspaces to search through.'
124
+ c.action do |_global_options, options, _args|
125
+ puts JSON.dump($client.admin_conversations_search(options))
126
+ end
127
+ end
128
+
129
+ g.desc 'Set the posting permissions for a public or private channel.'
130
+ g.long_desc %( Set the posting permissions for a public or private channel. )
131
+ g.command 'setConversationPrefs' do |c|
132
+ c.flag 'channel_id', desc: 'The channel to set the prefs for.'
133
+ c.flag 'prefs', desc: 'The prefs for this channel in a stringified JSON format.'
134
+ c.action do |_global_options, options, _args|
135
+ puts JSON.dump($client.admin_conversations_setConversationPrefs(options))
136
+ end
137
+ end
138
+
139
+ g.desc "This API endpoint can be used by any admin to set a channel's retention policy."
140
+ g.long_desc %( This API endpoint can be used by any admin to set a channel's retention policy. )
141
+ g.command 'setCustomRetention' do |c|
142
+ c.flag 'channel_id', desc: 'The channel to set the retention policy for.'
143
+ c.flag 'duration_days', desc: 'The message retention duration in days to set for this channel.'
144
+ c.action do |_global_options, options, _args|
145
+ puts JSON.dump($client.admin_conversations_setCustomRetention(options))
146
+ end
147
+ end
148
+
149
+ g.desc 'Set the workspaces in an Enterprise grid org that connect to a public or private channel.'
150
+ g.long_desc %( Set the workspaces in an Enterprise grid org that connect to a public or private channel. )
8
151
  g.command 'setTeams' do |c|
9
152
  c.flag 'channel_id', desc: 'The encoded channel_id to add or remove to workspaces.'
10
153
  c.flag 'org_channel', desc: 'True if channel has to be converted to an org channel.'
@@ -14,4 +157,13 @@ command 'admin_conversations' do |g|
14
157
  puts JSON.dump($client.admin_conversations_setTeams(options))
15
158
  end
16
159
  end
160
+
161
+ g.desc 'Unarchive a public or private channel.'
162
+ g.long_desc %( Unarchive a public or private channel. )
163
+ g.command 'unarchive' do |c|
164
+ c.flag 'channel_id', desc: 'The channel to unarchive.'
165
+ c.action do |_global_options, options, _args|
166
+ puts JSON.dump($client.admin_conversations_unarchive(options))
167
+ end
168
+ end
17
169
  end
@@ -0,0 +1,17 @@
1
+ # frozen_string_literal: true
2
+ # This file was auto-generated by lib/tasks/web.rake
3
+
4
+ desc 'AdminConversationsEkm methods.'
5
+ command 'admin_conversations_ekm' do |g|
6
+ g.desc 'List all disconnected channels—i.e., channels that were once connected to other workspaces and then disconnected—and the corresponding original channel IDs for key revocation with EKM.'
7
+ g.long_desc %( List all disconnected channels—i.e., channels that were once connected to other workspaces and then disconnected—and the corresponding original channel IDs for key revocation with EKM. )
8
+ g.command 'listOriginalConnectedChannelInfo' do |c|
9
+ c.flag 'channel_ids', desc: 'A comma-separated list of channels to filter to.'
10
+ c.flag 'cursor', desc: 'Set cursor to next_cursor returned by the previous call to list items in the next page.'
11
+ c.flag 'limit', desc: 'The maximum number of items to return. Must be between 1 - 1000 both inclusive.'
12
+ c.flag 'team_ids', desc: 'A comma-separated list of the workspaces to which the channels you would like returned belong.'
13
+ c.action do |_global_options, options, _args|
14
+ puts JSON.dump($client.admin_conversations_ekm_listOriginalConnectedChannelInfo(options))
15
+ end
16
+ end
17
+ end
@@ -8,7 +8,7 @@ command 'admin_conversations_restrictAccess' do |g|
8
8
  g.command 'addGroup' do |c|
9
9
  c.flag 'channel_id', desc: 'The channel to link this group to.'
10
10
  c.flag 'group_id', desc: 'The IDP Group ID to be an allowlist for the private channel.'
11
- c.flag 'team_id', desc: 'The workspace where the IDP Group and channel exist.'
11
+ c.flag 'team_id', desc: 'The workspace where the channel exists. This argument is required for channels only tied to one workspace, and optional for channels that are shared across an organization.'
12
12
  c.action do |_global_options, options, _args|
13
13
  puts JSON.dump($client.admin_conversations_restrictAccess_addGroup(options))
14
14
  end
@@ -18,7 +18,7 @@ command 'admin_conversations_restrictAccess' do |g|
18
18
  g.long_desc %( List all IDP Groups linked to a channel )
19
19
  g.command 'listGroups' do |c|
20
20
  c.flag 'channel_id', desc: '.'
21
- c.flag 'team_id', desc: 'The workspace where the channele exists. This argument is required for channels only tied to one workspace, and optional for channels that are shared across an organization.'
21
+ c.flag 'team_id', desc: 'The workspace where the channel exists. This argument is required for channels only tied to one workspace, and optional for channels that are shared across an organization.'
22
22
  c.action do |_global_options, options, _args|
23
23
  puts JSON.dump($client.admin_conversations_restrictAccess_listGroups(options))
24
24
  end
@@ -29,7 +29,7 @@ command 'admin_conversations_restrictAccess' do |g|
29
29
  g.command 'removeGroup' do |c|
30
30
  c.flag 'channel_id', desc: 'The channel to remove the linked group from.'
31
31
  c.flag 'group_id', desc: 'The IDP Group ID to remove from the private channel.'
32
- c.flag 'team_id', desc: 'The workspace where the IDP Group and channel exist.'
32
+ c.flag 'team_id', desc: 'The workspace where the channel exists. This argument is required for channels only tied to one workspace, and optional for channels that are shared across an organization.'
33
33
  c.action do |_global_options, options, _args|
34
34
  puts JSON.dump($client.admin_conversations_restrictAccess_removeGroup(options))
35
35
  end
@@ -1,7 +1,7 @@
1
1
  # frozen_string_literal: true
2
2
  # This file was auto-generated by lib/tasks/web.rake
3
3
 
4
- desc 'AdminConversationsWhitelist methods.'
4
+ desc 'Add and remove user groups from conversations. Use admin.conversations.* equivalents instead.'
5
5
  command 'admin_conversations_whitelist' do |g|
6
6
  g.desc 'Add an allowlist of IDP groups for accessing a channel'
7
7
  g.long_desc %( Add an allowlist of IDP groups for accessing a channel )
@@ -6,7 +6,7 @@ command 'admin_emoji' do |g|
6
6
  g.desc 'Add an emoji.'
7
7
  g.long_desc %( Add an emoji. )
8
8
  g.command 'add' do |c|
9
- c.flag 'name', desc: 'The name of the emoji to be removed. Colons (:myemoji:) around the value are not required, although they may be included.'
9
+ c.flag 'name', desc: 'The name of the emoji to be added. Colons (:myemoji:) around the value are not required, although they may be included.'
10
10
  c.flag 'url', desc: 'The URL of a file to use as an image for the emoji. Square images under 128KB and with transparent backgrounds work best.'
11
11
  c.action do |_global_options, options, _args|
12
12
  puts JSON.dump($client.admin_emoji_add(options))
@@ -6,7 +6,7 @@ command 'admin_teams' do |g|
6
6
  g.desc 'Create an Enterprise team.'
7
7
  g.long_desc %( Create an Enterprise team. )
8
8
  g.command 'create' do |c|
9
- c.flag 'team_domain', desc: 'Team domain (for example, slacksoftballteam).'
9
+ c.flag 'team_domain', desc: 'Team domain (for example, slacksoftballteam). Domains are limited to 21 characters.'
10
10
  c.flag 'team_name', desc: 'Team name (for example, Slack Softball Team).'
11
11
  c.flag 'team_description', desc: 'Description for the team.'
12
12
  c.flag 'team_discoverability', desc: "Who can join the team. A team's discoverability can be open, closed, invite_only, or unlisted."
@@ -3,8 +3,8 @@
3
3
 
4
4
  desc 'AdminUsergroups methods.'
5
5
  command 'admin_usergroups' do |g|
6
- g.desc 'Add one or more default channels to an IDP group.'
7
- g.long_desc %( Add one or more default channels to an IDP group. )
6
+ g.desc 'Add up to one hundred default channels to an IDP group.'
7
+ g.long_desc %( Add up to one hundred default channels to an IDP group. )
8
8
  g.command 'addChannels' do |c|
9
9
  c.flag 'channel_ids', desc: 'Comma separated string of channel IDs.'
10
10
  c.flag 'usergroup_id', desc: 'ID of the IDP group to add default channels for.'
@@ -23,6 +23,7 @@ command 'admin_users' do |g|
23
23
  c.flag 'email', desc: 'The email address of the person to invite.'
24
24
  c.flag 'team_id', desc: 'The ID (T1234) of the workspace.'
25
25
  c.flag 'custom_message', desc: 'An optional message to send to the user in the invite email.'
26
+ c.flag 'email_password_policy_enabled', desc: 'Allow invited user to sign in via email and password. Only available for Enterprise Grid teams via admin invite.'
26
27
  c.flag 'guest_expiration_ts', desc: 'Timestamp when guest account should be disabled. Only include this timestamp if you are inviting a guest user and you want their account to expire on a certain date.'
27
28
  c.flag 'is_restricted', desc: 'Is this user a multi-channel guest user? (default: false).'
28
29
  c.flag 'is_ultra_restricted', desc: 'Is this user a single channel guest user? (default: false).'
@@ -36,9 +37,9 @@ command 'admin_users' do |g|
36
37
  g.desc 'List users on a workspace'
37
38
  g.long_desc %( List users on a workspace )
38
39
  g.command 'list' do |c|
39
- c.flag 'team_id', desc: 'The ID (T1234) of the workspace.'
40
40
  c.flag 'cursor', desc: 'Set cursor to next_cursor returned by the previous call to list items in the next page.'
41
41
  c.flag 'limit', desc: 'Limit for how many users to be retrieved per page.'
42
+ c.flag 'team_id', desc: 'The ID (T1234) of the workspace.'
42
43
  c.action do |_global_options, options, _args|
43
44
  puts JSON.dump($client.admin_users_list(options))
44
45
  end
@@ -68,8 +69,8 @@ command 'admin_users' do |g|
68
69
  g.long_desc %( Set an expiration for a guest user )
69
70
  g.command 'setExpiration' do |c|
70
71
  c.flag 'expiration_ts', desc: 'Timestamp when guest account should be disabled.'
71
- c.flag 'team_id', desc: 'The ID (T1234) of the workspace.'
72
72
  c.flag 'user_id', desc: 'The ID of the user to set an expiration for.'
73
+ c.flag 'team_id', desc: 'The ID (T1234) of the workspace.'
73
74
  c.action do |_global_options, options, _args|
74
75
  puts JSON.dump($client.admin_users_setExpiration(options))
75
76
  end
@@ -3,6 +3,46 @@
3
3
 
4
4
  desc 'AdminUsersSession methods.'
5
5
  command 'admin_users_session' do |g|
6
+ g.desc 'Clear user-specific session settings—the session duration and what happens when the client closes—for a list of users.'
7
+ g.long_desc %( Clear user-specific session settings—the session duration and what happens when the client closes—for a list of users. )
8
+ g.command 'clearSettings' do |c|
9
+ c.flag 'user_ids', desc: "The IDs of users you'd like to clear session settings for."
10
+ c.action do |_global_options, options, _args|
11
+ puts JSON.dump($client.admin_users_session_clearSettings(options))
12
+ end
13
+ end
14
+
15
+ g.desc 'Get user-specific session settings—the session duration and what happens when the client closes—given a list of users.'
16
+ g.long_desc %( Get user-specific session settings—the session duration and what happens when the client closes—given a list of users. )
17
+ g.command 'getSettings' do |c|
18
+ c.flag 'user_ids', desc: "The IDs of users you'd like to fetch session settings for. Note: if a user does not have any active sessions, they will not be returned in the response."
19
+ c.action do |_global_options, options, _args|
20
+ puts JSON.dump($client.admin_users_session_getSettings(options))
21
+ end
22
+ end
23
+
24
+ g.desc 'Revoke a single session for a user. The user will be forced to login to Slack.'
25
+ g.long_desc %( Revoke a single session for a user. The user will be forced to login to Slack. )
26
+ g.command 'invalidate' do |c|
27
+ c.flag 'session_id', desc: 'ID of the session to invalidate.'
28
+ c.flag 'team_id', desc: 'ID of the workspace that the session belongs to.'
29
+ c.action do |_global_options, options, _args|
30
+ puts JSON.dump($client.admin_users_session_invalidate(options))
31
+ end
32
+ end
33
+
34
+ g.desc 'List active user sessions for an organization'
35
+ g.long_desc %( List active user sessions for an organization )
36
+ g.command 'list' do |c|
37
+ c.flag 'cursor', desc: 'Set cursor to next_cursor returned by the previous call to list items in the next page.'
38
+ c.flag 'limit', desc: 'The maximum number of items to return. Must be between 1 - 1000 both inclusive.'
39
+ c.flag 'team_id', desc: "The ID of the workspace you'd like active sessions for. If you pass a team_id, you'll need to pass a user_id as well."
40
+ c.flag 'user_id', desc: "The ID of user you'd like active sessions for. If you pass a user_id, you'll need to pass a team_id as well."
41
+ c.action do |_global_options, options, _args|
42
+ puts JSON.dump($client.admin_users_session_list(options))
43
+ end
44
+ end
45
+
6
46
  g.desc 'Wipes all valid sessions on all devices for a given user'
7
47
  g.long_desc %( Wipes all valid sessions on all devices for a given user )
8
48
  g.command 'reset' do |c|
@@ -13,4 +53,26 @@ command 'admin_users_session' do |g|
13
53
  puts JSON.dump($client.admin_users_session_reset(options))
14
54
  end
15
55
  end
56
+
57
+ g.desc 'Enqueues an asynchronous job to wipe all valid sessions on all devices for a given list of users'
58
+ g.long_desc %( Enqueues an asynchronous job to wipe all valid sessions on all devices for a given list of users )
59
+ g.command 'resetBulk' do |c|
60
+ c.flag 'user_ids', desc: 'The ID of the user to wipe sessions for.'
61
+ c.flag 'mobile_only', desc: 'Only expire mobile sessions (default: false).'
62
+ c.flag 'web_only', desc: 'Only expire web sessions (default: false).'
63
+ c.action do |_global_options, options, _args|
64
+ puts JSON.dump($client.admin_users_session_resetBulk(options))
65
+ end
66
+ end
67
+
68
+ g.desc 'Configure the user-level session settings—the session duration and what happens when the client closes—for one or more users.'
69
+ g.long_desc %( Configure the user-level session settings—the session duration and what happens when the client closes—for one or more users. )
70
+ g.command 'setSettings' do |c|
71
+ c.flag 'user_ids', desc: 'The list of user IDs to apply the session settings for.'
72
+ c.flag 'desktop_app_browser_quit', desc: 'Terminate the session when the client—either the desktop app or a browser window—is closed.'
73
+ c.flag 'duration', desc: "The session duration, in seconds. The minimum value is 28800, which represents 8 hours; the max value is 315569520 or 10 years (that's a long Slack session)."
74
+ c.action do |_global_options, options, _args|
75
+ puts JSON.dump($client.admin_users_session_setSettings(options))
76
+ end
77
+ end
16
78
  end
data/bin/commands/api.rb CHANGED
@@ -7,7 +7,6 @@ command 'api' do |g|
7
7
  g.long_desc %( Checks API calling code. )
8
8
  g.command 'test' do |c|
9
9
  c.flag 'error', desc: 'Error response to return.'
10
- c.flag 'foo', desc: 'example property to return.'
11
10
  c.action do |_global_options, options, _args|
12
11
  puts JSON.dump($client.api_test(options))
13
12
  end
@@ -0,0 +1,13 @@
1
+ # frozen_string_literal: true
2
+ # This file was auto-generated by lib/tasks/web.rake
3
+
4
+ desc 'AppsConnections methods.'
5
+ command 'apps_connections' do |g|
6
+ g.desc 'Generate a temporary Socket Mode WebSocket URL that your app can connect to in order to receive events and interactive payloads over,'
7
+ g.long_desc %( Generate a temporary Socket Mode WebSocket URL that your app can connect to in order to receive events and interactive payloads over, )
8
+ g.command 'open' do |c|
9
+ c.action do |_global_options, options, _args|
10
+ puts JSON.dump($client.apps_connections_open(options))
11
+ end
12
+ end
13
+ end
@@ -0,0 +1,16 @@
1
+ # frozen_string_literal: true
2
+ # This file was auto-generated by lib/tasks/web.rake
3
+
4
+ desc 'AppsEventAuthorizations methods.'
5
+ command 'apps_event_authorizations' do |g|
6
+ g.desc 'Get a list of authorizations for the given event context. Each authorization represents an app installation that the event is visible to.'
7
+ g.long_desc %( Get a list of authorizations for the given event context. Each authorization represents an app installation that the event is visible to. )
8
+ g.command 'list' do |c|
9
+ c.flag 'event_context', desc: '.'
10
+ c.flag 'cursor', desc: '.'
11
+ c.flag 'limit', desc: '.'
12
+ c.action do |_global_options, options, _args|
13
+ puts JSON.dump($client.apps_event_authorizations_list(options))
14
+ end
15
+ end
16
+ end
@@ -0,0 +1,51 @@
1
+ # frozen_string_literal: true
2
+ # This file was auto-generated by lib/tasks/web.rake
3
+
4
+ desc 'AppsManifest methods.'
5
+ command 'apps_manifest' do |g|
6
+ g.desc 'Create an app from an app manifest.'
7
+ g.long_desc %( Create an app from an app manifest. )
8
+ g.command 'create' do |c|
9
+ c.flag 'manifest', desc: 'A JSON app manifest encoded as a string. This manifest must use a valid app manifest schema - read our guide to creating one.'
10
+ c.action do |_global_options, options, _args|
11
+ puts JSON.dump($client.apps_manifest_create(options))
12
+ end
13
+ end
14
+
15
+ g.desc 'Permanently deletes an app created through app manifests'
16
+ g.long_desc %( Permanently deletes an app created through app manifests )
17
+ g.command 'delete' do |c|
18
+ c.flag 'app_id', desc: 'The ID of the app you want to delete.'
19
+ c.action do |_global_options, options, _args|
20
+ puts JSON.dump($client.apps_manifest_delete(options))
21
+ end
22
+ end
23
+
24
+ g.desc 'Export an app manifest from an existing app'
25
+ g.long_desc %( Export an app manifest from an existing app )
26
+ g.command 'export' do |c|
27
+ c.flag 'app_id', desc: 'The ID of the app whose configuration you want to export as a manifest.'
28
+ c.action do |_global_options, options, _args|
29
+ puts JSON.dump($client.apps_manifest_export(options))
30
+ end
31
+ end
32
+
33
+ g.desc 'Update an app from an app manifest'
34
+ g.long_desc %( Update an app from an app manifest )
35
+ g.command 'update' do |c|
36
+ c.flag 'app_id', desc: 'The ID of the app whose configuration you want to update.'
37
+ c.flag 'manifest', desc: 'A JSON app manifest encoded as a string. This manifest must use a valid app manifest schema - read our guide to creating one. As this method entirely replaces any previous configuration, manifest must contain both unmodified and modified fields.'
38
+ c.action do |_global_options, options, _args|
39
+ puts JSON.dump($client.apps_manifest_update(options))
40
+ end
41
+ end
42
+
43
+ g.desc 'Validate an app manifest'
44
+ g.long_desc %( Validate an app manifest )
45
+ g.command 'validate' do |c|
46
+ c.flag 'manifest', desc: 'The manifest to be validated. Will be validated against the app manifest schema - read our guide.'
47
+ c.action do |_global_options, options, _args|
48
+ puts JSON.dump($client.apps_manifest_validate(options))
49
+ end
50
+ end
51
+ end
@@ -0,0 +1,16 @@
1
+ # frozen_string_literal: true
2
+ # This file was auto-generated by lib/tasks/web.rake
3
+
4
+ desc 'AuthTeams methods.'
5
+ command 'auth_teams' do |g|
6
+ g.desc 'List the workspaces a token can access.'
7
+ g.long_desc %( List the workspaces a token can access. )
8
+ g.command 'list' do |c|
9
+ c.flag 'cursor', desc: 'Set cursor to next_cursor returned by the previous call to list items in the next page.'
10
+ c.flag 'include_icon', desc: 'Whether to return icon paths for each workspace. An icon path represents a URI pointing to the image signifying the workspace.'
11
+ c.flag 'limit', desc: 'The maximum number of workspaces to return. Must be a positive integer no larger than 1000.'
12
+ c.action do |_global_options, options, _args|
13
+ puts JSON.dump($client.auth_teams_list(options))
14
+ end
15
+ end
16
+ end
data/bin/commands/bots.rb CHANGED
@@ -7,6 +7,7 @@ command 'bots' do |g|
7
7
  g.long_desc %( Gets information about a bot user. )
8
8
  g.command 'info' do |c|
9
9
  c.flag 'bot', desc: 'Bot user to get info on.'
10
+ c.flag 'team_id', desc: 'encoded team id or enterprise id where the bot exists, required if org token is used.'
10
11
  c.action do |_global_options, options, _args|
11
12
  puts JSON.dump($client.bots_info(options))
12
13
  end