twilio-ruby 7.3.3 → 7.10.1
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/.dockerignore +1 -1
- data/.github/ISSUE_TEMPLATE/bug_report.yml +69 -0
- data/.github/workflows/test-and-deploy.yml +10 -2
- data/.gitignore +1 -0
- data/.rubocop.yml +1 -0
- data/CHANGES.md +543 -0
- data/Dockerfile +2 -1
- data/Gemfile +2 -0
- data/Makefile +1 -1
- data/README.md +7 -2
- data/cluster/cluster_oauth_spec.rb +19 -0
- data/cluster/cluster_orgs_spec.rb +40 -0
- data/{cluster_spec.rb → cluster/cluster_spec.rb} +0 -2
- data/examples/public_oauth.rb +13 -0
- data/lib/twilio-ruby/auth_strategy/auth_strategy.rb +19 -0
- data/lib/twilio-ruby/auth_strategy/no_auth_strategy.rb +17 -0
- data/lib/twilio-ruby/auth_strategy/token_auth_strategy.rb +39 -0
- data/lib/twilio-ruby/base/client_base.rb +8 -1
- data/lib/twilio-ruby/credential/auth_type.rb +17 -0
- data/lib/twilio-ruby/credential/client_credential_provider.rb +28 -0
- data/lib/twilio-ruby/credential/credential_provider.rb +11 -0
- data/lib/twilio-ruby/credential/orgs_credential_provider.rb +30 -0
- data/lib/twilio-ruby/framework/rest/api_v1_version.rb +22 -0
- data/lib/twilio-ruby/framework/rest/domain.rb +0 -1
- data/lib/twilio-ruby/framework/rest/error.rb +27 -0
- data/lib/twilio-ruby/framework/rest/page.rb +1 -0
- data/lib/twilio-ruby/framework/rest/page_metadata.rb +83 -0
- data/lib/twilio-ruby/framework/rest/resource.rb +16 -0
- data/lib/twilio-ruby/framework/rest/token_page.rb +73 -0
- data/lib/twilio-ruby/framework/rest/version.rb +91 -4
- data/lib/twilio-ruby/http/client_token_manager.rb +31 -0
- data/lib/twilio-ruby/http/http_client.rb +9 -0
- data/lib/twilio-ruby/http/org_token_manager.rb +31 -0
- data/lib/twilio-ruby/rest/accounts/v1/auth_token_promotion.rb +139 -0
- data/lib/twilio-ruby/rest/accounts/v1/bulk_consents.rb +99 -1
- data/lib/twilio-ruby/rest/accounts/v1/bulk_contacts.rb +98 -0
- data/lib/twilio-ruby/rest/accounts/v1/credential/aws.rb +266 -2
- data/lib/twilio-ruby/rest/accounts/v1/credential/public_key.rb +266 -2
- data/lib/twilio-ruby/rest/accounts/v1/credential.rb +63 -0
- data/lib/twilio-ruby/rest/accounts/v1/messaging_geopermissions.rb +285 -0
- data/lib/twilio-ruby/rest/accounts/v1/safelist.rb +164 -4
- data/lib/twilio-ruby/rest/accounts/v1/secondary_auth_token.rb +161 -0
- data/lib/twilio-ruby/rest/accounts/v1.rb +6 -0
- data/lib/twilio-ruby/rest/api/v2010/account/address/dependent_phone_number.rb +90 -2
- data/lib/twilio-ruby/rest/api/v2010/account/address.rb +333 -7
- data/lib/twilio-ruby/rest/api/v2010/account/application.rb +355 -2
- data/lib/twilio-ruby/rest/api/v2010/account/authorized_connect_app.rb +168 -2
- data/lib/twilio-ruby/rest/api/v2010/account/available_phone_number_country/local.rb +129 -5
- data/lib/twilio-ruby/rest/api/v2010/account/available_phone_number_country/machine_to_machine.rb +129 -5
- data/lib/twilio-ruby/rest/api/v2010/account/available_phone_number_country/mobile.rb +129 -5
- data/lib/twilio-ruby/rest/api/v2010/account/available_phone_number_country/national.rb +129 -5
- data/lib/twilio-ruby/rest/api/v2010/account/available_phone_number_country/shared_cost.rb +129 -5
- data/lib/twilio-ruby/rest/api/v2010/account/available_phone_number_country/toll_free.rb +129 -5
- data/lib/twilio-ruby/rest/api/v2010/account/available_phone_number_country/voip.rb +129 -5
- data/lib/twilio-ruby/rest/api/v2010/account/available_phone_number_country.rb +168 -2
- data/lib/twilio-ruby/rest/api/v2010/account/balance.rb +92 -0
- data/lib/twilio-ruby/rest/api/v2010/account/call/event.rb +90 -2
- data/lib/twilio-ruby/rest/api/v2010/account/call/notification.rb +177 -2
- data/lib/twilio-ruby/rest/api/v2010/account/call/payment.rb +240 -0
- data/lib/twilio-ruby/rest/api/v2010/account/call/recording.rb +290 -2
- data/lib/twilio-ruby/rest/api/v2010/account/call/siprec.rb +792 -0
- data/lib/twilio-ruby/rest/api/v2010/account/call/stream.rb +792 -0
- data/lib/twilio-ruby/rest/api/v2010/account/call/transcription.rb +235 -1
- data/lib/twilio-ruby/rest/api/v2010/account/call/user_defined_message.rb +103 -0
- data/lib/twilio-ruby/rest/api/v2010/account/call/user_defined_message_subscription.rb +176 -0
- data/lib/twilio-ruby/rest/api/v2010/account/call.rb +428 -15
- data/lib/twilio-ruby/rest/api/v2010/account/conference/participant.rb +464 -8
- data/lib/twilio-ruby/rest/api/v2010/account/conference/recording.rb +238 -2
- data/lib/twilio-ruby/rest/api/v2010/account/conference.rb +228 -3
- data/lib/twilio-ruby/rest/api/v2010/account/connect_app.rb +248 -2
- data/lib/twilio-ruby/rest/api/v2010/account/incoming_phone_number/assigned_add_on/assigned_add_on_extension.rb +170 -2
- data/lib/twilio-ruby/rest/api/v2010/account/incoming_phone_number/assigned_add_on.rb +228 -2
- data/lib/twilio-ruby/rest/api/v2010/account/incoming_phone_number/local.rb +200 -2
- data/lib/twilio-ruby/rest/api/v2010/account/incoming_phone_number/mobile.rb +200 -2
- data/lib/twilio-ruby/rest/api/v2010/account/incoming_phone_number/toll_free.rb +200 -2
- data/lib/twilio-ruby/rest/api/v2010/account/incoming_phone_number.rb +413 -2
- data/lib/twilio-ruby/rest/api/v2010/account/key.rb +227 -2
- data/lib/twilio-ruby/rest/api/v2010/account/message/feedback.rb +100 -0
- data/lib/twilio-ruby/rest/api/v2010/account/message/media.rb +197 -2
- data/lib/twilio-ruby/rest/api/v2010/account/message.rb +354 -8
- data/lib/twilio-ruby/rest/api/v2010/account/new_key.rb +99 -0
- data/lib/twilio-ruby/rest/api/v2010/account/new_signing_key.rb +99 -0
- data/lib/twilio-ruby/rest/api/v2010/account/notification.rb +176 -2
- data/lib/twilio-ruby/rest/api/v2010/account/outgoing_caller_id.rb +231 -2
- data/lib/twilio-ruby/rest/api/v2010/account/queue/member.rb +210 -2
- data/lib/twilio-ruby/rest/api/v2010/account/queue.rb +269 -2
- data/lib/twilio-ruby/rest/api/v2010/account/recording/add_on_result/payload/data.rb +143 -0
- data/lib/twilio-ruby/rest/api/v2010/account/recording/add_on_result/payload.rb +192 -2
- data/lib/twilio-ruby/rest/api/v2010/account/recording/add_on_result.rb +191 -2
- data/lib/twilio-ruby/rest/api/v2010/account/recording/transcription.rb +191 -2
- data/lib/twilio-ruby/rest/api/v2010/account/recording.rb +209 -3
- data/lib/twilio-ruby/rest/api/v2010/account/short_code.rb +224 -2
- data/lib/twilio-ruby/rest/api/v2010/account/signing_key.rb +227 -2
- data/lib/twilio-ruby/rest/api/v2010/account/sip/credential_list/credential.rb +269 -2
- data/lib/twilio-ruby/rest/api/v2010/account/sip/credential_list.rb +263 -2
- data/lib/twilio-ruby/rest/api/v2010/account/sip/domain/auth_types/auth_type_calls/auth_calls_credential_list_mapping.rb +228 -2
- data/lib/twilio-ruby/rest/api/v2010/account/sip/domain/auth_types/auth_type_calls/auth_calls_ip_access_control_list_mapping.rb +228 -2
- data/lib/twilio-ruby/rest/api/v2010/account/sip/domain/auth_types/auth_type_calls.rb +63 -0
- data/lib/twilio-ruby/rest/api/v2010/account/sip/domain/auth_types/auth_type_registrations/auth_registrations_credential_list_mapping.rb +228 -2
- data/lib/twilio-ruby/rest/api/v2010/account/sip/domain/auth_types/auth_type_registrations.rb +63 -0
- data/lib/twilio-ruby/rest/api/v2010/account/sip/domain/auth_types.rb +63 -0
- data/lib/twilio-ruby/rest/api/v2010/account/sip/domain/credential_list_mapping.rb +228 -2
- data/lib/twilio-ruby/rest/api/v2010/account/sip/domain/ip_access_control_list_mapping.rb +228 -2
- data/lib/twilio-ruby/rest/api/v2010/account/sip/domain.rb +335 -2
- data/lib/twilio-ruby/rest/api/v2010/account/sip/ip_access_control_list/ip_address.rb +278 -2
- data/lib/twilio-ruby/rest/api/v2010/account/sip/ip_access_control_list.rb +263 -2
- data/lib/twilio-ruby/rest/api/v2010/account/sip.rb +63 -0
- data/lib/twilio-ruby/rest/api/v2010/account/token.rb +99 -0
- data/lib/twilio-ruby/rest/api/v2010/account/transcription.rb +190 -2
- data/lib/twilio-ruby/rest/api/v2010/account/usage/record/all_time.rb +102 -6
- data/lib/twilio-ruby/rest/api/v2010/account/usage/record/daily.rb +102 -6
- data/lib/twilio-ruby/rest/api/v2010/account/usage/record/last_month.rb +102 -6
- data/lib/twilio-ruby/rest/api/v2010/account/usage/record/monthly.rb +102 -6
- data/lib/twilio-ruby/rest/api/v2010/account/usage/record/this_month.rb +102 -6
- data/lib/twilio-ruby/rest/api/v2010/account/usage/record/today.rb +102 -6
- data/lib/twilio-ruby/rest/api/v2010/account/usage/record/yearly.rb +102 -6
- data/lib/twilio-ruby/rest/api/v2010/account/usage/record/yesterday.rb +102 -6
- data/lib/twilio-ruby/rest/api/v2010/account/usage/record.rb +102 -6
- data/lib/twilio-ruby/rest/api/v2010/account/usage/trigger.rb +298 -7
- data/lib/twilio-ruby/rest/api/v2010/account/usage.rb +63 -0
- data/lib/twilio-ruby/rest/api/v2010/account/validation_request.rb +114 -0
- data/lib/twilio-ruby/rest/api/v2010/account.rb +245 -2
- data/lib/twilio-ruby/rest/assistants/v1/assistant/assistants_knowledge.rb +197 -2
- data/lib/twilio-ruby/rest/assistants/v1/assistant/assistants_tool.rb +190 -2
- data/lib/twilio-ruby/rest/assistants/v1/assistant/feedback.rb +126 -6
- data/lib/twilio-ruby/rest/assistants/v1/assistant/message.rb +100 -5
- data/lib/twilio-ruby/rest/assistants/v1/assistant.rb +282 -32
- data/lib/twilio-ruby/rest/assistants/v1/knowledge/chunk.rb +90 -2
- data/lib/twilio-ruby/rest/assistants/v1/knowledge/knowledge_status.rb +140 -0
- data/lib/twilio-ruby/rest/assistants/v1/knowledge.rb +309 -38
- data/lib/twilio-ruby/rest/assistants/v1/policy.rb +94 -2
- data/lib/twilio-ruby/rest/assistants/v1/session/message.rb +90 -2
- data/lib/twilio-ruby/rest/assistants/v1/session.rb +167 -2
- data/lib/twilio-ruby/rest/assistants/v1/tool.rb +292 -40
- data/lib/twilio-ruby/rest/bulkexports/v1/export/day.rb +168 -2
- data/lib/twilio-ruby/rest/bulkexports/v1/export/export_custom_job.rb +142 -3
- data/lib/twilio-ruby/rest/bulkexports/v1/export/job.rb +163 -1
- data/lib/twilio-ruby/rest/bulkexports/v1/export.rb +140 -0
- data/lib/twilio-ruby/rest/bulkexports/v1/export_configuration.rb +182 -0
- data/lib/twilio-ruby/rest/chat/v1/credential.rb +293 -2
- data/lib/twilio-ruby/rest/chat/v1/service/channel/invite.rb +234 -2
- data/lib/twilio-ruby/rest/chat/v1/service/channel/member.rb +275 -2
- data/lib/twilio-ruby/rest/chat/v1/service/channel/message.rb +277 -2
- data/lib/twilio-ruby/rest/chat/v1/service/channel.rb +281 -2
- data/lib/twilio-ruby/rest/chat/v1/service/role.rb +269 -2
- data/lib/twilio-ruby/rest/chat/v1/service/user/user_channel.rb +90 -2
- data/lib/twilio-ruby/rest/chat/v1/service/user.rb +278 -2
- data/lib/twilio-ruby/rest/chat/v1/service.rb +419 -2
- data/lib/twilio-ruby/rest/chat/v2/credential.rb +293 -2
- data/lib/twilio-ruby/rest/chat/v2/service/binding.rb +196 -2
- data/lib/twilio-ruby/rest/chat/v2/service/channel/invite.rb +234 -2
- data/lib/twilio-ruby/rest/chat/v2/service/channel/member.rb +309 -2
- data/lib/twilio-ruby/rest/chat/v2/service/channel/message.rb +308 -2
- data/lib/twilio-ruby/rest/chat/v2/service/channel/webhook.rb +299 -2
- data/lib/twilio-ruby/rest/chat/v2/service/channel.rb +306 -2
- data/lib/twilio-ruby/rest/chat/v2/service/role.rb +269 -2
- data/lib/twilio-ruby/rest/chat/v2/service/user/user_binding.rb +194 -2
- data/lib/twilio-ruby/rest/chat/v2/service/user/user_channel.rb +238 -2
- data/lib/twilio-ruby/rest/chat/v2/service/user.rb +282 -2
- data/lib/twilio-ruby/rest/chat/v2/service.rb +350 -2
- data/lib/twilio-ruby/rest/chat/v3/channel.rb +153 -0
- data/lib/twilio-ruby/rest/client.rb +10 -5
- data/lib/twilio-ruby/rest/content/v1/content/approval_create.rb +97 -2
- data/lib/twilio-ruby/rest/content/v1/content/approval_fetch.rb +140 -0
- data/lib/twilio-ruby/rest/content/v1/content.rb +1096 -126
- data/lib/twilio-ruby/rest/content/v1/content_and_approvals.rb +90 -2
- data/lib/twilio-ruby/rest/content/v1/legacy_content.rb +90 -2
- data/lib/twilio-ruby/rest/content/v2/content.rb +111 -2
- data/lib/twilio-ruby/rest/content/v2/content_and_approvals.rb +111 -2
- data/lib/twilio-ruby/rest/conversations/v1/address_configuration.rb +319 -2
- data/lib/twilio-ruby/rest/conversations/v1/configuration/webhook.rb +189 -3
- data/lib/twilio-ruby/rest/conversations/v1/configuration.rb +183 -0
- data/lib/twilio-ruby/rest/conversations/v1/conversation/message/delivery_receipt.rb +169 -2
- data/lib/twilio-ruby/rest/conversations/v1/conversation/message.rb +311 -2
- data/lib/twilio-ruby/rest/conversations/v1/conversation/participant.rb +315 -2
- data/lib/twilio-ruby/rest/conversations/v1/conversation/webhook.rb +293 -2
- data/lib/twilio-ruby/rest/conversations/v1/conversation.rb +356 -25
- data/lib/twilio-ruby/rest/conversations/v1/conversation_with_participants.rb +392 -0
- data/lib/twilio-ruby/rest/conversations/v1/credential.rb +296 -2
- data/lib/twilio-ruby/rest/conversations/v1/participant_conversation.rb +94 -2
- data/lib/twilio-ruby/rest/conversations/v1/role.rb +266 -2
- data/lib/twilio-ruby/rest/conversations/v1/service/binding.rb +199 -5
- data/lib/twilio-ruby/rest/conversations/v1/service/configuration/notification.rb +212 -0
- data/lib/twilio-ruby/rest/conversations/v1/service/configuration/webhook.rb +185 -0
- data/lib/twilio-ruby/rest/conversations/v1/service/configuration.rb +201 -16
- data/lib/twilio-ruby/rest/conversations/v1/service/conversation/message/delivery_receipt.rb +170 -2
- data/lib/twilio-ruby/rest/conversations/v1/service/conversation/message.rb +314 -2
- data/lib/twilio-ruby/rest/conversations/v1/service/conversation/participant.rb +318 -2
- data/lib/twilio-ruby/rest/conversations/v1/service/conversation/webhook.rb +296 -2
- data/lib/twilio-ruby/rest/conversations/v1/service/conversation.rb +360 -26
- data/lib/twilio-ruby/rest/conversations/v1/service/conversation_with_participants.rb +399 -0
- data/lib/twilio-ruby/rest/conversations/v1/service/participant_conversation.rb +94 -2
- data/lib/twilio-ruby/rest/conversations/v1/service/role.rb +269 -2
- data/lib/twilio-ruby/rest/conversations/v1/service/user/user_conversation.rb +235 -2
- data/lib/twilio-ruby/rest/conversations/v1/service/user.rb +285 -2
- data/lib/twilio-ruby/rest/conversations/v1/service.rb +261 -20
- data/lib/twilio-ruby/rest/conversations/v1/user/user_conversation.rb +233 -2
- data/lib/twilio-ruby/rest/conversations/v1/user.rb +282 -2
- data/lib/twilio-ruby/rest/conversations/v1.rb +6 -0
- data/lib/twilio-ruby/rest/events/v1/event_type.rb +169 -2
- data/lib/twilio-ruby/rest/events/v1/schema/schema_version.rb +168 -2
- data/lib/twilio-ruby/rest/events/v1/schema.rb +140 -0
- data/lib/twilio-ruby/rest/events/v1/sink/sink_test.rb +92 -0
- data/lib/twilio-ruby/rest/events/v1/sink/sink_validate.rb +99 -0
- data/lib/twilio-ruby/rest/events/v1/sink.rb +270 -2
- data/lib/twilio-ruby/rest/events/v1/subscription/subscribed_event.rb +266 -2
- data/lib/twilio-ruby/rest/events/v1/subscription.rb +270 -10
- data/lib/twilio-ruby/rest/flex_api/v1/assessments.rb +253 -5
- data/lib/twilio-ruby/rest/flex_api/v1/channel.rb +251 -2
- data/lib/twilio-ruby/rest/flex_api/v1/configuration.rb +175 -0
- data/lib/twilio-ruby/rest/flex_api/v1/create_flex_instance.rb +382 -0
- data/lib/twilio-ruby/rest/flex_api/v1/flex_flow.rb +358 -2
- data/lib/twilio-ruby/rest/flex_api/v1/insights_assessments_comment.rb +151 -5
- data/lib/twilio-ruby/rest/flex_api/v1/insights_conversations.rb +94 -2
- data/lib/twilio-ruby/rest/flex_api/v1/insights_questionnaires.rb +292 -2
- data/lib/twilio-ruby/rest/flex_api/v1/insights_questionnaires_category.rb +240 -2
- data/lib/twilio-ruby/rest/flex_api/v1/insights_questionnaires_question.rb +267 -2
- data/lib/twilio-ruby/rest/flex_api/v1/insights_segments.rb +97 -2
- data/lib/twilio-ruby/rest/flex_api/v1/insights_session.rb +142 -0
- data/lib/twilio-ruby/rest/flex_api/v1/insights_settings_answer_sets.rb +94 -0
- data/lib/twilio-ruby/rest/flex_api/v1/insights_settings_comment.rb +94 -0
- data/lib/twilio-ruby/rest/flex_api/v1/insights_user_roles.rb +142 -0
- data/lib/twilio-ruby/rest/flex_api/v1/interaction/interaction_channel/interaction_channel_invite.rb +127 -2
- data/lib/twilio-ruby/rest/flex_api/v1/interaction/interaction_channel/interaction_channel_participant.rb +219 -2
- data/lib/twilio-ruby/rest/flex_api/v1/interaction/interaction_channel/interaction_transfer.rb +547 -0
- data/lib/twilio-ruby/rest/flex_api/v1/interaction/interaction_channel.rb +235 -2
- data/lib/twilio-ruby/rest/flex_api/v1/interaction.rb +266 -1
- data/lib/twilio-ruby/rest/flex_api/v1/plugin/plugin_versions.rb +226 -2
- data/lib/twilio-ruby/rest/flex_api/v1/plugin.rb +256 -2
- data/lib/twilio-ruby/rest/flex_api/v1/plugin_archive.rb +143 -0
- data/lib/twilio-ruby/rest/flex_api/v1/plugin_configuration/configured_plugin.rb +173 -2
- data/lib/twilio-ruby/rest/flex_api/v1/plugin_configuration.rb +215 -2
- data/lib/twilio-ruby/rest/flex_api/v1/plugin_configuration_archive.rb +143 -0
- data/lib/twilio-ruby/rest/flex_api/v1/plugin_release.rb +209 -2
- data/lib/twilio-ruby/rest/flex_api/v1/plugin_version_archive.rb +144 -0
- data/lib/twilio-ruby/rest/flex_api/v1/provisioning_status.rb +139 -0
- data/lib/twilio-ruby/rest/flex_api/v1/web_channel.rb +278 -2
- data/lib/twilio-ruby/rest/flex_api/v1.rb +6 -0
- data/lib/twilio-ruby/rest/flex_api/v2/flex_user.rb +184 -39
- data/lib/twilio-ruby/rest/flex_api/v2/web_channels.rb +115 -0
- data/lib/twilio-ruby/rest/frontline_api/v1/user.rb +185 -0
- data/lib/twilio-ruby/rest/iam/v1/api_key.rb +201 -0
- data/lib/twilio-ruby/rest/iam/v1/get_api_keys.rb +99 -2
- data/lib/twilio-ruby/rest/iam/v1/{key.rb → new_api_key.rb} +127 -20
- data/lib/twilio-ruby/rest/iam/v1/o_auth_app.rb +646 -0
- data/lib/twilio-ruby/rest/iam/v1/token.rb +301 -0
- data/lib/twilio-ruby/rest/iam/v1.rb +25 -4
- data/lib/twilio-ruby/rest/iam_base.rb +1 -6
- data/lib/twilio-ruby/rest/insights/v1/call/annotation.rb +194 -0
- data/lib/twilio-ruby/rest/insights/v1/call/call_summary.rb +146 -0
- data/lib/twilio-ruby/rest/insights/v1/call/event.rb +92 -2
- data/lib/twilio-ruby/rest/insights/v1/call/metric.rb +94 -2
- data/lib/twilio-ruby/rest/insights/v1/call.rb +140 -0
- data/lib/twilio-ruby/rest/insights/v1/call_summaries.rb +188 -4
- data/lib/twilio-ruby/rest/insights/v1/conference/conference_participant.rb +183 -2
- data/lib/twilio-ruby/rest/insights/v1/conference.rb +187 -2
- data/lib/twilio-ruby/rest/insights/v1/room/participant.rb +168 -2
- data/lib/twilio-ruby/rest/insights/v1/room.rb +179 -2
- data/lib/twilio-ruby/rest/insights/v1/setting.rb +186 -0
- data/lib/twilio-ruby/rest/intelligence/v2/custom_operator.rb +275 -2
- data/lib/twilio-ruby/rest/intelligence/v2/operator.rb +171 -2
- data/lib/twilio-ruby/rest/intelligence/v2/operator_attachment.rb +163 -0
- data/lib/twilio-ruby/rest/intelligence/v2/operator_attachments.rb +140 -0
- data/lib/twilio-ruby/rest/intelligence/v2/operator_type.rb +167 -2
- data/lib/twilio-ruby/rest/intelligence/v2/prebuilt_operator.rb +171 -2
- data/lib/twilio-ruby/rest/intelligence/v2/service.rb +330 -3
- data/lib/twilio-ruby/rest/intelligence/v2/transcript/encrypted_operator_results.rb +359 -0
- data/lib/twilio-ruby/rest/intelligence/v2/transcript/encrypted_sentences.rb +359 -0
- data/lib/twilio-ruby/rest/intelligence/v2/transcript/media.rb +146 -0
- data/lib/twilio-ruby/rest/intelligence/v2/transcript/operator_result.rb +183 -2
- data/lib/twilio-ruby/rest/intelligence/v2/transcript/sentence.rb +97 -5
- data/lib/twilio-ruby/rest/intelligence/v2/transcript.rb +292 -2
- data/lib/twilio-ruby/rest/ip_messaging/v1/credential.rb +293 -2
- data/lib/twilio-ruby/rest/ip_messaging/v1/service/channel/invite.rb +234 -2
- data/lib/twilio-ruby/rest/ip_messaging/v1/service/channel/member.rb +275 -2
- data/lib/twilio-ruby/rest/ip_messaging/v1/service/channel/message.rb +277 -2
- data/lib/twilio-ruby/rest/ip_messaging/v1/service/channel.rb +281 -2
- data/lib/twilio-ruby/rest/ip_messaging/v1/service/role.rb +269 -2
- data/lib/twilio-ruby/rest/ip_messaging/v1/service/user/user_channel.rb +90 -2
- data/lib/twilio-ruby/rest/ip_messaging/v1/service/user.rb +278 -2
- data/lib/twilio-ruby/rest/ip_messaging/v1/service.rb +419 -2
- data/lib/twilio-ruby/rest/ip_messaging/v2/credential.rb +293 -2
- data/lib/twilio-ruby/rest/ip_messaging/v2/service/binding.rb +196 -2
- data/lib/twilio-ruby/rest/ip_messaging/v2/service/channel/invite.rb +234 -2
- data/lib/twilio-ruby/rest/ip_messaging/v2/service/channel/member.rb +309 -2
- data/lib/twilio-ruby/rest/ip_messaging/v2/service/channel/message.rb +308 -2
- data/lib/twilio-ruby/rest/ip_messaging/v2/service/channel/webhook.rb +299 -2
- data/lib/twilio-ruby/rest/ip_messaging/v2/service/channel.rb +306 -2
- data/lib/twilio-ruby/rest/ip_messaging/v2/service/role.rb +269 -2
- data/lib/twilio-ruby/rest/ip_messaging/v2/service/user/user_binding.rb +194 -2
- data/lib/twilio-ruby/rest/ip_messaging/v2/service/user/user_channel.rb +235 -2
- data/lib/twilio-ruby/rest/ip_messaging/v2/service/user.rb +282 -2
- data/lib/twilio-ruby/rest/ip_messaging/v2/service.rb +350 -2
- data/lib/twilio-ruby/rest/{microvisor/v1/app.rb → knowledge/v1/knowledge/chunk.rb} +133 -168
- data/lib/twilio-ruby/rest/knowledge/v1/knowledge/knowledge_status.rb +349 -0
- data/lib/twilio-ruby/rest/knowledge/v1/knowledge.rb +856 -0
- data/lib/twilio-ruby/rest/{preview/sync.rb → knowledge/v1.rb} +16 -16
- data/lib/twilio-ruby/rest/knowledge.rb +6 -0
- data/lib/twilio-ruby/rest/{microvisor_base.rb → knowledge_base.rb} +6 -6
- data/lib/twilio-ruby/rest/lookups/v1/phone_number.rb +157 -2
- data/lib/twilio-ruby/rest/lookups/v2/bucket.rb +500 -0
- data/lib/twilio-ruby/rest/lookups/v2/lookup_override.rb +603 -0
- data/lib/twilio-ruby/rest/lookups/v2/phone_number.rb +209 -15
- data/lib/twilio-ruby/rest/lookups/v2/query.rb +351 -0
- data/lib/twilio-ruby/rest/lookups/v2/rate_limit.rb +229 -0
- data/lib/twilio-ruby/rest/lookups/v2.rb +86 -0
- data/lib/twilio-ruby/rest/marketplace/v1/available_add_on/available_add_on_extension.rb +168 -2
- data/lib/twilio-ruby/rest/marketplace/v1/available_add_on.rb +167 -2
- data/lib/twilio-ruby/rest/marketplace/v1/installed_add_on/installed_add_on_extension.rb +205 -2
- data/lib/twilio-ruby/rest/marketplace/v1/installed_add_on/installed_add_on_usage.rb +97 -2
- data/lib/twilio-ruby/rest/marketplace/v1/installed_add_on.rb +272 -2
- data/lib/twilio-ruby/rest/marketplace/v1/module_data.rb +342 -0
- data/lib/twilio-ruby/rest/marketplace/v1/module_data_management.rb +201 -0
- data/lib/twilio-ruby/rest/marketplace/v1/referral_conversion.rb +99 -63
- data/lib/twilio-ruby/rest/marketplace/v1.rb +8 -2
- data/lib/twilio-ruby/rest/messaging/v1/brand_registration/brand_registration_otp.rb +92 -0
- data/lib/twilio-ruby/rest/messaging/v1/brand_registration/brand_vetting.rb +209 -2
- data/lib/twilio-ruby/rest/messaging/v1/brand_registration.rb +261 -2
- data/lib/twilio-ruby/rest/messaging/v1/deactivations.rb +145 -0
- data/lib/twilio-ruby/rest/messaging/v1/domain_certs.rb +198 -0
- data/lib/twilio-ruby/rest/messaging/v1/domain_config.rb +185 -0
- data/lib/twilio-ruby/rest/messaging/v1/domain_config_messaging_service.rb +140 -0
- data/lib/twilio-ruby/rest/messaging/v1/domain_validate_dn.rb +344 -0
- data/lib/twilio-ruby/rest/messaging/v1/external_campaign.rb +104 -0
- data/lib/twilio-ruby/rest/messaging/v1/linkshortening_messaging_service.rb +163 -0
- data/lib/twilio-ruby/rest/messaging/v1/linkshortening_messaging_service_domain_association.rb +140 -0
- data/lib/twilio-ruby/rest/messaging/v1/request_managed_cert.rb +379 -0
- data/lib/twilio-ruby/rest/messaging/v1/service/alpha_sender.rb +226 -2
- data/lib/twilio-ruby/rest/messaging/v1/service/channel_sender.rb +226 -2
- data/lib/twilio-ruby/rest/messaging/v1/service/destination_alpha_sender.rb +608 -0
- data/lib/twilio-ruby/rest/messaging/v1/service/phone_number.rb +226 -2
- data/lib/twilio-ruby/rest/messaging/v1/service/short_code.rb +226 -2
- data/lib/twilio-ruby/rest/messaging/v1/service/us_app_to_person.rb +326 -2
- data/lib/twilio-ruby/rest/messaging/v1/service/us_app_to_person_usecase.rb +98 -0
- data/lib/twilio-ruby/rest/messaging/v1/service.rb +381 -6
- data/lib/twilio-ruby/rest/messaging/v1/tollfree_verification.rb +731 -7
- data/lib/twilio-ruby/rest/messaging/v1/usecase.rb +91 -0
- data/lib/twilio-ruby/rest/messaging/v1.rb +30 -0
- data/lib/twilio-ruby/rest/messaging/v2/channels_sender.rb +1002 -0
- data/lib/twilio-ruby/rest/messaging/v2/domain_certs.rb +386 -0
- data/lib/twilio-ruby/rest/messaging/v2/typing_indicator.rb +237 -0
- data/lib/twilio-ruby/rest/messaging/v2.rb +70 -0
- data/lib/twilio-ruby/rest/messaging_base.rb +6 -1
- data/lib/twilio-ruby/rest/monitor/v1/alert.rb +173 -2
- data/lib/twilio-ruby/rest/monitor/v1/event.rb +180 -3
- data/lib/twilio-ruby/rest/notify/v1/credential.rb +293 -2
- data/lib/twilio-ruby/rest/notify/v1/service/binding.rb +254 -2
- data/lib/twilio-ruby/rest/notify/v1/service/notification.rb +150 -0
- data/lib/twilio-ruby/rest/notify/v1/service.rb +340 -2
- data/lib/twilio-ruby/rest/numbers/v1/bulk_eligibility.rb +170 -0
- data/lib/twilio-ruby/rest/numbers/v1/eligibility.rb +93 -0
- data/lib/twilio-ruby/rest/numbers/v1/porting_all_port_in.rb +367 -0
- data/lib/twilio-ruby/rest/numbers/v1/porting_port_in.rb +330 -8
- data/lib/twilio-ruby/rest/numbers/v1/porting_port_in_phone_number.rb +163 -0
- data/lib/twilio-ruby/rest/numbers/v1/porting_portability.rb +149 -0
- data/lib/twilio-ruby/rest/numbers/v1/porting_webhook_configuration.rb +93 -0
- data/lib/twilio-ruby/rest/numbers/v1/porting_webhook_configuration_delete.rb +133 -0
- data/lib/twilio-ruby/rest/numbers/v1/signing_request_configuration.rb +124 -2
- data/lib/twilio-ruby/rest/numbers/v1/webhook.rb +91 -0
- data/lib/twilio-ruby/rest/numbers/v1.rb +6 -0
- data/lib/twilio-ruby/rest/numbers/v2/application.rb +562 -0
- data/lib/twilio-ruby/rest/numbers/v2/authorization_document/dependent_hosted_number_order.rb +98 -2
- data/lib/twilio-ruby/rest/numbers/v2/authorization_document.rb +243 -2
- data/lib/twilio-ruby/rest/numbers/v2/bulk_hosted_number_order.rb +176 -0
- data/lib/twilio-ruby/rest/numbers/v2/bundle_clone.rb +153 -0
- data/lib/twilio-ruby/rest/numbers/v2/hosted_number_order.rb +411 -3
- data/lib/twilio-ruby/rest/numbers/v2/regulatory_compliance/bundle/bundle_copy.rb +126 -2
- data/lib/twilio-ruby/rest/numbers/v2/regulatory_compliance/bundle/evaluation.rb +197 -2
- data/lib/twilio-ruby/rest/numbers/v2/regulatory_compliance/bundle/item_assignment.rb +226 -2
- data/lib/twilio-ruby/rest/numbers/v2/regulatory_compliance/bundle/replace_items.rb +99 -0
- data/lib/twilio-ruby/rest/numbers/v2/regulatory_compliance/bundle.rb +312 -2
- data/lib/twilio-ruby/rest/numbers/v2/regulatory_compliance/end_user.rb +269 -2
- data/lib/twilio-ruby/rest/numbers/v2/regulatory_compliance/end_user_type.rb +167 -2
- data/lib/twilio-ruby/rest/numbers/v2/regulatory_compliance/regulation.rb +181 -2
- data/lib/twilio-ruby/rest/numbers/v2/regulatory_compliance/supporting_document.rb +269 -2
- data/lib/twilio-ruby/rest/numbers/v2/regulatory_compliance/supporting_document_type.rb +167 -2
- data/lib/twilio-ruby/rest/numbers/v2/regulatory_compliance.rb +63 -0
- data/lib/twilio-ruby/rest/numbers/v2.rb +15 -0
- data/lib/twilio-ruby/rest/numbers/v3/hosted_number_order.rb +484 -0
- data/lib/twilio-ruby/rest/numbers/v3.rb +40 -0
- data/lib/twilio-ruby/rest/numbers_base.rb +5 -0
- data/lib/twilio-ruby/rest/oauth/v1/authorize.rb +109 -0
- data/lib/twilio-ruby/rest/oauth/v1/token.rb +119 -0
- data/lib/twilio-ruby/rest/oauth/v2/authorize.rb +253 -0
- data/lib/twilio-ruby/rest/oauth/v2/token.rb +311 -0
- data/lib/twilio-ruby/rest/oauth/v2.rb +46 -0
- data/lib/twilio-ruby/rest/oauth_base.rb +6 -1
- data/lib/twilio-ruby/rest/preview/hosted_numbers/authorization_document/dependent_hosted_number_order.rb +100 -2
- data/lib/twilio-ruby/rest/preview/hosted_numbers/authorization_document.rb +275 -2
- data/lib/twilio-ruby/rest/preview/hosted_numbers/hosted_number_order.rb +345 -2
- data/lib/twilio-ruby/rest/preview/marketplace/available_add_on/available_add_on_extension.rb +168 -2
- data/lib/twilio-ruby/rest/preview/marketplace/available_add_on.rb +167 -2
- data/lib/twilio-ruby/rest/preview/marketplace/installed_add_on/installed_add_on_extension.rb +205 -2
- data/lib/twilio-ruby/rest/preview/marketplace/installed_add_on.rb +272 -2
- data/lib/twilio-ruby/rest/preview/wireless/command.rb +228 -2
- data/lib/twilio-ruby/rest/preview/wireless/rate_plan.rb +290 -2
- data/lib/twilio-ruby/rest/preview/wireless/sim/usage.rb +149 -0
- data/lib/twilio-ruby/rest/preview/wireless/sim.rb +258 -2
- data/lib/twilio-ruby/rest/preview.rb +0 -9
- data/lib/twilio-ruby/rest/preview_base.rb +0 -5
- data/lib/twilio-ruby/rest/preview_iam/v1/authorize.rb +253 -0
- data/lib/twilio-ruby/rest/preview_iam/v1/token.rb +301 -0
- data/lib/twilio-ruby/rest/preview_iam/v1.rb +46 -0
- data/lib/twilio-ruby/rest/preview_iam/versionless/organization/account.rb +468 -0
- data/lib/twilio-ruby/rest/preview_iam/versionless/organization/role_assignment.rb +559 -0
- data/lib/twilio-ruby/rest/preview_iam/versionless/organization/user.rb +768 -0
- data/lib/twilio-ruby/rest/preview_iam/versionless/organization.rb +413 -0
- data/lib/twilio-ruby/rest/preview_iam/versionless.rb +49 -0
- data/lib/twilio-ruby/rest/preview_iam.rb +9 -0
- data/lib/twilio-ruby/rest/preview_iam_base.rb +38 -0
- data/lib/twilio-ruby/rest/pricing/v1/messaging/country.rb +167 -2
- data/lib/twilio-ruby/rest/pricing/v1/messaging.rb +63 -0
- data/lib/twilio-ruby/rest/pricing/v1/phone_number/country.rb +167 -2
- data/lib/twilio-ruby/rest/pricing/v1/phone_number.rb +63 -0
- data/lib/twilio-ruby/rest/pricing/v1/voice/country.rb +167 -2
- data/lib/twilio-ruby/rest/pricing/v1/voice/number.rb +140 -0
- data/lib/twilio-ruby/rest/pricing/v1/voice.rb +63 -0
- data/lib/twilio-ruby/rest/pricing/v2/country.rb +167 -2
- data/lib/twilio-ruby/rest/pricing/v2/number.rb +146 -0
- data/lib/twilio-ruby/rest/pricing/v2/voice/country.rb +167 -2
- data/lib/twilio-ruby/rest/pricing/v2/voice/number.rb +146 -0
- data/lib/twilio-ruby/rest/pricing/v2/voice.rb +63 -0
- data/lib/twilio-ruby/rest/proxy/v1/service/phone_number.rb +269 -2
- data/lib/twilio-ruby/rest/proxy/v1/service/session/interaction.rb +191 -2
- data/lib/twilio-ruby/rest/proxy/v1/service/session/participant/message_interaction.rb +211 -2
- data/lib/twilio-ruby/rest/proxy/v1/service/session/participant.rb +237 -2
- data/lib/twilio-ruby/rest/proxy/v1/service/session.rb +284 -2
- data/lib/twilio-ruby/rest/proxy/v1/service.rb +302 -29
- data/lib/twilio-ruby/rest/routes/v2/phone_number.rb +179 -0
- data/lib/twilio-ruby/rest/routes/v2/sip_domain.rb +179 -0
- data/lib/twilio-ruby/rest/routes/v2/trunk.rb +179 -0
- data/lib/twilio-ruby/rest/serverless/v1/service/asset/asset_version.rb +169 -2
- data/lib/twilio-ruby/rest/serverless/v1/service/asset.rb +263 -2
- data/lib/twilio-ruby/rest/serverless/v1/service/build/build_status.rb +141 -0
- data/lib/twilio-ruby/rest/serverless/v1/service/build.rb +235 -2
- data/lib/twilio-ruby/rest/serverless/v1/service/environment/deployment.rb +209 -2
- data/lib/twilio-ruby/rest/serverless/v1/service/environment/log.rb +176 -3
- data/lib/twilio-ruby/rest/serverless/v1/service/environment/variable.rb +272 -2
- data/lib/twilio-ruby/rest/serverless/v1/service/environment.rb +229 -2
- data/lib/twilio-ruby/rest/serverless/v1/service/function/function_version/function_version_content.rb +142 -0
- data/lib/twilio-ruby/rest/serverless/v1/service/function/function_version.rb +169 -2
- data/lib/twilio-ruby/rest/serverless/v1/service/function.rb +263 -2
- data/lib/twilio-ruby/rest/serverless/v1/service.rb +275 -2
- data/lib/twilio-ruby/rest/studio/v1/flow/engagement/engagement_context.rb +141 -0
- data/lib/twilio-ruby/rest/studio/v1/flow/engagement/step/step_context.rb +142 -0
- data/lib/twilio-ruby/rest/studio/v1/flow/engagement/step.rb +183 -2
- data/lib/twilio-ruby/rest/studio/v1/flow/engagement.rb +232 -2
- data/lib/twilio-ruby/rest/studio/v1/flow/execution/execution_context.rb +141 -0
- data/lib/twilio-ruby/rest/studio/v1/flow/execution/execution_step/execution_step_context.rb +142 -0
- data/lib/twilio-ruby/rest/studio/v1/flow/execution/execution_step.rb +183 -2
- data/lib/twilio-ruby/rest/studio/v1/flow/execution.rb +273 -2
- data/lib/twilio-ruby/rest/studio/v1/flow.rb +189 -2
- data/lib/twilio-ruby/rest/studio/v2/flow/execution/execution_context.rb +141 -0
- data/lib/twilio-ruby/rest/studio/v2/flow/execution/execution_step/execution_step_context.rb +142 -0
- data/lib/twilio-ruby/rest/studio/v2/flow/execution/execution_step.rb +183 -2
- data/lib/twilio-ruby/rest/studio/v2/flow/execution.rb +273 -2
- data/lib/twilio-ruby/rest/studio/v2/flow/flow_revision.rb +168 -2
- data/lib/twilio-ruby/rest/studio/v2/flow/flow_test_user.rb +176 -0
- data/lib/twilio-ruby/rest/studio/v2/flow.rb +278 -2
- data/lib/twilio-ruby/rest/studio/v2/flow_validate.rb +107 -0
- data/lib/twilio-ruby/rest/supersim/v1/esim_profile.rb +217 -2
- data/lib/twilio-ruby/rest/supersim/v1/fleet.rb +282 -2
- data/lib/twilio-ruby/rest/supersim/v1/ip_command.rb +225 -2
- data/lib/twilio-ruby/rest/supersim/v1/network.rb +173 -2
- data/lib/twilio-ruby/rest/supersim/v1/network_access_profile/network_access_profile_network.rb +226 -2
- data/lib/twilio-ruby/rest/supersim/v1/network_access_profile.rb +241 -2
- data/lib/twilio-ruby/rest/supersim/v1/settings_update.rb +94 -2
- data/lib/twilio-ruby/rest/supersim/v1/sim/billing_period.rb +90 -2
- data/lib/twilio-ruby/rest/supersim/v1/sim/sim_ip_address.rb +90 -2
- data/lib/twilio-ruby/rest/supersim/v1/sim.rb +262 -2
- data/lib/twilio-ruby/rest/supersim/v1/sms_command.rb +217 -2
- data/lib/twilio-ruby/rest/supersim/v1/usage_record.rb +106 -2
- data/lib/twilio-ruby/rest/sync/v1/service/document/document_permission.rb +235 -2
- data/lib/twilio-ruby/rest/sync/v1/service/document.rb +275 -3
- data/lib/twilio-ruby/rest/sync/v1/service/sync_list/sync_list_item.rb +295 -2
- data/lib/twilio-ruby/rest/sync/v1/service/sync_list/sync_list_permission.rb +235 -2
- data/lib/twilio-ruby/rest/sync/v1/service/sync_list.rb +274 -4
- data/lib/twilio-ruby/rest/sync/v1/service/sync_map/sync_map_item.rb +298 -2
- data/lib/twilio-ruby/rest/sync/v1/service/sync_map/sync_map_permission.rb +235 -2
- data/lib/twilio-ruby/rest/sync/v1/service/sync_map.rb +274 -4
- data/lib/twilio-ruby/rest/sync/v1/service/sync_stream/stream_message.rb +100 -0
- data/lib/twilio-ruby/rest/sync/v1/service/sync_stream.rb +267 -3
- data/lib/twilio-ruby/rest/sync/v1/service.rb +299 -5
- data/lib/twilio-ruby/rest/taskrouter/v1/workspace/activity.rb +270 -2
- data/lib/twilio-ruby/rest/taskrouter/v1/workspace/event.rb +190 -2
- data/lib/twilio-ruby/rest/taskrouter/v1/workspace/task/reservation.rb +374 -4
- data/lib/twilio-ruby/rest/taskrouter/v1/workspace/task.rb +329 -3
- data/lib/twilio-ruby/rest/taskrouter/v1/workspace/task_channel.rb +272 -2
- data/lib/twilio-ruby/rest/taskrouter/v1/workspace/task_queue/task_queue_bulk_real_time_statistics.rb +94 -0
- data/lib/twilio-ruby/rest/taskrouter/v1/workspace/task_queue/task_queue_cumulative_statistics.rb +159 -0
- data/lib/twilio-ruby/rest/taskrouter/v1/workspace/task_queue/task_queue_real_time_statistics.rb +147 -0
- data/lib/twilio-ruby/rest/taskrouter/v1/workspace/task_queue/task_queue_statistics.rb +159 -0
- data/lib/twilio-ruby/rest/taskrouter/v1/workspace/task_queue/task_queues_statistics.rb +102 -2
- data/lib/twilio-ruby/rest/taskrouter/v1/workspace/task_queue.rb +301 -2
- data/lib/twilio-ruby/rest/taskrouter/v1/workspace/worker/reservation.rb +366 -4
- data/lib/twilio-ruby/rest/taskrouter/v1/workspace/worker/worker_channel.rb +210 -2
- data/lib/twilio-ruby/rest/taskrouter/v1/workspace/worker/worker_statistics.rb +156 -0
- data/lib/twilio-ruby/rest/taskrouter/v1/workspace/worker/workers_cumulative_statistics.rb +155 -0
- data/lib/twilio-ruby/rest/taskrouter/v1/workspace/worker/workers_real_time_statistics.rb +146 -0
- data/lib/twilio-ruby/rest/taskrouter/v1/workspace/worker/workers_statistics.rb +164 -0
- data/lib/twilio-ruby/rest/taskrouter/v1/workspace/worker.rb +299 -2
- data/lib/twilio-ruby/rest/taskrouter/v1/workspace/workflow/workflow_cumulative_statistics.rb +159 -0
- data/lib/twilio-ruby/rest/taskrouter/v1/workspace/workflow/workflow_real_time_statistics.rb +147 -0
- data/lib/twilio-ruby/rest/taskrouter/v1/workspace/workflow/workflow_statistics.rb +159 -0
- data/lib/twilio-ruby/rest/taskrouter/v1/workspace/workflow.rb +292 -2
- data/lib/twilio-ruby/rest/taskrouter/v1/workspace/workspace_cumulative_statistics.rb +158 -0
- data/lib/twilio-ruby/rest/taskrouter/v1/workspace/workspace_real_time_statistics.rb +146 -0
- data/lib/twilio-ruby/rest/taskrouter/v1/workspace/workspace_statistics.rb +158 -0
- data/lib/twilio-ruby/rest/taskrouter/v1/workspace.rb +295 -2
- data/lib/twilio-ruby/rest/trunking/v1/trunk/credential_list.rb +226 -2
- data/lib/twilio-ruby/rest/trunking/v1/trunk/ip_access_control_list.rb +226 -2
- data/lib/twilio-ruby/rest/trunking/v1/trunk/origination_url.rb +287 -2
- data/lib/twilio-ruby/rest/trunking/v1/trunk/phone_number.rb +227 -3
- data/lib/twilio-ruby/rest/trunking/v1/trunk/recording.rb +179 -0
- data/lib/twilio-ruby/rest/trunking/v1/trunk.rb +309 -2
- data/lib/twilio-ruby/rest/trusthub/v1/compliance_inquiries.rb +195 -4
- data/lib/twilio-ruby/rest/trusthub/v1/compliance_registration_inquiries.rb +299 -0
- data/lib/twilio-ruby/rest/trusthub/v1/compliance_tollfree_inquiries.rb +255 -1
- data/lib/twilio-ruby/rest/trusthub/v1/customer_profiles/customer_profiles_channel_endpoint_assignment.rb +233 -2
- data/lib/twilio-ruby/rest/trusthub/v1/customer_profiles/customer_profiles_entity_assignments.rb +228 -2
- data/lib/twilio-ruby/rest/trusthub/v1/customer_profiles/customer_profiles_evaluations.rb +204 -2
- data/lib/twilio-ruby/rest/trusthub/v1/customer_profiles.rb +284 -2
- data/lib/twilio-ruby/rest/trusthub/v1/end_user.rb +269 -2
- data/lib/twilio-ruby/rest/trusthub/v1/end_user_type.rb +167 -2
- data/lib/twilio-ruby/rest/trusthub/v1/policies.rb +167 -2
- data/lib/twilio-ruby/rest/trusthub/v1/supporting_document.rb +269 -2
- data/lib/twilio-ruby/rest/trusthub/v1/supporting_document_type.rb +167 -2
- data/lib/twilio-ruby/rest/trusthub/v1/trust_products/trust_products_channel_endpoint_assignment.rb +233 -2
- data/lib/twilio-ruby/rest/trusthub/v1/trust_products/trust_products_entity_assignments.rb +228 -2
- data/lib/twilio-ruby/rest/trusthub/v1/trust_products/trust_products_evaluations.rb +204 -2
- data/lib/twilio-ruby/rest/trusthub/v1/trust_products.rb +284 -2
- data/lib/twilio-ruby/rest/verify/v2/form.rb +140 -0
- data/lib/twilio-ruby/rest/verify/v2/safelist.rb +197 -0
- data/lib/twilio-ruby/rest/verify/v2/service/access_token.rb +186 -0
- data/lib/twilio-ruby/rest/verify/v2/service/approve_challenge.rb +402 -0
- data/lib/twilio-ruby/rest/verify/v2/service/entity/challenge/notification.rb +101 -0
- data/lib/twilio-ruby/rest/verify/v2/service/entity/challenge.rb +268 -2
- data/lib/twilio-ruby/rest/verify/v2/service/entity/factor.rb +253 -2
- data/lib/twilio-ruby/rest/verify/v2/service/entity/new_factor.rb +146 -0
- data/lib/twilio-ruby/rest/verify/v2/service/entity.rb +226 -2
- data/lib/twilio-ruby/rest/verify/v2/service/messaging_configuration.rb +266 -2
- data/lib/twilio-ruby/rest/verify/v2/service/new_challenge.rb +478 -0
- data/lib/twilio-ruby/rest/verify/v2/service/new_factor.rb +387 -0
- data/lib/twilio-ruby/rest/verify/v2/service/new_verify_factor.rb +357 -0
- data/lib/twilio-ruby/rest/verify/v2/service/rate_limit/bucket.rb +272 -2
- data/lib/twilio-ruby/rest/verify/v2/service/rate_limit.rb +266 -2
- data/lib/twilio-ruby/rest/verify/v2/service/verification.rb +265 -0
- data/lib/twilio-ruby/rest/verify/v2/service/verification_check.rb +114 -0
- data/lib/twilio-ruby/rest/verify/v2/service/webhook.rb +287 -2
- data/lib/twilio-ruby/rest/verify/v2/service.rb +547 -3
- data/lib/twilio-ruby/rest/verify/v2/template.rb +92 -2
- data/lib/twilio-ruby/rest/verify/v2/verification_attempt.rb +186 -5
- data/lib/twilio-ruby/rest/verify/v2/verification_attempts_summary.rb +163 -3
- data/lib/twilio-ruby/rest/video/v1/composition.rb +256 -2
- data/lib/twilio-ruby/rest/video/v1/composition_hook.rb +322 -2
- data/lib/twilio-ruby/rest/video/v1/composition_settings.rb +189 -0
- data/lib/twilio-ruby/rest/video/v1/recording.rb +202 -2
- data/lib/twilio-ruby/rest/video/v1/recording_settings.rb +189 -0
- data/lib/twilio-ruby/rest/video/v1/room/participant/anonymize.rb +141 -0
- data/lib/twilio-ruby/rest/video/v1/room/participant/published_track.rb +169 -2
- data/lib/twilio-ruby/rest/video/v1/room/participant/subscribe_rules.rb +130 -0
- data/lib/twilio-ruby/rest/video/v1/room/participant/subscribed_track.rb +169 -2
- data/lib/twilio-ruby/rest/video/v1/room/participant.rb +213 -2
- data/lib/twilio-ruby/rest/video/v1/room/recording_rules.rb +128 -0
- data/lib/twilio-ruby/rest/video/v1/room/room_recording.rb +198 -2
- data/lib/twilio-ruby/rest/video/v1/room/transcriptions.rb +648 -0
- data/lib/twilio-ruby/rest/video/v1/room.rb +341 -16
- data/lib/twilio-ruby/rest/voice/v1/archived_call.rb +133 -0
- data/lib/twilio-ruby/rest/voice/v1/byoc_trunk.rb +314 -2
- data/lib/twilio-ruby/rest/voice/v1/connection_policy/connection_policy_target.rb +287 -2
- data/lib/twilio-ruby/rest/voice/v1/connection_policy.rb +260 -2
- data/lib/twilio-ruby/rest/voice/v1/dialing_permissions/bulk_country_update.rb +98 -0
- data/lib/twilio-ruby/rest/voice/v1/dialing_permissions/country/highrisk_special_prefix.rb +90 -2
- data/lib/twilio-ruby/rest/voice/v1/dialing_permissions/country.rb +179 -2
- data/lib/twilio-ruby/rest/voice/v1/dialing_permissions/settings.rb +174 -0
- data/lib/twilio-ruby/rest/voice/v1/dialing_permissions.rb +63 -0
- data/lib/twilio-ruby/rest/voice/v1/ip_record.rb +266 -2
- data/lib/twilio-ruby/rest/voice/v1/source_ip_mapping.rb +263 -2
- data/lib/twilio-ruby/rest/wireless/v1/command.rb +250 -2
- data/lib/twilio-ruby/rest/wireless/v1/rate_plan.rb +300 -3
- data/lib/twilio-ruby/rest/wireless/v1/sim/data_session.rb +90 -2
- data/lib/twilio-ruby/rest/wireless/v1/sim/usage_record.rb +96 -2
- data/lib/twilio-ruby/rest/wireless/v1/sim.rb +286 -2
- data/lib/twilio-ruby/rest/wireless/v1/usage_record.rb +96 -2
- data/lib/twilio-ruby/twiml/voice_response.rb +305 -10
- data/lib/twilio-ruby/version.rb +1 -1
- data/twilio-ruby.gemspec +1 -1
- metadata +76 -32
- data/lib/twilio-ruby/rest/microvisor/v1/account_config.rb +0 -365
- data/lib/twilio-ruby/rest/microvisor/v1/account_secret.rb +0 -358
- data/lib/twilio-ruby/rest/microvisor/v1/app/app_manifest.rb +0 -209
- data/lib/twilio-ruby/rest/microvisor/v1/device/device_config.rb +0 -381
- data/lib/twilio-ruby/rest/microvisor/v1/device/device_secret.rb +0 -374
- data/lib/twilio-ruby/rest/microvisor/v1/device.rb +0 -430
- data/lib/twilio-ruby/rest/microvisor/v1.rb +0 -94
- data/lib/twilio-ruby/rest/microvisor.rb +0 -24
- data/lib/twilio-ruby/rest/preview/sync/service/document/document_permission.rb +0 -394
- data/lib/twilio-ruby/rest/preview/sync/service/document.rb +0 -455
- data/lib/twilio-ruby/rest/preview/sync/service/sync_list/sync_list_item.rb +0 -450
- data/lib/twilio-ruby/rest/preview/sync/service/sync_list/sync_list_permission.rb +0 -394
- data/lib/twilio-ruby/rest/preview/sync/service/sync_list.rb +0 -431
- data/lib/twilio-ruby/rest/preview/sync/service/sync_map/sync_map_item.rb +0 -453
- data/lib/twilio-ruby/rest/preview/sync/service/sync_map/sync_map_permission.rb +0 -394
- data/lib/twilio-ruby/rest/preview/sync/service/sync_map.rb +0 -431
- data/lib/twilio-ruby/rest/preview/sync/service.rb +0 -512
- data/lib/twilio-ruby/rest/proxy/v1/service/short_code.rb +0 -413
|
@@ -28,6 +28,7 @@ module Twilio
|
|
|
28
28
|
# @return [ParticipantList] ParticipantList
|
|
29
29
|
def initialize(version, account_sid: nil, conference_sid: nil)
|
|
30
30
|
super(version)
|
|
31
|
+
|
|
31
32
|
# Path Solution
|
|
32
33
|
@solution = { account_sid: account_sid, conference_sid: conference_sid }
|
|
33
34
|
@uri = "/Accounts/#{@solution[:account_sid]}/Conferences/#{@solution[:conference_sid]}/Participants.json"
|
|
@@ -36,7 +37,7 @@ module Twilio
|
|
|
36
37
|
##
|
|
37
38
|
# Create the ParticipantInstance
|
|
38
39
|
# @param [String] from The phone number, Client identifier, or username portion of SIP address that made this call. Phone numbers are in [E.164](https://www.twilio.com/docs/glossary/what-e164) format (e.g., +16175551212). Client identifiers are formatted `client:name`. If using a phone number, it must be a Twilio number or a Verified [outgoing caller id](https://www.twilio.com/docs/voice/api/outgoing-caller-ids) for your account. If the `to` parameter is a phone number, `from` must also be a phone number. If `to` is sip address, this value of `from` should be a username portion to be used to populate the P-Asserted-Identity header that is passed to the SIP endpoint.
|
|
39
|
-
# @param [String] to The phone number, SIP address,
|
|
40
|
+
# @param [String] to The phone number, SIP address, Client, TwiML App identifier that received this call. Phone numbers are in [E.164](https://www.twilio.com/docs/glossary/what-e164) format (e.g., +16175551212). SIP addresses are formatted as `sip:name@company.com`. Client identifiers are formatted `client:name`. TwiML App identifiers are formatted `app:<APP_SID>`. [Custom parameters](https://www.twilio.com/docs/voice/api/conference-participant-resource#custom-parameters) may also be specified.
|
|
40
41
|
# @param [String] status_callback The URL we should call using the `status_callback_method` to send status information to your application.
|
|
41
42
|
# @param [String] status_callback_method The HTTP method we should use to call `status_callback`. Can be: `GET` and `POST` and defaults to `POST`.
|
|
42
43
|
# @param [Array[String]] status_callback_event The conference state changes that should generate a call to `status_callback`. Can be: `initiated`, `ringing`, `answered`, and `completed`. Separate multiple values with a space. The default value is `completed`.
|
|
@@ -47,7 +48,7 @@ module Twilio
|
|
|
47
48
|
# @param [String] beep Whether to play a notification beep to the conference when the participant joins. Can be: `true`, `false`, `onEnter`, or `onExit`. The default value is `true`.
|
|
48
49
|
# @param [Boolean] start_conference_on_enter Whether to start the conference when the participant joins, if it has not already started. Can be: `true` or `false` and the default is `true`. If `false` and the conference has not started, the participant is muted and hears background music until another participant starts the conference.
|
|
49
50
|
# @param [Boolean] end_conference_on_exit Whether to end the conference when the participant leaves. Can be: `true` or `false` and defaults to `false`.
|
|
50
|
-
# @param [String] wait_url The URL
|
|
51
|
+
# @param [String] wait_url The URL that Twilio calls using the `wait_method` before the conference has started. The URL may return an MP3 file, a WAV file, or a TwiML document. The default value is the URL of our standard hold music. If you do not want anything to play while waiting for the conference to start, specify an empty string by setting `wait_url` to `''`. For more details on the allowable verbs within the `waitUrl`, see the `waitUrl` attribute in the [<Conference> TwiML instruction](https://www.twilio.com/docs/voice/twiml/conference#attributes-waiturl).
|
|
51
52
|
# @param [String] wait_method The HTTP method we should use to call `wait_url`. Can be `GET` or `POST` and the default is `POST`. When using a static audio file, this should be `GET` so that we can cache the file.
|
|
52
53
|
# @param [Boolean] early_media Whether to allow an agent to hear the state of the outbound call, including ringing or disconnect messages. Can be: `true` or `false` and defaults to `true`.
|
|
53
54
|
# @param [String] max_participants The maximum number of participants in the conference. Can be a positive integer from `2` to `250`. The default value is `250`.
|
|
@@ -61,7 +62,7 @@ module Twilio
|
|
|
61
62
|
# @param [String] recording_status_callback_method The HTTP method we should use when we call `recording_status_callback`. Can be: `GET` or `POST` and defaults to `POST`.
|
|
62
63
|
# @param [String] sip_auth_username The SIP username used for authentication.
|
|
63
64
|
# @param [String] sip_auth_password The SIP password for authentication.
|
|
64
|
-
# @param [String] region The [region](https://support.twilio.com/hc/en-us/articles/223132167-How-global-low-latency-routing-and-region-selection-work-for-conferences-and-Client-calls) where we should mix the recorded audio. Can be:`us1`, `ie1`, `de1`, `sg1`, `br1`, `au1`, or `jp1`.
|
|
65
|
+
# @param [String] region The [region](https://support.twilio.com/hc/en-us/articles/223132167-How-global-low-latency-routing-and-region-selection-work-for-conferences-and-Client-calls) where we should mix the recorded audio. Can be:`us1`, `us2`, `ie1`, `de1`, `sg1`, `br1`, `au1`, or `jp1`.
|
|
65
66
|
# @param [String] conference_recording_status_callback The URL we should call using the `conference_recording_status_callback_method` when the conference recording is available.
|
|
66
67
|
# @param [String] conference_recording_status_callback_method The HTTP method we should use to call `conference_recording_status_callback`. Can be: `GET` or `POST` and defaults to `POST`.
|
|
67
68
|
# @param [Array[String]] recording_status_callback_event The recording state changes that should generate a call to `recording_status_callback`. Can be: `started`, `in-progress`, `paused`, `resumed`, `stopped`, `completed`, `failed`, and `absent`. Separate multiple values with a space, ex: `'in-progress completed failed'`.
|
|
@@ -83,6 +84,8 @@ module Twilio
|
|
|
83
84
|
# @param [String] amd_status_callback_method The HTTP method we should use when calling the `amd_status_callback` URL. Can be: `GET` or `POST` and the default is `POST`.
|
|
84
85
|
# @param [String] trim Whether to trim any leading and trailing silence from the participant recording. Can be: `trim-silence` or `do-not-trim` and the default is `trim-silence`.
|
|
85
86
|
# @param [String] call_token A token string needed to invoke a forwarded call. A call_token is generated when an incoming call is received on a Twilio number. Pass an incoming call's call_token value to a forwarded call via the call_token parameter when creating a new call. A forwarded call should bear the same CallerID of the original incoming call.
|
|
87
|
+
# @param [String] client_notification_url The URL that we should use to deliver `push call notification`.
|
|
88
|
+
# @param [String] caller_display_name The name that populates the display name in the From header. Must be between 2 and 255 characters. Only applicable for calls to sip address.
|
|
86
89
|
# @return [ParticipantInstance] Created ParticipantInstance
|
|
87
90
|
def create(
|
|
88
91
|
from: nil,
|
|
@@ -132,7 +135,9 @@ module Twilio
|
|
|
132
135
|
amd_status_callback: :unset,
|
|
133
136
|
amd_status_callback_method: :unset,
|
|
134
137
|
trim: :unset,
|
|
135
|
-
call_token: :unset
|
|
138
|
+
call_token: :unset,
|
|
139
|
+
client_notification_url: :unset,
|
|
140
|
+
caller_display_name: :unset
|
|
136
141
|
)
|
|
137
142
|
|
|
138
143
|
data = Twilio::Values.of({
|
|
@@ -184,10 +189,16 @@ module Twilio
|
|
|
184
189
|
'AmdStatusCallbackMethod' => amd_status_callback_method,
|
|
185
190
|
'Trim' => trim,
|
|
186
191
|
'CallToken' => call_token,
|
|
192
|
+
'ClientNotificationUrl' => client_notification_url,
|
|
193
|
+
'CallerDisplayName' => caller_display_name,
|
|
187
194
|
})
|
|
188
195
|
|
|
189
196
|
headers = Twilio::Values.of({'Content-Type' => 'application/x-www-form-urlencoded', })
|
|
190
197
|
|
|
198
|
+
|
|
199
|
+
|
|
200
|
+
|
|
201
|
+
|
|
191
202
|
payload = @version.create('POST', @uri, data: data, headers: headers)
|
|
192
203
|
ParticipantInstance.new(
|
|
193
204
|
@version,
|
|
@@ -197,6 +208,186 @@ module Twilio
|
|
|
197
208
|
)
|
|
198
209
|
end
|
|
199
210
|
|
|
211
|
+
##
|
|
212
|
+
# Create the ParticipantInstanceMetadata
|
|
213
|
+
# @param [String] from The phone number, Client identifier, or username portion of SIP address that made this call. Phone numbers are in [E.164](https://www.twilio.com/docs/glossary/what-e164) format (e.g., +16175551212). Client identifiers are formatted `client:name`. If using a phone number, it must be a Twilio number or a Verified [outgoing caller id](https://www.twilio.com/docs/voice/api/outgoing-caller-ids) for your account. If the `to` parameter is a phone number, `from` must also be a phone number. If `to` is sip address, this value of `from` should be a username portion to be used to populate the P-Asserted-Identity header that is passed to the SIP endpoint.
|
|
214
|
+
# @param [String] to The phone number, SIP address, Client, TwiML App identifier that received this call. Phone numbers are in [E.164](https://www.twilio.com/docs/glossary/what-e164) format (e.g., +16175551212). SIP addresses are formatted as `sip:name@company.com`. Client identifiers are formatted `client:name`. TwiML App identifiers are formatted `app:<APP_SID>`. [Custom parameters](https://www.twilio.com/docs/voice/api/conference-participant-resource#custom-parameters) may also be specified.
|
|
215
|
+
# @param [String] status_callback The URL we should call using the `status_callback_method` to send status information to your application.
|
|
216
|
+
# @param [String] status_callback_method The HTTP method we should use to call `status_callback`. Can be: `GET` and `POST` and defaults to `POST`.
|
|
217
|
+
# @param [Array[String]] status_callback_event The conference state changes that should generate a call to `status_callback`. Can be: `initiated`, `ringing`, `answered`, and `completed`. Separate multiple values with a space. The default value is `completed`.
|
|
218
|
+
# @param [String] label A label for this participant. If one is supplied, it may subsequently be used to fetch, update or delete the participant.
|
|
219
|
+
# @param [String] timeout The number of seconds that we should allow the phone to ring before assuming there is no answer. Can be an integer between `5` and `600`, inclusive. The default value is `60`. We always add a 5-second timeout buffer to outgoing calls, so value of 10 would result in an actual timeout that was closer to 15 seconds.
|
|
220
|
+
# @param [Boolean] record Whether to record the participant and their conferences, including the time between conferences. Can be `true` or `false` and the default is `false`.
|
|
221
|
+
# @param [Boolean] muted Whether the agent is muted in the conference. Can be `true` or `false` and the default is `false`.
|
|
222
|
+
# @param [String] beep Whether to play a notification beep to the conference when the participant joins. Can be: `true`, `false`, `onEnter`, or `onExit`. The default value is `true`.
|
|
223
|
+
# @param [Boolean] start_conference_on_enter Whether to start the conference when the participant joins, if it has not already started. Can be: `true` or `false` and the default is `true`. If `false` and the conference has not started, the participant is muted and hears background music until another participant starts the conference.
|
|
224
|
+
# @param [Boolean] end_conference_on_exit Whether to end the conference when the participant leaves. Can be: `true` or `false` and defaults to `false`.
|
|
225
|
+
# @param [String] wait_url The URL that Twilio calls using the `wait_method` before the conference has started. The URL may return an MP3 file, a WAV file, or a TwiML document. The default value is the URL of our standard hold music. If you do not want anything to play while waiting for the conference to start, specify an empty string by setting `wait_url` to `''`. For more details on the allowable verbs within the `waitUrl`, see the `waitUrl` attribute in the [<Conference> TwiML instruction](https://www.twilio.com/docs/voice/twiml/conference#attributes-waiturl).
|
|
226
|
+
# @param [String] wait_method The HTTP method we should use to call `wait_url`. Can be `GET` or `POST` and the default is `POST`. When using a static audio file, this should be `GET` so that we can cache the file.
|
|
227
|
+
# @param [Boolean] early_media Whether to allow an agent to hear the state of the outbound call, including ringing or disconnect messages. Can be: `true` or `false` and defaults to `true`.
|
|
228
|
+
# @param [String] max_participants The maximum number of participants in the conference. Can be a positive integer from `2` to `250`. The default value is `250`.
|
|
229
|
+
# @param [String] conference_record Whether to record the conference the participant is joining. Can be: `true`, `false`, `record-from-start`, and `do-not-record`. The default value is `false`.
|
|
230
|
+
# @param [String] conference_trim Whether to trim leading and trailing silence from the conference recording. Can be: `trim-silence` or `do-not-trim` and defaults to `trim-silence`.
|
|
231
|
+
# @param [String] conference_status_callback The URL we should call using the `conference_status_callback_method` when the conference events in `conference_status_callback_event` occur. Only the value set by the first participant to join the conference is used. Subsequent `conference_status_callback` values are ignored.
|
|
232
|
+
# @param [String] conference_status_callback_method The HTTP method we should use to call `conference_status_callback`. Can be: `GET` or `POST` and defaults to `POST`.
|
|
233
|
+
# @param [Array[String]] conference_status_callback_event The conference state changes that should generate a call to `conference_status_callback`. Can be: `start`, `end`, `join`, `leave`, `mute`, `hold`, `modify`, `speaker`, and `announcement`. Separate multiple values with a space. Defaults to `start end`.
|
|
234
|
+
# @param [String] recording_channels The recording channels for the final recording. Can be: `mono` or `dual` and the default is `mono`.
|
|
235
|
+
# @param [String] recording_status_callback The URL that we should call using the `recording_status_callback_method` when the recording status changes.
|
|
236
|
+
# @param [String] recording_status_callback_method The HTTP method we should use when we call `recording_status_callback`. Can be: `GET` or `POST` and defaults to `POST`.
|
|
237
|
+
# @param [String] sip_auth_username The SIP username used for authentication.
|
|
238
|
+
# @param [String] sip_auth_password The SIP password for authentication.
|
|
239
|
+
# @param [String] region The [region](https://support.twilio.com/hc/en-us/articles/223132167-How-global-low-latency-routing-and-region-selection-work-for-conferences-and-Client-calls) where we should mix the recorded audio. Can be:`us1`, `us2`, `ie1`, `de1`, `sg1`, `br1`, `au1`, or `jp1`.
|
|
240
|
+
# @param [String] conference_recording_status_callback The URL we should call using the `conference_recording_status_callback_method` when the conference recording is available.
|
|
241
|
+
# @param [String] conference_recording_status_callback_method The HTTP method we should use to call `conference_recording_status_callback`. Can be: `GET` or `POST` and defaults to `POST`.
|
|
242
|
+
# @param [Array[String]] recording_status_callback_event The recording state changes that should generate a call to `recording_status_callback`. Can be: `started`, `in-progress`, `paused`, `resumed`, `stopped`, `completed`, `failed`, and `absent`. Separate multiple values with a space, ex: `'in-progress completed failed'`.
|
|
243
|
+
# @param [Array[String]] conference_recording_status_callback_event The conference recording state changes that generate a call to `conference_recording_status_callback`. Can be: `in-progress`, `completed`, `failed`, and `absent`. Separate multiple values with a space, ex: `'in-progress completed failed'`
|
|
244
|
+
# @param [Boolean] coaching Whether the participant is coaching another call. Can be: `true` or `false`. If not present, defaults to `false` unless `call_sid_to_coach` is defined. If `true`, `call_sid_to_coach` must be defined.
|
|
245
|
+
# @param [String] call_sid_to_coach The SID of the participant who is being `coached`. The participant being coached is the only participant who can hear the participant who is `coaching`.
|
|
246
|
+
# @param [String] jitter_buffer_size Jitter buffer size for the connecting participant. Twilio will use this setting to apply Jitter Buffer before participant's audio is mixed into the conference. Can be: `off`, `small`, `medium`, and `large`. Default to `large`.
|
|
247
|
+
# @param [String] byoc The SID of a BYOC (Bring Your Own Carrier) trunk to route this call with. Note that `byoc` is only meaningful when `to` is a phone number; it will otherwise be ignored. (Beta)
|
|
248
|
+
# @param [String] caller_id The phone number, Client identifier, or username portion of SIP address that made this call. Phone numbers are in [E.164](https://www.twilio.com/docs/glossary/what-e164) format (e.g., +16175551212). Client identifiers are formatted `client:name`. If using a phone number, it must be a Twilio number or a Verified [outgoing caller id](https://www.twilio.com/docs/voice/api/outgoing-caller-ids) for your account. If the `to` parameter is a phone number, `callerId` must also be a phone number. If `to` is sip address, this value of `callerId` should be a username portion to be used to populate the From header that is passed to the SIP endpoint.
|
|
249
|
+
# @param [String] call_reason The Reason for the outgoing call. Use it to specify the purpose of the call that is presented on the called party's phone. (Branded Calls Beta)
|
|
250
|
+
# @param [String] recording_track The audio track to record for the call. Can be: `inbound`, `outbound` or `both`. The default is `both`. `inbound` records the audio that is received by Twilio. `outbound` records the audio that is sent from Twilio. `both` records the audio that is received and sent by Twilio.
|
|
251
|
+
# @param [String] time_limit The maximum duration of the call in seconds. Constraints depend on account and configuration.
|
|
252
|
+
# @param [String] machine_detection Whether to detect if a human, answering machine, or fax has picked up the call. Can be: `Enable` or `DetectMessageEnd`. Use `Enable` if you would like us to return `AnsweredBy` as soon as the called party is identified. Use `DetectMessageEnd`, if you would like to leave a message on an answering machine. For more information, see [Answering Machine Detection](https://www.twilio.com/docs/voice/answering-machine-detection).
|
|
253
|
+
# @param [String] machine_detection_timeout The number of seconds that we should attempt to detect an answering machine before timing out and sending a voice request with `AnsweredBy` of `unknown`. The default timeout is 30 seconds.
|
|
254
|
+
# @param [String] machine_detection_speech_threshold The number of milliseconds that is used as the measuring stick for the length of the speech activity, where durations lower than this value will be interpreted as a human and longer than this value as a machine. Possible Values: 1000-6000. Default: 2400.
|
|
255
|
+
# @param [String] machine_detection_speech_end_threshold The number of milliseconds of silence after speech activity at which point the speech activity is considered complete. Possible Values: 500-5000. Default: 1200.
|
|
256
|
+
# @param [String] machine_detection_silence_timeout The number of milliseconds of initial silence after which an `unknown` AnsweredBy result will be returned. Possible Values: 2000-10000. Default: 5000.
|
|
257
|
+
# @param [String] amd_status_callback The URL that we should call using the `amd_status_callback_method` to notify customer application whether the call was answered by human, machine or fax.
|
|
258
|
+
# @param [String] amd_status_callback_method The HTTP method we should use when calling the `amd_status_callback` URL. Can be: `GET` or `POST` and the default is `POST`.
|
|
259
|
+
# @param [String] trim Whether to trim any leading and trailing silence from the participant recording. Can be: `trim-silence` or `do-not-trim` and the default is `trim-silence`.
|
|
260
|
+
# @param [String] call_token A token string needed to invoke a forwarded call. A call_token is generated when an incoming call is received on a Twilio number. Pass an incoming call's call_token value to a forwarded call via the call_token parameter when creating a new call. A forwarded call should bear the same CallerID of the original incoming call.
|
|
261
|
+
# @param [String] client_notification_url The URL that we should use to deliver `push call notification`.
|
|
262
|
+
# @param [String] caller_display_name The name that populates the display name in the From header. Must be between 2 and 255 characters. Only applicable for calls to sip address.
|
|
263
|
+
# @return [ParticipantInstance] Created ParticipantInstance
|
|
264
|
+
def create_with_metadata(
|
|
265
|
+
from: nil,
|
|
266
|
+
to: nil,
|
|
267
|
+
status_callback: :unset,
|
|
268
|
+
status_callback_method: :unset,
|
|
269
|
+
status_callback_event: :unset,
|
|
270
|
+
label: :unset,
|
|
271
|
+
timeout: :unset,
|
|
272
|
+
record: :unset,
|
|
273
|
+
muted: :unset,
|
|
274
|
+
beep: :unset,
|
|
275
|
+
start_conference_on_enter: :unset,
|
|
276
|
+
end_conference_on_exit: :unset,
|
|
277
|
+
wait_url: :unset,
|
|
278
|
+
wait_method: :unset,
|
|
279
|
+
early_media: :unset,
|
|
280
|
+
max_participants: :unset,
|
|
281
|
+
conference_record: :unset,
|
|
282
|
+
conference_trim: :unset,
|
|
283
|
+
conference_status_callback: :unset,
|
|
284
|
+
conference_status_callback_method: :unset,
|
|
285
|
+
conference_status_callback_event: :unset,
|
|
286
|
+
recording_channels: :unset,
|
|
287
|
+
recording_status_callback: :unset,
|
|
288
|
+
recording_status_callback_method: :unset,
|
|
289
|
+
sip_auth_username: :unset,
|
|
290
|
+
sip_auth_password: :unset,
|
|
291
|
+
region: :unset,
|
|
292
|
+
conference_recording_status_callback: :unset,
|
|
293
|
+
conference_recording_status_callback_method: :unset,
|
|
294
|
+
recording_status_callback_event: :unset,
|
|
295
|
+
conference_recording_status_callback_event: :unset,
|
|
296
|
+
coaching: :unset,
|
|
297
|
+
call_sid_to_coach: :unset,
|
|
298
|
+
jitter_buffer_size: :unset,
|
|
299
|
+
byoc: :unset,
|
|
300
|
+
caller_id: :unset,
|
|
301
|
+
call_reason: :unset,
|
|
302
|
+
recording_track: :unset,
|
|
303
|
+
time_limit: :unset,
|
|
304
|
+
machine_detection: :unset,
|
|
305
|
+
machine_detection_timeout: :unset,
|
|
306
|
+
machine_detection_speech_threshold: :unset,
|
|
307
|
+
machine_detection_speech_end_threshold: :unset,
|
|
308
|
+
machine_detection_silence_timeout: :unset,
|
|
309
|
+
amd_status_callback: :unset,
|
|
310
|
+
amd_status_callback_method: :unset,
|
|
311
|
+
trim: :unset,
|
|
312
|
+
call_token: :unset,
|
|
313
|
+
client_notification_url: :unset,
|
|
314
|
+
caller_display_name: :unset
|
|
315
|
+
)
|
|
316
|
+
|
|
317
|
+
data = Twilio::Values.of({
|
|
318
|
+
'From' => from,
|
|
319
|
+
'To' => to,
|
|
320
|
+
'StatusCallback' => status_callback,
|
|
321
|
+
'StatusCallbackMethod' => status_callback_method,
|
|
322
|
+
'StatusCallbackEvent' => Twilio.serialize_list(status_callback_event) { |e| e },
|
|
323
|
+
'Label' => label,
|
|
324
|
+
'Timeout' => timeout,
|
|
325
|
+
'Record' => record,
|
|
326
|
+
'Muted' => muted,
|
|
327
|
+
'Beep' => beep,
|
|
328
|
+
'StartConferenceOnEnter' => start_conference_on_enter,
|
|
329
|
+
'EndConferenceOnExit' => end_conference_on_exit,
|
|
330
|
+
'WaitUrl' => wait_url,
|
|
331
|
+
'WaitMethod' => wait_method,
|
|
332
|
+
'EarlyMedia' => early_media,
|
|
333
|
+
'MaxParticipants' => max_participants,
|
|
334
|
+
'ConferenceRecord' => conference_record,
|
|
335
|
+
'ConferenceTrim' => conference_trim,
|
|
336
|
+
'ConferenceStatusCallback' => conference_status_callback,
|
|
337
|
+
'ConferenceStatusCallbackMethod' => conference_status_callback_method,
|
|
338
|
+
'ConferenceStatusCallbackEvent' => Twilio.serialize_list(conference_status_callback_event) { |e| e },
|
|
339
|
+
'RecordingChannels' => recording_channels,
|
|
340
|
+
'RecordingStatusCallback' => recording_status_callback,
|
|
341
|
+
'RecordingStatusCallbackMethod' => recording_status_callback_method,
|
|
342
|
+
'SipAuthUsername' => sip_auth_username,
|
|
343
|
+
'SipAuthPassword' => sip_auth_password,
|
|
344
|
+
'Region' => region,
|
|
345
|
+
'ConferenceRecordingStatusCallback' => conference_recording_status_callback,
|
|
346
|
+
'ConferenceRecordingStatusCallbackMethod' => conference_recording_status_callback_method,
|
|
347
|
+
'RecordingStatusCallbackEvent' => Twilio.serialize_list(recording_status_callback_event) { |e| e },
|
|
348
|
+
'ConferenceRecordingStatusCallbackEvent' => Twilio.serialize_list(conference_recording_status_callback_event) { |e| e },
|
|
349
|
+
'Coaching' => coaching,
|
|
350
|
+
'CallSidToCoach' => call_sid_to_coach,
|
|
351
|
+
'JitterBufferSize' => jitter_buffer_size,
|
|
352
|
+
'Byoc' => byoc,
|
|
353
|
+
'CallerId' => caller_id,
|
|
354
|
+
'CallReason' => call_reason,
|
|
355
|
+
'RecordingTrack' => recording_track,
|
|
356
|
+
'TimeLimit' => time_limit,
|
|
357
|
+
'MachineDetection' => machine_detection,
|
|
358
|
+
'MachineDetectionTimeout' => machine_detection_timeout,
|
|
359
|
+
'MachineDetectionSpeechThreshold' => machine_detection_speech_threshold,
|
|
360
|
+
'MachineDetectionSpeechEndThreshold' => machine_detection_speech_end_threshold,
|
|
361
|
+
'MachineDetectionSilenceTimeout' => machine_detection_silence_timeout,
|
|
362
|
+
'AmdStatusCallback' => amd_status_callback,
|
|
363
|
+
'AmdStatusCallbackMethod' => amd_status_callback_method,
|
|
364
|
+
'Trim' => trim,
|
|
365
|
+
'CallToken' => call_token,
|
|
366
|
+
'ClientNotificationUrl' => client_notification_url,
|
|
367
|
+
'CallerDisplayName' => caller_display_name,
|
|
368
|
+
})
|
|
369
|
+
|
|
370
|
+
headers = Twilio::Values.of({'Content-Type' => 'application/x-www-form-urlencoded', })
|
|
371
|
+
|
|
372
|
+
|
|
373
|
+
|
|
374
|
+
|
|
375
|
+
|
|
376
|
+
response = @version.create_with_metadata('POST', @uri, data: data, headers: headers)
|
|
377
|
+
participant_instance = ParticipantInstance.new(
|
|
378
|
+
@version,
|
|
379
|
+
response.body,
|
|
380
|
+
account_sid: @solution[:account_sid],
|
|
381
|
+
conference_sid: @solution[:conference_sid],
|
|
382
|
+
)
|
|
383
|
+
ParticipantInstanceMetadata.new(
|
|
384
|
+
@version,
|
|
385
|
+
participant_instance,
|
|
386
|
+
response.headers,
|
|
387
|
+
response.status_code
|
|
388
|
+
)
|
|
389
|
+
end
|
|
390
|
+
|
|
200
391
|
|
|
201
392
|
##
|
|
202
393
|
# Lists ParticipantInstance records from the API as a list.
|
|
@@ -248,6 +439,34 @@ module Twilio
|
|
|
248
439
|
@version.stream(page, limit: limits[:limit], page_limit: limits[:page_limit])
|
|
249
440
|
end
|
|
250
441
|
|
|
442
|
+
##
|
|
443
|
+
# Lists ParticipantPageMetadata records from the API as a list.
|
|
444
|
+
# @param [Boolean] muted Whether to return only participants that are muted. Can be: `true` or `false`.
|
|
445
|
+
# @param [Boolean] hold Whether to return only participants that are on hold. Can be: `true` or `false`.
|
|
446
|
+
# @param [Boolean] coaching Whether to return only participants who are coaching another call. Can be: `true` or `false`.
|
|
447
|
+
# @param [Integer] limit Upper limit for the number of records to return. stream()
|
|
448
|
+
# guarantees to never return more than limit. Default is no limit
|
|
449
|
+
# @param [Integer] page_size Number of records to fetch per request, when
|
|
450
|
+
# not set will use the default value of 50 records. If no page_size is defined
|
|
451
|
+
# but a limit is defined, stream() will attempt to read the limit with the most
|
|
452
|
+
# efficient page size, i.e. min(limit, 1000)
|
|
453
|
+
# @return [Array] Array of up to limit results
|
|
454
|
+
def list_with_metadata(muted: :unset, hold: :unset, coaching: :unset, limit: nil, page_size: nil)
|
|
455
|
+
limits = @version.read_limits(limit, page_size)
|
|
456
|
+
params = Twilio::Values.of({
|
|
457
|
+
'Muted' => muted,
|
|
458
|
+
'Hold' => hold,
|
|
459
|
+
'Coaching' => coaching,
|
|
460
|
+
|
|
461
|
+
'PageSize' => limits[:page_size],
|
|
462
|
+
});
|
|
463
|
+
headers = Twilio::Values.of({})
|
|
464
|
+
|
|
465
|
+
response = @version.page('GET', @uri, params: params, headers: headers)
|
|
466
|
+
|
|
467
|
+
ParticipantPageMetadata.new(@version, response, @solution, limits[:limit])
|
|
468
|
+
end
|
|
469
|
+
|
|
251
470
|
##
|
|
252
471
|
# When passed a block, yields ParticipantInstance records from the API.
|
|
253
472
|
# This operation lazily loads records as efficiently as possible until the limit
|
|
@@ -272,7 +491,7 @@ module Twilio
|
|
|
272
491
|
# @param [Integer] page_number Page Number, this value is simply for client state
|
|
273
492
|
# @param [Integer] page_size Number of records to return, defaults to 50
|
|
274
493
|
# @return [Page] Page of ParticipantInstance
|
|
275
|
-
def page(muted: :unset, hold: :unset, coaching: :unset, page_token: :unset, page_number: :unset,
|
|
494
|
+
def page(muted: :unset, hold: :unset, coaching: :unset, page_token: :unset, page_number: :unset,page_size: :unset)
|
|
276
495
|
params = Twilio::Values.of({
|
|
277
496
|
'Muted' => muted,
|
|
278
497
|
'Hold' => hold,
|
|
@@ -281,8 +500,11 @@ module Twilio
|
|
|
281
500
|
'Page' => page_number,
|
|
282
501
|
'PageSize' => page_size,
|
|
283
502
|
})
|
|
503
|
+
headers = Twilio::Values.of({})
|
|
504
|
+
|
|
505
|
+
|
|
284
506
|
|
|
285
|
-
response = @version.page('GET', @uri, params: params)
|
|
507
|
+
response = @version.page('GET', @uri, params: params, headers: headers)
|
|
286
508
|
|
|
287
509
|
ParticipantPage.new(@version, response, @solution)
|
|
288
510
|
end
|
|
@@ -319,6 +541,7 @@ module Twilio
|
|
|
319
541
|
# @return [ParticipantContext] ParticipantContext
|
|
320
542
|
def initialize(version, account_sid, conference_sid, call_sid)
|
|
321
543
|
super(version)
|
|
544
|
+
|
|
322
545
|
|
|
323
546
|
# Path Solution
|
|
324
547
|
@solution = { account_sid: account_sid, conference_sid: conference_sid, call_sid: call_sid, }
|
|
@@ -333,9 +556,31 @@ module Twilio
|
|
|
333
556
|
|
|
334
557
|
headers = Twilio::Values.of({'Content-Type' => 'application/x-www-form-urlencoded', })
|
|
335
558
|
|
|
559
|
+
|
|
560
|
+
|
|
561
|
+
|
|
336
562
|
@version.delete('DELETE', @uri, headers: headers)
|
|
337
563
|
end
|
|
338
564
|
|
|
565
|
+
##
|
|
566
|
+
# Delete the ParticipantInstanceMetadata
|
|
567
|
+
# @return [Boolean] True if delete succeeds, false otherwise
|
|
568
|
+
def delete_with_metadata
|
|
569
|
+
|
|
570
|
+
headers = Twilio::Values.of({'Content-Type' => 'application/x-www-form-urlencoded', })
|
|
571
|
+
|
|
572
|
+
|
|
573
|
+
|
|
574
|
+
response = @version.delete_with_metadata('DELETE', @uri, headers: headers)
|
|
575
|
+
participant_instance = ParticipantInstance.new(
|
|
576
|
+
@version,
|
|
577
|
+
response.body,
|
|
578
|
+
account_sid: @solution[:account_sid],
|
|
579
|
+
sid: @solution[:sid],
|
|
580
|
+
)
|
|
581
|
+
ParticipantInstanceMetadata.new(@version, participant_instance, response.headers, response.status_code)
|
|
582
|
+
end
|
|
583
|
+
|
|
339
584
|
##
|
|
340
585
|
# Fetch the ParticipantInstance
|
|
341
586
|
# @return [ParticipantInstance] Fetched ParticipantInstance
|
|
@@ -343,6 +588,10 @@ module Twilio
|
|
|
343
588
|
|
|
344
589
|
headers = Twilio::Values.of({'Content-Type' => 'application/x-www-form-urlencoded', })
|
|
345
590
|
|
|
591
|
+
|
|
592
|
+
|
|
593
|
+
|
|
594
|
+
|
|
346
595
|
payload = @version.fetch('GET', @uri, headers: headers)
|
|
347
596
|
ParticipantInstance.new(
|
|
348
597
|
@version,
|
|
@@ -353,6 +602,33 @@ module Twilio
|
|
|
353
602
|
)
|
|
354
603
|
end
|
|
355
604
|
|
|
605
|
+
##
|
|
606
|
+
# Fetch the ParticipantInstanceMetadata
|
|
607
|
+
# @return [ParticipantInstance] Fetched ParticipantInstance
|
|
608
|
+
def fetch_with_metadata
|
|
609
|
+
|
|
610
|
+
headers = Twilio::Values.of({'Content-Type' => 'application/x-www-form-urlencoded', })
|
|
611
|
+
|
|
612
|
+
|
|
613
|
+
|
|
614
|
+
|
|
615
|
+
|
|
616
|
+
response = @version.fetch_with_metadata('GET', @uri, headers: headers)
|
|
617
|
+
participant_instance = ParticipantInstance.new(
|
|
618
|
+
@version,
|
|
619
|
+
response.body,
|
|
620
|
+
account_sid: @solution[:account_sid],
|
|
621
|
+
conference_sid: @solution[:conference_sid],
|
|
622
|
+
call_sid: @solution[:call_sid],
|
|
623
|
+
)
|
|
624
|
+
ParticipantInstanceMetadata.new(
|
|
625
|
+
@version,
|
|
626
|
+
participant_instance,
|
|
627
|
+
response.headers,
|
|
628
|
+
response.status_code
|
|
629
|
+
)
|
|
630
|
+
end
|
|
631
|
+
|
|
356
632
|
##
|
|
357
633
|
# Update the ParticipantInstance
|
|
358
634
|
# @param [Boolean] muted Whether the participant should be muted. Can be `true` or `false`. `true` will mute the participant, and `false` will un-mute them. Anything value other than `true` or `false` is interpreted as `false`.
|
|
@@ -361,7 +637,7 @@ module Twilio
|
|
|
361
637
|
# @param [String] hold_method The HTTP method we should use to call `hold_url`. Can be: `GET` or `POST` and the default is `GET`.
|
|
362
638
|
# @param [String] announce_url The URL we call using the `announce_method` for an announcement to the participant. The URL may return an MP3 file, a WAV file, or a TwiML document that contains `<Play>`, `<Say>`, `<Pause>`, or `<Redirect>` verbs.
|
|
363
639
|
# @param [String] announce_method The HTTP method we should use to call `announce_url`. Can be: `GET` or `POST` and defaults to `POST`.
|
|
364
|
-
# @param [String] wait_url The URL
|
|
640
|
+
# @param [String] wait_url The URL that Twilio calls using the `wait_method` before the conference has started. The URL may return an MP3 file, a WAV file, or a TwiML document. The default value is the URL of our standard hold music. If you do not want anything to play while waiting for the conference to start, specify an empty string by setting `wait_url` to `''`. For more details on the allowable verbs within the `waitUrl`, see the `waitUrl` attribute in the [<Conference> TwiML instruction](https://www.twilio.com/docs/voice/twiml/conference#attributes-waiturl).
|
|
365
641
|
# @param [String] wait_method The HTTP method we should use to call `wait_url`. Can be `GET` or `POST` and the default is `POST`. When using a static audio file, this should be `GET` so that we can cache the file.
|
|
366
642
|
# @param [Boolean] beep_on_exit Whether to play a notification beep to the conference when the participant exits. Can be: `true` or `false`.
|
|
367
643
|
# @param [Boolean] end_conference_on_exit Whether to end the conference when the participant leaves. Can be: `true` or `false` and defaults to `false`.
|
|
@@ -400,6 +676,10 @@ module Twilio
|
|
|
400
676
|
|
|
401
677
|
headers = Twilio::Values.of({'Content-Type' => 'application/x-www-form-urlencoded', })
|
|
402
678
|
|
|
679
|
+
|
|
680
|
+
|
|
681
|
+
|
|
682
|
+
|
|
403
683
|
payload = @version.update('POST', @uri, data: data, headers: headers)
|
|
404
684
|
ParticipantInstance.new(
|
|
405
685
|
@version,
|
|
@@ -410,6 +690,73 @@ module Twilio
|
|
|
410
690
|
)
|
|
411
691
|
end
|
|
412
692
|
|
|
693
|
+
##
|
|
694
|
+
# Update the ParticipantInstanceMetadata
|
|
695
|
+
# @param [Boolean] muted Whether the participant should be muted. Can be `true` or `false`. `true` will mute the participant, and `false` will un-mute them. Anything value other than `true` or `false` is interpreted as `false`.
|
|
696
|
+
# @param [Boolean] hold Whether the participant should be on hold. Can be: `true` or `false`. `true` puts the participant on hold, and `false` lets them rejoin the conference.
|
|
697
|
+
# @param [String] hold_url The URL we call using the `hold_method` for music that plays when the participant is on hold. The URL may return an MP3 file, a WAV file, or a TwiML document that contains `<Play>`, `<Say>`, `<Pause>`, or `<Redirect>` verbs.
|
|
698
|
+
# @param [String] hold_method The HTTP method we should use to call `hold_url`. Can be: `GET` or `POST` and the default is `GET`.
|
|
699
|
+
# @param [String] announce_url The URL we call using the `announce_method` for an announcement to the participant. The URL may return an MP3 file, a WAV file, or a TwiML document that contains `<Play>`, `<Say>`, `<Pause>`, or `<Redirect>` verbs.
|
|
700
|
+
# @param [String] announce_method The HTTP method we should use to call `announce_url`. Can be: `GET` or `POST` and defaults to `POST`.
|
|
701
|
+
# @param [String] wait_url The URL that Twilio calls using the `wait_method` before the conference has started. The URL may return an MP3 file, a WAV file, or a TwiML document. The default value is the URL of our standard hold music. If you do not want anything to play while waiting for the conference to start, specify an empty string by setting `wait_url` to `''`. For more details on the allowable verbs within the `waitUrl`, see the `waitUrl` attribute in the [<Conference> TwiML instruction](https://www.twilio.com/docs/voice/twiml/conference#attributes-waiturl).
|
|
702
|
+
# @param [String] wait_method The HTTP method we should use to call `wait_url`. Can be `GET` or `POST` and the default is `POST`. When using a static audio file, this should be `GET` so that we can cache the file.
|
|
703
|
+
# @param [Boolean] beep_on_exit Whether to play a notification beep to the conference when the participant exits. Can be: `true` or `false`.
|
|
704
|
+
# @param [Boolean] end_conference_on_exit Whether to end the conference when the participant leaves. Can be: `true` or `false` and defaults to `false`.
|
|
705
|
+
# @param [Boolean] coaching Whether the participant is coaching another call. Can be: `true` or `false`. If not present, defaults to `false` unless `call_sid_to_coach` is defined. If `true`, `call_sid_to_coach` must be defined.
|
|
706
|
+
# @param [String] call_sid_to_coach The SID of the participant who is being `coached`. The participant being coached is the only participant who can hear the participant who is `coaching`.
|
|
707
|
+
# @return [ParticipantInstance] Updated ParticipantInstance
|
|
708
|
+
def update_with_metadata(
|
|
709
|
+
muted: :unset,
|
|
710
|
+
hold: :unset,
|
|
711
|
+
hold_url: :unset,
|
|
712
|
+
hold_method: :unset,
|
|
713
|
+
announce_url: :unset,
|
|
714
|
+
announce_method: :unset,
|
|
715
|
+
wait_url: :unset,
|
|
716
|
+
wait_method: :unset,
|
|
717
|
+
beep_on_exit: :unset,
|
|
718
|
+
end_conference_on_exit: :unset,
|
|
719
|
+
coaching: :unset,
|
|
720
|
+
call_sid_to_coach: :unset
|
|
721
|
+
)
|
|
722
|
+
|
|
723
|
+
data = Twilio::Values.of({
|
|
724
|
+
'Muted' => muted,
|
|
725
|
+
'Hold' => hold,
|
|
726
|
+
'HoldUrl' => hold_url,
|
|
727
|
+
'HoldMethod' => hold_method,
|
|
728
|
+
'AnnounceUrl' => announce_url,
|
|
729
|
+
'AnnounceMethod' => announce_method,
|
|
730
|
+
'WaitUrl' => wait_url,
|
|
731
|
+
'WaitMethod' => wait_method,
|
|
732
|
+
'BeepOnExit' => beep_on_exit,
|
|
733
|
+
'EndConferenceOnExit' => end_conference_on_exit,
|
|
734
|
+
'Coaching' => coaching,
|
|
735
|
+
'CallSidToCoach' => call_sid_to_coach,
|
|
736
|
+
})
|
|
737
|
+
|
|
738
|
+
headers = Twilio::Values.of({'Content-Type' => 'application/x-www-form-urlencoded', })
|
|
739
|
+
|
|
740
|
+
|
|
741
|
+
|
|
742
|
+
|
|
743
|
+
|
|
744
|
+
response = @version.update_with_metadata('POST', @uri, data: data, headers: headers)
|
|
745
|
+
participant_instance = ParticipantInstance.new(
|
|
746
|
+
@version,
|
|
747
|
+
response.body,
|
|
748
|
+
account_sid: @solution[:account_sid],
|
|
749
|
+
conference_sid: @solution[:conference_sid],
|
|
750
|
+
call_sid: @solution[:call_sid],
|
|
751
|
+
)
|
|
752
|
+
ParticipantInstanceMetadata.new(
|
|
753
|
+
@version,
|
|
754
|
+
participant_instance,
|
|
755
|
+
response.headers,
|
|
756
|
+
response.status_code
|
|
757
|
+
)
|
|
758
|
+
end
|
|
759
|
+
|
|
413
760
|
|
|
414
761
|
##
|
|
415
762
|
# Provide a user friendly representation
|
|
@@ -426,6 +773,53 @@ module Twilio
|
|
|
426
773
|
end
|
|
427
774
|
end
|
|
428
775
|
|
|
776
|
+
class ParticipantInstanceMetadata < InstanceResourceMetadata
|
|
777
|
+
##
|
|
778
|
+
# Initializes a new ParticipantInstanceMetadata.
|
|
779
|
+
# @param [Version] version Version that contains the resource
|
|
780
|
+
# @param [}ParticipantInstance] participant_instance The instance associated with the metadata.
|
|
781
|
+
# @param [Hash] headers Header object with response headers.
|
|
782
|
+
# @param [Integer] status_code The HTTP status code of the response.
|
|
783
|
+
# @return [ParticipantInstanceMetadata] The initialized instance with metadata.
|
|
784
|
+
def initialize(version, participant_instance, headers, status_code)
|
|
785
|
+
super(version, headers, status_code)
|
|
786
|
+
@participant_instance = participant_instance
|
|
787
|
+
end
|
|
788
|
+
|
|
789
|
+
def participant
|
|
790
|
+
@participant_instance
|
|
791
|
+
end
|
|
792
|
+
|
|
793
|
+
def headers
|
|
794
|
+
@headers
|
|
795
|
+
end
|
|
796
|
+
|
|
797
|
+
def status_code
|
|
798
|
+
@status_code
|
|
799
|
+
end
|
|
800
|
+
|
|
801
|
+
def to_s
|
|
802
|
+
"<Twilio.Api.V2010.ParticipantInstanceMetadata status=#{@status_code}>"
|
|
803
|
+
end
|
|
804
|
+
end
|
|
805
|
+
|
|
806
|
+
class ParticipantListResponse < InstanceListResource
|
|
807
|
+
# @param [Array<ParticipantInstance>] instance
|
|
808
|
+
# @param [Hash{String => Object}] headers
|
|
809
|
+
# @param [Integer] status_code
|
|
810
|
+
def initialize(version, payload, key)
|
|
811
|
+
@participant_instance = payload.body[key].map do |data|
|
|
812
|
+
ParticipantInstance.new(version, data)
|
|
813
|
+
end
|
|
814
|
+
@headers = payload.headers
|
|
815
|
+
@status_code = payload.status_code
|
|
816
|
+
end
|
|
817
|
+
|
|
818
|
+
def participant_instance
|
|
819
|
+
@instance
|
|
820
|
+
end
|
|
821
|
+
end
|
|
822
|
+
|
|
429
823
|
class ParticipantPage < Page
|
|
430
824
|
##
|
|
431
825
|
# Initialize the ParticipantPage
|
|
@@ -435,6 +829,7 @@ module Twilio
|
|
|
435
829
|
# @return [ParticipantPage] ParticipantPage
|
|
436
830
|
def initialize(version, response, solution)
|
|
437
831
|
super(version, response)
|
|
832
|
+
|
|
438
833
|
|
|
439
834
|
# Path Solution
|
|
440
835
|
@solution = solution
|
|
@@ -454,6 +849,66 @@ module Twilio
|
|
|
454
849
|
'<Twilio.Api.V2010.ParticipantPage>'
|
|
455
850
|
end
|
|
456
851
|
end
|
|
852
|
+
|
|
853
|
+
class ParticipantPageMetadata < PageMetadata
|
|
854
|
+
attr_reader :participant_page
|
|
855
|
+
|
|
856
|
+
def initialize(version, response, solution, limit)
|
|
857
|
+
super(version, response)
|
|
858
|
+
@participant_page = []
|
|
859
|
+
@limit = limit
|
|
860
|
+
key = get_key(response.body)
|
|
861
|
+
records = 0
|
|
862
|
+
while( limit != :unset && records < limit )
|
|
863
|
+
@participant_page << ParticipantListResponse.new(version, @payload, key, limit - records)
|
|
864
|
+
@payload = self.next_page
|
|
865
|
+
break unless @payload
|
|
866
|
+
records += @payload.body[key].size
|
|
867
|
+
end
|
|
868
|
+
# Path Solution
|
|
869
|
+
@solution = solution
|
|
870
|
+
end
|
|
871
|
+
|
|
872
|
+
def each
|
|
873
|
+
@participant_page.each do |record|
|
|
874
|
+
yield record
|
|
875
|
+
end
|
|
876
|
+
end
|
|
877
|
+
|
|
878
|
+
def to_s
|
|
879
|
+
'<Twilio::REST::Api::V2010PageMetadata>';
|
|
880
|
+
end
|
|
881
|
+
end
|
|
882
|
+
class ParticipantListResponse < InstanceListResource
|
|
883
|
+
|
|
884
|
+
# @param [Array<ParticipantInstance>] instance
|
|
885
|
+
# @param [Hash{String => Object}] headers
|
|
886
|
+
# @param [Integer] status_code
|
|
887
|
+
def initialize(version, payload, key, limit = :unset)
|
|
888
|
+
data_list = payload.body[key]
|
|
889
|
+
if limit != :unset
|
|
890
|
+
data_list = data_list[0, limit]
|
|
891
|
+
end
|
|
892
|
+
@participant = data_list.map do |data|
|
|
893
|
+
ParticipantInstance.new(version, data)
|
|
894
|
+
end
|
|
895
|
+
@headers = payload.headers
|
|
896
|
+
@status_code = payload.status_code
|
|
897
|
+
end
|
|
898
|
+
|
|
899
|
+
def participant
|
|
900
|
+
@participant
|
|
901
|
+
end
|
|
902
|
+
|
|
903
|
+
def headers
|
|
904
|
+
@headers
|
|
905
|
+
end
|
|
906
|
+
|
|
907
|
+
def status_code
|
|
908
|
+
@status_code
|
|
909
|
+
end
|
|
910
|
+
end
|
|
911
|
+
|
|
457
912
|
class ParticipantInstance < InstanceResource
|
|
458
913
|
##
|
|
459
914
|
# Initialize the ParticipantInstance
|
|
@@ -467,6 +922,7 @@ module Twilio
|
|
|
467
922
|
def initialize(version, payload , account_sid: nil, conference_sid: nil, call_sid: nil)
|
|
468
923
|
super(version)
|
|
469
924
|
|
|
925
|
+
|
|
470
926
|
# Marshaled Properties
|
|
471
927
|
@properties = {
|
|
472
928
|
'account_sid' => payload['account_sid'],
|
|
@@ -616,7 +1072,7 @@ module Twilio
|
|
|
616
1072
|
# @param [String] hold_method The HTTP method we should use to call `hold_url`. Can be: `GET` or `POST` and the default is `GET`.
|
|
617
1073
|
# @param [String] announce_url The URL we call using the `announce_method` for an announcement to the participant. The URL may return an MP3 file, a WAV file, or a TwiML document that contains `<Play>`, `<Say>`, `<Pause>`, or `<Redirect>` verbs.
|
|
618
1074
|
# @param [String] announce_method The HTTP method we should use to call `announce_url`. Can be: `GET` or `POST` and defaults to `POST`.
|
|
619
|
-
# @param [String] wait_url The URL
|
|
1075
|
+
# @param [String] wait_url The URL that Twilio calls using the `wait_method` before the conference has started. The URL may return an MP3 file, a WAV file, or a TwiML document. The default value is the URL of our standard hold music. If you do not want anything to play while waiting for the conference to start, specify an empty string by setting `wait_url` to `''`. For more details on the allowable verbs within the `waitUrl`, see the `waitUrl` attribute in the [<Conference> TwiML instruction](https://www.twilio.com/docs/voice/twiml/conference#attributes-waiturl).
|
|
620
1076
|
# @param [String] wait_method The HTTP method we should use to call `wait_url`. Can be `GET` or `POST` and the default is `POST`. When using a static audio file, this should be `GET` so that we can cache the file.
|
|
621
1077
|
# @param [Boolean] beep_on_exit Whether to play a notification beep to the conference when the participant exits. Can be: `true` or `false`.
|
|
622
1078
|
# @param [Boolean] end_conference_on_exit Whether to end the conference when the participant leaves. Can be: `true` or `false` and defaults to `false`.
|