twilio-ruby 5.61.2 → 6.9.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.
Files changed (677) hide show
  1. checksums.yaml +4 -4
  2. data/.github/workflows/pr-lint.yml +21 -0
  3. data/.github/workflows/test-and-deploy.yml +139 -0
  4. data/.gitignore +3 -0
  5. data/.rubocop.yml +1 -1
  6. data/.rubocop_todo.yml +84 -21
  7. data/CHANGES.md +893 -1
  8. data/CONTRIBUTING.md +11 -9
  9. data/LICENSE +1 -1
  10. data/Makefile +13 -8
  11. data/PULL_REQUEST_TEMPLATE.md +1 -1
  12. data/README.md +136 -44
  13. data/UPGRADE.md +10 -0
  14. data/advanced-examples/custom-http-client.md +170 -0
  15. data/cluster_spec.rb +77 -0
  16. data/lib/rack/twilio_webhook_authentication.rb +25 -1
  17. data/lib/twilio-ruby/base/client_base.rb +121 -0
  18. data/lib/twilio-ruby/framework/rest/error.rb +0 -12
  19. data/lib/twilio-ruby/http/http_client.rb +11 -6
  20. data/lib/twilio-ruby/jwt/access_token.rb +0 -59
  21. data/lib/twilio-ruby/rest/accounts/v1/auth_token_promotion.rb +198 -178
  22. data/lib/twilio-ruby/rest/accounts/v1/credential/aws.rb +371 -332
  23. data/lib/twilio-ruby/rest/accounts/v1/credential/public_key.rb +371 -332
  24. data/lib/twilio-ruby/rest/accounts/v1/credential.rb +121 -114
  25. data/lib/twilio-ruby/rest/accounts/v1/safelist.rb +169 -0
  26. data/lib/twilio-ruby/rest/accounts/v1/secondary_auth_token.rb +214 -192
  27. data/lib/twilio-ruby/rest/accounts/v1.rb +51 -42
  28. data/lib/twilio-ruby/rest/accounts.rb +4 -34
  29. data/lib/twilio-ruby/rest/accounts_base.rb +38 -0
  30. data/lib/twilio-ruby/rest/api/v2010/account/address/dependent_phone_number.rb +370 -365
  31. data/lib/twilio-ruby/rest/api/v2010/account/address.rb +551 -514
  32. data/lib/twilio-ruby/rest/api/v2010/account/application.rb +615 -586
  33. data/lib/twilio-ruby/rest/api/v2010/account/authorized_connect_app.rb +313 -320
  34. data/lib/twilio-ruby/rest/api/v2010/account/available_phone_number_country/local.rb +394 -0
  35. data/lib/twilio-ruby/rest/api/v2010/account/available_phone_number_country/machine_to_machine.rb +394 -0
  36. data/lib/twilio-ruby/rest/api/v2010/account/available_phone_number_country/mobile.rb +394 -0
  37. data/lib/twilio-ruby/rest/api/v2010/account/available_phone_number_country/national.rb +394 -0
  38. data/lib/twilio-ruby/rest/api/v2010/account/available_phone_number_country/shared_cost.rb +394 -0
  39. data/lib/twilio-ruby/rest/api/v2010/account/available_phone_number_country/toll_free.rb +394 -0
  40. data/lib/twilio-ruby/rest/api/v2010/account/available_phone_number_country/voip.rb +394 -0
  41. data/lib/twilio-ruby/rest/api/v2010/account/available_phone_number_country.rb +432 -0
  42. data/lib/twilio-ruby/rest/api/v2010/account/balance.rb +136 -118
  43. data/lib/twilio-ruby/rest/api/v2010/account/call/event.rb +202 -194
  44. data/lib/twilio-ruby/rest/api/v2010/account/call/feedback.rb +252 -289
  45. data/lib/twilio-ruby/rest/api/v2010/account/call/feedback_summary.rb +317 -303
  46. data/lib/twilio-ruby/rest/api/v2010/account/call/notification.rb +400 -417
  47. data/lib/twilio-ruby/rest/api/v2010/account/call/payment.rb +291 -342
  48. data/lib/twilio-ruby/rest/api/v2010/account/call/recording.rb +494 -511
  49. data/lib/twilio-ruby/rest/api/v2010/account/call/siprec.rb +839 -634
  50. data/lib/twilio-ruby/rest/api/v2010/account/call/stream.rb +872 -0
  51. data/lib/twilio-ruby/rest/api/v2010/account/call/user_defined_message.rb +163 -0
  52. data/lib/twilio-ruby/rest/api/v2010/account/call/user_defined_message_subscription.rb +239 -0
  53. data/lib/twilio-ruby/rest/api/v2010/account/call.rb +952 -972
  54. data/lib/twilio-ruby/rest/api/v2010/account/conference/participant.rb +652 -717
  55. data/lib/twilio-ruby/rest/api/v2010/account/conference/recording.rb +451 -458
  56. data/lib/twilio-ruby/rest/api/v2010/account/conference.rb +489 -493
  57. data/lib/twilio-ruby/rest/api/v2010/account/connect_app.rb +426 -407
  58. data/lib/twilio-ruby/rest/api/v2010/account/incoming_phone_number/assigned_add_on/assigned_add_on_extension.rb +321 -351
  59. data/lib/twilio-ruby/rest/api/v2010/account/incoming_phone_number/assigned_add_on.rb +398 -418
  60. data/lib/twilio-ruby/rest/api/v2010/account/incoming_phone_number/local.rb +536 -554
  61. data/lib/twilio-ruby/rest/api/v2010/account/incoming_phone_number/mobile.rb +536 -553
  62. data/lib/twilio-ruby/rest/api/v2010/account/incoming_phone_number/toll_free.rb +536 -553
  63. data/lib/twilio-ruby/rest/api/v2010/account/incoming_phone_number.rb +841 -903
  64. data/lib/twilio-ruby/rest/api/v2010/account/key.rb +335 -302
  65. data/lib/twilio-ruby/rest/api/v2010/account/message/feedback.rb +167 -166
  66. data/lib/twilio-ruby/rest/api/v2010/account/message/media.rb +340 -350
  67. data/lib/twilio-ruby/rest/api/v2010/account/message.rb +615 -612
  68. data/lib/twilio-ruby/rest/api/v2010/account/new_key.rb +157 -138
  69. data/lib/twilio-ruby/rest/api/v2010/account/new_signing_key.rb +157 -138
  70. data/lib/twilio-ruby/rest/api/v2010/account/notification.rb +400 -399
  71. data/lib/twilio-ruby/rest/api/v2010/account/outgoing_caller_id.rb +368 -358
  72. data/lib/twilio-ruby/rest/api/v2010/account/queue/member.rb +340 -338
  73. data/lib/twilio-ruby/rest/api/v2010/account/queue.rb +426 -390
  74. data/lib/twilio-ruby/rest/api/v2010/account/recording/add_on_result/payload.rb +358 -380
  75. data/lib/twilio-ruby/rest/api/v2010/account/recording/add_on_result.rb +368 -385
  76. data/lib/twilio-ruby/rest/api/v2010/account/recording/transcription.rb +364 -372
  77. data/lib/twilio-ruby/rest/api/v2010/account/recording.rb +507 -486
  78. data/lib/twilio-ruby/rest/api/v2010/account/short_code.rb +417 -408
  79. data/lib/twilio-ruby/rest/api/v2010/account/signing_key.rb +335 -306
  80. data/lib/twilio-ruby/rest/api/v2010/account/sip/credential_list/credential.rb +375 -368
  81. data/lib/twilio-ruby/rest/api/v2010/account/sip/credential_list.rb +399 -373
  82. data/lib/twilio-ruby/rest/api/v2010/account/sip/domain/auth_types/auth_type_calls/auth_calls_credential_list_mapping.rb +346 -0
  83. data/lib/twilio-ruby/rest/api/v2010/account/sip/domain/auth_types/{auth_calls_mapping → auth_type_calls}/auth_calls_ip_access_control_list_mapping.rb +193 -195
  84. data/lib/twilio-ruby/rest/api/v2010/account/sip/domain/auth_types/auth_type_calls.rb +140 -0
  85. data/lib/twilio-ruby/rest/api/v2010/account/sip/domain/auth_types/{auth_registrations_mapping → auth_type_registrations}/auth_registrations_credential_list_mapping.rb +193 -195
  86. data/lib/twilio-ruby/rest/api/v2010/account/sip/domain/auth_types/auth_type_registrations.rb +126 -0
  87. data/lib/twilio-ruby/rest/api/v2010/account/sip/domain/auth_types.rb +94 -103
  88. data/lib/twilio-ruby/rest/api/v2010/account/sip/domain/credential_list_mapping.rb +339 -339
  89. data/lib/twilio-ruby/rest/api/v2010/account/sip/domain/ip_access_control_list_mapping.rb +339 -338
  90. data/lib/twilio-ruby/rest/api/v2010/account/sip/domain.rb +649 -645
  91. data/lib/twilio-ruby/rest/api/v2010/account/sip/ip_access_control_list/ip_address.rb +412 -421
  92. data/lib/twilio-ruby/rest/api/v2010/account/sip/ip_access_control_list.rb +399 -374
  93. data/lib/twilio-ruby/rest/api/v2010/account/sip.rb +141 -150
  94. data/lib/twilio-ruby/rest/api/v2010/account/token.rb +171 -154
  95. data/lib/twilio-ruby/rest/api/v2010/account/transcription.rb +364 -350
  96. data/lib/twilio-ruby/rest/api/v2010/account/usage/record/all_time.rb +314 -339
  97. data/lib/twilio-ruby/rest/api/v2010/account/usage/record/daily.rb +314 -339
  98. data/lib/twilio-ruby/rest/api/v2010/account/usage/record/last_month.rb +314 -339
  99. data/lib/twilio-ruby/rest/api/v2010/account/usage/record/monthly.rb +314 -339
  100. data/lib/twilio-ruby/rest/api/v2010/account/usage/record/this_month.rb +314 -339
  101. data/lib/twilio-ruby/rest/api/v2010/account/usage/record/today.rb +314 -339
  102. data/lib/twilio-ruby/rest/api/v2010/account/usage/record/yearly.rb +314 -339
  103. data/lib/twilio-ruby/rest/api/v2010/account/usage/record/yesterday.rb +314 -339
  104. data/lib/twilio-ruby/rest/api/v2010/account/usage/record.rb +381 -416
  105. data/lib/twilio-ruby/rest/api/v2010/account/usage/trigger.rb +485 -484
  106. data/lib/twilio-ruby/rest/api/v2010/account/usage.rb +112 -104
  107. data/lib/twilio-ruby/rest/api/v2010/account/validation_request.rb +172 -161
  108. data/lib/twilio-ruby/rest/api/v2010/account.rb +979 -943
  109. data/lib/twilio-ruby/rest/api/v2010.rb +126 -148
  110. data/lib/twilio-ruby/rest/api.rb +25 -34
  111. data/lib/twilio-ruby/rest/api_base.rb +38 -0
  112. data/lib/twilio-ruby/rest/bulkexports/v1/export/day.rb +299 -279
  113. data/lib/twilio-ruby/rest/bulkexports/v1/export/export_custom_job.rb +298 -279
  114. data/lib/twilio-ruby/rest/bulkexports/v1/export/job.rb +271 -248
  115. data/lib/twilio-ruby/rest/bulkexports/v1/export.rb +246 -235
  116. data/lib/twilio-ruby/rest/bulkexports/v1/export_configuration.rb +245 -218
  117. data/lib/twilio-ruby/rest/bulkexports/v1.rb +57 -55
  118. data/lib/twilio-ruby/rest/bulkexports.rb +3 -34
  119. data/lib/twilio-ruby/rest/bulkexports_base.rb +38 -0
  120. data/lib/twilio-ruby/rest/chat/v1/credential.rb +419 -403
  121. data/lib/twilio-ruby/rest/chat/v1/service/channel/invite.rb +374 -391
  122. data/lib/twilio-ruby/rest/chat/v1/service/channel/member.rb +422 -440
  123. data/lib/twilio-ruby/rest/chat/v1/service/channel/message.rb +438 -437
  124. data/lib/twilio-ruby/rest/chat/v1/service/channel.rb +534 -515
  125. data/lib/twilio-ruby/rest/chat/v1/service/role.rb +396 -367
  126. data/lib/twilio-ruby/rest/chat/v1/service/user/user_channel.rb +244 -239
  127. data/lib/twilio-ruby/rest/chat/v1/service/user.rb +465 -440
  128. data/lib/twilio-ruby/rest/chat/v1/service.rb +861 -894
  129. data/lib/twilio-ruby/rest/chat/v1.rb +57 -55
  130. data/lib/twilio-ruby/rest/chat/v2/credential.rb +419 -401
  131. data/lib/twilio-ruby/rest/chat/v2/service/binding.rb +371 -370
  132. data/lib/twilio-ruby/rest/chat/v2/service/channel/invite.rb +374 -386
  133. data/lib/twilio-ruby/rest/chat/v2/service/channel/member.rb +486 -527
  134. data/lib/twilio-ruby/rest/chat/v2/service/channel/message.rb +513 -533
  135. data/lib/twilio-ruby/rest/chat/v2/service/channel/webhook.rb +440 -467
  136. data/lib/twilio-ruby/rest/chat/v2/service/channel.rb +606 -605
  137. data/lib/twilio-ruby/rest/chat/v2/service/role.rb +396 -369
  138. data/lib/twilio-ruby/rest/chat/v2/service/user/user_binding.rb +364 -381
  139. data/lib/twilio-ruby/rest/chat/v2/service/user/user_channel.rb +406 -413
  140. data/lib/twilio-ruby/rest/chat/v2/service/user.rb +509 -491
  141. data/lib/twilio-ruby/rest/chat/v2/service.rb +764 -778
  142. data/lib/twilio-ruby/rest/chat/v2.rb +57 -53
  143. data/lib/twilio-ruby/rest/chat/v3/channel.rb +297 -0
  144. data/lib/twilio-ruby/rest/chat/v3.rb +71 -0
  145. data/lib/twilio-ruby/rest/chat.rb +10 -38
  146. data/lib/twilio-ruby/rest/chat_base.rb +48 -0
  147. data/lib/twilio-ruby/rest/client.rb +318 -561
  148. data/lib/twilio-ruby/rest/content/v1/content/approval_fetch.rb +208 -0
  149. data/lib/twilio-ruby/rest/content/v1/content.rb +363 -0
  150. data/lib/twilio-ruby/rest/content/v1/content_and_approvals.rb +251 -0
  151. data/lib/twilio-ruby/rest/content/v1/legacy_content.rb +265 -0
  152. data/lib/twilio-ruby/rest/content/v1.rb +61 -0
  153. data/lib/twilio-ruby/rest/content.rb +15 -0
  154. data/lib/twilio-ruby/rest/content_base.rb +38 -0
  155. data/lib/twilio-ruby/rest/conversations/v1/address_configuration.rb +482 -0
  156. data/lib/twilio-ruby/rest/conversations/v1/configuration/webhook.rb +254 -227
  157. data/lib/twilio-ruby/rest/conversations/v1/configuration.rb +279 -252
  158. data/lib/twilio-ruby/rest/conversations/v1/conversation/message/delivery_receipt.rb +334 -344
  159. data/lib/twilio-ruby/rest/conversations/v1/conversation/message.rb +537 -495
  160. data/lib/twilio-ruby/rest/conversations/v1/conversation/participant.rb +498 -495
  161. data/lib/twilio-ruby/rest/conversations/v1/conversation/webhook.rb +425 -403
  162. data/lib/twilio-ruby/rest/conversations/v1/conversation.rb +620 -552
  163. data/lib/twilio-ruby/rest/conversations/v1/credential.rb +425 -409
  164. data/lib/twilio-ruby/rest/conversations/v1/participant_conversation.rb +304 -304
  165. data/lib/twilio-ruby/rest/conversations/v1/role.rb +384 -356
  166. data/lib/twilio-ruby/rest/conversations/v1/service/binding.rb +364 -373
  167. data/lib/twilio-ruby/rest/conversations/v1/service/configuration/notification.rb +300 -289
  168. data/lib/twilio-ruby/rest/conversations/v1/service/configuration/webhook.rb +246 -235
  169. data/lib/twilio-ruby/rest/conversations/v1/service/configuration.rb +307 -279
  170. data/lib/twilio-ruby/rest/conversations/v1/service/conversation/message/delivery_receipt.rb +341 -371
  171. data/lib/twilio-ruby/rest/conversations/v1/service/conversation/message.rb +544 -535
  172. data/lib/twilio-ruby/rest/conversations/v1/service/conversation/participant.rb +507 -530
  173. data/lib/twilio-ruby/rest/conversations/v1/service/conversation/webhook.rb +434 -438
  174. data/lib/twilio-ruby/rest/conversations/v1/service/conversation.rb +632 -588
  175. data/lib/twilio-ruby/rest/conversations/v1/service/participant_conversation.rb +310 -317
  176. data/lib/twilio-ruby/rest/conversations/v1/service/role.rb +396 -380
  177. data/lib/twilio-ruby/rest/conversations/v1/service/user/user_conversation.rb +446 -455
  178. data/lib/twilio-ruby/rest/conversations/v1/service/user.rb +484 -474
  179. data/lib/twilio-ruby/rest/conversations/v1/service.rb +476 -447
  180. data/lib/twilio-ruby/rest/conversations/v1/user/user_conversation.rb +445 -435
  181. data/lib/twilio-ruby/rest/conversations/v1/user.rb +472 -441
  182. data/lib/twilio-ruby/rest/conversations/v1.rb +129 -119
  183. data/lib/twilio-ruby/rest/conversations.rb +18 -34
  184. data/lib/twilio-ruby/rest/conversations_base.rb +38 -0
  185. data/lib/twilio-ruby/rest/events/v1/event_type.rb +302 -288
  186. data/lib/twilio-ruby/rest/events/v1/schema/schema_version.rb +299 -0
  187. data/lib/twilio-ruby/rest/events/v1/schema.rb +227 -218
  188. data/lib/twilio-ruby/rest/events/v1/sink/sink_test.rb +114 -100
  189. data/lib/twilio-ruby/rest/events/v1/sink/sink_validate.rb +120 -103
  190. data/lib/twilio-ruby/rest/events/v1/sink.rb +434 -408
  191. data/lib/twilio-ruby/rest/events/v1/subscription/subscribed_event.rb +365 -339
  192. data/lib/twilio-ruby/rest/events/v1/subscription.rb +416 -387
  193. data/lib/twilio-ruby/rest/events/v1.rb +87 -87
  194. data/lib/twilio-ruby/rest/events.rb +5 -34
  195. data/lib/twilio-ruby/rest/events_base.rb +38 -0
  196. data/lib/twilio-ruby/rest/flex_api/v1/assessments.rb +448 -0
  197. data/lib/twilio-ruby/rest/flex_api/v1/channel.rb +365 -330
  198. data/lib/twilio-ruby/rest/flex_api/v1/configuration.rb +510 -475
  199. data/lib/twilio-ruby/rest/flex_api/v1/flex_flow.rb +563 -555
  200. data/lib/twilio-ruby/rest/flex_api/v1/insights_assessments_comment.rb +327 -0
  201. data/lib/twilio-ruby/rest/flex_api/v1/insights_conversations.rb +228 -0
  202. data/lib/twilio-ruby/rest/flex_api/v1/insights_questionnaires.rb +442 -0
  203. data/lib/twilio-ruby/rest/flex_api/v1/insights_questionnaires_category.rb +358 -0
  204. data/lib/twilio-ruby/rest/flex_api/v1/insights_questionnaires_question.rb +443 -0
  205. data/lib/twilio-ruby/rest/flex_api/v1/insights_segments.rb +361 -0
  206. data/lib/twilio-ruby/rest/flex_api/v1/insights_session.rb +217 -0
  207. data/lib/twilio-ruby/rest/flex_api/v1/insights_settings_answer_sets.rb +155 -0
  208. data/lib/twilio-ruby/rest/flex_api/v1/insights_settings_comment.rb +141 -0
  209. data/lib/twilio-ruby/rest/flex_api/v1/insights_user_roles.rb +196 -0
  210. data/lib/twilio-ruby/rest/flex_api/v1/interaction/interaction_channel/interaction_channel_invite.rb +251 -0
  211. data/lib/twilio-ruby/rest/flex_api/v1/interaction/interaction_channel/interaction_channel_participant.rb +339 -0
  212. data/lib/twilio-ruby/rest/flex_api/v1/interaction/interaction_channel.rb +406 -0
  213. data/lib/twilio-ruby/rest/flex_api/v1/interaction.rb +267 -0
  214. data/lib/twilio-ruby/rest/flex_api/v1/provisioning_status.rb +187 -0
  215. data/lib/twilio-ruby/rest/flex_api/v1/web_channel.rb +378 -331
  216. data/lib/twilio-ruby/rest/flex_api/v1.rb +201 -76
  217. data/lib/twilio-ruby/rest/flex_api/v2/web_channels.rb +146 -0
  218. data/lib/twilio-ruby/rest/flex_api/v2.rb +40 -0
  219. data/lib/twilio-ruby/rest/flex_api.rb +33 -31
  220. data/lib/twilio-ruby/rest/flex_api_base.rb +43 -0
  221. data/lib/twilio-ruby/rest/frontline_api/v1/user.rb +244 -227
  222. data/lib/twilio-ruby/rest/frontline_api/v1.rb +42 -38
  223. data/lib/twilio-ruby/rest/frontline_api.rb +2 -34
  224. data/lib/twilio-ruby/rest/frontline_api_base.rb +38 -0
  225. data/lib/twilio-ruby/rest/insights/v1/call/annotation.rb +319 -0
  226. data/lib/twilio-ruby/rest/insights/v1/call/call_summary.rb +350 -0
  227. data/lib/twilio-ruby/rest/insights/v1/call/event.rb +269 -255
  228. data/lib/twilio-ruby/rest/insights/v1/call/metric.rb +241 -225
  229. data/lib/twilio-ruby/rest/insights/v1/call.rb +260 -228
  230. data/lib/twilio-ruby/rest/insights/v1/call_summaries.rb +485 -426
  231. data/lib/twilio-ruby/rest/insights/v1/conference/conference_participant.rb +488 -0
  232. data/lib/twilio-ruby/rest/insights/v1/conference.rb +505 -0
  233. data/lib/twilio-ruby/rest/insights/v1/room/participant.rb +378 -371
  234. data/lib/twilio-ruby/rest/insights/v1/room.rb +490 -489
  235. data/lib/twilio-ruby/rest/insights/v1/setting.rb +254 -0
  236. data/lib/twilio-ruby/rest/insights/v1.rb +84 -60
  237. data/lib/twilio-ruby/rest/insights.rb +17 -31
  238. data/lib/twilio-ruby/rest/insights_base.rb +38 -0
  239. data/lib/twilio-ruby/rest/intelligence/v2/service.rb +510 -0
  240. data/lib/twilio-ruby/rest/intelligence/v2/transcript/media.rb +226 -0
  241. data/lib/twilio-ruby/rest/intelligence/v2/transcript/operator_result.rb +388 -0
  242. data/lib/twilio-ruby/rest/intelligence/v2/transcript/sentence.rb +248 -0
  243. data/lib/twilio-ruby/rest/intelligence/v2/transcript.rb +520 -0
  244. data/lib/twilio-ruby/rest/intelligence/v2.rb +64 -0
  245. data/lib/twilio-ruby/rest/intelligence.rb +6 -0
  246. data/lib/twilio-ruby/rest/intelligence_base.rb +38 -0
  247. data/lib/twilio-ruby/rest/ip_messaging/v1/credential.rb +419 -364
  248. data/lib/twilio-ruby/rest/ip_messaging/v1/service/channel/invite.rb +374 -359
  249. data/lib/twilio-ruby/rest/ip_messaging/v1/service/channel/member.rb +422 -397
  250. data/lib/twilio-ruby/rest/ip_messaging/v1/service/channel/message.rb +438 -409
  251. data/lib/twilio-ruby/rest/ip_messaging/v1/service/channel.rb +534 -488
  252. data/lib/twilio-ruby/rest/ip_messaging/v1/service/role.rb +396 -347
  253. data/lib/twilio-ruby/rest/ip_messaging/v1/service/user/user_channel.rb +244 -233
  254. data/lib/twilio-ruby/rest/ip_messaging/v1/service/user.rb +465 -418
  255. data/lib/twilio-ruby/rest/ip_messaging/v1/service.rb +861 -779
  256. data/lib/twilio-ruby/rest/ip_messaging/v1.rb +57 -53
  257. data/lib/twilio-ruby/rest/ip_messaging/v2/credential.rb +419 -364
  258. data/lib/twilio-ruby/rest/ip_messaging/v2/service/binding.rb +371 -343
  259. data/lib/twilio-ruby/rest/ip_messaging/v2/service/channel/invite.rb +374 -359
  260. data/lib/twilio-ruby/rest/ip_messaging/v2/service/channel/member.rb +486 -451
  261. data/lib/twilio-ruby/rest/ip_messaging/v2/service/channel/message.rb +513 -479
  262. data/lib/twilio-ruby/rest/ip_messaging/v2/service/channel/webhook.rb +440 -411
  263. data/lib/twilio-ruby/rest/ip_messaging/v2/service/channel.rb +606 -555
  264. data/lib/twilio-ruby/rest/ip_messaging/v2/service/role.rb +396 -347
  265. data/lib/twilio-ruby/rest/ip_messaging/v2/service/user/user_binding.rb +364 -351
  266. data/lib/twilio-ruby/rest/ip_messaging/v2/service/user/user_channel.rb +397 -384
  267. data/lib/twilio-ruby/rest/ip_messaging/v2/service/user.rb +509 -467
  268. data/lib/twilio-ruby/rest/ip_messaging/v2/service.rb +764 -689
  269. data/lib/twilio-ruby/rest/ip_messaging/v2.rb +57 -53
  270. data/lib/twilio-ruby/rest/ip_messaging.rb +3 -41
  271. data/lib/twilio-ruby/rest/ip_messaging_base.rb +43 -0
  272. data/lib/twilio-ruby/rest/lookups/v1/phone_number.rb +243 -239
  273. data/lib/twilio-ruby/rest/lookups/v1.rb +42 -39
  274. data/lib/twilio-ruby/rest/lookups/v2/phone_number.rb +370 -0
  275. data/lib/twilio-ruby/rest/lookups/v2.rb +49 -0
  276. data/lib/twilio-ruby/rest/lookups.rb +2 -34
  277. data/lib/twilio-ruby/rest/lookups_base.rb +43 -0
  278. data/lib/twilio-ruby/rest/media/v1/media_processor.rb +410 -374
  279. data/lib/twilio-ruby/rest/media/v1/media_recording.rb +404 -0
  280. data/lib/twilio-ruby/rest/media/v1/player_streamer/playback_grant.rb +245 -214
  281. data/lib/twilio-ruby/rest/media/v1/player_streamer.rb +422 -380
  282. data/lib/twilio-ruby/rest/media/v1.rb +72 -53
  283. data/lib/twilio-ruby/rest/media.rb +13 -34
  284. data/lib/twilio-ruby/rest/media_base.rb +38 -0
  285. data/lib/twilio-ruby/rest/messaging/v1/brand_registration/brand_registration_otp.rb +136 -0
  286. data/lib/twilio-ruby/rest/messaging/v1/brand_registration/brand_vetting.rb +358 -346
  287. data/lib/twilio-ruby/rest/messaging/v1/brand_registration.rb +487 -420
  288. data/lib/twilio-ruby/rest/messaging/v1/deactivations.rb +189 -0
  289. data/lib/twilio-ruby/rest/messaging/v1/domain_certs.rb +280 -0
  290. data/lib/twilio-ruby/rest/messaging/v1/domain_config.rb +289 -0
  291. data/lib/twilio-ruby/rest/messaging/v1/domain_config_messaging_service.rb +238 -0
  292. data/lib/twilio-ruby/rest/messaging/v1/external_campaign.rb +155 -144
  293. data/lib/twilio-ruby/rest/messaging/v1/linkshortening_messaging_service.rb +214 -0
  294. data/lib/twilio-ruby/rest/messaging/v1/linkshortening_messaging_service_domain_association.rb +196 -0
  295. data/lib/twilio-ruby/rest/messaging/v1/service/alpha_sender.rb +351 -335
  296. data/lib/twilio-ruby/rest/messaging/v1/service/channel_sender.rb +329 -0
  297. data/lib/twilio-ruby/rest/messaging/v1/service/phone_number.rb +358 -341
  298. data/lib/twilio-ruby/rest/messaging/v1/service/short_code.rb +358 -336
  299. data/lib/twilio-ruby/rest/messaging/v1/service/us_app_to_person.rb +506 -426
  300. data/lib/twilio-ruby/rest/messaging/v1/service/us_app_to_person_usecase.rb +121 -115
  301. data/lib/twilio-ruby/rest/messaging/v1/service.rb +767 -763
  302. data/lib/twilio-ruby/rest/messaging/v1/tollfree_verification.rb +777 -0
  303. data/lib/twilio-ruby/rest/messaging/v1/usecase.rb +106 -94
  304. data/lib/twilio-ruby/rest/messaging/v1.rb +187 -74
  305. data/lib/twilio-ruby/rest/messaging.rb +36 -35
  306. data/lib/twilio-ruby/rest/messaging_base.rb +38 -0
  307. data/lib/twilio-ruby/rest/microvisor/v1/account_config.rb +358 -0
  308. data/lib/twilio-ruby/rest/microvisor/v1/account_secret.rb +351 -0
  309. data/lib/twilio-ruby/rest/microvisor/v1/app/app_manifest.rb +208 -0
  310. data/lib/twilio-ruby/rest/microvisor/v1/app.rb +349 -0
  311. data/lib/twilio-ruby/rest/microvisor/v1/device/device_config.rb +374 -0
  312. data/lib/twilio-ruby/rest/microvisor/v1/device/device_secret.rb +367 -0
  313. data/lib/twilio-ruby/rest/microvisor/v1/device.rb +427 -0
  314. data/lib/twilio-ruby/rest/microvisor/v1.rb +94 -0
  315. data/lib/twilio-ruby/rest/microvisor.rb +24 -0
  316. data/lib/twilio-ruby/rest/microvisor_base.rb +38 -0
  317. data/lib/twilio-ruby/rest/monitor/v1/alert.rb +398 -395
  318. data/lib/twilio-ruby/rest/monitor/v1/event.rb +381 -390
  319. data/lib/twilio-ruby/rest/monitor/v1.rb +57 -53
  320. data/lib/twilio-ruby/rest/monitor.rb +3 -34
  321. data/lib/twilio-ruby/rest/monitor_base.rb +38 -0
  322. data/lib/twilio-ruby/rest/notify/v1/credential.rb +421 -408
  323. data/lib/twilio-ruby/rest/notify/v1/service/binding.rb +437 -452
  324. data/lib/twilio-ruby/rest/notify/v1/service/notification.rb +313 -362
  325. data/lib/twilio-ruby/rest/notify/v1/service.rb +626 -622
  326. data/lib/twilio-ruby/rest/notify/v1.rb +57 -55
  327. data/lib/twilio-ruby/rest/notify.rb +3 -34
  328. data/lib/twilio-ruby/rest/notify_base.rb +38 -0
  329. data/lib/twilio-ruby/rest/numbers/v1/bulk_eligibility.rb +224 -0
  330. data/lib/twilio-ruby/rest/numbers/v1/porting_bulk_portability.rb +229 -0
  331. data/lib/twilio-ruby/rest/numbers/v1/porting_port_in_fetch.rb +245 -0
  332. data/lib/twilio-ruby/rest/numbers/v1/porting_portability.rb +263 -0
  333. data/lib/twilio-ruby/rest/numbers/v1.rb +94 -0
  334. data/lib/twilio-ruby/rest/numbers/v2/authorization_document/dependent_hosted_number_order.rb +343 -0
  335. data/lib/twilio-ruby/rest/numbers/v2/authorization_document.rb +403 -0
  336. data/lib/twilio-ruby/rest/numbers/v2/bulk_hosted_number_order.rb +249 -0
  337. data/lib/twilio-ruby/rest/numbers/v2/hosted_number_order.rb +502 -0
  338. data/lib/twilio-ruby/rest/numbers/v2/regulatory_compliance/bundle/bundle_copy.rb +276 -179
  339. data/lib/twilio-ruby/rest/numbers/v2/regulatory_compliance/bundle/evaluation.rb +324 -298
  340. data/lib/twilio-ruby/rest/numbers/v2/regulatory_compliance/bundle/item_assignment.rb +333 -309
  341. data/lib/twilio-ruby/rest/numbers/v2/regulatory_compliance/bundle/replace_items.rb +194 -181
  342. data/lib/twilio-ruby/rest/numbers/v2/regulatory_compliance/bundle.rb +601 -550
  343. data/lib/twilio-ruby/rest/numbers/v2/regulatory_compliance/end_user.rb +391 -351
  344. data/lib/twilio-ruby/rest/numbers/v2/regulatory_compliance/end_user_type.rb +290 -266
  345. data/lib/twilio-ruby/rest/numbers/v2/regulatory_compliance/regulation.rb +322 -307
  346. data/lib/twilio-ruby/rest/numbers/v2/regulatory_compliance/supporting_document.rb +412 -364
  347. data/lib/twilio-ruby/rest/numbers/v2/regulatory_compliance/supporting_document_type.rb +290 -266
  348. data/lib/twilio-ruby/rest/numbers/v2/regulatory_compliance.rb +177 -181
  349. data/lib/twilio-ruby/rest/numbers/v2.rb +78 -28
  350. data/lib/twilio-ruby/rest/numbers.rb +2 -34
  351. data/lib/twilio-ruby/rest/numbers_base.rb +43 -0
  352. data/lib/twilio-ruby/rest/preview/deployed_devices/fleet/certificate.rb +410 -375
  353. data/lib/twilio-ruby/rest/preview/deployed_devices/fleet/deployment.rb +394 -358
  354. data/lib/twilio-ruby/rest/preview/deployed_devices/fleet/device.rb +449 -418
  355. data/lib/twilio-ruby/rest/preview/deployed_devices/fleet/key.rb +407 -369
  356. data/lib/twilio-ruby/rest/preview/deployed_devices/fleet.rb +494 -459
  357. data/lib/twilio-ruby/rest/preview/deployed_devices.rb +42 -38
  358. data/lib/twilio-ruby/rest/preview/hosted_numbers/authorization_document/dependent_hosted_number_order.rb +370 -396
  359. data/lib/twilio-ruby/rest/preview/hosted_numbers/authorization_document.rb +446 -446
  360. data/lib/twilio-ruby/rest/preview/hosted_numbers/hosted_number_order.rb +610 -625
  361. data/lib/twilio-ruby/rest/preview/hosted_numbers.rb +57 -55
  362. data/lib/twilio-ruby/rest/preview/marketplace/available_add_on/available_add_on_extension.rb +301 -298
  363. data/lib/twilio-ruby/rest/preview/marketplace/available_add_on.rb +325 -309
  364. data/lib/twilio-ruby/rest/preview/marketplace/installed_add_on/installed_add_on_extension.rb +342 -330
  365. data/lib/twilio-ruby/rest/preview/marketplace/installed_add_on.rb +429 -398
  366. data/lib/twilio-ruby/rest/preview/marketplace.rb +57 -53
  367. data/lib/twilio-ruby/rest/preview/sync/service/document/document_permission.rb +378 -374
  368. data/lib/twilio-ruby/rest/preview/sync/service/document.rb +442 -399
  369. data/lib/twilio-ruby/rest/preview/sync/service/sync_list/sync_list_item.rb +434 -407
  370. data/lib/twilio-ruby/rest/preview/sync/service/sync_list/sync_list_permission.rb +378 -374
  371. data/lib/twilio-ruby/rest/preview/sync/service/sync_list.rb +419 -398
  372. data/lib/twilio-ruby/rest/preview/sync/service/sync_map/sync_map_item.rb +437 -404
  373. data/lib/twilio-ruby/rest/preview/sync/service/sync_map/sync_map_permission.rb +378 -374
  374. data/lib/twilio-ruby/rest/preview/sync/service/sync_map.rb +419 -398
  375. data/lib/twilio-ruby/rest/preview/sync/service.rb +495 -452
  376. data/lib/twilio-ruby/rest/preview/sync.rb +42 -37
  377. data/lib/twilio-ruby/rest/preview/wireless/command.rb +387 -364
  378. data/lib/twilio-ruby/rest/preview/wireless/rate_plan.rb +448 -398
  379. data/lib/twilio-ruby/rest/preview/wireless/sim/usage.rb +232 -205
  380. data/lib/twilio-ruby/rest/preview/wireless/sim.rb +574 -523
  381. data/lib/twilio-ruby/rest/preview/wireless.rb +72 -69
  382. data/lib/twilio-ruby/rest/preview.rb +11 -137
  383. data/lib/twilio-ruby/rest/preview_base.rb +58 -0
  384. data/lib/twilio-ruby/rest/pricing/v1/messaging/country.rb +297 -275
  385. data/lib/twilio-ruby/rest/pricing/v1/messaging.rb +107 -119
  386. data/lib/twilio-ruby/rest/pricing/v1/phone_number/country.rb +290 -268
  387. data/lib/twilio-ruby/rest/pricing/v1/phone_number.rb +107 -119
  388. data/lib/twilio-ruby/rest/pricing/v1/voice/country.rb +297 -275
  389. data/lib/twilio-ruby/rest/pricing/v1/voice/number.rb +220 -197
  390. data/lib/twilio-ruby/rest/pricing/v1/voice.rb +121 -135
  391. data/lib/twilio-ruby/rest/pricing/v1.rb +45 -42
  392. data/lib/twilio-ruby/rest/pricing/v2/country.rb +289 -270
  393. data/lib/twilio-ruby/rest/pricing/v2/number.rb +232 -217
  394. data/lib/twilio-ruby/rest/pricing/v2/voice/country.rb +297 -275
  395. data/lib/twilio-ruby/rest/pricing/v2/voice/number.rb +238 -220
  396. data/lib/twilio-ruby/rest/pricing/v2/voice.rb +121 -138
  397. data/lib/twilio-ruby/rest/pricing/v2.rb +63 -65
  398. data/lib/twilio-ruby/rest/pricing.rb +6 -41
  399. data/lib/twilio-ruby/rest/pricing_base.rb +43 -0
  400. data/lib/twilio-ruby/rest/proxy/v1/service/phone_number.rb +419 -403
  401. data/lib/twilio-ruby/rest/proxy/v1/service/session/interaction.rb +408 -418
  402. data/lib/twilio-ruby/rest/proxy/v1/service/session/participant/message_interaction.rb +430 -449
  403. data/lib/twilio-ruby/rest/proxy/v1/service/session/participant.rb +421 -455
  404. data/lib/twilio-ruby/rest/proxy/v1/service/session.rb +522 -547
  405. data/lib/twilio-ruby/rest/proxy/v1/service/short_code.rb +399 -370
  406. data/lib/twilio-ruby/rest/proxy/v1/service.rb +559 -596
  407. data/lib/twilio-ruby/rest/proxy/v1.rb +42 -38
  408. data/lib/twilio-ruby/rest/proxy.rb +2 -34
  409. data/lib/twilio-ruby/rest/proxy_base.rb +38 -0
  410. data/lib/twilio-ruby/rest/routes/v2/phone_number.rb +268 -0
  411. data/lib/twilio-ruby/rest/routes/v2/sip_domain.rb +268 -0
  412. data/lib/twilio-ruby/rest/routes/v2/trunk.rb +268 -0
  413. data/lib/twilio-ruby/rest/routes/v2.rb +79 -0
  414. data/lib/twilio-ruby/rest/routes.rb +32 -0
  415. data/lib/twilio-ruby/rest/routes_base.rb +38 -0
  416. data/lib/twilio-ruby/rest/serverless/v1/service/asset/asset_version.rb +315 -323
  417. data/lib/twilio-ruby/rest/serverless/v1/service/asset.rb +412 -380
  418. data/lib/twilio-ruby/rest/serverless/v1/service/build/build_status.rb +208 -208
  419. data/lib/twilio-ruby/rest/serverless/v1/service/build.rb +407 -384
  420. data/lib/twilio-ruby/rest/serverless/v1/service/environment/deployment.rb +336 -338
  421. data/lib/twilio-ruby/rest/serverless/v1/service/environment/log.rb +361 -383
  422. data/lib/twilio-ruby/rest/serverless/v1/service/environment/variable.rb +403 -396
  423. data/lib/twilio-ruby/rest/serverless/v1/service/environment.rb +456 -447
  424. data/lib/twilio-ruby/rest/serverless/v1/service/function/function_version/function_version_content.rb +223 -234
  425. data/lib/twilio-ruby/rest/serverless/v1/service/function/function_version.rb +342 -353
  426. data/lib/twilio-ruby/rest/serverless/v1/service/function.rb +412 -380
  427. data/lib/twilio-ruby/rest/serverless/v1/service.rb +523 -493
  428. data/lib/twilio-ruby/rest/serverless/v1.rb +42 -37
  429. data/lib/twilio-ruby/rest/serverless.rb +2 -34
  430. data/lib/twilio-ruby/rest/serverless_base.rb +38 -0
  431. data/lib/twilio-ruby/rest/studio/v1/flow/engagement/engagement_context.rb +206 -199
  432. data/lib/twilio-ruby/rest/studio/v1/flow/engagement/step/step_context.rb +221 -218
  433. data/lib/twilio-ruby/rest/studio/v1/flow/engagement/step.rb +361 -355
  434. data/lib/twilio-ruby/rest/studio/v1/flow/engagement.rb +422 -394
  435. data/lib/twilio-ruby/rest/studio/v1/flow/execution/execution_context.rb +206 -200
  436. data/lib/twilio-ruby/rest/studio/v1/flow/execution/execution_step/execution_step_context.rb +221 -221
  437. data/lib/twilio-ruby/rest/studio/v1/flow/execution/execution_step.rb +361 -361
  438. data/lib/twilio-ruby/rest/studio/v1/flow/execution.rb +468 -449
  439. data/lib/twilio-ruby/rest/studio/v1/flow.rb +380 -355
  440. data/lib/twilio-ruby/rest/studio/v1.rb +42 -37
  441. data/lib/twilio-ruby/rest/studio/v2/flow/execution/execution_context.rb +206 -200
  442. data/lib/twilio-ruby/rest/studio/v2/flow/execution/execution_step/execution_step_context.rb +221 -221
  443. data/lib/twilio-ruby/rest/studio/v2/flow/execution/execution_step.rb +361 -361
  444. data/lib/twilio-ruby/rest/studio/v2/flow/execution.rb +461 -442
  445. data/lib/twilio-ruby/rest/studio/v2/flow/flow_revision.rb +341 -320
  446. data/lib/twilio-ruby/rest/studio/v2/flow/flow_test_user.rb +232 -0
  447. data/lib/twilio-ruby/rest/studio/v2/flow.rb +519 -472
  448. data/lib/twilio-ruby/rest/studio/v2/flow_validate.rb +121 -99
  449. data/lib/twilio-ruby/rest/studio/v2.rb +48 -44
  450. data/lib/twilio-ruby/rest/studio.rb +3 -41
  451. data/lib/twilio-ruby/rest/studio_base.rb +43 -0
  452. data/lib/twilio-ruby/rest/supersim/v1/esim_profile.rb +403 -0
  453. data/lib/twilio-ruby/rest/supersim/v1/fleet.rb +472 -484
  454. data/lib/twilio-ruby/rest/supersim/v1/ip_command.rb +398 -406
  455. data/lib/twilio-ruby/rest/supersim/v1/network.rb +302 -297
  456. data/lib/twilio-ruby/rest/supersim/v1/network_access_profile/network_access_profile_network.rb +337 -332
  457. data/lib/twilio-ruby/rest/supersim/v1/network_access_profile.rb +380 -351
  458. data/lib/twilio-ruby/rest/supersim/v1/settings_update.rb +256 -0
  459. data/lib/twilio-ruby/rest/supersim/v1/sim/billing_period.rb +242 -224
  460. data/lib/twilio-ruby/rest/supersim/v1/sim/sim_ip_address.rb +207 -0
  461. data/lib/twilio-ruby/rest/supersim/v1/sim.rb +460 -433
  462. data/lib/twilio-ruby/rest/supersim/v1/sms_command.rb +358 -361
  463. data/lib/twilio-ruby/rest/supersim/v1/usage_record.rb +286 -311
  464. data/lib/twilio-ruby/rest/supersim/v1.rb +144 -140
  465. data/lib/twilio-ruby/rest/supersim.rb +22 -40
  466. data/lib/twilio-ruby/rest/supersim_base.rb +38 -0
  467. data/lib/twilio-ruby/rest/sync/v1/service/document/document_permission.rb +376 -371
  468. data/lib/twilio-ruby/rest/sync/v1/service/document.rb +456 -423
  469. data/lib/twilio-ruby/rest/sync/v1/service/sync_list/sync_list_item.rb +466 -490
  470. data/lib/twilio-ruby/rest/sync/v1/service/sync_list/sync_list_permission.rb +376 -370
  471. data/lib/twilio-ruby/rest/sync/v1/service/sync_list.rb +470 -445
  472. data/lib/twilio-ruby/rest/sync/v1/service/sync_map/sync_map_item.rb +469 -495
  473. data/lib/twilio-ruby/rest/sync/v1/service/sync_map/sync_map_permission.rb +376 -368
  474. data/lib/twilio-ruby/rest/sync/v1/service/sync_map.rb +470 -444
  475. data/lib/twilio-ruby/rest/sync/v1/service/sync_stream/stream_message.rb +139 -132
  476. data/lib/twilio-ruby/rest/sync/v1/service/sync_stream.rb +419 -400
  477. data/lib/twilio-ruby/rest/sync/v1/service.rb +575 -567
  478. data/lib/twilio-ruby/rest/sync/v1.rb +42 -37
  479. data/lib/twilio-ruby/rest/sync.rb +2 -34
  480. data/lib/twilio-ruby/rest/sync_base.rb +38 -0
  481. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/activity.rb +405 -395
  482. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/event.rb +442 -464
  483. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/task/reservation.rb +705 -736
  484. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/task.rb +623 -661
  485. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/task_channel.rb +409 -382
  486. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/task_queue/task_queue_cumulative_statistics.rb +359 -365
  487. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/task_queue/task_queue_real_time_statistics.rb +279 -275
  488. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/task_queue/task_queue_statistics.rb +230 -236
  489. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/task_queue/task_queues_statistics.rb +239 -258
  490. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/task_queue.rb +574 -566
  491. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/worker/reservation.rb +687 -732
  492. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/worker/worker_channel.rb +389 -388
  493. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/worker/worker_statistics.rb +235 -239
  494. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/worker/workers_cumulative_statistics.rb +281 -265
  495. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/worker/workers_real_time_statistics.rb +215 -193
  496. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/worker/workers_statistics.rb +251 -234
  497. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/worker.rb +623 -631
  498. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/workflow/workflow_cumulative_statistics.rb +359 -373
  499. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/workflow/workflow_real_time_statistics.rb +245 -241
  500. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/workflow/workflow_statistics.rb +230 -244
  501. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/workflow.rb +523 -510
  502. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/workspace_cumulative_statistics.rb +353 -354
  503. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/workspace_real_time_statistics.rb +231 -206
  504. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/workspace_statistics.rb +241 -234
  505. data/lib/twilio-ruby/rest/taskrouter/v1/workspace.rb +720 -730
  506. data/lib/twilio-ruby/rest/taskrouter/v1.rb +42 -37
  507. data/lib/twilio-ruby/rest/taskrouter.rb +2 -34
  508. data/lib/twilio-ruby/rest/taskrouter_base.rb +38 -0
  509. data/lib/twilio-ruby/rest/trunking/v1/trunk/credential_list.rb +342 -320
  510. data/lib/twilio-ruby/rest/trunking/v1/trunk/ip_access_control_list.rb +342 -317
  511. data/lib/twilio-ruby/rest/trunking/v1/trunk/origination_url.rb +440 -419
  512. data/lib/twilio-ruby/rest/trunking/v1/trunk/phone_number.rb +475 -451
  513. data/lib/twilio-ruby/rest/trunking/v1/trunk/recording.rb +224 -191
  514. data/lib/twilio-ruby/rest/trunking/v1/trunk.rb +623 -630
  515. data/lib/twilio-ruby/rest/trunking/v1.rb +42 -38
  516. data/lib/twilio-ruby/rest/trunking.rb +2 -34
  517. data/lib/twilio-ruby/rest/trunking_base.rb +38 -0
  518. data/lib/twilio-ruby/rest/trusthub/v1/compliance_inquiries.rb +232 -0
  519. data/lib/twilio-ruby/rest/trusthub/v1/compliance_tollfree_inquiries.rb +211 -0
  520. data/lib/twilio-ruby/rest/trusthub/v1/customer_profiles/customer_profiles_channel_endpoint_assignment.rb +357 -352
  521. data/lib/twilio-ruby/rest/trusthub/v1/customer_profiles/customer_profiles_entity_assignments.rb +335 -323
  522. data/lib/twilio-ruby/rest/trusthub/v1/customer_profiles/customer_profiles_evaluations.rb +333 -321
  523. data/lib/twilio-ruby/rest/trusthub/v1/customer_profiles.rb +525 -513
  524. data/lib/twilio-ruby/rest/trusthub/v1/end_user.rb +383 -346
  525. data/lib/twilio-ruby/rest/trusthub/v1/end_user_type.rb +282 -261
  526. data/lib/twilio-ruby/rest/trusthub/v1/policies.rb +275 -252
  527. data/lib/twilio-ruby/rest/trusthub/v1/supporting_document.rb +397 -359
  528. data/lib/twilio-ruby/rest/trusthub/v1/supporting_document_type.rb +282 -261
  529. data/lib/twilio-ruby/rest/trusthub/v1/trust_products/trust_products_channel_endpoint_assignment.rb +357 -352
  530. data/lib/twilio-ruby/rest/trusthub/v1/trust_products/trust_products_entity_assignments.rb +335 -323
  531. data/lib/twilio-ruby/rest/trusthub/v1/trust_products/trust_products_evaluations.rb +333 -321
  532. data/lib/twilio-ruby/rest/trusthub/v1/trust_products.rb +525 -513
  533. data/lib/twilio-ruby/rest/trusthub/v1.rb +153 -139
  534. data/lib/twilio-ruby/rest/trusthub.rb +8 -34
  535. data/lib/twilio-ruby/rest/trusthub_base.rb +38 -0
  536. data/lib/twilio-ruby/rest/verify/v2/form.rb +195 -183
  537. data/lib/twilio-ruby/rest/verify/v2/safelist.rb +231 -0
  538. data/lib/twilio-ruby/rest/verify/v2/service/access_token.rb +265 -116
  539. data/lib/twilio-ruby/rest/verify/v2/service/entity/challenge/notification.rb +191 -198
  540. data/lib/twilio-ruby/rest/verify/v2/service/entity/challenge.rb +496 -521
  541. data/lib/twilio-ruby/rest/verify/v2/service/entity/factor.rb +447 -454
  542. data/lib/twilio-ruby/rest/verify/v2/service/entity/new_factor.rb +249 -279
  543. data/lib/twilio-ruby/rest/verify/v2/service/entity.rb +422 -422
  544. data/lib/twilio-ruby/rest/verify/v2/service/messaging_configuration.rb +379 -363
  545. data/lib/twilio-ruby/rest/verify/v2/service/rate_limit/bucket.rb +401 -388
  546. data/lib/twilio-ruby/rest/verify/v2/service/rate_limit.rb +420 -384
  547. data/lib/twilio-ruby/rest/verify/v2/service/verification.rb +380 -359
  548. data/lib/twilio-ruby/rest/verify/v2/service/verification_check.rb +218 -198
  549. data/lib/twilio-ruby/rest/verify/v2/service/webhook.rb +447 -420
  550. data/lib/twilio-ruby/rest/verify/v2/service.rb +782 -770
  551. data/lib/twilio-ruby/rest/verify/v2/template.rb +221 -198
  552. data/lib/twilio-ruby/rest/verify/v2/verification_attempt.rb +372 -319
  553. data/lib/twilio-ruby/rest/verify/v2/verification_attempts_summary.rb +247 -0
  554. data/lib/twilio-ruby/rest/verify/v2.rb +99 -78
  555. data/lib/twilio-ruby/rest/verify.rb +23 -36
  556. data/lib/twilio-ruby/rest/verify_base.rb +38 -0
  557. data/lib/twilio-ruby/rest/video/v1/composition.rb +477 -486
  558. data/lib/twilio-ruby/rest/video/v1/composition_hook.rb +525 -647
  559. data/lib/twilio-ruby/rest/video/v1/composition_settings.rb +281 -261
  560. data/lib/twilio-ruby/rest/video/v1/recording.rb +426 -405
  561. data/lib/twilio-ruby/rest/video/v1/recording_settings.rb +281 -261
  562. data/lib/twilio-ruby/rest/video/v1/room/participant/anonymize.rb +259 -0
  563. data/lib/twilio-ruby/rest/video/v1/room/participant/published_track.rb +331 -0
  564. data/lib/twilio-ruby/rest/video/v1/room/participant/subscribe_rules.rb +181 -0
  565. data/lib/twilio-ruby/rest/video/v1/room/participant/subscribed_track.rb +338 -0
  566. data/lib/twilio-ruby/rest/video/v1/room/participant.rb +498 -0
  567. data/lib/twilio-ruby/rest/video/v1/room/recording_rules.rb +170 -0
  568. data/lib/twilio-ruby/rest/video/v1/room/room_recording.rb +423 -0
  569. data/lib/twilio-ruby/rest/video/v1/room.rb +606 -567
  570. data/lib/twilio-ruby/rest/video/v1.rb +99 -99
  571. data/lib/twilio-ruby/rest/video.rb +7 -34
  572. data/lib/twilio-ruby/rest/video_base.rb +38 -0
  573. data/lib/twilio-ruby/rest/voice/v1/archived_call.rb +168 -0
  574. data/lib/twilio-ruby/rest/voice/v1/byoc_trunk.rb +501 -486
  575. data/lib/twilio-ruby/rest/voice/v1/connection_policy/connection_policy_target.rb +440 -434
  576. data/lib/twilio-ruby/rest/voice/v1/connection_policy.rb +391 -352
  577. data/lib/twilio-ruby/rest/voice/v1/dialing_permissions/bulk_country_update.rb +135 -121
  578. data/lib/twilio-ruby/rest/voice/v1/dialing_permissions/country/highrisk_special_prefix.rb +195 -183
  579. data/lib/twilio-ruby/rest/voice/v1/dialing_permissions/country.rb +375 -397
  580. data/lib/twilio-ruby/rest/voice/v1/dialing_permissions/settings.rb +217 -190
  581. data/lib/twilio-ruby/rest/voice/v1/dialing_permissions.rb +122 -121
  582. data/lib/twilio-ruby/rest/voice/v1/ip_record.rb +377 -339
  583. data/lib/twilio-ruby/rest/voice/v1/source_ip_mapping.rb +360 -319
  584. data/lib/twilio-ruby/rest/voice/v1.rb +130 -96
  585. data/lib/twilio-ruby/rest/voice.rb +12 -31
  586. data/lib/twilio-ruby/rest/voice_base.rb +38 -0
  587. data/lib/twilio-ruby/rest/wireless/v1/command.rb +408 -406
  588. data/lib/twilio-ruby/rest/wireless/v1/rate_plan.rb +463 -436
  589. data/lib/twilio-ruby/rest/wireless/v1/sim/data_session.rb +298 -284
  590. data/lib/twilio-ruby/rest/wireless/v1/sim/usage_record.rb +239 -243
  591. data/lib/twilio-ruby/rest/wireless/v1/sim.rb +634 -647
  592. data/lib/twilio-ruby/rest/wireless/v1/usage_record.rb +226 -221
  593. data/lib/twilio-ruby/rest/wireless/v1.rb +78 -76
  594. data/lib/twilio-ruby/rest/wireless.rb +5 -34
  595. data/lib/twilio-ruby/rest/wireless_base.rb +38 -0
  596. data/lib/twilio-ruby/rest.rb +1 -0
  597. data/lib/twilio-ruby/security/request_validator.rb +1 -1
  598. data/lib/twilio-ruby/twiml/voice_response.rb +209 -42
  599. data/lib/twilio-ruby/version.rb +1 -1
  600. data/lib/twilio-ruby.rb +1 -1
  601. data/sonar-project.properties +2 -2
  602. data/twilio-ruby.gemspec +2 -3
  603. metadata +155 -98
  604. data/.github/workflows/deploy.yml +0 -65
  605. data/.github/workflows/test.yml +0 -52
  606. data/conf/cacert.pem +0 -3376
  607. data/lib/twilio-ruby/framework/twilio_response.rb +0 -19
  608. data/lib/twilio-ruby/rest/api/v2010/account/available_phone_number/local.rb +0 -500
  609. data/lib/twilio-ruby/rest/api/v2010/account/available_phone_number/machine_to_machine.rb +0 -500
  610. data/lib/twilio-ruby/rest/api/v2010/account/available_phone_number/mobile.rb +0 -500
  611. data/lib/twilio-ruby/rest/api/v2010/account/available_phone_number/national.rb +0 -500
  612. data/lib/twilio-ruby/rest/api/v2010/account/available_phone_number/shared_cost.rb +0 -500
  613. data/lib/twilio-ruby/rest/api/v2010/account/available_phone_number/toll_free.rb +0 -500
  614. data/lib/twilio-ruby/rest/api/v2010/account/available_phone_number/voip.rb +0 -500
  615. data/lib/twilio-ruby/rest/api/v2010/account/available_phone_number.rb +0 -464
  616. data/lib/twilio-ruby/rest/api/v2010/account/sip/domain/auth_types/auth_calls_mapping/auth_calls_credential_list_mapping.rb +0 -348
  617. data/lib/twilio-ruby/rest/api/v2010/account/sip/domain/auth_types/auth_calls_mapping.rb +0 -163
  618. data/lib/twilio-ruby/rest/api/v2010/account/sip/domain/auth_types/auth_registrations_mapping.rb +0 -137
  619. data/lib/twilio-ruby/rest/autopilot/v1/assistant/defaults.rb +0 -220
  620. data/lib/twilio-ruby/rest/autopilot/v1/assistant/dialogue.rb +0 -214
  621. data/lib/twilio-ruby/rest/autopilot/v1/assistant/field_type/field_value.rb +0 -399
  622. data/lib/twilio-ruby/rest/autopilot/v1/assistant/field_type.rb +0 -418
  623. data/lib/twilio-ruby/rest/autopilot/v1/assistant/model_build.rb +0 -392
  624. data/lib/twilio-ruby/rest/autopilot/v1/assistant/query.rb +0 -469
  625. data/lib/twilio-ruby/rest/autopilot/v1/assistant/style_sheet.rb +0 -218
  626. data/lib/twilio-ruby/rest/autopilot/v1/assistant/task/field.rb +0 -386
  627. data/lib/twilio-ruby/rest/autopilot/v1/assistant/task/sample.rb +0 -456
  628. data/lib/twilio-ruby/rest/autopilot/v1/assistant/task/task_actions.rb +0 -255
  629. data/lib/twilio-ruby/rest/autopilot/v1/assistant/task/task_statistics.rb +0 -237
  630. data/lib/twilio-ruby/rest/autopilot/v1/assistant/task.rb +0 -507
  631. data/lib/twilio-ruby/rest/autopilot/v1/assistant/webhook.rb +0 -420
  632. data/lib/twilio-ruby/rest/autopilot/v1/assistant.rb +0 -650
  633. data/lib/twilio-ruby/rest/autopilot/v1/restore_assistant.rb +0 -194
  634. data/lib/twilio-ruby/rest/autopilot/v1.rb +0 -52
  635. data/lib/twilio-ruby/rest/autopilot.rb +0 -53
  636. data/lib/twilio-ruby/rest/events/v1/schema/version.rb +0 -290
  637. data/lib/twilio-ruby/rest/fax/v1/fax/fax_media.rb +0 -314
  638. data/lib/twilio-ruby/rest/fax/v1/fax.rb +0 -536
  639. data/lib/twilio-ruby/rest/fax/v1.rb +0 -45
  640. data/lib/twilio-ruby/rest/fax.rb +0 -47
  641. data/lib/twilio-ruby/rest/insights/v1/call/summary.rb +0 -307
  642. data/lib/twilio-ruby/rest/messaging/v1/deactivation.rb +0 -164
  643. data/lib/twilio-ruby/rest/preview/bulk_exports/export/day.rb +0 -294
  644. data/lib/twilio-ruby/rest/preview/bulk_exports/export/export_custom_job.rb +0 -275
  645. data/lib/twilio-ruby/rest/preview/bulk_exports/export/job.rb +0 -249
  646. data/lib/twilio-ruby/rest/preview/bulk_exports/export.rb +0 -251
  647. data/lib/twilio-ruby/rest/preview/bulk_exports/export_configuration.rb +0 -234
  648. data/lib/twilio-ruby/rest/preview/bulk_exports.rb +0 -62
  649. data/lib/twilio-ruby/rest/preview/trusted_comms/branded_channel/channel.rb +0 -165
  650. data/lib/twilio-ruby/rest/preview/trusted_comms/branded_channel.rb +0 -225
  651. data/lib/twilio-ruby/rest/preview/trusted_comms/brands_information.rb +0 -195
  652. data/lib/twilio-ruby/rest/preview/trusted_comms/cps.rb +0 -186
  653. data/lib/twilio-ruby/rest/preview/trusted_comms/current_call.rb +0 -277
  654. data/lib/twilio-ruby/rest/preview/trusted_comms.rb +0 -65
  655. data/lib/twilio-ruby/rest/preview/understand/assistant/assistant_fallback_actions.rb +0 -212
  656. data/lib/twilio-ruby/rest/preview/understand/assistant/assistant_initiation_actions.rb +0 -212
  657. data/lib/twilio-ruby/rest/preview/understand/assistant/dialogue.rb +0 -206
  658. data/lib/twilio-ruby/rest/preview/understand/assistant/field_type/field_value.rb +0 -386
  659. data/lib/twilio-ruby/rest/preview/understand/assistant/field_type.rb +0 -407
  660. data/lib/twilio-ruby/rest/preview/understand/assistant/model_build.rb +0 -380
  661. data/lib/twilio-ruby/rest/preview/understand/assistant/query.rb +0 -437
  662. data/lib/twilio-ruby/rest/preview/understand/assistant/style_sheet.rb +0 -212
  663. data/lib/twilio-ruby/rest/preview/understand/assistant/task/field.rb +0 -373
  664. data/lib/twilio-ruby/rest/preview/understand/assistant/task/sample.rb +0 -428
  665. data/lib/twilio-ruby/rest/preview/understand/assistant/task/task_actions.rb +0 -241
  666. data/lib/twilio-ruby/rest/preview/understand/assistant/task/task_statistics.rb +0 -225
  667. data/lib/twilio-ruby/rest/preview/understand/assistant/task.rb +0 -495
  668. data/lib/twilio-ruby/rest/preview/understand/assistant.rb +0 -629
  669. data/lib/twilio-ruby/rest/preview/understand.rb +0 -45
  670. data/lib/twilio-ruby/rest/studio/v2/flow/test_user.rb +0 -199
  671. data/lib/twilio-ruby/rest/supersim/v1/command.rb +0 -368
  672. data/lib/twilio-ruby/rest/video/v1/room/recording.rb +0 -406
  673. data/lib/twilio-ruby/rest/video/v1/room/room_participant/room_participant_published_track.rb +0 -335
  674. data/lib/twilio-ruby/rest/video/v1/room/room_participant/room_participant_subscribe_rule.rb +0 -175
  675. data/lib/twilio-ruby/rest/video/v1/room/room_participant/room_participant_subscribed_track.rb +0 -340
  676. data/lib/twilio-ruby/rest/video/v1/room/room_participant.rb +0 -483
  677. data/lib/twilio-ruby/rest/video/v1/room/room_recording_rule.rb +0 -144
