twilio-ruby 5.72.0 → 6.0.2

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