slack-ruby-client 0.13.1 → 2.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.
- checksums.yaml +4 -4
- data/.github/FUNDING.yml +1 -0
- data/.github/workflows/integration_test.yml +26 -0
- data/.github/workflows/lint.yml +14 -0
- data/.github/workflows/pr_lint.yml +21 -0
- data/.github/workflows/test.yml +36 -0
- data/.gitignore +5 -3
- data/.rubocop.yml +34 -5
- data/.rubocop_todo.yml +180 -46
- data/.ruby-version +1 -0
- data/CHANGELOG.md +119 -2
- data/CONTRIBUTING.md +23 -11
- data/Dangerfile +2 -0
- data/Gemfile +22 -5
- data/Gemfile.danger +6 -0
- data/LICENSE.md +1 -1
- data/README.md +236 -101
- data/RELEASING.md +2 -2
- data/Rakefile +2 -1
- data/UPGRADING.md +100 -2
- data/bin/commands/admin_analytics.rb +16 -0
- data/bin/commands/admin_apps.rb +51 -0
- data/bin/commands/admin_apps_approved.rb +17 -0
- data/bin/commands/admin_apps_requests.rb +28 -0
- data/bin/commands/admin_apps_restricted.rb +17 -0
- data/bin/commands/admin_audit_anomaly_allow.rb +23 -0
- data/bin/commands/admin_auth_policy.rb +39 -0
- data/bin/commands/admin_barriers.rb +47 -0
- data/bin/commands/admin_conversations.rb +171 -0
- data/bin/commands/admin_conversations_ekm.rb +17 -0
- data/bin/commands/admin_conversations_restrictAccess.rb +37 -0
- data/bin/commands/admin_emoji.rb +54 -0
- data/bin/commands/admin_inviteRequests.rb +36 -0
- data/bin/commands/admin_inviteRequests_approved.rb +16 -0
- data/bin/commands/admin_inviteRequests_denied.rb +16 -0
- data/bin/commands/admin_teams.rb +27 -0
- data/bin/commands/admin_teams_admins.rb +16 -0
- data/bin/commands/admin_teams_owners.rb +16 -0
- data/bin/commands/admin_teams_settings.rb +64 -0
- data/bin/commands/admin_usergroups.rb +48 -0
- data/bin/commands/admin_users.rb +98 -0
- data/bin/commands/admin_users_session.rb +78 -0
- data/bin/commands/admin_users_unsupportedVersions.rb +15 -0
- data/bin/commands/api.rb +1 -1
- data/bin/commands/apps.rb +15 -0
- data/bin/commands/apps_connections.rb +13 -0
- data/bin/commands/apps_event_authorizations.rb +16 -0
- data/bin/commands/apps_manifest.rb +52 -0
- data/bin/commands/auth.rb +1 -0
- data/bin/commands/auth_teams.rb +16 -0
- data/bin/commands/bookmarks.rb +53 -0
- data/bin/commands/bots.rb +2 -0
- data/bin/commands/calls.rb +52 -0
- data/bin/commands/calls_participants.rb +25 -0
- data/bin/commands/chat.rb +61 -14
- data/bin/commands/chat_scheduledMessages.rb +19 -0
- data/bin/commands/conversations.rb +82 -10
- data/bin/commands/dialog.rb +1 -0
- data/bin/commands/dnd.rb +6 -3
- data/bin/commands/emoji.rb +1 -0
- data/bin/commands/files.rb +34 -18
- data/bin/commands/files_comments.rb +1 -21
- data/bin/commands/files_remote.rb +78 -0
- data/bin/commands/migration.rb +2 -0
- data/bin/commands/oauth.rb +2 -14
- data/bin/commands/oauth_v2.rb +29 -0
- data/bin/commands/openid_connect.rb +27 -0
- data/bin/commands/pins.rb +3 -6
- data/bin/commands/reactions.rb +3 -3
- data/bin/commands/reminders.rb +7 -0
- data/bin/commands/rtm.rb +1 -15
- data/bin/commands/search.rb +6 -1
- data/bin/commands/stars.rb +8 -6
- data/bin/commands/team.rb +6 -0
- data/bin/commands/team_billing.rb +13 -0
- data/bin/commands/team_preferences.rb +13 -0
- data/bin/commands/team_profile.rb +1 -0
- data/bin/commands/tooling_tokens.rb +14 -0
- data/bin/commands/usergroups.rb +7 -1
- data/bin/commands/usergroups_users.rb +3 -0
- data/bin/commands/users.rb +6 -4
- data/bin/commands/users_admin.rb +1 -0
- data/bin/commands/users_prefs.rb +1 -0
- data/bin/commands/users_profile.rb +6 -5
- data/bin/commands/views.rb +50 -0
- data/bin/commands/workflows.rb +38 -0
- data/bin/commands.rb +41 -8
- data/bin/slack +3 -4
- data/examples/hi_real_time_and_web/Gemfile +1 -0
- data/examples/hi_real_time_and_web/hi.rb +7 -3
- data/examples/hi_real_time_async_async/Gemfile +1 -0
- data/examples/hi_real_time_async_async/hi.rb +6 -2
- data/examples/hi_web/Gemfile +1 -0
- data/examples/hi_web/hi.rb +1 -0
- data/examples/new_ticket/Gemfile +1 -0
- data/examples/new_ticket/new_ticket.rb +1 -0
- data/lib/slack/config.rb +2 -2
- data/lib/slack/events/config.rb +32 -0
- data/lib/slack/events/request.rb +72 -0
- data/lib/slack/logger.rb +6 -5
- data/lib/slack/messages/formatting.rb +1 -0
- data/lib/slack/messages/message.rb +1 -4
- data/lib/slack/real_time/api/message.rb +6 -3
- data/lib/slack/real_time/api/message_id.rb +1 -0
- data/lib/slack/real_time/api/ping.rb +5 -2
- data/lib/slack/real_time/api/templates/event_handler.erb +5 -1
- data/lib/slack/real_time/api/typing.rb +5 -2
- data/lib/slack/real_time/client.rb +105 -54
- data/lib/slack/real_time/concurrency/async.rb +77 -6
- data/lib/slack/real_time/concurrency.rb +1 -2
- data/lib/slack/real_time/config.rb +9 -13
- data/lib/slack/real_time/models/base.rb +1 -4
- data/lib/slack/real_time/models/bot.rb +1 -0
- data/lib/slack/real_time/models/channel.rb +5 -0
- data/lib/slack/real_time/models/im.rb +1 -0
- data/lib/slack/real_time/models/{group.rb → mpim.rb} +2 -1
- data/lib/slack/real_time/models/team.rb +1 -0
- data/lib/slack/real_time/models/user.rb +1 -0
- data/lib/slack/real_time/models.rb +3 -1
- data/lib/slack/real_time/socket.rb +45 -17
- data/lib/slack/real_time/stores/base.rb +28 -14
- data/lib/slack/real_time/stores/starter.rb +325 -297
- data/lib/slack/real_time/stores/store.rb +271 -196
- data/lib/slack/real_time/stores.rb +2 -7
- data/lib/slack/version.rb +2 -1
- data/lib/slack/web/api/endpoints/admin_analytics.rb +28 -0
- data/lib/slack/web/api/endpoints/admin_apps.rb +78 -0
- data/lib/slack/web/api/endpoints/admin_apps_approved.rb +35 -0
- data/lib/slack/web/api/endpoints/admin_apps_requests.rb +51 -0
- data/lib/slack/web/api/endpoints/admin_apps_restricted.rb +35 -0
- data/lib/slack/web/api/endpoints/admin_audit_anomaly_allow.rb +34 -0
- data/lib/slack/web/api/endpoints/admin_auth_policy.rb +72 -0
- data/lib/slack/web/api/endpoints/admin_barriers.rb +82 -0
- data/lib/slack/web/api/endpoints/admin_conversations.rb +264 -0
- data/lib/slack/web/api/endpoints/admin_conversations_ekm.rb +35 -0
- data/lib/slack/web/api/endpoints/admin_conversations_restrictAccess.rb +61 -0
- data/lib/slack/web/api/endpoints/admin_emoji.rb +88 -0
- data/lib/slack/web/api/endpoints/admin_inviteRequests.rb +61 -0
- data/lib/slack/web/api/endpoints/admin_inviteRequests_approved.rb +33 -0
- data/lib/slack/web/api/endpoints/admin_inviteRequests_denied.rb +33 -0
- data/lib/slack/web/api/endpoints/admin_teams.rb +50 -0
- data/lib/slack/web/api/endpoints/admin_teams_admins.rb +34 -0
- data/lib/slack/web/api/endpoints/admin_teams_owners.rb +34 -0
- data/lib/slack/web/api/endpoints/admin_teams_settings.rb +99 -0
- data/lib/slack/web/api/endpoints/admin_usergroups.rb +77 -0
- data/lib/slack/web/api/endpoints/admin_users.rb +163 -0
- data/lib/slack/web/api/endpoints/admin_users_session.rb +122 -0
- data/lib/slack/web/api/endpoints/admin_users_unsupportedVersions.rb +25 -0
- data/lib/slack/web/api/endpoints/api.rb +2 -3
- data/lib/slack/web/api/endpoints/apps.rb +27 -0
- data/lib/slack/web/api/endpoints/apps_connections.rb +21 -0
- data/lib/slack/web/api/endpoints/apps_event_authorizations.rb +34 -0
- data/lib/slack/web/api/endpoints/apps_manifest.rb +77 -0
- data/lib/slack/web/api/endpoints/auth.rb +2 -1
- data/lib/slack/web/api/endpoints/auth_teams.rb +33 -0
- data/lib/slack/web/api/endpoints/bookmarks.rb +88 -0
- data/lib/slack/web/api/endpoints/bots.rb +4 -1
- data/lib/slack/web/api/endpoints/calls.rb +83 -0
- data/lib/slack/web/api/endpoints/calls_participants.rb +42 -0
- data/lib/slack/web/api/endpoints/chat.rb +168 -65
- data/lib/slack/web/api/endpoints/chat_scheduledMessages.rb +40 -0
- data/lib/slack/web/api/endpoints/conversations.rb +182 -67
- data/lib/slack/web/api/endpoints/dialog.rb +5 -4
- data/lib/slack/web/api/endpoints/dnd.rb +9 -4
- data/lib/slack/web/api/endpoints/emoji.rb +1 -0
- data/lib/slack/web/api/endpoints/files.rb +69 -37
- data/lib/slack/web/api/endpoints/files_comments.rb +4 -36
- data/lib/slack/web/api/endpoints/files_remote.rb +127 -0
- data/lib/slack/web/api/endpoints/migration.rb +6 -3
- data/lib/slack/web/api/endpoints/oauth.rb +7 -31
- data/lib/slack/web/api/endpoints/oauth_v2.rb +48 -0
- data/lib/slack/web/api/endpoints/openid_connect.rb +42 -0
- data/lib/slack/web/api/endpoints/pins.rb +11 -18
- data/lib/slack/web/api/endpoints/reactions.rb +22 -21
- data/lib/slack/web/api/endpoints/reminders.rb +23 -10
- data/lib/slack/web/api/endpoints/rtm.rb +3 -25
- data/lib/slack/web/api/endpoints/search.rb +31 -16
- data/lib/slack/web/api/endpoints/stars.rb +14 -11
- data/lib/slack/web/api/endpoints/team.rb +15 -4
- data/lib/slack/web/api/endpoints/team_billing.rb +21 -0
- data/lib/slack/web/api/endpoints/team_preferences.rb +21 -0
- data/lib/slack/web/api/endpoints/team_profile.rb +2 -1
- data/lib/slack/web/api/endpoints/tooling_tokens.rb +24 -0
- data/lib/slack/web/api/endpoints/usergroups.rb +31 -20
- data/lib/slack/web/api/endpoints/usergroups_users.rb +13 -8
- data/lib/slack/web/api/endpoints/users.rb +24 -23
- data/lib/slack/web/api/endpoints/users_admin.rb +3 -2
- data/lib/slack/web/api/endpoints/users_prefs.rb +1 -0
- data/lib/slack/web/api/endpoints/users_profile.rb +8 -7
- data/lib/slack/web/api/endpoints/views.rb +102 -0
- data/lib/slack/web/api/endpoints/workflows.rb +61 -0
- data/lib/slack/web/api/endpoints.rb +82 -18
- data/lib/slack/web/api/error.rb +1 -0
- data/lib/slack/web/api/errors/server_error.rb +37 -0
- data/lib/slack/web/api/errors/slack_error.rb +14 -1
- data/lib/slack/web/api/errors/too_many_requests_error.rb +2 -4
- data/lib/slack/web/api/errors.rb +1116 -0
- data/lib/slack/web/api/mixins/{channels.id.rb → conversations.id.rb} +5 -6
- data/lib/slack/web/api/mixins/ids.id.rb +3 -2
- data/lib/slack/web/api/mixins/users.id.rb +3 -4
- data/lib/slack/web/api/mixins/users.search.rb +3 -1
- data/lib/slack/web/api/mixins.rb +2 -2
- data/lib/slack/web/api/patches/chat.attachments-blocks.patch +69 -0
- data/lib/slack/web/api/patches/{dialog.1.open-json-support.patch → dialog.encoded-json.patch} +4 -4
- data/lib/slack/web/api/patches/views.view-json.patch +55 -0
- data/lib/slack/web/api/templates/command.erb +1 -0
- data/lib/slack/web/api/templates/commands.erb +1 -0
- data/lib/slack/web/api/templates/endpoints.erb +2 -2
- data/lib/slack/web/api/templates/errors.erb +20 -0
- data/lib/slack/web/api/templates/method.erb +6 -2
- data/lib/slack/web/api/templates/method_spec.erb +2 -1
- data/lib/slack/web/client.rb +2 -1
- data/lib/slack/web/config.rb +5 -2
- data/lib/slack/web/faraday/connection.rb +24 -20
- data/lib/slack/web/faraday/request.rb +5 -1
- data/lib/slack/web/faraday/response/raise_error.rb +14 -7
- data/lib/slack/web/faraday/response/wrap_error.rb +24 -0
- data/lib/slack/web/pagination/cursor.rb +7 -7
- data/lib/slack-ruby-client.rb +12 -5
- data/lib/slack.rb +1 -0
- data/lib/slack_ruby_client.rb +1 -0
- data/lib/tasks/git.rake +1 -0
- data/lib/tasks/real_time.rake +51 -21
- data/lib/tasks/update.rake +1 -0
- data/lib/tasks/web.rake +48 -12
- data/screenshots/create-app.png +0 -0
- data/slack-ruby-client.gemspec +7 -12
- data/spec/fixtures/slack/web/429_error.yml +50 -54
- data/spec/fixtures/slack/web/auth_test_error.yml +51 -18
- data/spec/fixtures/slack/web/auth_test_success.yml +50 -26
- data/spec/fixtures/slack/web/conversations_info.yml +167 -0
- data/spec/fixtures/slack/web/conversations_setTopic.yml +84 -0
- data/spec/fixtures/slack/web/conversations_setTopic_one_page.yml +172 -0
- data/spec/fixtures/slack/web/conversations_setTopic_paginated.yml +253 -0
- data/spec/fixtures/slack/web/paginated_users_list.yml +501 -69
- data/spec/fixtures/slack/web/rtm_connect.yml +347 -26
- data/spec/fixtures/slack/web/users_info.yml +153 -69
- data/spec/fixtures/slack/web/users_list.yml +102 -41
- data/spec/fixtures/slack/web/views_open_error.yml +83 -0
- data/spec/integration/integration_spec.rb +115 -47
- data/spec/slack/config_spec.rb +2 -0
- data/spec/slack/events/config_spec.rb +35 -0
- data/spec/slack/events/request_spec.rb +188 -0
- data/spec/slack/messages/formatting_spec.rb +35 -13
- data/spec/slack/real_time/api/message_spec.rb +7 -2
- data/spec/slack/real_time/api/ping_spec.rb +3 -1
- data/spec/slack/real_time/api/typing_spec.rb +6 -2
- data/spec/slack/real_time/client_spec.rb +300 -142
- data/spec/slack/real_time/concurrency/it_behaves_like_a_realtime_socket.rb +2 -0
- data/spec/slack/real_time/concurrency/with_concurrency_spec.rb +10 -0
- data/spec/slack/real_time/concurrency/without_concurrency_spec.rb +10 -0
- data/spec/slack/real_time/event_handlers/bot_spec.rb +20 -17
- data/spec/slack/real_time/event_handlers/event_handlers_spec.rb +3 -2
- data/spec/slack/real_time/event_handlers/im_spec.rb +31 -27
- data/spec/slack/real_time/event_handlers/{group_spec.rb → private_channel_spec.rb} +36 -27
- data/spec/slack/real_time/event_handlers/{channel_spec.rb → public_channel_spec.rb} +31 -24
- data/spec/slack/real_time/event_handlers/team_spec.rb +8 -7
- data/spec/slack/real_time/event_handlers/user_spec.rb +7 -5
- data/spec/slack/real_time/rtm_connect_spec.rb +2 -1
- data/spec/slack/real_time/stores/store_spec.rb +50 -0
- data/spec/slack/slack_spec.rb +41 -6
- data/spec/slack/version_spec.rb +2 -1
- data/spec/slack/web/api/endpoints/admin_analytics_spec.rb +13 -0
- data/spec/slack/web/api/endpoints/admin_apps_approved_spec.rb +8 -0
- data/spec/slack/web/api/endpoints/admin_apps_requests_spec.rb +13 -0
- data/spec/slack/web/api/endpoints/admin_apps_restricted_spec.rb +8 -0
- data/spec/slack/web/api/endpoints/admin_apps_spec.rb +18 -0
- data/spec/slack/web/api/endpoints/admin_audit_anomaly_allow_spec.rb +8 -0
- data/spec/slack/web/api/endpoints/admin_auth_policy_spec.rb +35 -0
- data/spec/slack/web/api/endpoints/admin_barriers_spec.rb +38 -0
- data/spec/slack/web/api/endpoints/admin_conversations_ekm_spec.rb +8 -0
- data/spec/slack/web/api/endpoints/admin_conversations_restrictAccess_spec.rb +32 -0
- data/spec/slack/web/api/endpoints/admin_conversations_spec.rb +98 -0
- data/spec/slack/web/api/endpoints/admin_emoji_spec.rb +37 -0
- data/spec/slack/web/api/endpoints/admin_inviteRequests_approved_spec.rb +8 -0
- data/spec/slack/web/api/endpoints/admin_inviteRequests_denied_spec.rb +8 -0
- data/spec/slack/web/api/endpoints/admin_inviteRequests_spec.rb +18 -0
- data/spec/slack/web/api/endpoints/admin_teams_admins_spec.rb +13 -0
- data/spec/slack/web/api/endpoints/admin_teams_owners_spec.rb +13 -0
- data/spec/slack/web/api/endpoints/admin_teams_settings_spec.rb +53 -0
- data/spec/slack/web/api/endpoints/admin_teams_spec.rb +16 -0
- data/spec/slack/web/api/endpoints/admin_usergroups_spec.rb +37 -0
- data/spec/slack/web/api/endpoints/admin_users_session_spec.rb +41 -0
- data/spec/slack/web/api/endpoints/admin_users_spec.rb +67 -0
- data/spec/slack/web/api/endpoints/admin_users_unsupportedVersions_spec.rb +8 -0
- data/spec/slack/web/api/endpoints/api_spec.rb +1 -0
- data/spec/slack/web/api/endpoints/apps_connections_spec.rb +8 -0
- data/spec/slack/web/api/endpoints/apps_event_authorizations_spec.rb +13 -0
- data/spec/slack/web/api/endpoints/apps_manifest_spec.rb +36 -0
- data/spec/slack/web/api/endpoints/apps_spec.rb +16 -0
- data/spec/slack/web/api/endpoints/{apps_permissions_resources_spec.rb → auth_teams_spec.rb} +2 -1
- data/spec/slack/web/api/endpoints/bookmarks_spec.rb +40 -0
- data/spec/slack/web/api/endpoints/bots_spec.rb +1 -0
- data/spec/slack/web/api/endpoints/calls_participants_spec.rb +24 -0
- data/spec/slack/web/api/endpoints/calls_spec.rb +31 -0
- data/spec/slack/web/api/endpoints/chat_scheduledMessages_spec.rb +8 -0
- data/spec/slack/web/api/endpoints/custom_specs/auth_spec.rb +9 -7
- data/spec/slack/web/api/endpoints/custom_specs/chat_spec.rb +144 -40
- data/spec/slack/web/api/endpoints/custom_specs/conversations_spec.rb +13 -0
- data/spec/slack/web/api/endpoints/custom_specs/dialog_spec.rb +18 -6
- data/spec/slack/web/api/endpoints/custom_specs/users_spec.rb +8 -3
- data/spec/slack/web/api/endpoints/custom_specs/views_spec.rb +112 -0
- data/spec/slack/web/api/endpoints/dnd_spec.rb +4 -3
- data/spec/slack/web/api/endpoints/emoji_spec.rb +1 -0
- data/spec/slack/web/api/endpoints/files_comments_spec.rb +3 -21
- data/spec/slack/web/api/endpoints/files_remote_spec.rb +24 -0
- data/spec/slack/web/api/endpoints/files_spec.rb +18 -4
- data/spec/slack/web/api/endpoints/migration_spec.rb +1 -0
- data/spec/slack/web/api/endpoints/oauth_spec.rb +1 -22
- data/spec/slack/web/api/endpoints/oauth_v2_spec.rb +16 -0
- data/spec/slack/web/api/endpoints/openid_connect_spec.rb +8 -0
- data/spec/slack/web/api/endpoints/pins_spec.rb +1 -0
- data/spec/slack/web/api/endpoints/reactions_spec.rb +8 -1
- data/spec/slack/web/api/endpoints/reminders_spec.rb +3 -2
- data/spec/slack/web/api/endpoints/rtm_spec.rb +1 -0
- data/spec/slack/web/api/endpoints/search_spec.rb +1 -0
- data/spec/slack/web/api/endpoints/stars_spec.rb +1 -0
- data/spec/slack/web/api/endpoints/{apps_permissions_scopes_spec.rb → team_billing_spec.rb} +2 -1
- data/spec/slack/web/api/endpoints/team_preferences_spec.rb +8 -0
- data/spec/slack/web/api/endpoints/team_profile_spec.rb +1 -0
- data/spec/slack/web/api/endpoints/team_spec.rb +1 -0
- data/spec/slack/web/api/endpoints/tooling_tokens_spec.rb +13 -0
- data/spec/slack/web/api/endpoints/usergroups_spec.rb +1 -0
- data/spec/slack/web/api/endpoints/usergroups_users_spec.rb +3 -2
- data/spec/slack/web/api/endpoints/users_admin_spec.rb +1 -0
- data/spec/slack/web/api/endpoints/users_prefs_spec.rb +1 -0
- data/spec/slack/web/api/endpoints/users_profile_spec.rb +1 -0
- data/spec/slack/web/api/endpoints/workflows_spec.rb +26 -0
- data/spec/slack/web/api/error_spec.rb +7 -7
- data/spec/slack/web/api/errors/slack_error_spec.rb +26 -7
- data/spec/slack/web/api/mixins/conversations_list_spec.rb +21 -0
- data/spec/slack/web/api/mixins/conversations_spec.rb +45 -0
- data/spec/slack/web/api/mixins/users_spec.rb +19 -8
- data/spec/slack/web/api/pagination/cursor_spec.rb +47 -15
- data/spec/slack/web/client_spec.rb +199 -22
- data/spec/slack/web/faraday/request_spec.rb +80 -0
- data/spec/slack/web/faraday/response/raise_error_spec.rb +48 -12
- data/spec/spec_helper.rb +9 -2
- data/spec/support/queue_with_timeout.rb +5 -4
- data/spec/support/real_time/concurrency/mock.rb +1 -0
- data/spec/support/real_time/connected_client.rb +6 -6
- data/spec/support/real_time/event.rb +1 -0
- data/spec/support/real_time/loaded_client.rb +120 -0
- data/spec/support/token.rb +1 -0
- data/spec/support/vcr.rb +37 -1
- metadata +174 -262
- data/.travis.yml +0 -32
- data/bin/commands/apps_permissions.rb +0 -22
- data/bin/commands/apps_permissions_resources.rb +0 -14
- data/bin/commands/apps_permissions_scopes.rb +0 -12
- data/bin/commands/apps_permissions_users.rb +0 -25
- data/bin/commands/channels.rb +0 -175
- data/bin/commands/groups.rb +0 -174
- data/bin/commands/im.rb +0 -67
- data/bin/commands/mpim.rb +0 -65
- data/examples/hi_real_time/Gemfile +0 -5
- data/examples/hi_real_time/hi.gif +0 -0
- data/examples/hi_real_time/hi.rb +0 -37
- data/examples/hi_real_time_async_celluloid/Gemfile +0 -6
- data/examples/hi_real_time_async_celluloid/Procfile +0 -2
- data/examples/hi_real_time_async_celluloid/hi.rb +0 -35
- data/examples/hi_real_time_async_eventmachine/Gemfile +0 -6
- data/examples/hi_real_time_async_eventmachine/Procfile +0 -2
- data/examples/hi_real_time_async_eventmachine/hi.rb +0 -35
- data/lib/slack/real_time/concurrency/celluloid.rb +0 -118
- data/lib/slack/real_time/concurrency/eventmachine.rb +0 -66
- data/lib/slack/web/api/endpoints/apps_permissions.rb +0 -35
- data/lib/slack/web/api/endpoints/apps_permissions_resources.rb +0 -30
- data/lib/slack/web/api/endpoints/apps_permissions_scopes.rb +0 -20
- data/lib/slack/web/api/endpoints/apps_permissions_users.rb +0 -49
- data/lib/slack/web/api/endpoints/channels.rb +0 -266
- data/lib/slack/web/api/endpoints/groups.rb +0 -265
- data/lib/slack/web/api/endpoints/im.rb +0 -113
- data/lib/slack/web/api/endpoints/mpim.rb +0 -108
- data/lib/slack/web/api/endpoints/presence.rb +0 -23
- data/lib/slack/web/api/mixins/channels.id.json +0 -20
- data/lib/slack/web/api/mixins/groups.id.json +0 -20
- data/lib/slack/web/api/mixins/groups.id.rb +0 -26
- data/lib/slack/web/api/patches/chat.1.text-attachments-required.patch +0 -13
- data/lib/slack/web/api/patches/chat.2.attachments-json.patch +0 -17
- data/lib/slack/web/api/patches/chat.3.update-attachments-support.patch +0 -21
- data/lib/slack/web/api/patches/chat.4.postEphemeral-attachments-support.patch +0 -17
- data/lib/slack/web/api/patches/chat.5.postEphemeral-text-or-attachments.patch +0 -13
- data/screenshots/register-bot.png +0 -0
- data/spec/fixtures/slack/web/503_error.yml +0 -14
- data/spec/fixtures/slack/web/channels_info.yml +0 -46
- data/spec/fixtures/slack/web/groups_info.yml +0 -43
- data/spec/fixtures/slack/web/rtm_start.yml +0 -104
- data/spec/slack/real_time/concurrency/celluloid_spec.rb +0 -106
- data/spec/slack/real_time/concurrency/eventmachine_spec.rb +0 -47
- data/spec/slack/real_time/rtm_start_spec.rb +0 -13
- data/spec/slack/real_time/store_spec.rb +0 -11
- data/spec/slack/web/api/endpoints/apps_permissions_spec.rb +0 -15
- data/spec/slack/web/api/endpoints/apps_permissions_users_spec.rb +0 -18
- data/spec/slack/web/api/endpoints/conversations_spec.rb +0 -100
- data/spec/slack/web/api/endpoints/custom_specs/channels_spec.rb +0 -11
- data/spec/slack/web/api/endpoints/custom_specs/groups_spec.rb +0 -11
- data/spec/slack/web/api/endpoints/im_spec.rb +0 -38
- data/spec/slack/web/api/endpoints/mpim_spec.rb +0 -38
- data/spec/slack/web/api/errors/service_unavailable_spec.rb +0 -14
- data/spec/slack/web/api/mixins/channels_spec.rb +0 -33
- data/spec/slack/web/api/mixins/groups_spec.rb +0 -33
|
@@ -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
|
|
@@ -16,9 +17,9 @@ module Slack
|
|
|
16
17
|
# Additional parameters provided to the slash command.
|
|
17
18
|
# @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/undocumented/chat/chat.command.json
|
|
18
19
|
def chat_command(options = {})
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
options = options.merge(channel:
|
|
20
|
+
raise ArgumentError, 'Required arguments :channel missing' if options[:channel].nil?
|
|
21
|
+
raise ArgumentError, 'Required arguments :command missing' if options[:command].nil?
|
|
22
|
+
options = options.merge(channel: conversations_id(options)['channel']['id']) if options[:channel]
|
|
22
23
|
logger.warn('The chat.command method is undocumented.')
|
|
23
24
|
post('chat.command', options)
|
|
24
25
|
end
|
|
@@ -30,30 +31,48 @@ module Slack
|
|
|
30
31
|
# Channel containing the message to be deleted.
|
|
31
32
|
# @option options [timestamp] :ts
|
|
32
33
|
# Timestamp of the message to be deleted.
|
|
33
|
-
# @option options [
|
|
34
|
+
# @option options [boolean] :as_user
|
|
34
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.
|
|
35
36
|
# @see https://api.slack.com/methods/chat.delete
|
|
36
37
|
# @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/chat/chat.delete.json
|
|
37
38
|
def chat_delete(options = {})
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
options = options.merge(channel:
|
|
39
|
+
raise ArgumentError, 'Required arguments :channel missing' if options[:channel].nil?
|
|
40
|
+
raise ArgumentError, 'Required arguments :ts missing' if options[:ts].nil?
|
|
41
|
+
options = options.merge(channel: conversations_id(options)['channel']['id']) if options[:channel]
|
|
41
42
|
post('chat.delete', options)
|
|
42
43
|
end
|
|
43
44
|
|
|
45
|
+
#
|
|
46
|
+
# Deletes a pending scheduled message from the queue.
|
|
47
|
+
#
|
|
48
|
+
# @option options [channel] :channel
|
|
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
|
+
raise ArgumentError, 'Required arguments :channel missing' if options[:channel].nil?
|
|
58
|
+
raise ArgumentError, '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
|
+
|
|
44
63
|
#
|
|
45
64
|
# Retrieve a permalink URL for a specific extant message
|
|
46
65
|
#
|
|
47
66
|
# @option options [channel] :channel
|
|
48
67
|
# The ID of the conversation or channel containing the message.
|
|
49
|
-
# @option options [
|
|
68
|
+
# @option options [string] :message_ts
|
|
50
69
|
# A message's ts value, uniquely identifying it within a channel.
|
|
51
70
|
# @see https://api.slack.com/methods/chat.getPermalink
|
|
52
71
|
# @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/chat/chat.getPermalink.json
|
|
53
72
|
def chat_getPermalink(options = {})
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
options = options.merge(channel:
|
|
73
|
+
raise ArgumentError, 'Required arguments :channel missing' if options[:channel].nil?
|
|
74
|
+
raise ArgumentError, 'Required arguments :message_ts missing' if options[:message_ts].nil?
|
|
75
|
+
options = options.merge(channel: conversations_id(options)['channel']['id']) if options[:channel]
|
|
57
76
|
post('chat.getPermalink', options)
|
|
58
77
|
end
|
|
59
78
|
|
|
@@ -62,13 +81,13 @@ module Slack
|
|
|
62
81
|
#
|
|
63
82
|
# @option options [channel] :channel
|
|
64
83
|
# Channel to send message to. Can be a public channel, private group or IM channel. Can be an encoded ID, or a name.
|
|
65
|
-
# @option options [
|
|
84
|
+
# @option options [string] :text
|
|
66
85
|
# Text of the message to send.
|
|
67
86
|
# @see https://api.slack.com/methods/chat.meMessage
|
|
68
87
|
# @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/chat/chat.meMessage.json
|
|
69
88
|
def chat_meMessage(options = {})
|
|
70
|
-
|
|
71
|
-
|
|
89
|
+
raise ArgumentError, 'Required arguments :channel missing' if options[:channel].nil?
|
|
90
|
+
raise ArgumentError, 'Required arguments :text missing' if options[:text].nil?
|
|
72
91
|
post('chat.meMessage', options)
|
|
73
92
|
end
|
|
74
93
|
|
|
@@ -77,24 +96,34 @@ module Slack
|
|
|
77
96
|
#
|
|
78
97
|
# @option options [channel] :channel
|
|
79
98
|
# Channel, private group, or IM channel to send message to. Can be an encoded ID, or a name.
|
|
80
|
-
# @option options [
|
|
81
|
-
#
|
|
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.
|
|
82
101
|
# @option options [user] :user
|
|
83
102
|
# id of the user who will receive the ephemeral message. The user should be in the channel specified by the channel argument.
|
|
84
|
-
# @option options [
|
|
85
|
-
# Pass true to post the message as the authed
|
|
86
|
-
# @option options [
|
|
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
|
|
87
106
|
# A JSON-based array of structured attachments, presented as a URL-encoded string.
|
|
88
|
-
# @option options [
|
|
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
|
|
89
114
|
# Find and link channel names and usernames.
|
|
90
|
-
# @option options [
|
|
115
|
+
# @option options [string] :parse
|
|
91
116
|
# Change how messages are treated. Defaults to none. See below.
|
|
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.
|
|
92
121
|
# @see https://api.slack.com/methods/chat.postEphemeral
|
|
93
122
|
# @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/chat/chat.postEphemeral.json
|
|
94
123
|
def chat_postEphemeral(options = {})
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
124
|
+
raise ArgumentError, 'Required arguments :channel missing' if options[:channel].nil?
|
|
125
|
+
raise ArgumentError, 'Required arguments :text, :attachments or :blocks missing' if options[:text].nil? && options[:attachments].nil? && options[:blocks].nil?
|
|
126
|
+
raise ArgumentError, 'Required arguments :user missing' if options[:user].nil?
|
|
98
127
|
options = options.merge(user: users_id(options)['user']['id']) if options[:user]
|
|
99
128
|
# attachments must be passed as an encoded JSON string
|
|
100
129
|
if options.key?(:attachments)
|
|
@@ -102,6 +131,12 @@ module Slack
|
|
|
102
131
|
attachments = JSON.dump(attachments) unless attachments.is_a?(String)
|
|
103
132
|
options = options.merge(attachments: attachments)
|
|
104
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
|
|
105
140
|
post('chat.postEphemeral', options)
|
|
106
141
|
end
|
|
107
142
|
|
|
@@ -110,68 +145,122 @@ module Slack
|
|
|
110
145
|
#
|
|
111
146
|
# @option options [channel] :channel
|
|
112
147
|
# Channel, private group, or IM channel to send message to. Can be an encoded ID, or a name. See below for more details.
|
|
113
|
-
# @option options [
|
|
114
|
-
# Text of the message to send. See below for an explanation of formatting. This field is usually required, unless you're providing only attachments instead. Provide no more than 40,000 characters or risk truncation.
|
|
115
|
-
# @option options [Object] :as_user
|
|
116
|
-
# Pass true to post the message as the authed user, instead of as a bot. Defaults to false. See authorship below.
|
|
117
|
-
# @option options [Object] :attachments
|
|
148
|
+
# @option options [string] :attachments
|
|
118
149
|
# A JSON-based array of structured attachments, presented as a URL-encoded string.
|
|
119
|
-
# @option options [
|
|
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
|
+
# Set to true to post the message as the authed user, instead of as a bot. Defaults to false. Cannot be used by new Slack apps. See authorship below.
|
|
156
|
+
# @option options [string] :icon_emoji
|
|
120
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.
|
|
121
|
-
# @option options [
|
|
158
|
+
# @option options [string] :icon_url
|
|
122
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.
|
|
123
|
-
# @option options [
|
|
124
|
-
# Find and link
|
|
125
|
-
# @option options [
|
|
160
|
+
# @option options [boolean] :link_names
|
|
161
|
+
# Find and link user groups. No longer supports linking individual users; use syntax shown in Mentioning Users instead.
|
|
162
|
+
# @option options [string] :metadata
|
|
163
|
+
# JSON object with event_type and event_payload fields, presented as a URL-encoded string. Metadata you post to Slack is accessible to any app or user who is a member of that workspace.
|
|
164
|
+
# @option options [boolean] :mrkdwn
|
|
126
165
|
# Disable Slack markup parsing by setting to false. Enabled by default.
|
|
127
|
-
# @option options [
|
|
128
|
-
# Change how messages are treated.
|
|
129
|
-
# @option options [
|
|
166
|
+
# @option options [string] :parse
|
|
167
|
+
# Change how messages are treated. See below.
|
|
168
|
+
# @option options [boolean] :reply_broadcast
|
|
130
169
|
# Used in conjunction with thread_ts and indicates whether reply should be made visible to everyone in the channel or conversation. Defaults to false.
|
|
131
|
-
# @option options [
|
|
170
|
+
# @option options [string] :thread_ts
|
|
132
171
|
# Provide another message's ts value to make this message a reply. Avoid using a reply's ts value; use its parent instead.
|
|
133
|
-
# @option options [
|
|
172
|
+
# @option options [boolean] :unfurl_links
|
|
134
173
|
# Pass true to enable unfurling of primarily text-based content.
|
|
135
|
-
# @option options [
|
|
174
|
+
# @option options [boolean] :unfurl_media
|
|
136
175
|
# Pass false to disable unfurling of media content.
|
|
137
|
-
# @option options [
|
|
176
|
+
# @option options [string] :username
|
|
138
177
|
# Set your bot's user name. Must be used in conjunction with as_user set to false, otherwise ignored. See authorship below.
|
|
139
178
|
# @see https://api.slack.com/methods/chat.postMessage
|
|
140
179
|
# @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/chat/chat.postMessage.json
|
|
141
180
|
def chat_postMessage(options = {})
|
|
142
|
-
|
|
143
|
-
|
|
181
|
+
raise ArgumentError, 'Required arguments :channel missing' if options[:channel].nil?
|
|
182
|
+
raise ArgumentError, 'Required arguments :text, :attachments or :blocks missing' if options[:text].nil? && options[:attachments].nil? && options[:blocks].nil?
|
|
144
183
|
# attachments must be passed as an encoded JSON string
|
|
145
184
|
if options.key?(:attachments)
|
|
146
185
|
attachments = options[:attachments]
|
|
147
186
|
attachments = JSON.dump(attachments) unless attachments.is_a?(String)
|
|
148
187
|
options = options.merge(attachments: attachments)
|
|
149
188
|
end
|
|
189
|
+
# blocks must be passed as an encoded JSON string
|
|
190
|
+
if options.key?(:blocks)
|
|
191
|
+
blocks = options[:blocks]
|
|
192
|
+
blocks = JSON.dump(blocks) unless blocks.is_a?(String)
|
|
193
|
+
options = options.merge(blocks: blocks)
|
|
194
|
+
end
|
|
150
195
|
post('chat.postMessage', options)
|
|
151
196
|
end
|
|
152
197
|
|
|
198
|
+
#
|
|
199
|
+
# Schedules a message to be sent to a channel.
|
|
200
|
+
#
|
|
201
|
+
# @option options [channel] :channel
|
|
202
|
+
# Channel, private group, or DM channel to send message to. Can be an encoded ID, or a name. See below for more details.
|
|
203
|
+
# @option options [integer] :post_at
|
|
204
|
+
# Unix EPOCH timestamp of time in future to send the message.
|
|
205
|
+
# @option options [string] :text
|
|
206
|
+
# How this field works and whether it is required depends on other fields you use in your API call. See below for more detail.
|
|
207
|
+
# @option options [boolean] :as_user
|
|
208
|
+
# Set to true to post the message as the authed user, instead of as a bot. Defaults to false. Cannot be used by new Slack apps. See chat.postMessage.
|
|
209
|
+
# @option options [string] :attachments
|
|
210
|
+
# A JSON-based array of structured attachments, presented as a URL-encoded string.
|
|
211
|
+
# @option options [blocks[] as string] :blocks
|
|
212
|
+
# A JSON-based array of structured blocks, presented as a URL-encoded string.
|
|
213
|
+
# @option options [boolean] :link_names
|
|
214
|
+
# Find and link user groups. No longer supports linking individual users; use syntax shown in Mentioning Users instead.
|
|
215
|
+
# @option options [string] :metadata
|
|
216
|
+
# JSON object with event_type and event_payload fields, presented as a URL-encoded string. Metadata you post to Slack is accessible to any app or user who is a member of that workspace.
|
|
217
|
+
# @option options [string] :parse
|
|
218
|
+
# Change how messages are treated. See chat.postMessage.
|
|
219
|
+
# @option options [boolean] :reply_broadcast
|
|
220
|
+
# Used in conjunction with thread_ts and indicates whether reply should be made visible to everyone in the channel or conversation. Defaults to false.
|
|
221
|
+
# @option options [string] :thread_ts
|
|
222
|
+
# Provide another message's ts value to make this message a reply. Avoid using a reply's ts value; use its parent instead.
|
|
223
|
+
# @option options [boolean] :unfurl_links
|
|
224
|
+
# Pass true to enable unfurling of primarily text-based content.
|
|
225
|
+
# @option options [boolean] :unfurl_media
|
|
226
|
+
# Pass false to disable unfurling of media content.
|
|
227
|
+
# @see https://api.slack.com/methods/chat.scheduleMessage
|
|
228
|
+
# @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/chat/chat.scheduleMessage.json
|
|
229
|
+
def chat_scheduleMessage(options = {})
|
|
230
|
+
raise ArgumentError, 'Required arguments :channel missing' if options[:channel].nil?
|
|
231
|
+
raise ArgumentError, 'Required arguments :post_at missing' if options[:post_at].nil?
|
|
232
|
+
raise ArgumentError, 'Required arguments :text missing' if options[:text].nil?
|
|
233
|
+
post('chat.scheduleMessage', options)
|
|
234
|
+
end
|
|
235
|
+
|
|
153
236
|
#
|
|
154
237
|
# Provide custom unfurl behavior for user-posted URLs
|
|
155
238
|
#
|
|
156
239
|
# @option options [channel] :channel
|
|
157
|
-
# Channel ID of the message.
|
|
240
|
+
# Channel ID of the message. Both channel and ts must be provided together, or unfurl_id and source must be provided together.
|
|
158
241
|
# @option options [timestamp] :ts
|
|
159
242
|
# Timestamp of the message to add unfurl behavior to.
|
|
160
|
-
# @option options [
|
|
161
|
-
# URL-encoded JSON map with keys set to URLs featured in the the message, pointing to their unfurl message attachments.
|
|
243
|
+
# @option options [string] :unfurls
|
|
244
|
+
# URL-encoded JSON map with keys set to URLs featured in the the message, pointing to their unfurl blocks or message attachments.
|
|
245
|
+
# @option options [string] :source
|
|
246
|
+
# 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.
|
|
247
|
+
# @option options [string] :unfurl_id
|
|
248
|
+
# The ID of the link to unfurl. Both unfurl_id and source must be provided together, or channel and ts must be provided together.
|
|
249
|
+
# @option options [Object] :user_auth_blocks
|
|
250
|
+
# 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.
|
|
162
251
|
# @option options [Object] :user_auth_message
|
|
163
|
-
# Provide a simply-formatted string to send as an ephemeral message to the user as invitation to authenticate further and enable full unfurling behavior.
|
|
164
|
-
# @option options [
|
|
252
|
+
# 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.
|
|
253
|
+
# @option options [boolean] :user_auth_required
|
|
165
254
|
# Set to true or 1 to indicate the user must install your Slack app to trigger unfurls for this domain.
|
|
166
255
|
# @option options [Object] :user_auth_url
|
|
167
256
|
# Send users to this custom URL where they will complete authentication in your app to fully trigger unfurling. Value should be properly URL-encoded.
|
|
168
257
|
# @see https://api.slack.com/methods/chat.unfurl
|
|
169
258
|
# @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/chat/chat.unfurl.json
|
|
170
259
|
def chat_unfurl(options = {})
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
options = options.merge(channel:
|
|
260
|
+
raise ArgumentError, 'Required arguments :channel missing' if options[:channel].nil?
|
|
261
|
+
raise ArgumentError, 'Required arguments :ts missing' if options[:ts].nil?
|
|
262
|
+
raise ArgumentError, 'Required arguments :unfurls missing' if options[:unfurls].nil?
|
|
263
|
+
options = options.merge(channel: conversations_id(options)['channel']['id']) if options[:channel]
|
|
175
264
|
post('chat.unfurl', options)
|
|
176
265
|
end
|
|
177
266
|
|
|
@@ -180,31 +269,45 @@ module Slack
|
|
|
180
269
|
#
|
|
181
270
|
# @option options [channel] :channel
|
|
182
271
|
# Channel containing the message to be updated.
|
|
183
|
-
# @option options [Object] :text
|
|
184
|
-
# New text for the message, using the default formatting rules. It's not required when presenting attachments.
|
|
185
272
|
# @option options [timestamp] :ts
|
|
186
273
|
# Timestamp of the message to be updated.
|
|
187
|
-
# @option options [
|
|
274
|
+
# @option options [boolean] :as_user
|
|
188
275
|
# Pass true to update the message as the authed user. Bot users in this context are considered authed users.
|
|
189
|
-
# @option options [
|
|
190
|
-
# A JSON-based array of structured attachments, presented as a URL-encoded string. This field is required when not presenting text.
|
|
191
|
-
# @option options [
|
|
192
|
-
#
|
|
193
|
-
# @option options [
|
|
194
|
-
#
|
|
276
|
+
# @option options [string] :attachments
|
|
277
|
+
# 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.
|
|
278
|
+
# @option options [blocks[] as string] :blocks
|
|
279
|
+
# 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.
|
|
280
|
+
# @option options [array] :file_ids
|
|
281
|
+
# Array of new file ids that will be sent with this message.
|
|
282
|
+
# @option options [boolean] :link_names
|
|
283
|
+
# 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.
|
|
284
|
+
# @option options [string] :metadata
|
|
285
|
+
# JSON object with event_type and event_payload fields, presented as a URL-encoded string. If you don't include this field, the message's previous metadata will be retained. To remove previous metadata, include an empty object for this field. Metadata you post to Slack is accessible to any app or user who is a member of that workspace.
|
|
286
|
+
# @option options [string] :parse
|
|
287
|
+
# 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.
|
|
288
|
+
# @option options [boolean] :reply_broadcast
|
|
289
|
+
# Broadcast an existing thread reply to make it visible to everyone in the channel or conversation.
|
|
290
|
+
# @option options [string] :text
|
|
291
|
+
# New text for the message, using the default formatting rules. It's not required when presenting blocks or attachments.
|
|
195
292
|
# @see https://api.slack.com/methods/chat.update
|
|
196
293
|
# @see https://github.com/slack-ruby/slack-api-ref/blob/master/methods/chat/chat.update.json
|
|
197
294
|
def chat_update(options = {})
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
options = options.merge(channel:
|
|
295
|
+
raise ArgumentError, 'Required arguments :channel missing' if options[:channel].nil?
|
|
296
|
+
raise ArgumentError, 'Required arguments :text, :attachments, :blocks or :reply_broadcast missing' if options[:text].nil? && options[:attachments].nil? && options[:blocks].nil? && options[:reply_broadcast].nil?
|
|
297
|
+
raise ArgumentError, 'Required arguments :ts missing' if options[:ts].nil?
|
|
298
|
+
options = options.merge(channel: conversations_id(options)['channel']['id']) if options[:channel]
|
|
202
299
|
# attachments must be passed as an encoded JSON string
|
|
203
300
|
if options.key?(:attachments)
|
|
204
301
|
attachments = options[:attachments]
|
|
205
302
|
attachments = JSON.dump(attachments) unless attachments.is_a?(String)
|
|
206
303
|
options = options.merge(attachments: attachments)
|
|
207
304
|
end
|
|
305
|
+
# blocks must be passed as an encoded JSON string
|
|
306
|
+
if options.key?(:blocks)
|
|
307
|
+
blocks = options[:blocks]
|
|
308
|
+
blocks = JSON.dump(blocks) unless blocks.is_a?(String)
|
|
309
|
+
options = options.merge(blocks: blocks)
|
|
310
|
+
end
|
|
208
311
|
post('chat.update', options)
|
|
209
312
|
end
|
|
210
313
|
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
|