@@ -1,747 +1,716 @@
1
1
  ##
2
- # This code was generated by
3
- # \ / _ _ _| _ _
4
- # | (_)\/(_)(_|\/| |(/_ v1.0.0
5
- # / /
2
+ # This code was generated by
3
+ # ___ _ _ _ _ _ _ ____ ____ ____ _ ____ ____ _ _ ____ ____ ____ ___ __ __
4
+ # | | | | | | | | | __ | | |__| | __ | __ |___ |\ | |___ |__/ |__| | | | |__/
5
+ # | |_|_| | |___ | |__| |__| | | | |__] |___ | \| |___ | \ | | | |__| | \
6
6
  #
7
- # frozen_string_literal: true
7
+ # Twilio - Taskrouter
8
+ # This is the public Twilio REST API.
9
+ #
10
+ # NOTE: This class is auto generated by OpenAPI Generator.
11
+ # https://openapi-generator.tech
12
+ # Do not edit the class manually.
13
+ #
14
+
8
15
 
9
16
  module Twilio
10
- module REST
11
- class Taskrouter < Domain
12
- class V1 < Version
13
- class WorkspaceContext < InstanceContext
14
- class TaskContext < InstanceContext
15
- class ReservationList < ListResource
16
- ##
17
- # Initialize the ReservationList
18
- # @param [Version] version Version that contains the resource
19
- # @param [String] workspace_sid The SID of the Workspace that this task is
20
- # contained within.
21
- # @param [String] task_sid The SID of the reserved Task resource.
22
- # @return [ReservationList] ReservationList
23
- def initialize(version, workspace_sid: nil, task_sid: nil)
24
- super(version)
25
-
26
- # Path Solution
27
- @solution = {workspace_sid: workspace_sid, task_sid: task_sid}
28
- @uri = "/Workspaces/#{@solution[:workspace_sid]}/Tasks/#{@solution[:task_sid]}/Reservations"
29
- end
30
-
31
- ##
32
- # Lists ReservationInstance records from the API as a list.
33
- # Unlike stream(), this operation is eager and will load `limit` records into
34
- # memory before returning.
35
- # @param [reservation.Status] reservation_status Returns the list of reservations
36
- # for a task with a specified ReservationStatus. Can be: `pending`, `accepted`,
37
- # `rejected`, or `timeout`.
38
- # @param [Integer] limit Upper limit for the number of records to return. stream()
39
- # guarantees to never return more than limit. Default is no limit
40
- # @param [Integer] page_size Number of records to fetch per request, when
41
- # not set will use the default value of 50 records. If no page_size is defined
42
- # but a limit is defined, stream() will attempt to read the limit with the most
43
- # efficient page size, i.e. min(limit, 1000)
44
- # @return [Array] Array of up to limit results
45
- def list(reservation_status: :unset, limit: nil, page_size: nil)
46
- self.stream(reservation_status: reservation_status, limit: limit, page_size: page_size).entries
47
- end
48
-
49
- ##
50
- # Streams ReservationInstance records from the API as an Enumerable.
51
- # This operation lazily loads records as efficiently as possible until the limit
52
- # is reached.
53
- # @param [reservation.Status] reservation_status Returns the list of reservations
54
- # for a task with a specified ReservationStatus. Can be: `pending`, `accepted`,
55
- # `rejected`, or `timeout`.
56
- # @param [Integer] limit Upper limit for the number of records to return. stream()
57
- # guarantees to never return more than limit. Default is no limit.
58
- # @param [Integer] page_size Number of records to fetch per request, when
59
- # not set will use the default value of 50 records. If no page_size is defined
60
- # but a limit is defined, stream() will attempt to read the limit with the most
61
- # efficient page size, i.e. min(limit, 1000)
62
- # @return [Enumerable] Enumerable that will yield up to limit results
63
- def stream(reservation_status: :unset, limit: nil, page_size: nil)
64
- limits = @version.read_limits(limit, page_size)
65
-
66
- page = self.page(reservation_status: reservation_status, page_size: limits[:page_size], )
67
-
68
- @version.stream(page, limit: limits[:limit], page_limit: limits[:page_limit])
69
- end
70
-
71
- ##
72
- # When passed a block, yields ReservationInstance records from the API.
73
- # This operation lazily loads records as efficiently as possible until the limit
74
- # is reached.
75
- def each
76
- limits = @version.read_limits
77
-
78
- page = self.page(page_size: limits[:page_size], )
79
-
80
- @version.stream(page,
81
- limit: limits[:limit],
82
- page_limit: limits[:page_limit]).each {|x| yield x}
83
- end
84
-
85
- ##
86
- # Retrieve a single page of ReservationInstance records from the API.
87
- # Request is executed immediately.
88
- # @param [reservation.Status] reservation_status Returns the list of reservations
89
- # for a task with a specified ReservationStatus. Can be: `pending`, `accepted`,
90
- # `rejected`, or `timeout`.
91
- # @param [String] page_token PageToken provided by the API
92
- # @param [Integer] page_number Page Number, this value is simply for client state
93
- # @param [Integer] page_size Number of records to return, defaults to 50
94
- # @return [Page] Page of ReservationInstance
95
- def page(reservation_status: :unset, page_token: :unset, page_number: :unset, page_size: :unset)
96
- params = Twilio::Values.of({
97
- 'ReservationStatus' => reservation_status,
98
- 'PageToken' => page_token,
99
- 'Page' => page_number,
100
- 'PageSize' => page_size,
101
- })
102
-
103
- response = @version.page('GET', @uri, params: params)
104
-
105
- ReservationPage.new(@version, response, @solution)
106
- end
107
-
108
- ##
109
- # Retrieve a single page of ReservationInstance records from the API.
110
- # Request is executed immediately.
111
- # @param [String] target_url API-generated URL for the requested results page
112
- # @return [Page] Page of ReservationInstance
113
- def get_page(target_url)
114
- response = @version.domain.request(
115
- 'GET',
116
- target_url
117
- )
118
- ReservationPage.new(@version, response, @solution)
119
- end
120
-
121
- ##
122
- # Provide a user friendly representation
123
- def to_s
124
- '#<Twilio.Taskrouter.V1.ReservationList>'
125
- end
126
- end
17
+ module REST
18
+ class Taskrouter < TaskrouterBase
19
+ class V1 < Version
20
+ class WorkspaceContext < InstanceContext
21
+ class TaskContext < InstanceContext
22
+
23
+ class ReservationList < ListResource
24
+ ##
25
+ # Initialize the ReservationList
26
+ # @param [Version] version Version that contains the resource
27
+ # @return [ReservationList] ReservationList
28
+ def initialize(version, workspace_sid: nil, task_sid: nil)
29
+ super(version)
30
+ # Path Solution
31
+ @solution = { workspace_sid: workspace_sid, task_sid: task_sid }
32
+ @uri = "/Workspaces/#{@solution[:workspace_sid]}/Tasks/#{@solution[:task_sid]}/Reservations"
33
+
34
+ end
35
+
36
+ ##
37
+ # Lists ReservationInstance records from the API as a list.
38
+ # Unlike stream(), this operation is eager and will load `limit` records into
39
+ # memory before returning.
40
+ # @param [Status] reservation_status Returns the list of reservations for a task with a specified ReservationStatus. Can be: `pending`, `accepted`, `rejected`, or `timeout`.
41
+ # @param [String] worker_sid The SID of the reserved Worker resource to read.
42
+ # @param [Integer] limit Upper limit for the number of records to return. stream()
43
+ # guarantees to never return more than limit. Default is no limit
44
+ # @param [Integer] page_size Number of records to fetch per request, when
45
+ # not set will use the default value of 50 records. If no page_size is defined
46
+ # but a limit is defined, stream() will attempt to read the limit with the most
47
+ # efficient page size, i.e. min(limit, 1000)
48
+ # @return [Array] Array of up to limit results
49
+ def list(reservation_status: :unset, worker_sid: :unset, limit: nil, page_size: nil)
50
+ self.stream(
51
+ reservation_status: reservation_status,
52
+ worker_sid: worker_sid,
53
+ limit: limit,
54
+ page_size: page_size
55
+ ).entries
56
+ end
57
+
58
+ ##
59
+ # Streams Instance records from the API as an Enumerable.
60
+ # This operation lazily loads records as efficiently as possible until the limit
61
+ # is reached.
62
+ # @param [Status] reservation_status Returns the list of reservations for a task with a specified ReservationStatus. Can be: `pending`, `accepted`, `rejected`, or `timeout`.
63
+ # @param [String] worker_sid The SID of the reserved Worker resource to read.
64
+ # @param [Integer] limit Upper limit for the number of records to return. stream()
65
+ # guarantees to never return more than limit. Default is no limit
66
+ # @param [Integer] page_size Number of records to fetch per request, when
67
+ # not set will use the default value of 50 records. If no page_size is defined
68
+ # but a limit is defined, stream() will attempt to read the limit with the most
69
+ # efficient page size, i.e. min(limit, 1000)
70
+ # @return [Enumerable] Enumerable that will yield up to limit results
71
+ def stream(reservation_status: :unset, worker_sid: :unset, limit: nil, page_size: nil)
72
+ limits = @version.read_limits(limit, page_size)
73
+
74
+ page = self.page(
75
+ reservation_status: reservation_status,
76
+ worker_sid: worker_sid,
77
+ page_size: limits[:page_size], )
78
+
79
+ @version.stream(page, limit: limits[:limit], page_limit: limits[:page_limit])
80
+ end
81
+
82
+ ##
83
+ # When passed a block, yields ReservationInstance records from the API.
84
+ # This operation lazily loads records as efficiently as possible until the limit
85
+ # is reached.
86
+ def each
87
+ limits = @version.read_limits
88
+
89
+ page = self.page(page_size: limits[:page_size], )
90
+
91
+ @version.stream(page,
92
+ limit: limits[:limit],
93
+ page_limit: limits[:page_limit]).each {|x| yield x}
94
+ end
95
+
96
+ ##
97
+ # Retrieve a single page of ReservationInstance records from the API.
98
+ # Request is executed immediately.
99
+ # @param [Status] reservation_status Returns the list of reservations for a task with a specified ReservationStatus. Can be: `pending`, `accepted`, `rejected`, or `timeout`.
100
+ # @param [String] worker_sid The SID of the reserved Worker resource to read.
101
+ # @param [String] page_token PageToken provided by the API
102
+ # @param [Integer] page_number Page Number, this value is simply for client state
103
+ # @param [Integer] page_size Number of records to return, defaults to 50
104
+ # @return [Page] Page of ReservationInstance
105
+ def page(reservation_status: :unset, worker_sid: :unset, page_token: :unset, page_number: :unset, page_size: :unset)
106
+ params = Twilio::Values.of({
107
+ 'ReservationStatus' => reservation_status,
108
+ 'WorkerSid' => worker_sid,
109
+ 'PageToken' => page_token,
110
+ 'Page' => page_number,
111
+ 'PageSize' => page_size,
112
+ })
113
+
114
+ response = @version.page('GET', @uri, params: params)
115
+
116
+ ReservationPage.new(@version, response, @solution)
117
+ end
118
+
119
+ ##
120
+ # Retrieve a single page of ReservationInstance records from the API.
121
+ # Request is executed immediately.
122
+ # @param [String] target_url API-generated URL for the requested results page
123
+ # @return [Page] Page of ReservationInstance
124
+ def get_page(target_url)
125
+ response = @version.domain.request(
126
+ 'GET',
127
+ target_url
128
+ )
129
+ ReservationPage.new(@version, response, @solution)
130
+ end
131
+
132
+
133
+
134
+ # Provide a user friendly representation
135
+ def to_s
136
+ '#<Twilio.Taskrouter.V1.ReservationList>'
137
+ end
138
+ end
127
139
 
