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,743 +1,698 @@
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 WorkerContext < 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 worker is
20
- # contained within.
21
- # @param [String] worker_sid The SID of the reserved Worker resource.
22
- # @return [ReservationList] ReservationList
23
- def initialize(version, workspace_sid: nil, worker_sid: nil)
24
- super(version)
25
-
26
- # Path Solution
27
- @solution = {workspace_sid: workspace_sid, worker_sid: worker_sid}
28
- @uri = "/Workspaces/#{@solution[:workspace_sid]}/Workers/#{@solution[:worker_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 worker with a specified ReservationStatus. Can be: `pending`, `accepted`,
37
- # `rejected`, `timeout`, `canceled`, or `rescinded`.
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 worker with a specified ReservationStatus. Can be: `pending`, `accepted`,
55
- # `rejected`, `timeout`, `canceled`, or `rescinded`.
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 worker with a specified ReservationStatus. Can be: `pending`, `accepted`,
90
- # `rejected`, `timeout`, `canceled`, or `rescinded`.
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 WorkerContext < 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, worker_sid: nil)
29
+ super(version)
30
+ # Path Solution
31
+ @solution = { workspace_sid: workspace_sid, worker_sid: worker_sid }
32
+ @uri = "/Workspaces/#{@solution[:workspace_sid]}/Workers/#{@solution[:worker_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 worker with a specified ReservationStatus. Can be: `pending`, `accepted`, `rejected`, `timeout`, `canceled`, or `rescinded`.
41
+ # @param [Integer] limit Upper limit for the number of records to return. stream()
42
+ # guarantees to never return more than limit. Default is no limit
43
+ # @param [Integer] page_size Number of records to fetch per request, when
44
+ # not set will use the default value of 50 records. If no page_size is defined
45
+ # but a limit is defined, stream() will attempt to read the limit with the most
46
+ # efficient page size, i.e. min(limit, 1000)
47
+ # @return [Array] Array of up to limit results
48
+ def list(reservation_status: :unset, limit: nil, page_size: nil)
49
+ self.stream(
50
+ reservation_status: reservation_status,
51
+ limit: limit,
52
+ page_size: page_size
53
+ ).entries
54
+ end
55
+
56
+ ##
57
+ # Streams Instance records from the API as an Enumerable.
58
+ # This operation lazily loads records as efficiently as possible until the limit
59
+ # is reached.
60
+ # @param [Status] reservation_status Returns the list of reservations for a worker with a specified ReservationStatus. Can be: `pending`, `accepted`, `rejected`, `timeout`, `canceled`, or `rescinded`.
61
+ # @param [Integer] limit Upper limit for the number of records to return. stream()
62
+ # guarantees to never return more than limit. Default is no limit
63
+ # @param [Integer] page_size Number of records to fetch per request, when
64
+ # not set will use the default value of 50 records. If no page_size is defined
65
+ # but a limit is defined, stream() will attempt to read the limit with the most
66
+ # efficient page size, i.e. min(limit, 1000)
67
+ # @return [Enumerable] Enumerable that will yield up to limit results
68
+ def stream(reservation_status: :unset, limit: nil, page_size: nil)
69
+ limits = @version.read_limits(limit, page_size)
70
+
71
+ page = self.page(
72
+ reservation_status: reservation_status,
73
+ page_size: limits[:page_size], )
74
+
75
+ @version.stream(page, limit: limits[:limit], page_limit: limits[:page_limit])
76
+ end
77
+
78
+ ##
79
+ # When passed a block, yields ReservationInstance records from the API.
80
+ # This operation lazily loads records as efficiently as possible until the limit
81
+ # is reached.
82
+ def each
83
+ limits = @version.read_limits
84
+
85
+ page = self.page(page_size: limits[:page_size], )
86
+
87
+ @version.stream(page,
88
+ limit: limits[:limit],
89
+ page_limit: limits[:page_limit]).each {|x| yield x}
90
+ end
91
+
92
+ ##
93
+ # Retrieve a single page of ReservationInstance records from the API.
94
+ # Request is executed immediately.
95
+ # @param [Status] reservation_status Returns the list of reservations for a worker with a specified ReservationStatus. Can be: `pending`, `accepted`, `rejected`, `timeout`, `canceled`, or `rescinded`.
96
+ # @param [String] page_token PageToken provided by the API
97
+ # @param [Integer] page_number Page Number, this value is simply for client state
98
+ # @param [Integer] page_size Number of records to return, defaults to 50
99
+ # @return [Page] Page of ReservationInstance
100
+ def page(reservation_status: :unset, page_token: :unset, page_number: :unset, page_size: :unset)
101
+ params = Twilio::Values.of({
102
+ 'ReservationStatus' => reservation_status,
103
+ 'PageToken' => page_token,
104
+ 'Page' => page_number,
105
+ 'PageSize' => page_size,
106
+ })
107
+
108
+ response = @version.page('GET', @uri, params: params)
109
+
110
+ ReservationPage.new(@version, response, @solution)
111
+ end
112
+
113
+ ##
114
+ # Retrieve a single page of ReservationInstance records from the API.
115
+ # Request is executed immediately.
116
+ # @param [String] target_url API-generated URL for the requested results page
117
+ # @return [Page] Page of ReservationInstance
118
+ def get_page(target_url)
119
+ response = @version.domain.request(
120
+ 'GET',
121
+ target_url
122
+ )
123
+ ReservationPage.new(@version, response, @solution)
124
+ end
125
+
126
+
127
+
128
+ # Provide a user friendly representation
129
+ def to_s
130
+ '#<Twilio.Taskrouter.V1.ReservationList>'
131
+ end
132
+ end
127
133
 
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
- worker_sid: @solution[:worker_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
134
 
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
167
- # WorkerReservation resource to fetch.
168
- # @param [String] worker_sid The SID of the reserved Worker resource with the
169
- # WorkerReservation resource to fetch.
170
- # @param [String] sid The SID of the WorkerReservation resource to fetch.
171
- # @return [ReservationContext] ReservationContext
172
- def initialize(version, workspace_sid, worker_sid, sid)
173
- super(version)
174
-
175
- # Path Solution
176
- @solution = {workspace_sid: workspace_sid, worker_sid: worker_sid, sid: sid, }
177
- @uri = "/Workspaces/#{@solution[:workspace_sid]}/Workers/#{@solution[:worker_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
- worker_sid: @solution[:worker_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`, `timeout`, `canceled`,
199
- # or `rescinded`.
200
- # @param [String] worker_activity_sid The new worker activity SID if rejecting a
201
- # reservation.
202
- # @param [String] instruction The assignment instruction for the reservation.
203
- # @param [String] dequeue_post_work_activity_sid The SID of the Activity resource
204
- # to start after executing a Dequeue instruction.
205
- # @param [String] dequeue_from The caller ID of the call to the worker when
206
- # executing a Dequeue instruction.
207
- # @param [String] dequeue_record Whether to record both legs of a call when
208
- # executing a Dequeue instruction or which leg to record.
209
- # @param [String] dequeue_timeout The timeout for call when executing a Dequeue
210
- # instruction.
211
- # @param [String] dequeue_to The contact URI of the worker when executing a
212
- # Dequeue instruction. Can be the URI of the Twilio Client, the SIP URI for
213
- # Programmable SIP, or the {E.164}[https://www.twilio.com/docs/glossary/what-e164]
214
- # formatted phone number, depending on the destination.
215
- # @param [String] dequeue_status_callback_url The callback URL for completed call
216
- # event when executing a Dequeue instruction.
217
- # @param [String] call_from The Caller ID of the outbound call when executing a
218
- # Call instruction.
219
- # @param [String] call_record Whether to record both legs of a call when executing
220
- # a Call instruction.
221
- # @param [String] call_timeout The timeout for a call when executing a Call
222
- # instruction.
223
- # @param [String] call_to The contact URI of the worker when executing a Call
224
- # instruction. Can be the URI of the Twilio Client, the SIP URI for Programmable
225
- # SIP, or the {E.164}[https://www.twilio.com/docs/glossary/what-e164] formatted
226
- # phone number, depending on the destination.
227
- # @param [String] call_url TwiML URI executed on answering the worker's leg as a
228
- # result of the Call instruction.
229
- # @param [String] call_status_callback_url The URL to call for the completed call
230
- # event when executing a Call instruction.
231
- # @param [Boolean] call_accept Whether to accept a reservation when executing a
232
- # Call instruction.
233
- # @param [String] redirect_call_sid The Call SID of the call parked in the queue
234
- # when executing a Redirect instruction.
235
- # @param [Boolean] redirect_accept Whether the reservation should be accepted when
236
- # executing a Redirect instruction.
237
- # @param [String] redirect_url TwiML URI to redirect the call to when executing
238
- # the Redirect instruction.
239
- # @param [String] to The Contact URI of the worker when executing a Conference
240
- # instruction. Can be the URI of the Twilio Client, the SIP URI for Programmable
241
- # SIP, or the {E.164}[https://www.twilio.com/docs/glossary/what-e164] formatted
242
- # phone number, depending on the destination.
243
- # @param [String] from The caller ID of the call to the worker when executing a
244
- # Conference instruction.
245
- # @param [String] status_callback The URL we should call using the
246
- # `status_callback_method` to send status information to your application.
247
- # @param [String] status_callback_method The HTTP method we should use to call
248
- # `status_callback`. Can be: `POST` or `GET` and the default is `POST`.
249
- # @param [Array[reservation.CallStatus]] status_callback_event The call progress
250
- # events that we will send to `status_callback`. Can be: `initiated`, `ringing`,
251
- # `answered`, or `completed`.
252
- # @param [String] timeout The timeout for a call when executing a Conference
253
- # instruction.
254
- # @param [Boolean] record Whether to record the participant and their conferences,
255
- # including the time between conferences. Can be `true` or `false` and the default
256
- # is `false`.
257
- # @param [Boolean] muted Whether the agent is muted in the conference. Defaults to
258
- # `false`.
259
- # @param [String] beep Whether to play a notification beep when the participant
260
- # joins or when to play a beep. Can be: `true`, `false`, `onEnter`, or `onExit`.
261
- # The default value is `true`.
262
- # @param [Boolean] start_conference_on_enter Whether to start the conference when
263
- # the participant joins, if it has not already started. Can be: `true` or `false`
264
- # and the default is `true`. If `false` and the conference has not started, the
265
- # participant is muted and hears background music until another participant starts
266
- # the conference.
267
- # @param [Boolean] end_conference_on_exit Whether to end the conference when the
268
- # agent leaves.
269
- # @param [String] wait_url The URL we should call using the `wait_method` for the
270
- # music to play while participants are waiting for the conference to start. The
271
- # default value is the URL of our standard hold music. {Learn more about hold
272
- # music}[https://www.twilio.com/labs/twimlets/holdmusic].
273
- # @param [String] wait_method The HTTP method we should use to call `wait_url`.
274
- # Can be `GET` or `POST` and the default is `POST`. When using a static audio
275
- # file, this should be `GET` so that we can cache the file.
276
- # @param [Boolean] early_media Whether to allow an agent to hear the state of the
277
- # outbound call, including ringing or disconnect messages. The default is `true`.
278
- # @param [String] max_participants The maximum number of participants allowed in
279
- # the conference. Can be a positive integer from `2` to `250`. The default value
280
- # is `250`.
281
- # @param [String] conference_status_callback The URL we should call using the
282
- # `conference_status_callback_method` when the conference events in
283
- # `conference_status_callback_event` occur. Only the value set by the first
284
- # participant to join the conference is used. Subsequent
285
- # `conference_status_callback` values are ignored.
286
- # @param [String] conference_status_callback_method The HTTP method we should use
287
- # to call `conference_status_callback`. Can be: `GET` or `POST` and defaults to
288
- # `POST`.
289
- # @param [Array[reservation.ConferenceEvent]] conference_status_callback_event The
290
- # conference status events that we will send to `conference_status_callback`. Can
291
- # be: `start`, `end`, `join`, `leave`, `mute`, `hold`, `speaker`.
292
- # @param [String] conference_record Whether to record the conference the
293
- # participant is joining or when to record the conference. Can be: `true`,
294
- # `false`, `record-from-start`, and `do-not-record`. The default value is `false`.
295
- # @param [String] conference_trim Whether to trim leading and trailing silence
296
- # from your recorded conference audio files. Can be: `trim-silence` or
297
- # `do-not-trim` and defaults to `trim-silence`.
298
- # @param [String] recording_channels The recording channels for the final
299
- # recording. Can be: `mono` or `dual` and the default is `mono`.
300
- # @param [String] recording_status_callback The URL that we should call using the
301
- # `recording_status_callback_method` when the recording status changes.
302
- # @param [String] recording_status_callback_method The HTTP method we should use
303
- # when we call `recording_status_callback`. Can be: `GET` or `POST` and defaults
304
- # to `POST`.
305
- # @param [String] conference_recording_status_callback The URL we should call
306
- # using the `conference_recording_status_callback_method` when the conference
307
- # recording is available.
308
- # @param [String] conference_recording_status_callback_method The HTTP method we
309
- # should use to call `conference_recording_status_callback`. Can be: `GET` or
310
- # `POST` and defaults to `POST`.
311
- # @param [String] region The
312
- # {region}[https://support.twilio.com/hc/en-us/articles/223132167-How-global-low-latency-routing-and-region-selection-work-for-conferences-and-Client-calls]
313
- # where we should mix the recorded audio. Can be:`us1`, `ie1`, `de1`, `sg1`,
314
- # `br1`, `au1`, or `jp1`.
315
- # @param [String] sip_auth_username The SIP username used for authentication.
316
- # @param [String] sip_auth_password The SIP password for authentication.
317
- # @param [Array[String]] dequeue_status_callback_event The call progress events
318
- # sent via webhooks as a result of a Dequeue instruction.
319
- # @param [String] post_work_activity_sid The new worker activity SID after
320
- # executing a Conference 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, 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
- 'EndConferenceOnCustomerExit' => end_conference_on_customer_exit,
379
- 'BeepOnCustomerEntrance' => beep_on_customer_entrance,
380
- })
381
- headers = Twilio::Values.of({'If-Match' => if_match, })
382
-
383
- payload = @version.update('POST', @uri, data: data, headers: headers)
384
-
385
- ReservationInstance.new(
386
- @version,
387
- payload,
388
- workspace_sid: @solution[:workspace_sid],
389
- worker_sid: @solution[:worker_sid],
390
- sid: @solution[:sid],
391
- )
392
- end
393
-
394
- ##
395
- # Provide a user friendly representation
396
- def to_s
397
- context = @solution.map {|k, v| "#{k}: #{v}"}.join(',')
398
- "#<Twilio.Taskrouter.V1.ReservationContext #{context}>"
399
- end
400
-
401
- ##
402
- # Provide a detailed, user friendly representation
403
- def inspect
404
- context = @solution.map {|k, v| "#{k}: #{v}"}.join(',')
405
- "#<Twilio.Taskrouter.V1.ReservationContext #{context}>"
406
- end
407
- end
135
+ class ReservationContext < InstanceContext
136
+ ##
137
+ # Initialize the ReservationContext
138
+ # @param [Version] version Version that contains the resource
139
+ # @param [String] workspace_sid The SID of the Workspace with the WorkerReservation resources to update.
140
+ # @param [String] worker_sid The SID of the reserved Worker resource with the WorkerReservation resources to update.
141
+ # @param [String] sid The SID of the WorkerReservation resource to update.
142
+ # @return [ReservationContext] ReservationContext
143
+ def initialize(version, workspace_sid, worker_sid, sid)
144
+ super(version)
145
+
146
+ # Path Solution
147
+ @solution = { workspace_sid: workspace_sid, worker_sid: worker_sid, sid: sid, }
148
+ @uri = "/Workspaces/#{@solution[:workspace_sid]}/Workers/#{@solution[:worker_sid]}/Reservations/#{@solution[:sid]}"
149
+
150
+
151
+ end
152
+ ##
153
+ # Fetch the ReservationInstance
154
+ # @return [ReservationInstance] Fetched ReservationInstance
155
+ def fetch
156
+
157
+ payload = @version.fetch('GET', @uri)
158
+ ReservationInstance.new(
159
+ @version,
160
+ payload,
161
+ workspace_sid: @solution[:workspace_sid],
162
+ worker_sid: @solution[:worker_sid],
163
+ sid: @solution[:sid],
164
+ )
165
+ end
166
+
167
+ ##
168
+ # Update the ReservationInstance
169
+ # @param [Status] reservation_status
170
+ # @param [String] worker_activity_sid The new worker activity SID if rejecting a reservation.
171
+ # @param [String] instruction The assignment instruction for the reservation.
172
+ # @param [String] dequeue_post_work_activity_sid The SID of the Activity resource to start after executing a Dequeue instruction.
173
+ # @param [String] dequeue_from The caller ID of the call to the worker when executing a Dequeue instruction.
174
+ # @param [String] dequeue_record Whether to record both legs of a call when executing a Dequeue instruction or which leg to record.
175
+ # @param [String] dequeue_timeout The timeout for call when executing a Dequeue instruction.
176
+ # @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.
177
+ # @param [String] dequeue_status_callback_url The callback URL for completed call event when executing a Dequeue instruction.
178
+ # @param [String] call_from The Caller ID of the outbound call when executing a Call instruction.
179
+ # @param [String] call_record Whether to record both legs of a call when executing a Call instruction.
180
+ # @param [String] call_timeout The timeout for a call when executing a Call instruction.
181
+ # @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.
182
+ # @param [String] call_url TwiML URI executed on answering the worker's leg as a result of the Call instruction.
183
+ # @param [String] call_status_callback_url The URL to call for the completed call event when executing a Call instruction.
184
+ # @param [Boolean] call_accept Whether to accept a reservation when executing a Call instruction.
185
+ # @param [String] redirect_call_sid The Call SID of the call parked in the queue when executing a Redirect instruction.
186
+ # @param [Boolean] redirect_accept Whether the reservation should be accepted when executing a Redirect instruction.
187
+ # @param [String] redirect_url TwiML URI to redirect the call to when executing the Redirect instruction.
188
+ # @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.
189
+ # @param [String] from The caller ID of the call to the worker when executing a Conference instruction.
190
+ # @param [String] status_callback The URL we should call using the `status_callback_method` to send status information to your application.
191
+ # @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`.
192
+ # @param [Array[CallStatus]] status_callback_event The call progress events that we will send to `status_callback`. Can be: `initiated`, `ringing`, `answered`, or `completed`.
193
+ # @param [String] timeout The timeout for a call when executing a Conference instruction.
194
+ # @param [Boolean] record Whether to record the participant and their conferences, including the time between conferences. Can be `true` or `false` and the default is `false`.
195
+ # @param [Boolean] muted Whether the agent is muted in the conference. Defaults to `false`.
196
+ # @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`.
197
+ # @param [Boolean] start_conference_on_enter Whether to start the conference when the participant joins, if it has not already started. Can be: `true` or `false` and the default is `true`. If `false` and the conference has not started, the participant is muted and hears background music until another participant starts the conference.
198
+ # @param [Boolean] end_conference_on_exit Whether to end the conference when the agent leaves.
199
+ # @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).
200
+ # @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.
201
+ # @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`.
202
+ # @param [String] max_participants The maximum number of participants allowed in the conference. Can be a positive integer from `2` to `250`. The default value is `250`.
203
+ # @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.
204
+ # @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`.
205
+ # @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`.
206
+ # @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`.
207
+ # @param [String] conference_trim Whether to trim leading and trailing silence from your recorded conference audio files. Can be: `trim-silence` or `do-not-trim` and defaults to `trim-silence`.
208
+ # @param [String] recording_channels The recording channels for the final recording. Can be: `mono` or `dual` and the default is `mono`.
209
+ # @param [String] recording_status_callback The URL that we should call using the `recording_status_callback_method` when the recording status changes.
210
+ # @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`.
211
+ # @param [String] conference_recording_status_callback The URL we should call using the `conference_recording_status_callback_method` when the conference recording is available.
212
+ # @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`.
213
+ # @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`.
214
+ # @param [String] sip_auth_username The SIP username used for authentication.
215
+ # @param [String] sip_auth_password The SIP password for authentication.
216
+ # @param [Array[String]] dequeue_status_callback_event The call progress events sent via webhooks as a result of a Dequeue instruction.
217
+ # @param [String] post_work_activity_sid The new worker activity SID after executing a Conference instruction.
218
+ # @param [Boolean] end_conference_on_customer_exit Whether to end the conference when the customer leaves.
219
+ # @param [Boolean] beep_on_customer_entrance Whether to play a notification beep when the customer joins.
220
+ # @param [String] jitter_buffer_size The jitter buffer size for conference. Can be: `small`, `medium`, `large`, `off`.
221
+ # @param [String] if_match The If-Match HTTP request header
222
+ # @return [ReservationInstance] Updated ReservationInstance
223
+ def update(
224
+ reservation_status: :unset,
225
+ worker_activity_sid: :unset,
226
+ instruction: :unset,
227
+ dequeue_post_work_activity_sid: :unset,
228
+ dequeue_from: :unset,
229
+ dequeue_record: :unset,
230
+ dequeue_timeout: :unset,
231
+ dequeue_to: :unset,
232
+ dequeue_status_callback_url: :unset,
233
+ call_from: :unset,
234
+ call_record: :unset,
235
+ call_timeout: :unset,
236
+ call_to: :unset,
237
+ call_url: :unset,
238
+ call_status_callback_url: :unset,
239
+ call_accept: :unset,
240
+ redirect_call_sid: :unset,
241
+ redirect_accept: :unset,
242
+ redirect_url: :unset,
243
+ to: :unset,
244
+ from: :unset,
245
+ status_callback: :unset,
246
+ status_callback_method: :unset,
247
+ status_callback_event: :unset,
248
+ timeout: :unset,
249
+ record: :unset,
250
+ muted: :unset,
251
+ beep: :unset,
252
+ start_conference_on_enter: :unset,
253
+ end_conference_on_exit: :unset,
254
+ wait_url: :unset,
255
+ wait_method: :unset,
256
+ early_media: :unset,
257
+ max_participants: :unset,
258
+ conference_status_callback: :unset,
259
+ conference_status_callback_method: :unset,
260
+ conference_status_callback_event: :unset,
261
+ conference_record: :unset,
262
+ conference_trim: :unset,
263
+ recording_channels: :unset,
264
+ recording_status_callback: :unset,
265
+ recording_status_callback_method: :unset,
266
+ conference_recording_status_callback: :unset,
267
+ conference_recording_status_callback_method: :unset,
268
+ region: :unset,
269
+ sip_auth_username: :unset,
270
+ sip_auth_password: :unset,
271
+ dequeue_status_callback_event: :unset,
272
+ post_work_activity_sid: :unset,
273
+ end_conference_on_customer_exit: :unset,
274
+ beep_on_customer_entrance: :unset,
275
+ jitter_buffer_size: :unset,
276
+ if_match: :unset
277
+ )
278
+
279
+ data = Twilio::Values.of({
280
+ 'ReservationStatus' => reservation_status,
281
+ 'WorkerActivitySid' => worker_activity_sid,
282
+ 'Instruction' => instruction,
283
+ 'DequeuePostWorkActivitySid' => dequeue_post_work_activity_sid,
284
+ 'DequeueFrom' => dequeue_from,
285
+ 'DequeueRecord' => dequeue_record,
286
+ 'DequeueTimeout' => dequeue_timeout,
287
+ 'DequeueTo' => dequeue_to,
288
+ 'DequeueStatusCallbackUrl' => dequeue_status_callback_url,
289
+ 'CallFrom' => call_from,
290
+ 'CallRecord' => call_record,
291
+ 'CallTimeout' => call_timeout,
292
+ 'CallTo' => call_to,
293
+ 'CallUrl' => call_url,
294
+ 'CallStatusCallbackUrl' => call_status_callback_url,
295
+ 'CallAccept' => call_accept,
296
+ 'RedirectCallSid' => redirect_call_sid,
297
+ 'RedirectAccept' => redirect_accept,
298
+ 'RedirectUrl' => redirect_url,
299
+ 'To' => to,
300
+ 'From' => from,
301
+ 'StatusCallback' => status_callback,
302
+ 'StatusCallbackMethod' => status_callback_method,
303
+ 'StatusCallbackEvent' => Twilio.serialize_list(status_callback_event) { |e| e },
304
+ 'Timeout' => timeout,
305
+ 'Record' => record,
306
+ 'Muted' => muted,
307
+ 'Beep' => beep,
308
+ 'StartConferenceOnEnter' => start_conference_on_enter,
309
+ 'EndConferenceOnExit' => end_conference_on_exit,
310
+ 'WaitUrl' => wait_url,
311
+ 'WaitMethod' => wait_method,
312
+ 'EarlyMedia' => early_media,
313
+ 'MaxParticipants' => max_participants,
314
+ 'ConferenceStatusCallback' => conference_status_callback,
315
+ 'ConferenceStatusCallbackMethod' => conference_status_callback_method,
316
+ 'ConferenceStatusCallbackEvent' => Twilio.serialize_list(conference_status_callback_event) { |e| e },
317
+ 'ConferenceRecord' => conference_record,
318
+ 'ConferenceTrim' => conference_trim,
319
+ 'RecordingChannels' => recording_channels,
320
+ 'RecordingStatusCallback' => recording_status_callback,
321
+ 'RecordingStatusCallbackMethod' => recording_status_callback_method,
322
+ 'ConferenceRecordingStatusCallback' => conference_recording_status_callback,
323
+ 'ConferenceRecordingStatusCallbackMethod' => conference_recording_status_callback_method,
324
+ 'Region' => region,
325
+ 'SipAuthUsername' => sip_auth_username,
326
+ 'SipAuthPassword' => sip_auth_password,
327
+ 'DequeueStatusCallbackEvent' => Twilio.serialize_list(dequeue_status_callback_event) { |e| e },
328
+ 'PostWorkActivitySid' => post_work_activity_sid,
329
+ 'EndConferenceOnCustomerExit' => end_conference_on_customer_exit,
330
+ 'BeepOnCustomerEntrance' => beep_on_customer_entrance,
331
+ 'JitterBufferSize' => jitter_buffer_size,
332
+ })
333
+
334
+ headers = Twilio::Values.of({ 'If-Match' => if_match, })
335
+ payload = @version.update('POST', @uri, data: data, headers: headers)
336
+ ReservationInstance.new(
337
+ @version,
338
+ payload,
339
+ workspace_sid: @solution[:workspace_sid],
340
+ worker_sid: @solution[:worker_sid],
341
+ sid: @solution[:sid],
342
+ )
343
+ end
344
+
345
+
346
+ ##
347
+ # Provide a user friendly representation
348
+ def to_s
349
+ context = @solution.map{|k, v| "#{k}: #{v}"}.join(',')
350
+ "#<Twilio.Taskrouter.V1.ReservationContext #{context}>"
351
+ end
352
+
353
+ ##
354
+ # Provide a detailed, user friendly representation
355
+ def inspect
356
+ context = @solution.map{|k, v| "#{k}: #{v}"}.join(',')
357
+ "#<Twilio.Taskrouter.V1.ReservationContext #{context}>"
358
+ end
359
+ end
408
360
 
409
- class ReservationInstance < InstanceResource
410
- ##
411
- # Initialize the ReservationInstance
412
- # @param [Version] version Version that contains the resource
413
- # @param [Hash] payload payload that contains response from Twilio
414
- # @param [String] workspace_sid The SID of the Workspace that this worker is
415
- # contained within.
416
- # @param [String] worker_sid The SID of the reserved Worker resource.
417
- # @param [String] sid The SID of the WorkerReservation resource to fetch.
418
- # @return [ReservationInstance] ReservationInstance
419
- def initialize(version, payload, workspace_sid: nil, worker_sid: nil, sid: nil)
420
- super(version)
421
-
422
- # Marshaled Properties
423
- @properties = {
424
- 'account_sid' => payload['account_sid'],
425
- 'date_created' => Twilio.deserialize_iso8601_datetime(payload['date_created']),
426
- 'date_updated' => Twilio.deserialize_iso8601_datetime(payload['date_updated']),
427
- 'reservation_status' => payload['reservation_status'],
428
- 'sid' => payload['sid'],
429
- 'task_sid' => payload['task_sid'],
430
- 'worker_name' => payload['worker_name'],
431
- 'worker_sid' => payload['worker_sid'],
432
- 'workspace_sid' => payload['workspace_sid'],
433
- 'url' => payload['url'],
434
- 'links' => payload['links'],
435
- }
436
-
437
- # Context
438
- @instance_context = nil
439
- @params = {
440
- 'workspace_sid' => workspace_sid,
441
- 'worker_sid' => worker_sid,
442
- 'sid' => sid || @properties['sid'],
443
- }
444
- end
445
-
446
- ##
447
- # Generate an instance context for the instance, the context is capable of
448
- # performing various actions. All instance actions are proxied to the context
449
- # @return [ReservationContext] ReservationContext for this ReservationInstance
450
- def context
451
- unless @instance_context
452
- @instance_context = ReservationContext.new(
453
- @version,
454
- @params['workspace_sid'],
455
- @params['worker_sid'],
456
- @params['sid'],
457
- )
361
+ class ReservationPage < Page
362
+ ##
363
+ # Initialize the ReservationPage
364
+ # @param [Version] version Version that contains the resource
365
+ # @param [Response] response Response from the API
366
+ # @param [Hash] solution Path solution for the resource
367
+ # @return [ReservationPage] ReservationPage
368
+ def initialize(version, response, solution)
369
+ super(version, response)
370
+
371
+ # Path Solution
372
+ @solution = solution
373
+ end
374
+
375
+ ##
376
+ # Build an instance of ReservationInstance
377
+ # @param [Hash] payload Payload response from the API
378
+ # @return [ReservationInstance] ReservationInstance
379
+ def get_instance(payload)
380
+ ReservationInstance.new(@version, payload, workspace_sid: @solution[:workspace_sid], worker_sid: @solution[:worker_sid])
381
+ end
382
+
383
+ ##
384
+ # Provide a user friendly representation
385
+ def to_s
386
+ '<Twilio.Taskrouter.V1.ReservationPage>'
387
+ end
388
+ end
389
+ class ReservationInstance < InstanceResource
390
+ ##
391
+ # Initialize the ReservationInstance
392
+ # @param [Version] version Version that contains the resource
393
+ # @param [Hash] payload payload that contains response from Twilio
394
+ # @param [String] account_sid The SID of the
395
+ # {Account}[https://www.twilio.com/docs/iam/api/account] that created this Reservation
396
+ # resource.
397
+ # @param [String] sid The SID of the Call resource to fetch.
398
+ # @return [ReservationInstance] ReservationInstance
399
+ def initialize(version, payload , workspace_sid: nil, worker_sid: nil, sid: nil)
400
+ super(version)
401
+
402
+ # Marshaled Properties
403
+ @properties = {
404
+ 'account_sid' => payload['account_sid'],
405
+ 'date_created' => Twilio.deserialize_iso8601_datetime(payload['date_created']),
406
+ 'date_updated' => Twilio.deserialize_iso8601_datetime(payload['date_updated']),
407
+ 'reservation_status' => payload['reservation_status'],
408
+ 'sid' => payload['sid'],
409
+ 'task_sid' => payload['task_sid'],
410
+ 'worker_name' => payload['worker_name'],
411
+ 'worker_sid' => payload['worker_sid'],
412
+ 'workspace_sid' => payload['workspace_sid'],
413
+ 'url' => payload['url'],
414
+ 'links' => payload['links'],
415
+ }
416
+
417
+ # Context
418
+ @instance_context = nil
419
+ @params = { 'workspace_sid' => workspace_sid || @properties['workspace_sid'] ,'worker_sid' => worker_sid || @properties['worker_sid'] ,'sid' => sid || @properties['sid'] , }
420
+ end
421
+
422
+ ##
423
+ # Generate an instance context for the instance, the context is capable of
424
+ # performing various actions. All instance actions are proxied to the context
425
+ # @return [ReservationContext] CallContext for this CallInstance
426
+ def context
427
+ unless @instance_context
428
+ @instance_context = ReservationContext.new(@version , @params['workspace_sid'], @params['worker_sid'], @params['sid'])
429
+ end
430
+ @instance_context
431
+ end
432
+
433
+ ##
434
+ # @return [String] The SID of the [Account](https://www.twilio.com/docs/iam/api/account) that created the WorkerReservation resource.
435
+ def account_sid
436
+ @properties['account_sid']
437
+ end
438
+
439
+ ##
440
+ # @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.
441
+ def date_created
442
+ @properties['date_created']
443
+ end
444
+
445
+ ##
446
+ # @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.
447
+ def date_updated
448
+ @properties['date_updated']
449
+ end
450
+
451
+ ##
452
+ # @return [Status]
453
+ def reservation_status
454
+ @properties['reservation_status']
455
+ end
456
+
457
+ ##
458
+ # @return [String] The unique string that we created to identify the WorkerReservation resource.
459
+ def sid
460
+ @properties['sid']
461
+ end
462
+
463
+ ##
464
+ # @return [String] The SID of the reserved Task resource.
465
+ def task_sid
466
+ @properties['task_sid']
467
+ end
468
+
469
+ ##
470
+ # @return [String] The `friendly_name` of the Worker that is reserved.
471
+ def worker_name
472
+ @properties['worker_name']
473
+ end
474
+
475
+ ##
476
+ # @return [String] The SID of the reserved Worker resource.
477
+ def worker_sid
478
+ @properties['worker_sid']
479
+ end
480
+
481
+ ##
482
+ # @return [String] The SID of the Workspace that this worker is contained within.
483
+ def workspace_sid
484
+ @properties['workspace_sid']
485
+ end
486
+
487
+ ##
488
+ # @return [String] The absolute URL of the WorkerReservation resource.
489
+ def url
490
+ @properties['url']
491
+ end
492
+
493
+ ##
494
+ # @return [Hash] The URLs of related resources.
495
+ def links
496
+ @properties['links']
497
+ end
498
+
499
+ ##
500
+ # Fetch the ReservationInstance
501
+ # @return [ReservationInstance] Fetched ReservationInstance
502
+ def fetch
503
+
504
+ context.fetch
505
+ end
506
+
507
+ ##
508
+ # Update the ReservationInstance
509
+ # @param [Status] reservation_status
510
+ # @param [String] worker_activity_sid The new worker activity SID if rejecting a reservation.
511
+ # @param [String] instruction The assignment instruction for the reservation.
512
+ # @param [String] dequeue_post_work_activity_sid The SID of the Activity resource to start after executing a Dequeue instruction.
513
+ # @param [String] dequeue_from The caller ID of the call to the worker when executing a Dequeue instruction.
514
+ # @param [String] dequeue_record Whether to record both legs of a call when executing a Dequeue instruction or which leg to record.
515
+ # @param [String] dequeue_timeout The timeout for call when executing a Dequeue instruction.
516
+ # @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.
517
+ # @param [String] dequeue_status_callback_url The callback URL for completed call event when executing a Dequeue instruction.
518
+ # @param [String] call_from The Caller ID of the outbound call when executing a Call instruction.
519
+ # @param [String] call_record Whether to record both legs of a call when executing a Call instruction.
520
+ # @param [String] call_timeout The timeout for a call when executing a Call instruction.
521
+ # @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.
522
+ # @param [String] call_url TwiML URI executed on answering the worker's leg as a result of the Call instruction.
523
+ # @param [String] call_status_callback_url The URL to call for the completed call event when executing a Call instruction.
524
+ # @param [Boolean] call_accept Whether to accept a reservation when executing a Call instruction.
525
+ # @param [String] redirect_call_sid The Call SID of the call parked in the queue when executing a Redirect instruction.
526
+ # @param [Boolean] redirect_accept Whether the reservation should be accepted when executing a Redirect instruction.
527
+ # @param [String] redirect_url TwiML URI to redirect the call to when executing the Redirect instruction.
528
+ # @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.
529
+ # @param [String] from The caller ID of the call to the worker when executing a Conference instruction.
530
+ # @param [String] status_callback The URL we should call using the `status_callback_method` to send status information to your application.
531
+ # @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`.
532
+ # @param [Array[CallStatus]] status_callback_event The call progress events that we will send to `status_callback`. Can be: `initiated`, `ringing`, `answered`, or `completed`.
533
+ # @param [String] timeout The timeout for a call when executing a Conference instruction.
534
+ # @param [Boolean] record Whether to record the participant and their conferences, including the time between conferences. Can be `true` or `false` and the default is `false`.
535
+ # @param [Boolean] muted Whether the agent is muted in the conference. Defaults to `false`.
536
+ # @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`.
537
+ # @param [Boolean] start_conference_on_enter Whether to start the conference when the participant joins, if it has not already started. Can be: `true` or `false` and the default is `true`. If `false` and the conference has not started, the participant is muted and hears background music until another participant starts the conference.
538
+ # @param [Boolean] end_conference_on_exit Whether to end the conference when the agent leaves.
539
+ # @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).
540
+ # @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.
541
+ # @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`.
542
+ # @param [String] max_participants The maximum number of participants allowed in the conference. Can be a positive integer from `2` to `250`. The default value is `250`.
543
+ # @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.
544
+ # @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`.
545
+ # @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`.
546
+ # @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`.
547
+ # @param [String] conference_trim Whether to trim leading and trailing silence from your recorded conference audio files. Can be: `trim-silence` or `do-not-trim` and defaults to `trim-silence`.
548
+ # @param [String] recording_channels The recording channels for the final recording. Can be: `mono` or `dual` and the default is `mono`.
549
+ # @param [String] recording_status_callback The URL that we should call using the `recording_status_callback_method` when the recording status changes.
550
+ # @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`.
551
+ # @param [String] conference_recording_status_callback The URL we should call using the `conference_recording_status_callback_method` when the conference recording is available.
552
+ # @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`.
553
+ # @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`.
554
+ # @param [String] sip_auth_username The SIP username used for authentication.
555
+ # @param [String] sip_auth_password The SIP password for authentication.
556
+ # @param [Array[String]] dequeue_status_callback_event The call progress events sent via webhooks as a result of a Dequeue instruction.
557
+ # @param [String] post_work_activity_sid The new worker activity SID after executing a Conference instruction.
558
+ # @param [Boolean] end_conference_on_customer_exit Whether to end the conference when the customer leaves.
559
+ # @param [Boolean] beep_on_customer_entrance Whether to play a notification beep when the customer joins.
560
+ # @param [String] jitter_buffer_size The jitter buffer size for conference. Can be: `small`, `medium`, `large`, `off`.
561
+ # @param [String] if_match The If-Match HTTP request header
562
+ # @return [ReservationInstance] Updated ReservationInstance
563
+ def update(
564
+ reservation_status: :unset,
565
+ worker_activity_sid: :unset,
566
+ instruction: :unset,
567
+ dequeue_post_work_activity_sid: :unset,
568
+ dequeue_from: :unset,
569
+ dequeue_record: :unset,
570
+ dequeue_timeout: :unset,
571
+ dequeue_to: :unset,
572
+ dequeue_status_callback_url: :unset,
573
+ call_from: :unset,
574
+ call_record: :unset,
575
+ call_timeout: :unset,
576
+ call_to: :unset,
577
+ call_url: :unset,
578
+ call_status_callback_url: :unset,
579
+ call_accept: :unset,
580
+ redirect_call_sid: :unset,
581
+ redirect_accept: :unset,
582
+ redirect_url: :unset,
583
+ to: :unset,
584
+ from: :unset,
585
+ status_callback: :unset,
586
+ status_callback_method: :unset,
587
+ status_callback_event: :unset,
588
+ timeout: :unset,
589
+ record: :unset,
590
+ muted: :unset,
591
+ beep: :unset,
592
+ start_conference_on_enter: :unset,
593
+ end_conference_on_exit: :unset,
594
+ wait_url: :unset,
595
+ wait_method: :unset,
596
+ early_media: :unset,
597
+ max_participants: :unset,
598
+ conference_status_callback: :unset,
599
+ conference_status_callback_method: :unset,
600
+ conference_status_callback_event: :unset,
601
+ conference_record: :unset,
602
+ conference_trim: :unset,
603
+ recording_channels: :unset,
604
+ recording_status_callback: :unset,
605
+ recording_status_callback_method: :unset,
606
+ conference_recording_status_callback: :unset,
607
+ conference_recording_status_callback_method: :unset,
608
+ region: :unset,
609
+ sip_auth_username: :unset,
610
+ sip_auth_password: :unset,
611
+ dequeue_status_callback_event: :unset,
612
+ post_work_activity_sid: :unset,
613
+ end_conference_on_customer_exit: :unset,
614
+ beep_on_customer_entrance: :unset,
615
+ jitter_buffer_size: :unset,
616
+ if_match: :unset
617
+ )
618
+
619
+ context.update(
620
+ reservation_status: reservation_status,
621
+ worker_activity_sid: worker_activity_sid,
622
+ instruction: instruction,
623
+ dequeue_post_work_activity_sid: dequeue_post_work_activity_sid,
624
+ dequeue_from: dequeue_from,
625
+ dequeue_record: dequeue_record,
626
+ dequeue_timeout: dequeue_timeout,
627
+ dequeue_to: dequeue_to,
628
+ dequeue_status_callback_url: dequeue_status_callback_url,
629
+ call_from: call_from,
630
+ call_record: call_record,
631
+ call_timeout: call_timeout,
632
+ call_to: call_to,
633
+ call_url: call_url,
634
+ call_status_callback_url: call_status_callback_url,
635
+ call_accept: call_accept,
636
+ redirect_call_sid: redirect_call_sid,
637
+ redirect_accept: redirect_accept,
638
+ redirect_url: redirect_url,
639
+ to: to,
640
+ from: from,
641
+ status_callback: status_callback,
642
+ status_callback_method: status_callback_method,
643
+ status_callback_event: status_callback_event,
644
+ timeout: timeout,
645
+ record: record,
646
+ muted: muted,
647
+ beep: beep,
648
+ start_conference_on_enter: start_conference_on_enter,
649
+ end_conference_on_exit: end_conference_on_exit,
650
+ wait_url: wait_url,
651
+ wait_method: wait_method,
652
+ early_media: early_media,
653
+ max_participants: max_participants,
654
+ conference_status_callback: conference_status_callback,
655
+ conference_status_callback_method: conference_status_callback_method,
656
+ conference_status_callback_event: conference_status_callback_event,
657
+ conference_record: conference_record,
658
+ conference_trim: conference_trim,
659
+ recording_channels: recording_channels,
660
+ recording_status_callback: recording_status_callback,
661
+ recording_status_callback_method: recording_status_callback_method,
662
+ conference_recording_status_callback: conference_recording_status_callback,
663
+ conference_recording_status_callback_method: conference_recording_status_callback_method,
664
+ region: region,
665
+ sip_auth_username: sip_auth_username,
666
+ sip_auth_password: sip_auth_password,
667
+ dequeue_status_callback_event: dequeue_status_callback_event,
668
+ post_work_activity_sid: post_work_activity_sid,
669
+ end_conference_on_customer_exit: end_conference_on_customer_exit,
670
+ beep_on_customer_entrance: beep_on_customer_entrance,
671
+ jitter_buffer_size: jitter_buffer_size,
672
+ if_match: if_match,
673
+ )
674
+ end
675
+
676
+ ##
677
+ # Provide a user friendly representation
678
+ def to_s
679
+ values = @params.map{|k, v| "#{k}: #{v}"}.join(" ")
680
+ "<Twilio.Taskrouter.V1.ReservationInstance #{values}>"
681
+ end
682
+
683
+ ##
684
+ # Provide a detailed, user friendly representation
685
+ def inspect
686
+ values = @properties.map{|k, v| "#{k}: #{v}"}.join(" ")
687
+ "<Twilio.Taskrouter.V1.ReservationInstance #{values}>"
688
+ end
458
689
  end
459
- @instance_context
460
- end
461
-
462
- ##
463
- # @return [String] The SID of the Account that created the resource
464
- def account_sid
465
- @properties['account_sid']
466
- end
467
-
468
- ##
469
- # @return [Time] The ISO 8601 date and time in GMT when the resource was created
470
- def date_created
471
- @properties['date_created']
472
- end
473
-
474
- ##
475
- # @return [Time] The ISO 8601 date and time in GMT when the resource was last updated
476
- def date_updated
477
- @properties['date_updated']
478
- end
479
-
480
- ##
481
- # @return [reservation.Status] The current status of the reservation
482
- def reservation_status
483
- @properties['reservation_status']
484
- end
485
-
486
- ##
487
- # @return [String] The unique string that identifies the resource
488
- def sid
489
- @properties['sid']
490
- end
491
-
492
- ##
493
- # @return [String] The SID of the reserved Task resource
494
- def task_sid
495
- @properties['task_sid']
496
- end
497
-
498
- ##
499
- # @return [String] The friendly_name of the Worker that is reserved
500
- def worker_name
501
- @properties['worker_name']
502
- end
503
-
504
- ##
505
- # @return [String] The SID of the reserved Worker resource
506
- def worker_sid
507
- @properties['worker_sid']
508
- end
509
-
510
- ##
511
- # @return [String] The SID of the Workspace that this worker is contained within.
512
- def workspace_sid
513
- @properties['workspace_sid']
514
- end
515
-
516
- ##
517
- # @return [String] The absolute URL of the WorkerReservation resource
518
- def url
519
- @properties['url']
520
- end
521
-
522
- ##
523
- # @return [String] The URLs of related resources
524
- def links
525
- @properties['links']
526
- end
527
-
528
- ##
529
- # Fetch the ReservationInstance
530
- # @return [ReservationInstance] Fetched ReservationInstance
531
- def fetch
532
- context.fetch
533
- end
534
-
535
- ##
536
- # Update the ReservationInstance
537
- # @param [reservation.Status] reservation_status The new status of the
538
- # reservation. Can be: `pending`, `accepted`, `rejected`, `timeout`, `canceled`,
539
- # or `rescinded`.
540
- # @param [String] worker_activity_sid The new worker activity SID if rejecting a
541
- # reservation.
542
- # @param [String] instruction The assignment instruction for the reservation.
543
- # @param [String] dequeue_post_work_activity_sid The SID of the Activity resource
544
- # to start after executing a Dequeue instruction.
545
- # @param [String] dequeue_from The caller ID of the call to the worker when
546
- # executing a Dequeue instruction.
547
- # @param [String] dequeue_record Whether to record both legs of a call when
548
- # executing a Dequeue instruction or which leg to record.
549
- # @param [String] dequeue_timeout The timeout for call when executing a Dequeue
550
- # instruction.
551
- # @param [String] dequeue_to The contact URI of the worker when executing a
552
- # Dequeue instruction. Can be the URI of the Twilio Client, the SIP URI for
553
- # Programmable SIP, or the {E.164}[https://www.twilio.com/docs/glossary/what-e164]
554
- # formatted phone number, depending on the destination.
555
- # @param [String] dequeue_status_callback_url The callback URL for completed call
556
- # event when executing a Dequeue instruction.
557
- # @param [String] call_from The Caller ID of the outbound call when executing a
558
- # Call instruction.
559
- # @param [String] call_record Whether to record both legs of a call when executing
560
- # a Call instruction.
561
- # @param [String] call_timeout The timeout for a call when executing a Call
562
- # 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 The timeout for a 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. Can be `true` or `false` and the default
596
- # is `false`.
597
- # @param [Boolean] muted Whether the agent is muted in the conference. Defaults to
598
- # `false`.
599
- # @param [String] beep Whether to play a notification beep when the participant
600
- # joins or when to play a beep. Can be: `true`, `false`, `onEnter`, or `onExit`.
601
- # The default value is `true`.
602
- # @param [Boolean] start_conference_on_enter Whether to start the conference when
603
- # the participant joins, if it has not already started. Can be: `true` or `false`
604
- # and the default is `true`. If `false` and the conference has not started, the
605
- # participant is muted and hears background music until another participant starts
606
- # the conference.
607
- # @param [Boolean] end_conference_on_exit Whether to end the conference when the
608
- # agent leaves.
609
- # @param [String] wait_url The URL we should call using the `wait_method` for the
610
- # music to play while participants are waiting for the conference to start. The
611
- # default value is the URL of our standard hold music. {Learn more about hold
612
- # music}[https://www.twilio.com/labs/twimlets/holdmusic].
613
- # @param [String] wait_method The HTTP method we should use to call `wait_url`.
614
- # Can be `GET` or `POST` and the default is `POST`. When using a static audio
615
- # file, this should be `GET` so that we can cache the file.
616
- # @param [Boolean] early_media Whether to allow an agent to hear the state of the
617
- # outbound call, including ringing or disconnect messages. The default is `true`.
618
- # @param [String] max_participants The maximum number of participants allowed in
619
- # the conference. Can be a positive integer from `2` to `250`. The default value
620
- # is `250`.
621
- # @param [String] conference_status_callback The URL we should call using the
622
- # `conference_status_callback_method` when the conference events in
623
- # `conference_status_callback_event` occur. Only the value set by the first
624
- # participant to join the conference is used. Subsequent
625
- # `conference_status_callback` values are ignored.
626
- # @param [String] conference_status_callback_method The HTTP method we should use
627
- # to call `conference_status_callback`. Can be: `GET` or `POST` and defaults to
628
- # `POST`.
629
- # @param [Array[reservation.ConferenceEvent]] conference_status_callback_event The
630
- # conference status events that we will send to `conference_status_callback`. Can
631
- # be: `start`, `end`, `join`, `leave`, `mute`, `hold`, `speaker`.
632
- # @param [String] conference_record Whether to record the conference the
633
- # participant is joining or when to record the conference. Can be: `true`,
634
- # `false`, `record-from-start`, and `do-not-record`. The default value is `false`.
635
- # @param [String] conference_trim Whether to trim leading and trailing silence
636
- # from your recorded conference audio files. Can be: `trim-silence` or
637
- # `do-not-trim` and defaults to `trim-silence`.
638
- # @param [String] recording_channels The recording channels for the final
639
- # recording. Can be: `mono` or `dual` and the default is `mono`.
640
- # @param [String] recording_status_callback The URL that we should call using the
641
- # `recording_status_callback_method` when the recording status changes.
642
- # @param [String] recording_status_callback_method The HTTP method we should use
643
- # when we call `recording_status_callback`. Can be: `GET` or `POST` and defaults
644
- # to `POST`.
645
- # @param [String] conference_recording_status_callback The URL we should call
646
- # using the `conference_recording_status_callback_method` when the conference
647
- # recording is available.
648
- # @param [String] conference_recording_status_callback_method The HTTP method we
649
- # should use to call `conference_recording_status_callback`. Can be: `GET` or
650
- # `POST` and defaults to `POST`.
651
- # @param [String] region The
652
- # {region}[https://support.twilio.com/hc/en-us/articles/223132167-How-global-low-latency-routing-and-region-selection-work-for-conferences-and-Client-calls]
653
- # where we should mix the recorded audio. Can be:`us1`, `ie1`, `de1`, `sg1`,
654
- # `br1`, `au1`, or `jp1`.
655
- # @param [String] sip_auth_username The SIP username used for authentication.
656
- # @param [String] sip_auth_password The SIP password for authentication.
657
- # @param [Array[String]] dequeue_status_callback_event The call progress events
658
- # sent via webhooks as a result of a Dequeue instruction.
659
- # @param [String] post_work_activity_sid The new worker activity SID after
660
- # executing a Conference instruction.
661
- # @param [Boolean] end_conference_on_customer_exit Whether to end the conference
662
- # when the customer leaves.
663
- # @param [Boolean] beep_on_customer_entrance Whether to play a notification beep
664
- # when the customer joins.
665
- # @param [String] if_match The If-Match HTTP request header
666
- # @return [ReservationInstance] Updated ReservationInstance
667
- 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, end_conference_on_customer_exit: :unset, beep_on_customer_entrance: :unset, if_match: :unset)
668
- context.update(
669
- reservation_status: reservation_status,
670
- worker_activity_sid: worker_activity_sid,
671
- instruction: instruction,
672
- dequeue_post_work_activity_sid: dequeue_post_work_activity_sid,
673
- dequeue_from: dequeue_from,
674
- dequeue_record: dequeue_record,
675
- dequeue_timeout: dequeue_timeout,
676
- dequeue_to: dequeue_to,
677
- dequeue_status_callback_url: dequeue_status_callback_url,
678
- call_from: call_from,
679
- call_record: call_record,
680
- call_timeout: call_timeout,
681
- call_to: call_to,
682
- call_url: call_url,
683
- call_status_callback_url: call_status_callback_url,
684
- call_accept: call_accept,
685
- redirect_call_sid: redirect_call_sid,
686
- redirect_accept: redirect_accept,
687
- redirect_url: redirect_url,
688
- to: to,
689
- from: from,
690
- status_callback: status_callback,
691
- status_callback_method: status_callback_method,
692
- status_callback_event: status_callback_event,
693
- timeout: timeout,
694
- record: record,
695
- muted: muted,
696
- beep: beep,
697
- start_conference_on_enter: start_conference_on_enter,
698
- end_conference_on_exit: end_conference_on_exit,
699
- wait_url: wait_url,
700
- wait_method: wait_method,
701
- early_media: early_media,
702
- max_participants: max_participants,
703
- conference_status_callback: conference_status_callback,
704
- conference_status_callback_method: conference_status_callback_method,
705
- conference_status_callback_event: conference_status_callback_event,
706
- conference_record: conference_record,
707
- conference_trim: conference_trim,
708
- recording_channels: recording_channels,
709
- recording_status_callback: recording_status_callback,
710
- recording_status_callback_method: recording_status_callback_method,
711
- conference_recording_status_callback: conference_recording_status_callback,
712
- conference_recording_status_callback_method: conference_recording_status_callback_method,
713
- region: region,
714
- sip_auth_username: sip_auth_username,
715
- sip_auth_password: sip_auth_password,
716
- dequeue_status_callback_event: dequeue_status_callback_event,
717
- post_work_activity_sid: post_work_activity_sid,
718
- end_conference_on_customer_exit: end_conference_on_customer_exit,
719
- beep_on_customer_entrance: beep_on_customer_entrance,
720
- if_match: if_match,
721
- )
722
- end
723
-
724
- ##
725
- # Provide a user friendly representation
726
- def to_s
727
- values = @params.map{|k, v| "#{k}: #{v}"}.join(" ")
728
- "<Twilio.Taskrouter.V1.ReservationInstance #{values}>"
729
- end
730
-
731
- ##
732
- # Provide a detailed, user friendly representation
733
- def inspect
734
- values = @properties.map{|k, v| "#{k}: #{v}"}.join(" ")
735
- "<Twilio.Taskrouter.V1.ReservationInstance #{values}>"
736
- end
690
+
691
+ end
692
+ end
737
693
  end
738
- end
739
694
  end
740
- end
741
695
  end
742
- end
743
- end
696
+ end
697
+
698
+