128
- class ReservationPage < Page
129
- ##
130
- # Initialize the ReservationPage
131
- # @param [Version] version Version that contains the resource
132
- # @param [Response] response Response from the API
133
- # @param [Hash] solution Path solution for the resource
134
- # @return [ReservationPage] ReservationPage
135
- def initialize(version, response, solution)
136
- super(version, response)
137
-
138
- # Path Solution
139
- @solution = solution
140
- end
141
-
142
- ##
143
- # Build an instance of ReservationInstance
144
- # @param [Hash] payload Payload response from the API
145
- # @return [ReservationInstance] ReservationInstance
146
- def get_instance(payload)
147
- ReservationInstance.new(
148
- @version,
149
- payload,
150
- workspace_sid: @solution[:workspace_sid],
151
- task_sid: @solution[:task_sid],
152
- )
153
- end
154
-
155
- ##
156
- # Provide a user friendly representation
157
- def to_s
158
- '<Twilio.Taskrouter.V1.ReservationPage>'
159
- end
160
- end
161
140
 
162
- class ReservationContext < InstanceContext
163
- ##
164
- # Initialize the ReservationContext
165
- # @param [Version] version Version that contains the resource
166
- # @param [String] workspace_sid The SID of the Workspace with the TaskReservation
167
- # resource to fetch.
168
- # @param [String] task_sid The SID of the reserved Task resource with the
169
- # TaskReservation resource to fetch.
170
- # @param [String] sid The SID of the TaskReservation resource to fetch.
171
- # @return [ReservationContext] ReservationContext
172
- def initialize(version, workspace_sid, task_sid, sid)
173
- super(version)
174
-
175
- # Path Solution
176
- @solution = {workspace_sid: workspace_sid, task_sid: task_sid, sid: sid, }
177
- @uri = "/Workspaces/#{@solution[:workspace_sid]}/Tasks/#{@solution[:task_sid]}/Reservations/#{@solution[:sid]}"
178
- end
179
-
180
- ##
181
- # Fetch the ReservationInstance
182
- # @return [ReservationInstance] Fetched ReservationInstance
183
- def fetch
184
- payload = @version.fetch('GET', @uri)
185
-
186
- ReservationInstance.new(
187
- @version,
188
- payload,
189
- workspace_sid: @solution[:workspace_sid],
190
- task_sid: @solution[:task_sid],
191
- sid: @solution[:sid],
192
- )
193
- end
194
-
195
- ##
196
- # Update the ReservationInstance
197
- # @param [reservation.Status] reservation_status The new status of the
198
- # reservation. Can be: `pending`, `accepted`, `rejected`, or `timeout`.
199
- # @param [String] worker_activity_sid The new worker activity SID if rejecting a
200
- # reservation.
201
- # @param [String] instruction The assignment instruction for reservation.
202
- # @param [String] dequeue_post_work_activity_sid The SID of the Activity resource
203
- # to start after executing a Dequeue instruction.
204
- # @param [String] dequeue_from The Caller ID of the call to the worker when
205
- # executing a Dequeue instruction.
206
- # @param [String] dequeue_record Whether to record both legs of a call when
207
- # executing a Dequeue instruction or which leg to record.
208
- # @param [String] dequeue_timeout Timeout for call when executing a Dequeue
209
- # instruction.
210
- # @param [String] dequeue_to The Contact URI of the worker when executing a
211
- # Dequeue instruction. Can be the URI of the Twilio Client, the SIP URI for
212
- # Programmable SIP, or the {E.164}[https://www.twilio.com/docs/glossary/what-e164]
213
- # formatted phone number, depending on the destination.
214
- # @param [String] dequeue_status_callback_url The Callback URL for completed call
215
- # event when executing a Dequeue instruction.
216
- # @param [String] call_from The Caller ID of the outbound call when executing a
217
- # Call instruction.
218
- # @param [String] call_record Whether to record both legs of a call when executing
219
- # a Call instruction or which leg to record.
220
- # @param [String] call_timeout Timeout for call when executing a Call instruction.
221
- # @param [String] call_to The Contact URI of the worker when executing a Call
222
- # instruction. Can be the URI of the Twilio Client, the SIP URI for Programmable
223
- # SIP, or the {E.164}[https://www.twilio.com/docs/glossary/what-e164] formatted
224
- # phone number, depending on the destination.
225
- # @param [String] call_url TwiML URI executed on answering the worker's leg as a
226
- # result of the Call instruction.
227
- # @param [String] call_status_callback_url The URL to call for the completed call
228
- # event when executing a Call instruction.
229
- # @param [Boolean] call_accept Whether to accept a reservation when executing a
230
- # Call instruction.
231
- # @param [String] redirect_call_sid The Call SID of the call parked in the queue
232
- # when executing a Redirect instruction.
233
- # @param [Boolean] redirect_accept Whether the reservation should be accepted when
234
- # executing a Redirect instruction.
235
- # @param [String] redirect_url TwiML URI to redirect the call to when executing
236
- # the Redirect instruction.
237
- # @param [String] to The Contact URI of the worker when executing a Conference
238
- # instruction. Can be the URI of the Twilio Client, the SIP URI for Programmable
239
- # SIP, or the {E.164}[https://www.twilio.com/docs/glossary/what-e164] formatted
240
- # phone number, depending on the destination.
241
- # @param [String] from The Caller ID of the call to the worker when executing a
242
- # Conference instruction.
243
- # @param [String] status_callback The URL we should call using the
244
- # `status_callback_method` to send status information to your application.
245
- # @param [String] status_callback_method The HTTP method we should use to call
246
- # `status_callback`. Can be: `POST` or `GET` and the default is `POST`.
247
- # @param [Array[reservation.CallStatus]] status_callback_event The call progress
248
- # events that we will send to `status_callback`. Can be: `initiated`, `ringing`,
249
- # `answered`, or `completed`.
250
- # @param [String] timeout Timeout for call when executing a Conference
251
- # instruction.
252
- # @param [Boolean] record Whether to record the participant and their conferences,
253
- # including the time between conferences. The default is `false`.
254
- # @param [Boolean] muted Whether the agent is muted in the conference. The default
255
- # is `false`.
256
- # @param [String] beep Whether to play a notification beep when the participant
257
- # joins or when to play a beep. Can be: `true`, `false`, `onEnter`, or `onExit`.
258
- # The default value is `true`.
259
- # @param [Boolean] start_conference_on_enter Whether to start the conference when
260
- # the participant joins, if it has not already started. The default is `true`. If
261
- # `false` and the conference has not started, the participant is muted and hears
262
- # background music until another participant starts the conference.
263
- # @param [Boolean] end_conference_on_exit Whether to end the conference when the
264
- # agent leaves.
265
- # @param [String] wait_url The URL we should call using the `wait_method` for the
266
- # music to play while participants are waiting for the conference to start. The
267
- # default value is the URL of our standard hold music. {Learn more about hold
268
- # music}[https://www.twilio.com/labs/twimlets/holdmusic].
269
- # @param [String] wait_method The HTTP method we should use to call `wait_url`.
270
- # Can be `GET` or `POST` and the default is `POST`. When using a static audio
271
- # file, this should be `GET` so that we can cache the file.
272
- # @param [Boolean] early_media Whether to allow an agent to hear the state of the
273
- # outbound call, including ringing or disconnect messages. The default is `true`.
274
- # @param [String] max_participants The maximum number of participants in the
275
- # conference. Can be a positive integer from `2` to `250`. The default value is
276
- # `250`.
277
- # @param [String] conference_status_callback The URL we should call using the
278
- # `conference_status_callback_method` when the conference events in
279
- # `conference_status_callback_event` occur. Only the value set by the first
280
- # participant to join the conference is used. Subsequent
281
- # `conference_status_callback` values are ignored.
282
- # @param [String] conference_status_callback_method The HTTP method we should use
283
- # to call `conference_status_callback`. Can be: `GET` or `POST` and defaults to
284
- # `POST`.
285
- # @param [Array[reservation.ConferenceEvent]] conference_status_callback_event The
286
- # conference status events that we will send to `conference_status_callback`. Can
287
- # be: `start`, `end`, `join`, `leave`, `mute`, `hold`, `speaker`.
288
- # @param [String] conference_record Whether to record the conference the
289
- # participant is joining or when to record the conference. Can be: `true`,
290
- # `false`, `record-from-start`, and `do-not-record`. The default value is `false`.
291
- # @param [String] conference_trim How to trim the leading and trailing silence
292
- # from your recorded conference audio files. Can be: `trim-silence` or
293
- # `do-not-trim` and defaults to `trim-silence`.
294
- # @param [String] recording_channels The recording channels for the final
295
- # recording. Can be: `mono` or `dual` and the default is `mono`.
296
- # @param [String] recording_status_callback The URL that we should call using the
297
- # `recording_status_callback_method` when the recording status changes.
298
- # @param [String] recording_status_callback_method The HTTP method we should use
299
- # when we call `recording_status_callback`. Can be: `GET` or `POST` and defaults
300
- # to `POST`.
301
- # @param [String] conference_recording_status_callback The URL we should call
302
- # using the `conference_recording_status_callback_method` when the conference
303
- # recording is available.
304
- # @param [String] conference_recording_status_callback_method The HTTP method we
305
- # should use to call `conference_recording_status_callback`. Can be: `GET` or
306
- # `POST` and defaults to `POST`.
307
- # @param [String] region The
308
- # {region}[https://support.twilio.com/hc/en-us/articles/223132167-How-global-low-latency-routing-and-region-selection-work-for-conferences-and-Client-calls]
309
- # where we should mix the recorded audio. Can be:`us1`, `ie1`, `de1`, `sg1`,
310
- # `br1`, `au1`, or `jp1`.
311
- # @param [String] sip_auth_username The SIP username used for authentication.
312
- # @param [String] sip_auth_password The SIP password for authentication.
313
- # @param [Array[String]] dequeue_status_callback_event The Call progress events
314
- # sent via webhooks as a result of a Dequeue instruction.
315
- # @param [String] post_work_activity_sid The new worker activity SID after
316
- # executing a Conference instruction.
317
- # @param [reservation.SupervisorMode] supervisor_mode The Supervisor mode when
318
- # executing the Supervise instruction.
319
- # @param [String] supervisor The Supervisor SID/URI when executing the Supervise
320
- # instruction.
321
- # @param [Boolean] end_conference_on_customer_exit Whether to end the conference
322
- # when the customer leaves.
323
- # @param [Boolean] beep_on_customer_entrance Whether to play a notification beep
324
- # when the customer joins.
325
- # @param [String] if_match The If-Match HTTP request header
326
- # @return [ReservationInstance] Updated ReservationInstance
327
- def update(reservation_status: :unset, worker_activity_sid: :unset, instruction: :unset, dequeue_post_work_activity_sid: :unset, dequeue_from: :unset, dequeue_record: :unset, dequeue_timeout: :unset, dequeue_to: :unset, dequeue_status_callback_url: :unset, call_from: :unset, call_record: :unset, call_timeout: :unset, call_to: :unset, call_url: :unset, call_status_callback_url: :unset, call_accept: :unset, redirect_call_sid: :unset, redirect_accept: :unset, redirect_url: :unset, to: :unset, from: :unset, status_callback: :unset, status_callback_method: :unset, status_callback_event: :unset, timeout: :unset, record: :unset, muted: :unset, beep: :unset, start_conference_on_enter: :unset, end_conference_on_exit: :unset, wait_url: :unset, wait_method: :unset, early_media: :unset, max_participants: :unset, conference_status_callback: :unset, conference_status_callback_method: :unset, conference_status_callback_event: :unset, conference_record: :unset, conference_trim: :unset, recording_channels: :unset, recording_status_callback: :unset, recording_status_callback_method: :unset, conference_recording_status_callback: :unset, conference_recording_status_callback_method: :unset, region: :unset, sip_auth_username: :unset, sip_auth_password: :unset, dequeue_status_callback_event: :unset, post_work_activity_sid: :unset, supervisor_mode: :unset, supervisor: :unset, end_conference_on_customer_exit: :unset, beep_on_customer_entrance: :unset, if_match: :unset)
328
- data = Twilio::Values.of({
329
- 'ReservationStatus' => reservation_status,
330
- 'WorkerActivitySid' => worker_activity_sid,
331
- 'Instruction' => instruction,
332
- 'DequeuePostWorkActivitySid' => dequeue_post_work_activity_sid,
333
- 'DequeueFrom' => dequeue_from,
334
- 'DequeueRecord' => dequeue_record,
335
- 'DequeueTimeout' => dequeue_timeout,
336
- 'DequeueTo' => dequeue_to,
337
- 'DequeueStatusCallbackUrl' => dequeue_status_callback_url,
338
- 'CallFrom' => call_from,
339
- 'CallRecord' => call_record,
340
- 'CallTimeout' => call_timeout,
341
- 'CallTo' => call_to,
342
- 'CallUrl' => call_url,
343
- 'CallStatusCallbackUrl' => call_status_callback_url,
344
- 'CallAccept' => call_accept,
345
- 'RedirectCallSid' => redirect_call_sid,
346
- 'RedirectAccept' => redirect_accept,
347
- 'RedirectUrl' => redirect_url,
348
- 'To' => to,
349
- 'From' => from,
350
- 'StatusCallback' => status_callback,
351
- 'StatusCallbackMethod' => status_callback_method,
352
- 'StatusCallbackEvent' => Twilio.serialize_list(status_callback_event) { |e| e },
353
- 'Timeout' => timeout,
354
- 'Record' => record,
355
- 'Muted' => muted,
356
- 'Beep' => beep,
357
- 'StartConferenceOnEnter' => start_conference_on_enter,
358
- 'EndConferenceOnExit' => end_conference_on_exit,
359
- 'WaitUrl' => wait_url,
360
- 'WaitMethod' => wait_method,
361
- 'EarlyMedia' => early_media,
362
- 'MaxParticipants' => max_participants,
363
- 'ConferenceStatusCallback' => conference_status_callback,
364
- 'ConferenceStatusCallbackMethod' => conference_status_callback_method,
365
- 'ConferenceStatusCallbackEvent' => Twilio.serialize_list(conference_status_callback_event) { |e| e },
366
- 'ConferenceRecord' => conference_record,
367
- 'ConferenceTrim' => conference_trim,
368
- 'RecordingChannels' => recording_channels,
369
- 'RecordingStatusCallback' => recording_status_callback,
370
- 'RecordingStatusCallbackMethod' => recording_status_callback_method,
371
- 'ConferenceRecordingStatusCallback' => conference_recording_status_callback,
372
- 'ConferenceRecordingStatusCallbackMethod' => conference_recording_status_callback_method,
373
- 'Region' => region,
374
- 'SipAuthUsername' => sip_auth_username,
375
- 'SipAuthPassword' => sip_auth_password,
376
- 'DequeueStatusCallbackEvent' => Twilio.serialize_list(dequeue_status_callback_event) { |e| e },
377
- 'PostWorkActivitySid' => post_work_activity_sid,
378
- 'SupervisorMode' => supervisor_mode,
379
- 'Supervisor' => supervisor,
380
- 'EndConferenceOnCustomerExit' => end_conference_on_customer_exit,
381
- 'BeepOnCustomerEntrance' => beep_on_customer_entrance,
382
- })
383
- headers = Twilio::Values.of({'If-Match' => if_match, })
384
-
385
- payload = @version.update('POST', @uri, data: data, headers: headers)
386
-
387
- ReservationInstance.new(
388
- @version,
389
- payload,
390
- workspace_sid: @solution[:workspace_sid],
391
- task_sid: @solution[:task_sid],
392
- sid: @solution[:sid],
393
- )
394
- end
395
-
396
- ##
397
- # Provide a user friendly representation
398
- def to_s
399
- context = @solution.map {|k, v| "#{k}: #{v}"}.join(',')
400
- "#<Twilio.Taskrouter.V1.ReservationContext #{context}>"
401
- end
402
-
403
- ##
404
- # Provide a detailed, user friendly representation
405
- def inspect
406
- context = @solution.map {|k, v| "#{k}: #{v}"}.join(',')
407
- "#<Twilio.Taskrouter.V1.ReservationContext #{context}>"
408
- end
409
- end
141
+ class ReservationContext < InstanceContext
142
+ ##
143
+ # Initialize the ReservationContext
144
+ # @param [Version] version Version that contains the resource
145
+ # @param [String] workspace_sid The SID of the Workspace with the TaskReservation resources to update.
146
+ # @param [String] task_sid The SID of the reserved Task resource with the TaskReservation resources to update.
147
+ # @param [String] sid The SID of the TaskReservation resource to update.
148
+ # @return [ReservationContext] ReservationContext
149
+ def initialize(version, workspace_sid, task_sid, sid)
150
+ super(version)
151
+
152
+ # Path Solution
153
+ @solution = { workspace_sid: workspace_sid, task_sid: task_sid, sid: sid, }
154
+ @uri = "/Workspaces/#{@solution[:workspace_sid]}/Tasks/#{@solution[:task_sid]}/Reservations/#{@solution[:sid]}"
155
+
156
+
157
+ end
158
+ ##
159
+ # Fetch the ReservationInstance
160
+ # @return [ReservationInstance] Fetched ReservationInstance
161
+ def fetch
162
+
163
+ payload = @version.fetch('GET', @uri)
164
+ ReservationInstance.new(
165
+ @version,
166
+ payload,
167
+ workspace_sid: @solution[:workspace_sid],
168
+ task_sid: @solution[:task_sid],
169
+ sid: @solution[:sid],
170
+ )
171
+ end
172
+
173
+ ##
174
+ # Update the ReservationInstance
175
+ # @param [Status] reservation_status
176
+ # @param [String] worker_activity_sid The new worker activity SID if rejecting a reservation.
177
+ # @param [String] instruction The assignment instruction for reservation.
178
+ # @param [String] dequeue_post_work_activity_sid The SID of the Activity resource to start after executing a Dequeue instruction.
179
+ # @param [String] dequeue_from The Caller ID of the call to the worker when executing a Dequeue instruction.
180
+ # @param [String] dequeue_record Whether to record both legs of a call when executing a Dequeue instruction or which leg to record.
181
+ # @param [String] dequeue_timeout Timeout for call when executing a Dequeue instruction.
182
+ # @param [String] dequeue_to The Contact URI of the worker when executing a Dequeue instruction. Can be the URI of the Twilio Client, the SIP URI for Programmable SIP, or the [E.164](https://www.twilio.com/docs/glossary/what-e164) formatted phone number, depending on the destination.
183
+ # @param [String] dequeue_status_callback_url The Callback URL for completed call event when executing a Dequeue instruction.
184
+ # @param [String] call_from The Caller ID of the outbound call when executing a Call instruction.
185
+ # @param [String] call_record Whether to record both legs of a call when executing a Call instruction or which leg to record.
186
+ # @param [String] call_timeout Timeout for call when executing a Call instruction.
187
+ # @param [String] call_to The Contact URI of the worker when executing a Call instruction. Can be the URI of the Twilio Client, the SIP URI for Programmable SIP, or the [E.164](https://www.twilio.com/docs/glossary/what-e164) formatted phone number, depending on the destination.
188
+ # @param [String] call_url TwiML URI executed on answering the worker's leg as a result of the Call instruction.
189
+ # @param [String] call_status_callback_url The URL to call for the completed call event when executing a Call instruction.
190
+ # @param [Boolean] call_accept Whether to accept a reservation when executing a Call instruction.
191
+ # @param [String] redirect_call_sid The Call SID of the call parked in the queue when executing a Redirect instruction.
192
+ # @param [Boolean] redirect_accept Whether the reservation should be accepted when executing a Redirect instruction.
193
+ # @param [String] redirect_url TwiML URI to redirect the call to when executing the Redirect instruction.
194
+ # @param [String] to The Contact URI of the worker when executing a Conference instruction. Can be the URI of the Twilio Client, the SIP URI for Programmable SIP, or the [E.164](https://www.twilio.com/docs/glossary/what-e164) formatted phone number, depending on the destination.
195
+ # @param [String] from The Caller ID of the call to the worker when executing a Conference instruction.
196
+ # @param [String] status_callback The URL we should call using the `status_callback_method` to send status information to your application.
197
+ # @param [String] status_callback_method The HTTP method we should use to call `status_callback`. Can be: `POST` or `GET` and the default is `POST`.
198
+ # @param [Array[CallStatus]] status_callback_event The call progress events that we will send to `status_callback`. Can be: `initiated`, `ringing`, `answered`, or `completed`.
199
+ # @param [String] timeout Timeout for call when executing a Conference instruction.
200
+ # @param [Boolean] record Whether to record the participant and their conferences, including the time between conferences. The default is `false`.
201
+ # @param [Boolean] muted Whether the agent is muted in the conference. The default is `false`.
202
+ # @param [String] beep Whether to play a notification beep when the participant joins or when to play a beep. Can be: `true`, `false`, `onEnter`, or `onExit`. The default value is `true`.
203
+ # @param [Boolean] start_conference_on_enter Whether to start the conference when the participant joins, if it has not already started. 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.
204
+ # @param [Boolean] end_conference_on_exit Whether to end the conference when the agent leaves.
205
+ # @param [String] wait_url The URL we should call using the `wait_method` for the music to play while participants are waiting for the conference to start. The default value is the URL of our standard hold music. [Learn more about hold music](https://www.twilio.com/labs/twimlets/holdmusic).
206
+ # @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.
207
+ # @param [Boolean] early_media Whether to allow an agent to hear the state of the outbound call, including ringing or disconnect messages. The default is `true`.
208
+ # @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`.
209
+ # @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.
210
+ # @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`.
211
+ # @param [Array[ConferenceEvent]] conference_status_callback_event The conference status events that we will send to `conference_status_callback`. Can be: `start`, `end`, `join`, `leave`, `mute`, `hold`, `speaker`.
212
+ # @param [String] conference_record Whether to record the conference the participant is joining or when to record the conference. Can be: `true`, `false`, `record-from-start`, and `do-not-record`. The default value is `false`.
213
+ # @param [String] conference_trim How to trim the leading and trailing silence from your recorded conference audio files. Can be: `trim-silence` or `do-not-trim` and defaults to `trim-silence`.
214
+ # @param [String] recording_channels The recording channels for the final recording. Can be: `mono` or `dual` and the default is `mono`.
215
+ # @param [String] recording_status_callback The URL that we should call using the `recording_status_callback_method` when the recording status changes.
216
+ # @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`.
217
+ # @param [String] conference_recording_status_callback The URL we should call using the `conference_recording_status_callback_method` when the conference recording is available.
218
+ # @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`.
219
+ # @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`.
220
+ # @param [String] sip_auth_username The SIP username used for authentication.
221
+ # @param [String] sip_auth_password The SIP password for authentication.
222
+ # @param [Array[String]] dequeue_status_callback_event The Call progress events sent via webhooks as a result of a Dequeue instruction.
223
+ # @param [String] post_work_activity_sid The new worker activity SID after executing a Conference instruction.
224
+ # @param [SupervisorMode] supervisor_mode
225
+ # @param [String] supervisor The Supervisor SID/URI when executing the Supervise instruction.
226
+ # @param [Boolean] end_conference_on_customer_exit Whether to end the conference when the customer leaves.
227
+ # @param [Boolean] beep_on_customer_entrance Whether to play a notification beep when the customer joins.
228
+ # @param [String] jitter_buffer_size The jitter buffer size for conference. Can be: `small`, `medium`, `large`, `off`.
229
+ # @param [String] if_match The If-Match HTTP request header
230
+ # @return [ReservationInstance] Updated ReservationInstance
231
+ def update(
232
+ reservation_status: :unset,
233
+ worker_activity_sid: :unset,
234
+ instruction: :unset,
235
+ dequeue_post_work_activity_sid: :unset,
236
+ dequeue_from: :unset,
237
+ dequeue_record: :unset,
238
+ dequeue_timeout: :unset,
239
+ dequeue_to: :unset,
240
+ dequeue_status_callback_url: :unset,
241
+ call_from: :unset,
242
+ call_record: :unset,
243
+ call_timeout: :unset,
244
+ call_to: :unset,
245
+ call_url: :unset,
246
+ call_status_callback_url: :unset,
247
+ call_accept: :unset,
248
+ redirect_call_sid: :unset,
249
+ redirect_accept: :unset,
250
+ redirect_url: :unset,
251
+ to: :unset,
252
+ from: :unset,
253
+ status_callback: :unset,
254
+ status_callback_method: :unset,
255
+ status_callback_event: :unset,
256
+ timeout: :unset,
257
+ record: :unset,
258
+ muted: :unset,
259
+ beep: :unset,
260
+ start_conference_on_enter: :unset,
261
+ end_conference_on_exit: :unset,
262
+ wait_url: :unset,
263
+ wait_method: :unset,
264
+ early_media: :unset,
265
+ max_participants: :unset,
266
+ conference_status_callback: :unset,
267
+ conference_status_callback_method: :unset,
268
+ conference_status_callback_event: :unset,
269
+ conference_record: :unset,
270
+ conference_trim: :unset,
271
+ recording_channels: :unset,
272
+ recording_status_callback: :unset,
273
+ recording_status_callback_method: :unset,
274
+ conference_recording_status_callback: :unset,
275
+ conference_recording_status_callback_method: :unset,
276
+ region: :unset,
277
+ sip_auth_username: :unset,
278
+ sip_auth_password: :unset,
279
+ dequeue_status_callback_event: :unset,
280
+ post_work_activity_sid: :unset,
281
+ supervisor_mode: :unset,
282
+ supervisor: :unset,
283
+ end_conference_on_customer_exit: :unset,
284
+ beep_on_customer_entrance: :unset,
285
+ jitter_buffer_size: :unset,
286
+ if_match: :unset
287
+ )
288
+
289
+ data = Twilio::Values.of({
290
+ 'ReservationStatus' => reservation_status,
291
+ 'WorkerActivitySid' => worker_activity_sid,
292
+ 'Instruction' => instruction,
293
+ 'DequeuePostWorkActivitySid' => dequeue_post_work_activity_sid,
294
+ 'DequeueFrom' => dequeue_from,
295
+ 'DequeueRecord' => dequeue_record,
296
+ 'DequeueTimeout' => dequeue_timeout,
297
+ 'DequeueTo' => dequeue_to,
298
+ 'DequeueStatusCallbackUrl' => dequeue_status_callback_url,
299
+ 'CallFrom' => call_from,
300
+ 'CallRecord' => call_record,
301
+ 'CallTimeout' => call_timeout,
302
+ 'CallTo' => call_to,
303
+ 'CallUrl' => call_url,
304
+ 'CallStatusCallbackUrl' => call_status_callback_url,
305
+ 'CallAccept' => call_accept,
306
+ 'RedirectCallSid' => redirect_call_sid,
307
+ 'RedirectAccept' => redirect_accept,
308
+ 'RedirectUrl' => redirect_url,
309
+ 'To' => to,
310
+ 'From' => from,
311
+ 'StatusCallback' => status_callback,
312
+ 'StatusCallbackMethod' => status_callback_method,
313
+ 'StatusCallbackEvent' => Twilio.serialize_list(status_callback_event) { |e| e },
314
+ 'Timeout' => timeout,
315
+ 'Record' => record,
316
+ 'Muted' => muted,
317
+ 'Beep' => beep,
318
+ 'StartConferenceOnEnter' => start_conference_on_enter,
319
+ 'EndConferenceOnExit' => end_conference_on_exit,
320
+ 'WaitUrl' => wait_url,
321
+ 'WaitMethod' => wait_method,
322
+ 'EarlyMedia' => early_media,
323
+ 'MaxParticipants' => max_participants,
324
+ 'ConferenceStatusCallback' => conference_status_callback,
325
+ 'ConferenceStatusCallbackMethod' => conference_status_callback_method,
326
+ 'ConferenceStatusCallbackEvent' => Twilio.serialize_list(conference_status_callback_event) { |e| e },
327
+ 'ConferenceRecord' => conference_record,
328
+ 'ConferenceTrim' => conference_trim,
329
+ 'RecordingChannels' => recording_channels,
330
+ 'RecordingStatusCallback' => recording_status_callback,
331
+ 'RecordingStatusCallbackMethod' => recording_status_callback_method,
332
+ 'ConferenceRecordingStatusCallback' => conference_recording_status_callback,
333
+ 'ConferenceRecordingStatusCallbackMethod' => conference_recording_status_callback_method,
334
+ 'Region' => region,
335
+ 'SipAuthUsername' => sip_auth_username,
336
+ 'SipAuthPassword' => sip_auth_password,
337
+ 'DequeueStatusCallbackEvent' => Twilio.serialize_list(dequeue_status_callback_event) { |e| e },
338
+ 'PostWorkActivitySid' => post_work_activity_sid,
339
+ 'SupervisorMode' => supervisor_mode,
340
+ 'Supervisor' => supervisor,
341
+ 'EndConferenceOnCustomerExit' => end_conference_on_customer_exit,
342
+ 'BeepOnCustomerEntrance' => beep_on_customer_entrance,
343
+ 'JitterBufferSize' => jitter_buffer_size,
344
+ })
345
+
346
+ headers = Twilio::Values.of({ 'If-Match' => if_match, })
347
+ payload = @version.update('POST', @uri, data: data, headers: headers)
348
+ ReservationInstance.new(
349
+ @version,
350
+ payload,
351
+ workspace_sid: @solution[:workspace_sid],
352
+ task_sid: @solution[:task_sid],
353
+ sid: @solution[:sid],
354
+ )
355
+ end
356
+
357
+
358
+ ##
359
+ # Provide a user friendly representation
360
+ def to_s
361
+ context = @solution.map{|k, v| "#{k}: #{v}"}.join(',')
362
+ "#<Twilio.Taskrouter.V1.ReservationContext #{context}>"
363
+ end
364
+
365
+ ##
366
+ # Provide a detailed, user friendly representation
367
+ def inspect
368
+ context = @solution.map{|k, v| "#{k}: #{v}"}.join(',')
369
+ "#<Twilio.Taskrouter.V1.ReservationContext #{context}>"
370
+ end
371
+ end
410
372
 
411
- class ReservationInstance < InstanceResource
412
- ##
413
- # Initialize the ReservationInstance
414
- # @param [Version] version Version that contains the resource
415
- # @param [Hash] payload payload that contains response from Twilio
416
- # @param [String] workspace_sid The SID of the Workspace that this task is
417
- # contained within.
418
- # @param [String] task_sid The SID of the reserved Task resource.
419
- # @param [String] sid The SID of the TaskReservation resource to fetch.
420
- # @return [ReservationInstance] ReservationInstance
421
- def initialize(version, payload, workspace_sid: nil, task_sid: nil, sid: nil)
422
- super(version)
423
-
424
- # Marshaled Properties
425
- @properties = {
426
- 'account_sid' => payload['account_sid'],
427
- 'date_created' => Twilio.deserialize_iso8601_datetime(payload['date_created']),
428
- 'date_updated' => Twilio.deserialize_iso8601_datetime(payload['date_updated']),
429
- 'reservation_status' => payload['reservation_status'],
430
- 'sid' => payload['sid'],
431
- 'task_sid' => payload['task_sid'],
432
- 'worker_name' => payload['worker_name'],
433
- 'worker_sid' => payload['worker_sid'],
434
- 'workspace_sid' => payload['workspace_sid'],
435
- 'url' => payload['url'],
436
- 'links' => payload['links'],
437
- }
438
-
439
- # Context
440
- @instance_context = nil
441
- @params = {
442
- 'workspace_sid' => workspace_sid,
443
- 'task_sid' => task_sid,
444
- 'sid' => sid || @properties['sid'],
445
- }
446
- end
447
-
448
- ##
449
- # Generate an instance context for the instance, the context is capable of
450
- # performing various actions. All instance actions are proxied to the context
451
- # @return [ReservationContext] ReservationContext for this ReservationInstance
452
- def context
453
- unless @instance_context
454
- @instance_context = ReservationContext.new(
455
- @version,
456
- @params['workspace_sid'],
457
- @params['task_sid'],
458
- @params['sid'],
459
- )
373
+ class ReservationPage < Page
374
+ ##
375
+ # Initialize the ReservationPage
376
+ # @param [Version] version Version that contains the resource
377
+ # @param [Response] response Response from the API
378
+ # @param [Hash] solution Path solution for the resource
379
+ # @return [ReservationPage] ReservationPage
380
+ def initialize(version, response, solution)
381
+ super(version, response)
382
+
383
+ # Path Solution
384
+ @solution = solution
385
+ end
386
+
387
+ ##
388
+ # Build an instance of ReservationInstance
389
+ # @param [Hash] payload Payload response from the API
390
+ # @return [ReservationInstance] ReservationInstance
391
+ def get_instance(payload)
392
+ ReservationInstance.new(@version, payload, workspace_sid: @solution[:workspace_sid], task_sid: @solution[:task_sid])
393
+ end
394
+
395
+ ##
396
+ # Provide a user friendly representation
397
+ def to_s
398
+ '<Twilio.Taskrouter.V1.ReservationPage>'
399
+ end
400
+ end
401
+ class ReservationInstance < InstanceResource
402
+ ##
403
+ # Initialize the ReservationInstance
404
+ # @param [Version] version Version that contains the resource
405
+ # @param [Hash] payload payload that contains response from Twilio
406
+ # @param [String] account_sid The SID of the
407
+ # {Account}[https://www.twilio.com/docs/iam/api/account] that created this Reservation
408
+ # resource.
409
+ # @param [String] sid The SID of the Call resource to fetch.
410
+ # @return [ReservationInstance] ReservationInstance
411
+ def initialize(version, payload , workspace_sid: nil, task_sid: nil, sid: nil)
412
+ super(version)
413
+
414
+ # Marshaled Properties
415
+ @properties = {
416
+ 'account_sid' => payload['account_sid'],
417
+ 'date_created' => Twilio.deserialize_iso8601_datetime(payload['date_created']),
418
+ 'date_updated' => Twilio.deserialize_iso8601_datetime(payload['date_updated']),
419
+ 'reservation_status' => payload['reservation_status'],
420
+ 'sid' => payload['sid'],
421
+ 'task_sid' => payload['task_sid'],
422
+ 'worker_name' => payload['worker_name'],
423
+ 'worker_sid' => payload['worker_sid'],
424
+ 'workspace_sid' => payload['workspace_sid'],
425
+ 'url' => payload['url'],
426
+ 'links' => payload['links'],
427
+ }
428
+
429
+ # Context
430
+ @instance_context = nil
431
+ @params = { 'workspace_sid' => workspace_sid || @properties['workspace_sid'] ,'task_sid' => task_sid || @properties['task_sid'] ,'sid' => sid || @properties['sid'] , }
432
+ end
433
+
434
+ ##
435
+ # Generate an instance context for the instance, the context is capable of
436
+ # performing various actions. All instance actions are proxied to the context
437
+ # @return [ReservationContext] CallContext for this CallInstance
438
+ def context
439
+ unless @instance_context
440
+ @instance_context = ReservationContext.new(@version , @params['workspace_sid'], @params['task_sid'], @params['sid'])
441
+ end
442
+ @instance_context
443
+ end
444
+
445
+ ##
446
+ # @return [String] The SID of the [Account](https://www.twilio.com/docs/iam/api/account) that created the TaskReservation resource.
447
+ def account_sid
448
+ @properties['account_sid']
449
+ end
450
+
451
+ ##
452
+ # @return [Time] The date and time in GMT when the resource was created specified in [ISO 8601](https://en.wikipedia.org/wiki/ISO_8601) format.
453
+ def date_created
454
+ @properties['date_created']
455
+ end
456
+
457
+ ##
458
+ # @return [Time] The date and time in GMT when the resource was last updated specified in [ISO 8601](https://en.wikipedia.org/wiki/ISO_8601) format.
459
+ def date_updated
460
+ @properties['date_updated']
461
+ end
462
+
463
+ ##
464
+ # @return [Status]
465
+ def reservation_status
466
+ @properties['reservation_status']
467
+ end
468
+
469
+ ##
470
+ # @return [String] The unique string that we created to identify the TaskReservation resource.
471
+ def sid
472
+ @properties['sid']
473
+ end
474
+
475
+ ##
476
+ # @return [String] The SID of the reserved Task resource.
477
+ def task_sid
478
+ @properties['task_sid']
479
+ end
480
+
481
+ ##
482
+ # @return [String] The `friendly_name` of the Worker that is reserved.
483
+ def worker_name
484
+ @properties['worker_name']
485
+ end
486
+
487
+ ##
488
+ # @return [String] The SID of the reserved Worker resource.
489
+ def worker_sid
490
+ @properties['worker_sid']
491
+ end
492
+
493
+ ##
494
+ # @return [String] The SID of the Workspace that this task is contained within.
495
+ def workspace_sid
496
+ @properties['workspace_sid']
497
+ end
498
+
499
+ ##
500
+ # @return [String] The absolute URL of the TaskReservation reservation.
501
+ def url
502
+ @properties['url']
503
+ end
504
+
505
+ ##
506
+ # @return [Hash] The URLs of related resources.
507
+ def links
508
+ @properties['links']
509
+ end
510
+
511
+ ##
512
+ # Fetch the ReservationInstance
513
+ # @return [ReservationInstance] Fetched ReservationInstance
514
+ def fetch
515
+
516
+ context.fetch
517
+ end
518
+
519
+ ##
520
+ # Update the ReservationInstance
521
+ # @param [Status] reservation_status
522
+ # @param [String] worker_activity_sid The new worker activity SID if rejecting a reservation.
523
+ # @param [String] instruction The assignment instruction for reservation.
524
+ # @param [String] dequeue_post_work_activity_sid The SID of the Activity resource to start after executing a Dequeue instruction.
525
+ # @param [String] dequeue_from The Caller ID of the call to the worker when executing a Dequeue instruction.
526
+ # @param [String] dequeue_record Whether to record both legs of a call when executing a Dequeue instruction or which leg to record.
527
+ # @param [String] dequeue_timeout Timeout for call when executing a Dequeue instruction.
528
+ # @param [String] dequeue_to The Contact URI of the worker when executing a Dequeue instruction. Can be the URI of the Twilio Client, the SIP URI for Programmable SIP, or the [E.164](https://www.twilio.com/docs/glossary/what-e164) formatted phone number, depending on the destination.
529
+ # @param [String] dequeue_status_callback_url The Callback URL for completed call event when executing a Dequeue instruction.
530
+ # @param [String] call_from The Caller ID of the outbound call when executing a Call instruction.
531
+ # @param [String] call_record Whether to record both legs of a call when executing a Call instruction or which leg to record.
532
+ # @param [String] call_timeout Timeout for call when executing a Call instruction.
533
+ # @param [String] call_to The Contact URI of the worker when executing a Call instruction. Can be the URI of the Twilio Client, the SIP URI for Programmable SIP, or the [E.164](https://www.twilio.com/docs/glossary/what-e164) formatted phone number, depending on the destination.
534
+ # @param [String] call_url TwiML URI executed on answering the worker's leg as a result of the Call instruction.
535
+ # @param [String] call_status_callback_url The URL to call for the completed call event when executing a Call instruction.
536
+ # @param [Boolean] call_accept Whether to accept a reservation when executing a Call instruction.
537
+ # @param [String] redirect_call_sid The Call SID of the call parked in the queue when executing a Redirect instruction.
538
+ # @param [Boolean] redirect_accept Whether the reservation should be accepted when executing a Redirect instruction.
539
+ # @param [String] redirect_url TwiML URI to redirect the call to when executing the Redirect instruction.
540
+ # @param [String] to The Contact URI of the worker when executing a Conference instruction. Can be the URI of the Twilio Client, the SIP URI for Programmable SIP, or the [E.164](https://www.twilio.com/docs/glossary/what-e164) formatted phone number, depending on the destination.
541
+ # @param [String] from The Caller ID of the call to the worker when executing a Conference instruction.
542
+ # @param [String] status_callback The URL we should call using the `status_callback_method` to send status information to your application.
543
+ # @param [String] status_callback_method The HTTP method we should use to call `status_callback`. Can be: `POST` or `GET` and the default is `POST`.
544
+ # @param [Array[CallStatus]] status_callback_event The call progress events that we will send to `status_callback`. Can be: `initiated`, `ringing`, `answered`, or `completed`.
545
+ # @param [String] timeout Timeout for call when executing a Conference instruction.
546
+ # @param [Boolean] record Whether to record the participant and their conferences, including the time between conferences. The default is `false`.
547
+ # @param [Boolean] muted Whether the agent is muted in the conference. The default is `false`.
548
+ # @param [String] beep Whether to play a notification beep when the participant joins or when to play a beep. Can be: `true`, `false`, `onEnter`, or `onExit`. The default value is `true`.
549
+ # @param [Boolean] start_conference_on_enter Whether to start the conference when the participant joins, if it has not already started. 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.
550
+ # @param [Boolean] end_conference_on_exit Whether to end the conference when the agent leaves.
551
+ # @param [String] wait_url The URL we should call using the `wait_method` for the music to play while participants are waiting for the conference to start. The default value is the URL of our standard hold music. [Learn more about hold music](https://www.twilio.com/labs/twimlets/holdmusic).
552
+ # @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.
553
+ # @param [Boolean] early_media Whether to allow an agent to hear the state of the outbound call, including ringing or disconnect messages. The default is `true`.
554
+ # @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`.
555
+ # @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.
556
+ # @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`.
557
+ # @param [Array[ConferenceEvent]] conference_status_callback_event The conference status events that we will send to `conference_status_callback`. Can be: `start`, `end`, `join`, `leave`, `mute`, `hold`, `speaker`.
558
+ # @param [String] conference_record Whether to record the conference the participant is joining or when to record the conference. Can be: `true`, `false`, `record-from-start`, and `do-not-record`. The default value is `false`.
559
+ # @param [String] conference_trim How to trim the leading and trailing silence from your recorded conference audio files. Can be: `trim-silence` or `do-not-trim` and defaults to `trim-silence`.
560
+ # @param [String] recording_channels The recording channels for the final recording. Can be: `mono` or `dual` and the default is `mono`.
561
+ # @param [String] recording_status_callback The URL that we should call using the `recording_status_callback_method` when the recording status changes.
562
+ # @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`.
563
+ # @param [String] conference_recording_status_callback The URL we should call using the `conference_recording_status_callback_method` when the conference recording is available.
564
+ # @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`.
565
+ # @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`.
566
+ # @param [String] sip_auth_username The SIP username used for authentication.
567
+ # @param [String] sip_auth_password The SIP password for authentication.
568
+ # @param [Array[String]] dequeue_status_callback_event The Call progress events sent via webhooks as a result of a Dequeue instruction.
569
+ # @param [String] post_work_activity_sid The new worker activity SID after executing a Conference instruction.
570
+ # @param [SupervisorMode] supervisor_mode
571
+ # @param [String] supervisor The Supervisor SID/URI when executing the Supervise instruction.
572
+ # @param [Boolean] end_conference_on_customer_exit Whether to end the conference when the customer leaves.
573
+ # @param [Boolean] beep_on_customer_entrance Whether to play a notification beep when the customer joins.
574
+ # @param [String] jitter_buffer_size The jitter buffer size for conference. Can be: `small`, `medium`, `large`, `off`.
575
+ # @param [String] if_match The If-Match HTTP request header
576
+ # @return [ReservationInstance] Updated ReservationInstance
577
+ def update(
578
+ reservation_status: :unset,
579
+ worker_activity_sid: :unset,
580
+ instruction: :unset,
581
+ dequeue_post_work_activity_sid: :unset,
582
+ dequeue_from: :unset,
583
+ dequeue_record: :unset,
584
+ dequeue_timeout: :unset,
585
+ dequeue_to: :unset,
586
+ dequeue_status_callback_url: :unset,
587
+ call_from: :unset,
588
+ call_record: :unset,
589
+ call_timeout: :unset,
590
+ call_to: :unset,
591
+ call_url: :unset,
592
+ call_status_callback_url: :unset,
593
+ call_accept: :unset,
594
+ redirect_call_sid: :unset,
595
+ redirect_accept: :unset,
596
+ redirect_url: :unset,
597
+ to: :unset,
598
+ from: :unset,
599
+ status_callback: :unset,
600
+ status_callback_method: :unset,
601
+ status_callback_event: :unset,
602
+ timeout: :unset,
603
+ record: :unset,
604
+ muted: :unset,
605
+ beep: :unset,
606
+ start_conference_on_enter: :unset,
607
+ end_conference_on_exit: :unset,
608
+ wait_url: :unset,
609
+ wait_method: :unset,
610
+ early_media: :unset,
611
+ max_participants: :unset,
612
+ conference_status_callback: :unset,
613
+ conference_status_callback_method: :unset,
614
+ conference_status_callback_event: :unset,
615
+ conference_record: :unset,
616
+ conference_trim: :unset,
617
+ recording_channels: :unset,
618
+ recording_status_callback: :unset,
619
+ recording_status_callback_method: :unset,
620
+ conference_recording_status_callback: :unset,
621
+ conference_recording_status_callback_method: :unset,
622
+ region: :unset,
623
+ sip_auth_username: :unset,
624
+ sip_auth_password: :unset,
625
+ dequeue_status_callback_event: :unset,
626
+ post_work_activity_sid: :unset,
627
+ supervisor_mode: :unset,
628
+ supervisor: :unset,
629
+ end_conference_on_customer_exit: :unset,
630
+ beep_on_customer_entrance: :unset,
631
+ jitter_buffer_size: :unset,
632
+ if_match: :unset
633
+ )
634
+
635
+ context.update(
636
+ reservation_status: reservation_status,
637
+ worker_activity_sid: worker_activity_sid,
638
+ instruction: instruction,
639
+ dequeue_post_work_activity_sid: dequeue_post_work_activity_sid,
640
+ dequeue_from: dequeue_from,
641
+ dequeue_record: dequeue_record,
642
+ dequeue_timeout: dequeue_timeout,
643
+ dequeue_to: dequeue_to,
644
+ dequeue_status_callback_url: dequeue_status_callback_url,
645
+ call_from: call_from,
646
+ call_record: call_record,
647
+ call_timeout: call_timeout,
648
+ call_to: call_to,
649
+ call_url: call_url,
650
+ call_status_callback_url: call_status_callback_url,
651
+ call_accept: call_accept,
652
+ redirect_call_sid: redirect_call_sid,
653
+ redirect_accept: redirect_accept,
654
+ redirect_url: redirect_url,
655
+ to: to,
656
+ from: from,
657
+ status_callback: status_callback,
658
+ status_callback_method: status_callback_method,
659
+ status_callback_event: status_callback_event,
660
+ timeout: timeout,
661
+ record: record,
662
+ muted: muted,
663
+ beep: beep,
664
+ start_conference_on_enter: start_conference_on_enter,
665
+ end_conference_on_exit: end_conference_on_exit,
666
+ wait_url: wait_url,
667
+ wait_method: wait_method,
668
+ early_media: early_media,
669
+ max_participants: max_participants,
670
+ conference_status_callback: conference_status_callback,
671
+ conference_status_callback_method: conference_status_callback_method,
672
+ conference_status_callback_event: conference_status_callback_event,
673
+ conference_record: conference_record,
674
+ conference_trim: conference_trim,
675
+ recording_channels: recording_channels,
676
+ recording_status_callback: recording_status_callback,
677
+ recording_status_callback_method: recording_status_callback_method,
678
+ conference_recording_status_callback: conference_recording_status_callback,
679
+ conference_recording_status_callback_method: conference_recording_status_callback_method,
680
+ region: region,
681
+ sip_auth_username: sip_auth_username,
682
+ sip_auth_password: sip_auth_password,
683
+ dequeue_status_callback_event: dequeue_status_callback_event,
684
+ post_work_activity_sid: post_work_activity_sid,
685
+ supervisor_mode: supervisor_mode,
686
+ supervisor: supervisor,
687
+ end_conference_on_customer_exit: end_conference_on_customer_exit,
688
+ beep_on_customer_entrance: beep_on_customer_entrance,
689
+ jitter_buffer_size: jitter_buffer_size,
690
+ if_match: if_match,
691
+ )
692
+ end
693
+
694
+ ##
695
+ # Provide a user friendly representation
696
+ def to_s
697
+ values = @params.map{|k, v| "#{k}: #{v}"}.join(" ")
698
+ "<Twilio.Taskrouter.V1.ReservationInstance #{values}>"
699
+ end
700
+
701
+ ##
702
+ # Provide a detailed, user friendly representation
703
+ def inspect
704
+ values = @properties.map{|k, v| "#{k}: #{v}"}.join(" ")
705
+ "<Twilio.Taskrouter.V1.ReservationInstance #{values}>"
706
+ end
460
707
  end
461
- @instance_context
462
- end
463
-
464
- ##
465
- # @return [String] The SID of the Account that created the resource
466
- def account_sid
467
- @properties['account_sid']
468
- end
469
-
470
- ##
471
- # @return [Time] The ISO 8601 date and time in GMT when the resource was created
472
- def date_created
473
- @properties['date_created']
474
- end
475
-
476
- ##
477
- # @return [Time] The ISO 8601 date and time in GMT when the resource was last updated
478
- def date_updated
479
- @properties['date_updated']
480
- end
481
-
482
- ##
483
- # @return [reservation.Status] The current status of the reservation
484
- def reservation_status
485
- @properties['reservation_status']
486
- end
487
-
488
- ##
489
- # @return [String] The unique string that identifies the resource
490
- def sid
491
- @properties['sid']
492
- end
493
-
494
- ##
495
- # @return [String] The SID of the reserved Task resource
496
- def task_sid
497
- @properties['task_sid']
498
- end
499
-
500
- ##
501
- # @return [String] The friendly_name of the Worker that is reserved
502
- def worker_name
503
- @properties['worker_name']
504
- end
505
-
506
- ##
507
- # @return [String] The SID of the reserved Worker resource
508
- def worker_sid
509
- @properties['worker_sid']
510
- end
511
-
512
- ##
513
- # @return [String] The SID of the Workspace that this task is contained within.
514
- def workspace_sid
515
- @properties['workspace_sid']
516
- end
517
-
518
- ##
519
- # @return [String] The absolute URL of the TaskReservation reservation
520
- def url
521
- @properties['url']
522
- end
523
-
524
- ##
525
- # @return [String] The URLs of related resources
526
- def links
527
- @properties['links']
528
- end
529
-
530
- ##
531
- # Fetch the ReservationInstance
532
- # @return [ReservationInstance] Fetched ReservationInstance
533
- def fetch
534
- context.fetch
535
- end
536
-
537
- ##
538
- # Update the ReservationInstance
539
- # @param [reservation.Status] reservation_status The new status of the
540
- # reservation. Can be: `pending`, `accepted`, `rejected`, or `timeout`.
541
- # @param [String] worker_activity_sid The new worker activity SID if rejecting a
542
- # reservation.
543
- # @param [String] instruction The assignment instruction for reservation.
544
- # @param [String] dequeue_post_work_activity_sid The SID of the Activity resource
545
- # to start after executing a Dequeue instruction.
546
- # @param [String] dequeue_from The Caller ID of the call to the worker when
547
- # executing a Dequeue instruction.
548
- # @param [String] dequeue_record Whether to record both legs of a call when
549
- # executing a Dequeue instruction or which leg to record.
550
- # @param [String] dequeue_timeout Timeout for call when executing a Dequeue
551
- # instruction.
552
- # @param [String] dequeue_to The Contact URI of the worker when executing a
553
- # Dequeue instruction. Can be the URI of the Twilio Client, the SIP URI for
554
- # Programmable SIP, or the {E.164}[https://www.twilio.com/docs/glossary/what-e164]
555
- # formatted phone number, depending on the destination.
556
- # @param [String] dequeue_status_callback_url The Callback URL for completed call
557
- # event when executing a Dequeue instruction.
558
- # @param [String] call_from The Caller ID of the outbound call when executing a
559
- # Call instruction.
560
- # @param [String] call_record Whether to record both legs of a call when executing
561
- # a Call instruction or which leg to record.
562
- # @param [String] call_timeout Timeout for call when executing a Call instruction.
563
- # @param [String] call_to The Contact URI of the worker when executing a Call
564
- # instruction. Can be the URI of the Twilio Client, the SIP URI for Programmable
565
- # SIP, or the {E.164}[https://www.twilio.com/docs/glossary/what-e164] formatted
566
- # phone number, depending on the destination.
567
- # @param [String] call_url TwiML URI executed on answering the worker's leg as a
568
- # result of the Call instruction.
569
- # @param [String] call_status_callback_url The URL to call for the completed call
570
- # event when executing a Call instruction.
571
- # @param [Boolean] call_accept Whether to accept a reservation when executing a
572
- # Call instruction.
573
- # @param [String] redirect_call_sid The Call SID of the call parked in the queue
574
- # when executing a Redirect instruction.
575
- # @param [Boolean] redirect_accept Whether the reservation should be accepted when
576
- # executing a Redirect instruction.
577
- # @param [String] redirect_url TwiML URI to redirect the call to when executing
578
- # the Redirect instruction.
579
- # @param [String] to The Contact URI of the worker when executing a Conference
580
- # instruction. Can be the URI of the Twilio Client, the SIP URI for Programmable
581
- # SIP, or the {E.164}[https://www.twilio.com/docs/glossary/what-e164] formatted
582
- # phone number, depending on the destination.
583
- # @param [String] from The Caller ID of the call to the worker when executing a
584
- # Conference instruction.
585
- # @param [String] status_callback The URL we should call using the
586
- # `status_callback_method` to send status information to your application.
587
- # @param [String] status_callback_method The HTTP method we should use to call
588
- # `status_callback`. Can be: `POST` or `GET` and the default is `POST`.
589
- # @param [Array[reservation.CallStatus]] status_callback_event The call progress
590
- # events that we will send to `status_callback`. Can be: `initiated`, `ringing`,
591
- # `answered`, or `completed`.
592
- # @param [String] timeout Timeout for call when executing a Conference
593
- # instruction.
594
- # @param [Boolean] record Whether to record the participant and their conferences,
595
- # including the time between conferences. The default is `false`.
596
- # @param [Boolean] muted Whether the agent is muted in the conference. The default
597
- # is `false`.
598
- # @param [String] beep Whether to play a notification beep when the participant
599
- # joins or when to play a beep. Can be: `true`, `false`, `onEnter`, or `onExit`.
600
- # The default value is `true`.
601
- # @param [Boolean] start_conference_on_enter Whether to start the conference when
602
- # the participant joins, if it has not already started. The default is `true`. If
603
- # `false` and the conference has not started, the participant is muted and hears
604
- # background music until another participant starts the conference.
605
- # @param [Boolean] end_conference_on_exit Whether to end the conference when the
606
- # agent leaves.
607
- # @param [String] wait_url The URL we should call using the `wait_method` for the
608
- # music to play while participants are waiting for the conference to start. The
609
- # default value is the URL of our standard hold music. {Learn more about hold
610
- # music}[https://www.twilio.com/labs/twimlets/holdmusic].
611
- # @param [String] wait_method The HTTP method we should use to call `wait_url`.
612
- # Can be `GET` or `POST` and the default is `POST`. When using a static audio
613
- # file, this should be `GET` so that we can cache the file.
614
- # @param [Boolean] early_media Whether to allow an agent to hear the state of the
615
- # outbound call, including ringing or disconnect messages. The default is `true`.
616
- # @param [String] max_participants The maximum number of participants in the
617
- # conference. Can be a positive integer from `2` to `250`. The default value is
618
- # `250`.
619
- # @param [String] conference_status_callback The URL we should call using the
620
- # `conference_status_callback_method` when the conference events in
621
- # `conference_status_callback_event` occur. Only the value set by the first
622
- # participant to join the conference is used. Subsequent
623
- # `conference_status_callback` values are ignored.
624
- # @param [String] conference_status_callback_method The HTTP method we should use
625
- # to call `conference_status_callback`. Can be: `GET` or `POST` and defaults to
626
- # `POST`.
627
- # @param [Array[reservation.ConferenceEvent]] conference_status_callback_event The
628
- # conference status events that we will send to `conference_status_callback`. Can
629
- # be: `start`, `end`, `join`, `leave`, `mute`, `hold`, `speaker`.
630
- # @param [String] conference_record Whether to record the conference the
631
- # participant is joining or when to record the conference. Can be: `true`,
632
- # `false`, `record-from-start`, and `do-not-record`. The default value is `false`.
633
- # @param [String] conference_trim How to trim the leading and trailing silence
634
- # from your recorded conference audio files. Can be: `trim-silence` or
635
- # `do-not-trim` and defaults to `trim-silence`.
636
- # @param [String] recording_channels The recording channels for the final
637
- # recording. Can be: `mono` or `dual` and the default is `mono`.
638
- # @param [String] recording_status_callback The URL that we should call using the
639
- # `recording_status_callback_method` when the recording status changes.
640
- # @param [String] recording_status_callback_method The HTTP method we should use
641
- # when we call `recording_status_callback`. Can be: `GET` or `POST` and defaults
642
- # to `POST`.
643
- # @param [String] conference_recording_status_callback The URL we should call
644
- # using the `conference_recording_status_callback_method` when the conference
645
- # recording is available.
646
- # @param [String] conference_recording_status_callback_method The HTTP method we
647
- # should use to call `conference_recording_status_callback`. Can be: `GET` or
648
- # `POST` and defaults to `POST`.
649
- # @param [String] region The
650
- # {region}[https://support.twilio.com/hc/en-us/articles/223132167-How-global-low-latency-routing-and-region-selection-work-for-conferences-and-Client-calls]
651
- # where we should mix the recorded audio. Can be:`us1`, `ie1`, `de1`, `sg1`,
652
- # `br1`, `au1`, or `jp1`.
653
- # @param [String] sip_auth_username The SIP username used for authentication.
654
- # @param [String] sip_auth_password The SIP password for authentication.
655
- # @param [Array[String]] dequeue_status_callback_event The Call progress events
656
- # sent via webhooks as a result of a Dequeue instruction.
657
- # @param [String] post_work_activity_sid The new worker activity SID after
658
- # executing a Conference instruction.
659
- # @param [reservation.SupervisorMode] supervisor_mode The Supervisor mode when
660
- # executing the Supervise instruction.
661
- # @param [String] supervisor The Supervisor SID/URI when executing the Supervise
662
- # instruction.
663
- # @param [Boolean] end_conference_on_customer_exit Whether to end the conference
664
- # when the customer leaves.
665
- # @param [Boolean] beep_on_customer_entrance Whether to play a notification beep
666
- # when the customer joins.
667
- # @param [String] if_match The If-Match HTTP request header
668
- # @return [ReservationInstance] Updated ReservationInstance
669
- def update(reservation_status: :unset, worker_activity_sid: :unset, instruction: :unset, dequeue_post_work_activity_sid: :unset, dequeue_from: :unset, dequeue_record: :unset, dequeue_timeout: :unset, dequeue_to: :unset, dequeue_status_callback_url: :unset, call_from: :unset, call_record: :unset, call_timeout: :unset, call_to: :unset, call_url: :unset, call_status_callback_url: :unset, call_accept: :unset, redirect_call_sid: :unset, redirect_accept: :unset, redirect_url: :unset, to: :unset, from: :unset, status_callback: :unset, status_callback_method: :unset, status_callback_event: :unset, timeout: :unset, record: :unset, muted: :unset, beep: :unset, start_conference_on_enter: :unset, end_conference_on_exit: :unset, wait_url: :unset, wait_method: :unset, early_media: :unset, max_participants: :unset, conference_status_callback: :unset, conference_status_callback_method: :unset, conference_status_callback_event: :unset, conference_record: :unset, conference_trim: :unset, recording_channels: :unset, recording_status_callback: :unset, recording_status_callback_method: :unset, conference_recording_status_callback: :unset, conference_recording_status_callback_method: :unset, region: :unset, sip_auth_username: :unset, sip_auth_password: :unset, dequeue_status_callback_event: :unset, post_work_activity_sid: :unset, supervisor_mode: :unset, supervisor: :unset, end_conference_on_customer_exit: :unset, beep_on_customer_entrance: :unset, if_match: :unset)
670
- context.update(
671
- reservation_status: reservation_status,
672
- worker_activity_sid: worker_activity_sid,
673
- instruction: instruction,
674
- dequeue_post_work_activity_sid: dequeue_post_work_activity_sid,
675
- dequeue_from: dequeue_from,
676
- dequeue_record: dequeue_record,
677
- dequeue_timeout: dequeue_timeout,
678
- dequeue_to: dequeue_to,
679
- dequeue_status_callback_url: dequeue_status_callback_url,
680
- call_from: call_from,
681
- call_record: call_record,
682
- call_timeout: call_timeout,
683
- call_to: call_to,
684
- call_url: call_url,
685
- call_status_callback_url: call_status_callback_url,
686
- call_accept: call_accept,
687
- redirect_call_sid: redirect_call_sid,
688
- redirect_accept: redirect_accept,
689
- redirect_url: redirect_url,
690
- to: to,
691
- from: from,
692
- status_callback: status_callback,
693
- status_callback_method: status_callback_method,
694
- status_callback_event: status_callback_event,
695
- timeout: timeout,
696
- record: record,
697
- muted: muted,
698
- beep: beep,
699
- start_conference_on_enter: start_conference_on_enter,
700
- end_conference_on_exit: end_conference_on_exit,
701
- wait_url: wait_url,
702
- wait_method: wait_method,
703
- early_media: early_media,
704
- max_participants: max_participants,
705
- conference_status_callback: conference_status_callback,
706
- conference_status_callback_method: conference_status_callback_method,
707
- conference_status_callback_event: conference_status_callback_event,
708
- conference_record: conference_record,
709
- conference_trim: conference_trim,
710
- recording_channels: recording_channels,
711
- recording_status_callback: recording_status_callback,
712
- recording_status_callback_method: recording_status_callback_method,
713
- conference_recording_status_callback: conference_recording_status_callback,
714
- conference_recording_status_callback_method: conference_recording_status_callback_method,
715
- region: region,
716
- sip_auth_username: sip_auth_username,
717
- sip_auth_password: sip_auth_password,
718
- dequeue_status_callback_event: dequeue_status_callback_event,
719
- post_work_activity_sid: post_work_activity_sid,
720
- supervisor_mode: supervisor_mode,
721
- supervisor: supervisor,
722
- end_conference_on_customer_exit: end_conference_on_customer_exit,
723
- beep_on_customer_entrance: beep_on_customer_entrance,
724
- if_match: if_match,
725
- )
726
- end
727
-
728
- ##
729
- # Provide a user friendly representation
730
- def to_s
731
- values = @params.map{|k, v| "#{k}: #{v}"}.join(" ")
732
- "<Twilio.Taskrouter.V1.ReservationInstance #{values}>"
733
- end
734
-
735
- ##
736
- # Provide a detailed, user friendly representation
737
- def inspect
738
- values = @properties.map{|k, v| "#{k}: #{v}"}.join(" ")
739
- "<Twilio.Taskrouter.V1.ReservationInstance #{values}>"
740
- end
708
+
709
+ end
710
+ end
741
711
  end
742
- end
743
712
  end
744
- end
745
713
  end
746
- end
747
- end
714
+ end
715
+
716
+