twilio-ruby 5.61.2 → 6.9.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (677) hide show
  1. checksums.yaml +4 -4
  2. data/.github/workflows/pr-lint.yml +21 -0
  3. data/.github/workflows/test-and-deploy.yml +139 -0
  4. data/.gitignore +3 -0
  5. data/.rubocop.yml +1 -1
  6. data/.rubocop_todo.yml +84 -21
  7. data/CHANGES.md +893 -1
  8. data/CONTRIBUTING.md +11 -9
  9. data/LICENSE +1 -1
  10. data/Makefile +13 -8
  11. data/PULL_REQUEST_TEMPLATE.md +1 -1
  12. data/README.md +136 -44
  13. data/UPGRADE.md +10 -0
  14. data/advanced-examples/custom-http-client.md +170 -0
  15. data/cluster_spec.rb +77 -0
  16. data/lib/rack/twilio_webhook_authentication.rb +25 -1
  17. data/lib/twilio-ruby/base/client_base.rb +121 -0
  18. data/lib/twilio-ruby/framework/rest/error.rb +0 -12
  19. data/lib/twilio-ruby/http/http_client.rb +11 -6
  20. data/lib/twilio-ruby/jwt/access_token.rb +0 -59
  21. data/lib/twilio-ruby/rest/accounts/v1/auth_token_promotion.rb +198 -178
  22. data/lib/twilio-ruby/rest/accounts/v1/credential/aws.rb +371 -332
  23. data/lib/twilio-ruby/rest/accounts/v1/credential/public_key.rb +371 -332
  24. data/lib/twilio-ruby/rest/accounts/v1/credential.rb +121 -114
  25. data/lib/twilio-ruby/rest/accounts/v1/safelist.rb +169 -0
  26. data/lib/twilio-ruby/rest/accounts/v1/secondary_auth_token.rb +214 -192
  27. data/lib/twilio-ruby/rest/accounts/v1.rb +51 -42
  28. data/lib/twilio-ruby/rest/accounts.rb +4 -34
  29. data/lib/twilio-ruby/rest/accounts_base.rb +38 -0
  30. data/lib/twilio-ruby/rest/api/v2010/account/address/dependent_phone_number.rb +370 -365
  31. data/lib/twilio-ruby/rest/api/v2010/account/address.rb +551 -514
  32. data/lib/twilio-ruby/rest/api/v2010/account/application.rb +615 -586
  33. data/lib/twilio-ruby/rest/api/v2010/account/authorized_connect_app.rb +313 -320
  34. data/lib/twilio-ruby/rest/api/v2010/account/available_phone_number_country/local.rb +394 -0
  35. data/lib/twilio-ruby/rest/api/v2010/account/available_phone_number_country/machine_to_machine.rb +394 -0
  36. data/lib/twilio-ruby/rest/api/v2010/account/available_phone_number_country/mobile.rb +394 -0
  37. data/lib/twilio-ruby/rest/api/v2010/account/available_phone_number_country/national.rb +394 -0
  38. data/lib/twilio-ruby/rest/api/v2010/account/available_phone_number_country/shared_cost.rb +394 -0
  39. data/lib/twilio-ruby/rest/api/v2010/account/available_phone_number_country/toll_free.rb +394 -0
  40. data/lib/twilio-ruby/rest/api/v2010/account/available_phone_number_country/voip.rb +394 -0
  41. data/lib/twilio-ruby/rest/api/v2010/account/available_phone_number_country.rb +432 -0
  42. data/lib/twilio-ruby/rest/api/v2010/account/balance.rb +136 -118
  43. data/lib/twilio-ruby/rest/api/v2010/account/call/event.rb +202 -194
  44. data/lib/twilio-ruby/rest/api/v2010/account/call/feedback.rb +252 -289
  45. data/lib/twilio-ruby/rest/api/v2010/account/call/feedback_summary.rb +317 -303
  46. data/lib/twilio-ruby/rest/api/v2010/account/call/notification.rb +400 -417
  47. data/lib/twilio-ruby/rest/api/v2010/account/call/payment.rb +291 -342
  48. data/lib/twilio-ruby/rest/api/v2010/account/call/recording.rb +494 -511
  49. data/lib/twilio-ruby/rest/api/v2010/account/call/siprec.rb +839 -634
  50. data/lib/twilio-ruby/rest/api/v2010/account/call/stream.rb +872 -0
  51. data/lib/twilio-ruby/rest/api/v2010/account/call/user_defined_message.rb +163 -0
  52. data/lib/twilio-ruby/rest/api/v2010/account/call/user_defined_message_subscription.rb +239 -0
  53. data/lib/twilio-ruby/rest/api/v2010/account/call.rb +952 -972
  54. data/lib/twilio-ruby/rest/api/v2010/account/conference/participant.rb +652 -717
  55. data/lib/twilio-ruby/rest/api/v2010/account/conference/recording.rb +451 -458
  56. data/lib/twilio-ruby/rest/api/v2010/account/conference.rb +489 -493
  57. data/lib/twilio-ruby/rest/api/v2010/account/connect_app.rb +426 -407
  58. data/lib/twilio-ruby/rest/api/v2010/account/incoming_phone_number/assigned_add_on/assigned_add_on_extension.rb +321 -351
  59. data/lib/twilio-ruby/rest/api/v2010/account/incoming_phone_number/assigned_add_on.rb +398 -418
  60. data/lib/twilio-ruby/rest/api/v2010/account/incoming_phone_number/local.rb +536 -554
  61. data/lib/twilio-ruby/rest/api/v2010/account/incoming_phone_number/mobile.rb +536 -553
  62. data/lib/twilio-ruby/rest/api/v2010/account/incoming_phone_number/toll_free.rb +536 -553
  63. data/lib/twilio-ruby/rest/api/v2010/account/incoming_phone_number.rb +841 -903
  64. data/lib/twilio-ruby/rest/api/v2010/account/key.rb +335 -302
  65. data/lib/twilio-ruby/rest/api/v2010/account/message/feedback.rb +167 -166
  66. data/lib/twilio-ruby/rest/api/v2010/account/message/media.rb +340 -350
  67. data/lib/twilio-ruby/rest/api/v2010/account/message.rb +615 -612
  68. data/lib/twilio-ruby/rest/api/v2010/account/new_key.rb +157 -138
  69. data/lib/twilio-ruby/rest/api/v2010/account/new_signing_key.rb +157 -138
  70. data/lib/twilio-ruby/rest/api/v2010/account/notification.rb +400 -399
  71. data/lib/twilio-ruby/rest/api/v2010/account/outgoing_caller_id.rb +368 -358
  72. data/lib/twilio-ruby/rest/api/v2010/account/queue/member.rb +340 -338
  73. data/lib/twilio-ruby/rest/api/v2010/account/queue.rb +426 -390
  74. data/lib/twilio-ruby/rest/api/v2010/account/recording/add_on_result/payload.rb +358 -380
  75. data/lib/twilio-ruby/rest/api/v2010/account/recording/add_on_result.rb +368 -385
  76. data/lib/twilio-ruby/rest/api/v2010/account/recording/transcription.rb +364 -372
  77. data/lib/twilio-ruby/rest/api/v2010/account/recording.rb +507 -486
  78. data/lib/twilio-ruby/rest/api/v2010/account/short_code.rb +417 -408
  79. data/lib/twilio-ruby/rest/api/v2010/account/signing_key.rb +335 -306
  80. data/lib/twilio-ruby/rest/api/v2010/account/sip/credential_list/credential.rb +375 -368
  81. data/lib/twilio-ruby/rest/api/v2010/account/sip/credential_list.rb +399 -373
  82. data/lib/twilio-ruby/rest/api/v2010/account/sip/domain/auth_types/auth_type_calls/auth_calls_credential_list_mapping.rb +346 -0
  83. data/lib/twilio-ruby/rest/api/v2010/account/sip/domain/auth_types/{auth_calls_mapping → auth_type_calls}/auth_calls_ip_access_control_list_mapping.rb +193 -195
  84. data/lib/twilio-ruby/rest/api/v2010/account/sip/domain/auth_types/auth_type_calls.rb +140 -0
  85. data/lib/twilio-ruby/rest/api/v2010/account/sip/domain/auth_types/{auth_registrations_mapping → auth_type_registrations}/auth_registrations_credential_list_mapping.rb +193 -195
  86. data/lib/twilio-ruby/rest/api/v2010/account/sip/domain/auth_types/auth_type_registrations.rb +126 -0
  87. data/lib/twilio-ruby/rest/api/v2010/account/sip/domain/auth_types.rb +94 -103
  88. data/lib/twilio-ruby/rest/api/v2010/account/sip/domain/credential_list_mapping.rb +339 -339
  89. data/lib/twilio-ruby/rest/api/v2010/account/sip/domain/ip_access_control_list_mapping.rb +339 -338
  90. data/lib/twilio-ruby/rest/api/v2010/account/sip/domain.rb +649 -645
  91. data/lib/twilio-ruby/rest/api/v2010/account/sip/ip_access_control_list/ip_address.rb +412 -421
  92. data/lib/twilio-ruby/rest/api/v2010/account/sip/ip_access_control_list.rb +399 -374
  93. data/lib/twilio-ruby/rest/api/v2010/account/sip.rb +141 -150
  94. data/lib/twilio-ruby/rest/api/v2010/account/token.rb +171 -154
  95. data/lib/twilio-ruby/rest/api/v2010/account/transcription.rb +364 -350
  96. data/lib/twilio-ruby/rest/api/v2010/account/usage/record/all_time.rb +314 -339
  97. data/lib/twilio-ruby/rest/api/v2010/account/usage/record/daily.rb +314 -339
  98. data/lib/twilio-ruby/rest/api/v2010/account/usage/record/last_month.rb +314 -339
  99. data/lib/twilio-ruby/rest/api/v2010/account/usage/record/monthly.rb +314 -339
  100. data/lib/twilio-ruby/rest/api/v2010/account/usage/record/this_month.rb +314 -339
  101. data/lib/twilio-ruby/rest/api/v2010/account/usage/record/today.rb +314 -339
  102. data/lib/twilio-ruby/rest/api/v2010/account/usage/record/yearly.rb +314 -339
  103. data/lib/twilio-ruby/rest/api/v2010/account/usage/record/yesterday.rb +314 -339
  104. data/lib/twilio-ruby/rest/api/v2010/account/usage/record.rb +381 -416
  105. data/lib/twilio-ruby/rest/api/v2010/account/usage/trigger.rb +485 -484
  106. data/lib/twilio-ruby/rest/api/v2010/account/usage.rb +112 -104
  107. data/lib/twilio-ruby/rest/api/v2010/account/validation_request.rb +172 -161
  108. data/lib/twilio-ruby/rest/api/v2010/account.rb +979 -943
  109. data/lib/twilio-ruby/rest/api/v2010.rb +126 -148
  110. data/lib/twilio-ruby/rest/api.rb +25 -34
  111. data/lib/twilio-ruby/rest/api_base.rb +38 -0
  112. data/lib/twilio-ruby/rest/bulkexports/v1/export/day.rb +299 -279
  113. data/lib/twilio-ruby/rest/bulkexports/v1/export/export_custom_job.rb +298 -279
  114. data/lib/twilio-ruby/rest/bulkexports/v1/export/job.rb +271 -248
  115. data/lib/twilio-ruby/rest/bulkexports/v1/export.rb +246 -235
  116. data/lib/twilio-ruby/rest/bulkexports/v1/export_configuration.rb +245 -218
  117. data/lib/twilio-ruby/rest/bulkexports/v1.rb +57 -55
  118. data/lib/twilio-ruby/rest/bulkexports.rb +3 -34
  119. data/lib/twilio-ruby/rest/bulkexports_base.rb +38 -0
  120. data/lib/twilio-ruby/rest/chat/v1/credential.rb +419 -403
  121. data/lib/twilio-ruby/rest/chat/v1/service/channel/invite.rb +374 -391
  122. data/lib/twilio-ruby/rest/chat/v1/service/channel/member.rb +422 -440
  123. data/lib/twilio-ruby/rest/chat/v1/service/channel/message.rb +438 -437
  124. data/lib/twilio-ruby/rest/chat/v1/service/channel.rb +534 -515
  125. data/lib/twilio-ruby/rest/chat/v1/service/role.rb +396 -367
  126. data/lib/twilio-ruby/rest/chat/v1/service/user/user_channel.rb +244 -239
  127. data/lib/twilio-ruby/rest/chat/v1/service/user.rb +465 -440
  128. data/lib/twilio-ruby/rest/chat/v1/service.rb +861 -894
  129. data/lib/twilio-ruby/rest/chat/v1.rb +57 -55
  130. data/lib/twilio-ruby/rest/chat/v2/credential.rb +419 -401
  131. data/lib/twilio-ruby/rest/chat/v2/service/binding.rb +371 -370
  132. data/lib/twilio-ruby/rest/chat/v2/service/channel/invite.rb +374 -386
  133. data/lib/twilio-ruby/rest/chat/v2/service/channel/member.rb +486 -527
  134. data/lib/twilio-ruby/rest/chat/v2/service/channel/message.rb +513 -533
  135. data/lib/twilio-ruby/rest/chat/v2/service/channel/webhook.rb +440 -467
  136. data/lib/twilio-ruby/rest/chat/v2/service/channel.rb +606 -605
  137. data/lib/twilio-ruby/rest/chat/v2/service/role.rb +396 -369
  138. data/lib/twilio-ruby/rest/chat/v2/service/user/user_binding.rb +364 -381
  139. data/lib/twilio-ruby/rest/chat/v2/service/user/user_channel.rb +406 -413
  140. data/lib/twilio-ruby/rest/chat/v2/service/user.rb +509 -491
  141. data/lib/twilio-ruby/rest/chat/v2/service.rb +764 -778
  142. data/lib/twilio-ruby/rest/chat/v2.rb +57 -53
  143. data/lib/twilio-ruby/rest/chat/v3/channel.rb +297 -0
  144. data/lib/twilio-ruby/rest/chat/v3.rb +71 -0
  145. data/lib/twilio-ruby/rest/chat.rb +10 -38
  146. data/lib/twilio-ruby/rest/chat_base.rb +48 -0
  147. data/lib/twilio-ruby/rest/client.rb +318 -561
  148. data/lib/twilio-ruby/rest/content/v1/content/approval_fetch.rb +208 -0
  149. data/lib/twilio-ruby/rest/content/v1/content.rb +363 -0
  150. data/lib/twilio-ruby/rest/content/v1/content_and_approvals.rb +251 -0
  151. data/lib/twilio-ruby/rest/content/v1/legacy_content.rb +265 -0
  152. data/lib/twilio-ruby/rest/content/v1.rb +61 -0
  153. data/lib/twilio-ruby/rest/content.rb +15 -0
  154. data/lib/twilio-ruby/rest/content_base.rb +38 -0
  155. data/lib/twilio-ruby/rest/conversations/v1/address_configuration.rb +482 -0
  156. data/lib/twilio-ruby/rest/conversations/v1/configuration/webhook.rb +254 -227
  157. data/lib/twilio-ruby/rest/conversations/v1/configuration.rb +279 -252
  158. data/lib/twilio-ruby/rest/conversations/v1/conversation/message/delivery_receipt.rb +334 -344
  159. data/lib/twilio-ruby/rest/conversations/v1/conversation/message.rb +537 -495
  160. data/lib/twilio-ruby/rest/conversations/v1/conversation/participant.rb +498 -495
  161. data/lib/twilio-ruby/rest/conversations/v1/conversation/webhook.rb +425 -403
  162. data/lib/twilio-ruby/rest/conversations/v1/conversation.rb +620 -552
  163. data/lib/twilio-ruby/rest/conversations/v1/credential.rb +425 -409
  164. data/lib/twilio-ruby/rest/conversations/v1/participant_conversation.rb +304 -304
  165. data/lib/twilio-ruby/rest/conversations/v1/role.rb +384 -356
  166. data/lib/twilio-ruby/rest/conversations/v1/service/binding.rb +364 -373
  167. data/lib/twilio-ruby/rest/conversations/v1/service/configuration/notification.rb +300 -289
  168. data/lib/twilio-ruby/rest/conversations/v1/service/configuration/webhook.rb +246 -235
  169. data/lib/twilio-ruby/rest/conversations/v1/service/configuration.rb +307 -279
  170. data/lib/twilio-ruby/rest/conversations/v1/service/conversation/message/delivery_receipt.rb +341 -371
  171. data/lib/twilio-ruby/rest/conversations/v1/service/conversation/message.rb +544 -535
  172. data/lib/twilio-ruby/rest/conversations/v1/service/conversation/participant.rb +507 -530
  173. data/lib/twilio-ruby/rest/conversations/v1/service/conversation/webhook.rb +434 -438
  174. data/lib/twilio-ruby/rest/conversations/v1/service/conversation.rb +632 -588
  175. data/lib/twilio-ruby/rest/conversations/v1/service/participant_conversation.rb +310 -317
  176. data/lib/twilio-ruby/rest/conversations/v1/service/role.rb +396 -380
  177. data/lib/twilio-ruby/rest/conversations/v1/service/user/user_conversation.rb +446 -455
  178. data/lib/twilio-ruby/rest/conversations/v1/service/user.rb +484 -474
  179. data/lib/twilio-ruby/rest/conversations/v1/service.rb +476 -447
  180. data/lib/twilio-ruby/rest/conversations/v1/user/user_conversation.rb +445 -435
  181. data/lib/twilio-ruby/rest/conversations/v1/user.rb +472 -441
  182. data/lib/twilio-ruby/rest/conversations/v1.rb +129 -119
  183. data/lib/twilio-ruby/rest/conversations.rb +18 -34
  184. data/lib/twilio-ruby/rest/conversations_base.rb +38 -0
  185. data/lib/twilio-ruby/rest/events/v1/event_type.rb +302 -288
  186. data/lib/twilio-ruby/rest/events/v1/schema/schema_version.rb +299 -0
  187. data/lib/twilio-ruby/rest/events/v1/schema.rb +227 -218
  188. data/lib/twilio-ruby/rest/events/v1/sink/sink_test.rb +114 -100
  189. data/lib/twilio-ruby/rest/events/v1/sink/sink_validate.rb +120 -103
  190. data/lib/twilio-ruby/rest/events/v1/sink.rb +434 -408
  191. data/lib/twilio-ruby/rest/events/v1/subscription/subscribed_event.rb +365 -339
  192. data/lib/twilio-ruby/rest/events/v1/subscription.rb +416 -387
  193. data/lib/twilio-ruby/rest/events/v1.rb +87 -87
  194. data/lib/twilio-ruby/rest/events.rb +5 -34
  195. data/lib/twilio-ruby/rest/events_base.rb +38 -0
  196. data/lib/twilio-ruby/rest/flex_api/v1/assessments.rb +448 -0
  197. data/lib/twilio-ruby/rest/flex_api/v1/channel.rb +365 -330
  198. data/lib/twilio-ruby/rest/flex_api/v1/configuration.rb +510 -475
  199. data/lib/twilio-ruby/rest/flex_api/v1/flex_flow.rb +563 -555
  200. data/lib/twilio-ruby/rest/flex_api/v1/insights_assessments_comment.rb +327 -0
  201. data/lib/twilio-ruby/rest/flex_api/v1/insights_conversations.rb +228 -0
  202. data/lib/twilio-ruby/rest/flex_api/v1/insights_questionnaires.rb +442 -0
  203. data/lib/twilio-ruby/rest/flex_api/v1/insights_questionnaires_category.rb +358 -0
  204. data/lib/twilio-ruby/rest/flex_api/v1/insights_questionnaires_question.rb +443 -0
  205. data/lib/twilio-ruby/rest/flex_api/v1/insights_segments.rb +361 -0
  206. data/lib/twilio-ruby/rest/flex_api/v1/insights_session.rb +217 -0
  207. data/lib/twilio-ruby/rest/flex_api/v1/insights_settings_answer_sets.rb +155 -0
  208. data/lib/twilio-ruby/rest/flex_api/v1/insights_settings_comment.rb +141 -0
  209. data/lib/twilio-ruby/rest/flex_api/v1/insights_user_roles.rb +196 -0
  210. data/lib/twilio-ruby/rest/flex_api/v1/interaction/interaction_channel/interaction_channel_invite.rb +251 -0
  211. data/lib/twilio-ruby/rest/flex_api/v1/interaction/interaction_channel/interaction_channel_participant.rb +339 -0
  212. data/lib/twilio-ruby/rest/flex_api/v1/interaction/interaction_channel.rb +406 -0
  213. data/lib/twilio-ruby/rest/flex_api/v1/interaction.rb +267 -0
  214. data/lib/twilio-ruby/rest/flex_api/v1/provisioning_status.rb +187 -0
  215. data/lib/twilio-ruby/rest/flex_api/v1/web_channel.rb +378 -331
  216. data/lib/twilio-ruby/rest/flex_api/v1.rb +201 -76
  217. data/lib/twilio-ruby/rest/flex_api/v2/web_channels.rb +146 -0
  218. data/lib/twilio-ruby/rest/flex_api/v2.rb +40 -0
  219. data/lib/twilio-ruby/rest/flex_api.rb +33 -31
  220. data/lib/twilio-ruby/rest/flex_api_base.rb +43 -0
  221. data/lib/twilio-ruby/rest/frontline_api/v1/user.rb +244 -227
  222. data/lib/twilio-ruby/rest/frontline_api/v1.rb +42 -38
  223. data/lib/twilio-ruby/rest/frontline_api.rb +2 -34
  224. data/lib/twilio-ruby/rest/frontline_api_base.rb +38 -0
  225. data/lib/twilio-ruby/rest/insights/v1/call/annotation.rb +319 -0
  226. data/lib/twilio-ruby/rest/insights/v1/call/call_summary.rb +350 -0
  227. data/lib/twilio-ruby/rest/insights/v1/call/event.rb +269 -255
  228. data/lib/twilio-ruby/rest/insights/v1/call/metric.rb +241 -225
  229. data/lib/twilio-ruby/rest/insights/v1/call.rb +260 -228
  230. data/lib/twilio-ruby/rest/insights/v1/call_summaries.rb +485 -426
  231. data/lib/twilio-ruby/rest/insights/v1/conference/conference_participant.rb +488 -0
  232. data/lib/twilio-ruby/rest/insights/v1/conference.rb +505 -0
  233. data/lib/twilio-ruby/rest/insights/v1/room/participant.rb +378 -371
  234. data/lib/twilio-ruby/rest/insights/v1/room.rb +490 -489
  235. data/lib/twilio-ruby/rest/insights/v1/setting.rb +254 -0
  236. data/lib/twilio-ruby/rest/insights/v1.rb +84 -60
  237. data/lib/twilio-ruby/rest/insights.rb +17 -31
  238. data/lib/twilio-ruby/rest/insights_base.rb +38 -0
  239. data/lib/twilio-ruby/rest/intelligence/v2/service.rb +510 -0
  240. data/lib/twilio-ruby/rest/intelligence/v2/transcript/media.rb +226 -0
  241. data/lib/twilio-ruby/rest/intelligence/v2/transcript/operator_result.rb +388 -0
  242. data/lib/twilio-ruby/rest/intelligence/v2/transcript/sentence.rb +248 -0
  243. data/lib/twilio-ruby/rest/intelligence/v2/transcript.rb +520 -0
  244. data/lib/twilio-ruby/rest/intelligence/v2.rb +64 -0
  245. data/lib/twilio-ruby/rest/intelligence.rb +6 -0
  246. data/lib/twilio-ruby/rest/intelligence_base.rb +38 -0
  247. data/lib/twilio-ruby/rest/ip_messaging/v1/credential.rb +419 -364
  248. data/lib/twilio-ruby/rest/ip_messaging/v1/service/channel/invite.rb +374 -359
  249. data/lib/twilio-ruby/rest/ip_messaging/v1/service/channel/member.rb +422 -397
  250. data/lib/twilio-ruby/rest/ip_messaging/v1/service/channel/message.rb +438 -409
  251. data/lib/twilio-ruby/rest/ip_messaging/v1/service/channel.rb +534 -488
  252. data/lib/twilio-ruby/rest/ip_messaging/v1/service/role.rb +396 -347
  253. data/lib/twilio-ruby/rest/ip_messaging/v1/service/user/user_channel.rb +244 -233
  254. data/lib/twilio-ruby/rest/ip_messaging/v1/service/user.rb +465 -418
  255. data/lib/twilio-ruby/rest/ip_messaging/v1/service.rb +861 -779
  256. data/lib/twilio-ruby/rest/ip_messaging/v1.rb +57 -53
  257. data/lib/twilio-ruby/rest/ip_messaging/v2/credential.rb +419 -364
  258. data/lib/twilio-ruby/rest/ip_messaging/v2/service/binding.rb +371 -343
  259. data/lib/twilio-ruby/rest/ip_messaging/v2/service/channel/invite.rb +374 -359
  260. data/lib/twilio-ruby/rest/ip_messaging/v2/service/channel/member.rb +486 -451
  261. data/lib/twilio-ruby/rest/ip_messaging/v2/service/channel/message.rb +513 -479
  262. data/lib/twilio-ruby/rest/ip_messaging/v2/service/channel/webhook.rb +440 -411
  263. data/lib/twilio-ruby/rest/ip_messaging/v2/service/channel.rb +606 -555
  264. data/lib/twilio-ruby/rest/ip_messaging/v2/service/role.rb +396 -347
  265. data/lib/twilio-ruby/rest/ip_messaging/v2/service/user/user_binding.rb +364 -351
  266. data/lib/twilio-ruby/rest/ip_messaging/v2/service/user/user_channel.rb +397 -384
  267. data/lib/twilio-ruby/rest/ip_messaging/v2/service/user.rb +509 -467
  268. data/lib/twilio-ruby/rest/ip_messaging/v2/service.rb +764 -689
  269. data/lib/twilio-ruby/rest/ip_messaging/v2.rb +57 -53
  270. data/lib/twilio-ruby/rest/ip_messaging.rb +3 -41
  271. data/lib/twilio-ruby/rest/ip_messaging_base.rb +43 -0
  272. data/lib/twilio-ruby/rest/lookups/v1/phone_number.rb +243 -239
  273. data/lib/twilio-ruby/rest/lookups/v1.rb +42 -39
  274. data/lib/twilio-ruby/rest/lookups/v2/phone_number.rb +370 -0
  275. data/lib/twilio-ruby/rest/lookups/v2.rb +49 -0
  276. data/lib/twilio-ruby/rest/lookups.rb +2 -34
  277. data/lib/twilio-ruby/rest/lookups_base.rb +43 -0
  278. data/lib/twilio-ruby/rest/media/v1/media_processor.rb +410 -374
  279. data/lib/twilio-ruby/rest/media/v1/media_recording.rb +404 -0
  280. data/lib/twilio-ruby/rest/media/v1/player_streamer/playback_grant.rb +245 -214
  281. data/lib/twilio-ruby/rest/media/v1/player_streamer.rb +422 -380
  282. data/lib/twilio-ruby/rest/media/v1.rb +72 -53
  283. data/lib/twilio-ruby/rest/media.rb +13 -34
  284. data/lib/twilio-ruby/rest/media_base.rb +38 -0
  285. data/lib/twilio-ruby/rest/messaging/v1/brand_registration/brand_registration_otp.rb +136 -0
  286. data/lib/twilio-ruby/rest/messaging/v1/brand_registration/brand_vetting.rb +358 -346
  287. data/lib/twilio-ruby/rest/messaging/v1/brand_registration.rb +487 -420
  288. data/lib/twilio-ruby/rest/messaging/v1/deactivations.rb +189 -0
  289. data/lib/twilio-ruby/rest/messaging/v1/domain_certs.rb +280 -0
  290. data/lib/twilio-ruby/rest/messaging/v1/domain_config.rb +289 -0
  291. data/lib/twilio-ruby/rest/messaging/v1/domain_config_messaging_service.rb +238 -0
  292. data/lib/twilio-ruby/rest/messaging/v1/external_campaign.rb +155 -144
  293. data/lib/twilio-ruby/rest/messaging/v1/linkshortening_messaging_service.rb +214 -0
  294. data/lib/twilio-ruby/rest/messaging/v1/linkshortening_messaging_service_domain_association.rb +196 -0
  295. data/lib/twilio-ruby/rest/messaging/v1/service/alpha_sender.rb +351 -335
  296. data/lib/twilio-ruby/rest/messaging/v1/service/channel_sender.rb +329 -0
  297. data/lib/twilio-ruby/rest/messaging/v1/service/phone_number.rb +358 -341
  298. data/lib/twilio-ruby/rest/messaging/v1/service/short_code.rb +358 -336
  299. data/lib/twilio-ruby/rest/messaging/v1/service/us_app_to_person.rb +506 -426
  300. data/lib/twilio-ruby/rest/messaging/v1/service/us_app_to_person_usecase.rb +121 -115
  301. data/lib/twilio-ruby/rest/messaging/v1/service.rb +767 -763
  302. data/lib/twilio-ruby/rest/messaging/v1/tollfree_verification.rb +777 -0
  303. data/lib/twilio-ruby/rest/messaging/v1/usecase.rb +106 -94
  304. data/lib/twilio-ruby/rest/messaging/v1.rb +187 -74
  305. data/lib/twilio-ruby/rest/messaging.rb +36 -35
  306. data/lib/twilio-ruby/rest/messaging_base.rb +38 -0
  307. data/lib/twilio-ruby/rest/microvisor/v1/account_config.rb +358 -0
  308. data/lib/twilio-ruby/rest/microvisor/v1/account_secret.rb +351 -0
  309. data/lib/twilio-ruby/rest/microvisor/v1/app/app_manifest.rb +208 -0
  310. data/lib/twilio-ruby/rest/microvisor/v1/app.rb +349 -0
  311. data/lib/twilio-ruby/rest/microvisor/v1/device/device_config.rb +374 -0
  312. data/lib/twilio-ruby/rest/microvisor/v1/device/device_secret.rb +367 -0
  313. data/lib/twilio-ruby/rest/microvisor/v1/device.rb +427 -0
  314. data/lib/twilio-ruby/rest/microvisor/v1.rb +94 -0
  315. data/lib/twilio-ruby/rest/microvisor.rb +24 -0
  316. data/lib/twilio-ruby/rest/microvisor_base.rb +38 -0
  317. data/lib/twilio-ruby/rest/monitor/v1/alert.rb +398 -395
  318. data/lib/twilio-ruby/rest/monitor/v1/event.rb +381 -390
  319. data/lib/twilio-ruby/rest/monitor/v1.rb +57 -53
  320. data/lib/twilio-ruby/rest/monitor.rb +3 -34
  321. data/lib/twilio-ruby/rest/monitor_base.rb +38 -0
  322. data/lib/twilio-ruby/rest/notify/v1/credential.rb +421 -408
  323. data/lib/twilio-ruby/rest/notify/v1/service/binding.rb +437 -452
  324. data/lib/twilio-ruby/rest/notify/v1/service/notification.rb +313 -362
  325. data/lib/twilio-ruby/rest/notify/v1/service.rb +626 -622
  326. data/lib/twilio-ruby/rest/notify/v1.rb +57 -55
  327. data/lib/twilio-ruby/rest/notify.rb +3 -34
  328. data/lib/twilio-ruby/rest/notify_base.rb +38 -0
  329. data/lib/twilio-ruby/rest/numbers/v1/bulk_eligibility.rb +224 -0
  330. data/lib/twilio-ruby/rest/numbers/v1/porting_bulk_portability.rb +229 -0
  331. data/lib/twilio-ruby/rest/numbers/v1/porting_port_in_fetch.rb +245 -0
  332. data/lib/twilio-ruby/rest/numbers/v1/porting_portability.rb +263 -0
  333. data/lib/twilio-ruby/rest/numbers/v1.rb +94 -0
  334. data/lib/twilio-ruby/rest/numbers/v2/authorization_document/dependent_hosted_number_order.rb +343 -0
  335. data/lib/twilio-ruby/rest/numbers/v2/authorization_document.rb +403 -0
  336. data/lib/twilio-ruby/rest/numbers/v2/bulk_hosted_number_order.rb +249 -0
  337. data/lib/twilio-ruby/rest/numbers/v2/hosted_number_order.rb +502 -0
  338. data/lib/twilio-ruby/rest/numbers/v2/regulatory_compliance/bundle/bundle_copy.rb +276 -179
  339. data/lib/twilio-ruby/rest/numbers/v2/regulatory_compliance/bundle/evaluation.rb +324 -298
  340. data/lib/twilio-ruby/rest/numbers/v2/regulatory_compliance/bundle/item_assignment.rb +333 -309
  341. data/lib/twilio-ruby/rest/numbers/v2/regulatory_compliance/bundle/replace_items.rb +194 -181
  342. data/lib/twilio-ruby/rest/numbers/v2/regulatory_compliance/bundle.rb +601 -550
  343. data/lib/twilio-ruby/rest/numbers/v2/regulatory_compliance/end_user.rb +391 -351
  344. data/lib/twilio-ruby/rest/numbers/v2/regulatory_compliance/end_user_type.rb +290 -266
  345. data/lib/twilio-ruby/rest/numbers/v2/regulatory_compliance/regulation.rb +322 -307
  346. data/lib/twilio-ruby/rest/numbers/v2/regulatory_compliance/supporting_document.rb +412 -364
  347. data/lib/twilio-ruby/rest/numbers/v2/regulatory_compliance/supporting_document_type.rb +290 -266
  348. data/lib/twilio-ruby/rest/numbers/v2/regulatory_compliance.rb +177 -181
  349. data/lib/twilio-ruby/rest/numbers/v2.rb +78 -28
  350. data/lib/twilio-ruby/rest/numbers.rb +2 -34
  351. data/lib/twilio-ruby/rest/numbers_base.rb +43 -0
  352. data/lib/twilio-ruby/rest/preview/deployed_devices/fleet/certificate.rb +410 -375
  353. data/lib/twilio-ruby/rest/preview/deployed_devices/fleet/deployment.rb +394 -358
  354. data/lib/twilio-ruby/rest/preview/deployed_devices/fleet/device.rb +449 -418
  355. data/lib/twilio-ruby/rest/preview/deployed_devices/fleet/key.rb +407 -369
  356. data/lib/twilio-ruby/rest/preview/deployed_devices/fleet.rb +494 -459
  357. data/lib/twilio-ruby/rest/preview/deployed_devices.rb +42 -38
  358. data/lib/twilio-ruby/rest/preview/hosted_numbers/authorization_document/dependent_hosted_number_order.rb +370 -396
  359. data/lib/twilio-ruby/rest/preview/hosted_numbers/authorization_document.rb +446 -446
  360. data/lib/twilio-ruby/rest/preview/hosted_numbers/hosted_number_order.rb +610 -625
  361. data/lib/twilio-ruby/rest/preview/hosted_numbers.rb +57 -55
  362. data/lib/twilio-ruby/rest/preview/marketplace/available_add_on/available_add_on_extension.rb +301 -298
  363. data/lib/twilio-ruby/rest/preview/marketplace/available_add_on.rb +325 -309
  364. data/lib/twilio-ruby/rest/preview/marketplace/installed_add_on/installed_add_on_extension.rb +342 -330
  365. data/lib/twilio-ruby/rest/preview/marketplace/installed_add_on.rb +429 -398
  366. data/lib/twilio-ruby/rest/preview/marketplace.rb +57 -53
  367. data/lib/twilio-ruby/rest/preview/sync/service/document/document_permission.rb +378 -374
  368. data/lib/twilio-ruby/rest/preview/sync/service/document.rb +442 -399
  369. data/lib/twilio-ruby/rest/preview/sync/service/sync_list/sync_list_item.rb +434 -407
  370. data/lib/twilio-ruby/rest/preview/sync/service/sync_list/sync_list_permission.rb +378 -374
  371. data/lib/twilio-ruby/rest/preview/sync/service/sync_list.rb +419 -398
  372. data/lib/twilio-ruby/rest/preview/sync/service/sync_map/sync_map_item.rb +437 -404
  373. data/lib/twilio-ruby/rest/preview/sync/service/sync_map/sync_map_permission.rb +378 -374
  374. data/lib/twilio-ruby/rest/preview/sync/service/sync_map.rb +419 -398
  375. data/lib/twilio-ruby/rest/preview/sync/service.rb +495 -452
  376. data/lib/twilio-ruby/rest/preview/sync.rb +42 -37
  377. data/lib/twilio-ruby/rest/preview/wireless/command.rb +387 -364
  378. data/lib/twilio-ruby/rest/preview/wireless/rate_plan.rb +448 -398
  379. data/lib/twilio-ruby/rest/preview/wireless/sim/usage.rb +232 -205
  380. data/lib/twilio-ruby/rest/preview/wireless/sim.rb +574 -523
  381. data/lib/twilio-ruby/rest/preview/wireless.rb +72 -69
  382. data/lib/twilio-ruby/rest/preview.rb +11 -137
  383. data/lib/twilio-ruby/rest/preview_base.rb +58 -0
  384. data/lib/twilio-ruby/rest/pricing/v1/messaging/country.rb +297 -275
  385. data/lib/twilio-ruby/rest/pricing/v1/messaging.rb +107 -119
  386. data/lib/twilio-ruby/rest/pricing/v1/phone_number/country.rb +290 -268
  387. data/lib/twilio-ruby/rest/pricing/v1/phone_number.rb +107 -119
  388. data/lib/twilio-ruby/rest/pricing/v1/voice/country.rb +297 -275
  389. data/lib/twilio-ruby/rest/pricing/v1/voice/number.rb +220 -197
  390. data/lib/twilio-ruby/rest/pricing/v1/voice.rb +121 -135
  391. data/lib/twilio-ruby/rest/pricing/v1.rb +45 -42
  392. data/lib/twilio-ruby/rest/pricing/v2/country.rb +289 -270
  393. data/lib/twilio-ruby/rest/pricing/v2/number.rb +232 -217
  394. data/lib/twilio-ruby/rest/pricing/v2/voice/country.rb +297 -275
  395. data/lib/twilio-ruby/rest/pricing/v2/voice/number.rb +238 -220
  396. data/lib/twilio-ruby/rest/pricing/v2/voice.rb +121 -138
  397. data/lib/twilio-ruby/rest/pricing/v2.rb +63 -65
  398. data/lib/twilio-ruby/rest/pricing.rb +6 -41
  399. data/lib/twilio-ruby/rest/pricing_base.rb +43 -0
  400. data/lib/twilio-ruby/rest/proxy/v1/service/phone_number.rb +419 -403
  401. data/lib/twilio-ruby/rest/proxy/v1/service/session/interaction.rb +408 -418
  402. data/lib/twilio-ruby/rest/proxy/v1/service/session/participant/message_interaction.rb +430 -449
  403. data/lib/twilio-ruby/rest/proxy/v1/service/session/participant.rb +421 -455
  404. data/lib/twilio-ruby/rest/proxy/v1/service/session.rb +522 -547
  405. data/lib/twilio-ruby/rest/proxy/v1/service/short_code.rb +399 -370
  406. data/lib/twilio-ruby/rest/proxy/v1/service.rb +559 -596
  407. data/lib/twilio-ruby/rest/proxy/v1.rb +42 -38
  408. data/lib/twilio-ruby/rest/proxy.rb +2 -34
  409. data/lib/twilio-ruby/rest/proxy_base.rb +38 -0
  410. data/lib/twilio-ruby/rest/routes/v2/phone_number.rb +268 -0
  411. data/lib/twilio-ruby/rest/routes/v2/sip_domain.rb +268 -0
  412. data/lib/twilio-ruby/rest/routes/v2/trunk.rb +268 -0
  413. data/lib/twilio-ruby/rest/routes/v2.rb +79 -0
  414. data/lib/twilio-ruby/rest/routes.rb +32 -0
  415. data/lib/twilio-ruby/rest/routes_base.rb +38 -0
  416. data/lib/twilio-ruby/rest/serverless/v1/service/asset/asset_version.rb +315 -323
  417. data/lib/twilio-ruby/rest/serverless/v1/service/asset.rb +412 -380
  418. data/lib/twilio-ruby/rest/serverless/v1/service/build/build_status.rb +208 -208
  419. data/lib/twilio-ruby/rest/serverless/v1/service/build.rb +407 -384
  420. data/lib/twilio-ruby/rest/serverless/v1/service/environment/deployment.rb +336 -338
  421. data/lib/twilio-ruby/rest/serverless/v1/service/environment/log.rb +361 -383
  422. data/lib/twilio-ruby/rest/serverless/v1/service/environment/variable.rb +403 -396
  423. data/lib/twilio-ruby/rest/serverless/v1/service/environment.rb +456 -447
  424. data/lib/twilio-ruby/rest/serverless/v1/service/function/function_version/function_version_content.rb +223 -234
  425. data/lib/twilio-ruby/rest/serverless/v1/service/function/function_version.rb +342 -353
  426. data/lib/twilio-ruby/rest/serverless/v1/service/function.rb +412 -380
  427. data/lib/twilio-ruby/rest/serverless/v1/service.rb +523 -493
  428. data/lib/twilio-ruby/rest/serverless/v1.rb +42 -37
  429. data/lib/twilio-ruby/rest/serverless.rb +2 -34
  430. data/lib/twilio-ruby/rest/serverless_base.rb +38 -0
  431. data/lib/twilio-ruby/rest/studio/v1/flow/engagement/engagement_context.rb +206 -199
  432. data/lib/twilio-ruby/rest/studio/v1/flow/engagement/step/step_context.rb +221 -218
  433. data/lib/twilio-ruby/rest/studio/v1/flow/engagement/step.rb +361 -355
  434. data/lib/twilio-ruby/rest/studio/v1/flow/engagement.rb +422 -394
  435. data/lib/twilio-ruby/rest/studio/v1/flow/execution/execution_context.rb +206 -200
  436. data/lib/twilio-ruby/rest/studio/v1/flow/execution/execution_step/execution_step_context.rb +221 -221
  437. data/lib/twilio-ruby/rest/studio/v1/flow/execution/execution_step.rb +361 -361
  438. data/lib/twilio-ruby/rest/studio/v1/flow/execution.rb +468 -449
  439. data/lib/twilio-ruby/rest/studio/v1/flow.rb +380 -355
  440. data/lib/twilio-ruby/rest/studio/v1.rb +42 -37
  441. data/lib/twilio-ruby/rest/studio/v2/flow/execution/execution_context.rb +206 -200
  442. data/lib/twilio-ruby/rest/studio/v2/flow/execution/execution_step/execution_step_context.rb +221 -221
  443. data/lib/twilio-ruby/rest/studio/v2/flow/execution/execution_step.rb +361 -361
  444. data/lib/twilio-ruby/rest/studio/v2/flow/execution.rb +461 -442
  445. data/lib/twilio-ruby/rest/studio/v2/flow/flow_revision.rb +341 -320
  446. data/lib/twilio-ruby/rest/studio/v2/flow/flow_test_user.rb +232 -0
  447. data/lib/twilio-ruby/rest/studio/v2/flow.rb +519 -472
  448. data/lib/twilio-ruby/rest/studio/v2/flow_validate.rb +121 -99
  449. data/lib/twilio-ruby/rest/studio/v2.rb +48 -44
  450. data/lib/twilio-ruby/rest/studio.rb +3 -41
  451. data/lib/twilio-ruby/rest/studio_base.rb +43 -0
  452. data/lib/twilio-ruby/rest/supersim/v1/esim_profile.rb +403 -0
  453. data/lib/twilio-ruby/rest/supersim/v1/fleet.rb +472 -484
  454. data/lib/twilio-ruby/rest/supersim/v1/ip_command.rb +398 -406
  455. data/lib/twilio-ruby/rest/supersim/v1/network.rb +302 -297
  456. data/lib/twilio-ruby/rest/supersim/v1/network_access_profile/network_access_profile_network.rb +337 -332
  457. data/lib/twilio-ruby/rest/supersim/v1/network_access_profile.rb +380 -351
  458. data/lib/twilio-ruby/rest/supersim/v1/settings_update.rb +256 -0
  459. data/lib/twilio-ruby/rest/supersim/v1/sim/billing_period.rb +242 -224
  460. data/lib/twilio-ruby/rest/supersim/v1/sim/sim_ip_address.rb +207 -0
  461. data/lib/twilio-ruby/rest/supersim/v1/sim.rb +460 -433
  462. data/lib/twilio-ruby/rest/supersim/v1/sms_command.rb +358 -361
  463. data/lib/twilio-ruby/rest/supersim/v1/usage_record.rb +286 -311
  464. data/lib/twilio-ruby/rest/supersim/v1.rb +144 -140
  465. data/lib/twilio-ruby/rest/supersim.rb +22 -40
  466. data/lib/twilio-ruby/rest/supersim_base.rb +38 -0
  467. data/lib/twilio-ruby/rest/sync/v1/service/document/document_permission.rb +376 -371
  468. data/lib/twilio-ruby/rest/sync/v1/service/document.rb +456 -423
  469. data/lib/twilio-ruby/rest/sync/v1/service/sync_list/sync_list_item.rb +466 -490
  470. data/lib/twilio-ruby/rest/sync/v1/service/sync_list/sync_list_permission.rb +376 -370
  471. data/lib/twilio-ruby/rest/sync/v1/service/sync_list.rb +470 -445
  472. data/lib/twilio-ruby/rest/sync/v1/service/sync_map/sync_map_item.rb +469 -495
  473. data/lib/twilio-ruby/rest/sync/v1/service/sync_map/sync_map_permission.rb +376 -368
  474. data/lib/twilio-ruby/rest/sync/v1/service/sync_map.rb +470 -444
  475. data/lib/twilio-ruby/rest/sync/v1/service/sync_stream/stream_message.rb +139 -132
  476. data/lib/twilio-ruby/rest/sync/v1/service/sync_stream.rb +419 -400
  477. data/lib/twilio-ruby/rest/sync/v1/service.rb +575 -567
  478. data/lib/twilio-ruby/rest/sync/v1.rb +42 -37
  479. data/lib/twilio-ruby/rest/sync.rb +2 -34
  480. data/lib/twilio-ruby/rest/sync_base.rb +38 -0
  481. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/activity.rb +405 -395
  482. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/event.rb +442 -464
  483. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/task/reservation.rb +705 -736
  484. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/task.rb +623 -661
  485. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/task_channel.rb +409 -382
  486. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/task_queue/task_queue_cumulative_statistics.rb +359 -365
  487. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/task_queue/task_queue_real_time_statistics.rb +279 -275
  488. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/task_queue/task_queue_statistics.rb +230 -236
  489. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/task_queue/task_queues_statistics.rb +239 -258
  490. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/task_queue.rb +574 -566
  491. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/worker/reservation.rb +687 -732
  492. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/worker/worker_channel.rb +389 -388
  493. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/worker/worker_statistics.rb +235 -239
  494. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/worker/workers_cumulative_statistics.rb +281 -265
  495. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/worker/workers_real_time_statistics.rb +215 -193
  496. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/worker/workers_statistics.rb +251 -234
  497. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/worker.rb +623 -631
  498. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/workflow/workflow_cumulative_statistics.rb +359 -373
  499. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/workflow/workflow_real_time_statistics.rb +245 -241
  500. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/workflow/workflow_statistics.rb +230 -244
  501. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/workflow.rb +523 -510
  502. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/workspace_cumulative_statistics.rb +353 -354
  503. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/workspace_real_time_statistics.rb +231 -206
  504. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/workspace_statistics.rb +241 -234
  505. data/lib/twilio-ruby/rest/taskrouter/v1/workspace.rb +720 -730
  506. data/lib/twilio-ruby/rest/taskrouter/v1.rb +42 -37
  507. data/lib/twilio-ruby/rest/taskrouter.rb +2 -34
  508. data/lib/twilio-ruby/rest/taskrouter_base.rb +38 -0
  509. data/lib/twilio-ruby/rest/trunking/v1/trunk/credential_list.rb +342 -320
  510. data/lib/twilio-ruby/rest/trunking/v1/trunk/ip_access_control_list.rb +342 -317
  511. data/lib/twilio-ruby/rest/trunking/v1/trunk/origination_url.rb +440 -419
  512. data/lib/twilio-ruby/rest/trunking/v1/trunk/phone_number.rb +475 -451
  513. data/lib/twilio-ruby/rest/trunking/v1/trunk/recording.rb +224 -191
  514. data/lib/twilio-ruby/rest/trunking/v1/trunk.rb +623 -630
  515. data/lib/twilio-ruby/rest/trunking/v1.rb +42 -38
  516. data/lib/twilio-ruby/rest/trunking.rb +2 -34
  517. data/lib/twilio-ruby/rest/trunking_base.rb +38 -0
  518. data/lib/twilio-ruby/rest/trusthub/v1/compliance_inquiries.rb +232 -0
  519. data/lib/twilio-ruby/rest/trusthub/v1/compliance_tollfree_inquiries.rb +211 -0
  520. data/lib/twilio-ruby/rest/trusthub/v1/customer_profiles/customer_profiles_channel_endpoint_assignment.rb +357 -352
  521. data/lib/twilio-ruby/rest/trusthub/v1/customer_profiles/customer_profiles_entity_assignments.rb +335 -323
  522. data/lib/twilio-ruby/rest/trusthub/v1/customer_profiles/customer_profiles_evaluations.rb +333 -321
  523. data/lib/twilio-ruby/rest/trusthub/v1/customer_profiles.rb +525 -513
  524. data/lib/twilio-ruby/rest/trusthub/v1/end_user.rb +383 -346
  525. data/lib/twilio-ruby/rest/trusthub/v1/end_user_type.rb +282 -261
  526. data/lib/twilio-ruby/rest/trusthub/v1/policies.rb +275 -252
  527. data/lib/twilio-ruby/rest/trusthub/v1/supporting_document.rb +397 -359
  528. data/lib/twilio-ruby/rest/trusthub/v1/supporting_document_type.rb +282 -261
  529. data/lib/twilio-ruby/rest/trusthub/v1/trust_products/trust_products_channel_endpoint_assignment.rb +357 -352
  530. data/lib/twilio-ruby/rest/trusthub/v1/trust_products/trust_products_entity_assignments.rb +335 -323
  531. data/lib/twilio-ruby/rest/trusthub/v1/trust_products/trust_products_evaluations.rb +333 -321
  532. data/lib/twilio-ruby/rest/trusthub/v1/trust_products.rb +525 -513
  533. data/lib/twilio-ruby/rest/trusthub/v1.rb +153 -139
  534. data/lib/twilio-ruby/rest/trusthub.rb +8 -34
  535. data/lib/twilio-ruby/rest/trusthub_base.rb +38 -0
  536. data/lib/twilio-ruby/rest/verify/v2/form.rb +195 -183
  537. data/lib/twilio-ruby/rest/verify/v2/safelist.rb +231 -0
  538. data/lib/twilio-ruby/rest/verify/v2/service/access_token.rb +265 -116
  539. data/lib/twilio-ruby/rest/verify/v2/service/entity/challenge/notification.rb +191 -198
  540. data/lib/twilio-ruby/rest/verify/v2/service/entity/challenge.rb +496 -521
  541. data/lib/twilio-ruby/rest/verify/v2/service/entity/factor.rb +447 -454
  542. data/lib/twilio-ruby/rest/verify/v2/service/entity/new_factor.rb +249 -279
  543. data/lib/twilio-ruby/rest/verify/v2/service/entity.rb +422 -422
  544. data/lib/twilio-ruby/rest/verify/v2/service/messaging_configuration.rb +379 -363
  545. data/lib/twilio-ruby/rest/verify/v2/service/rate_limit/bucket.rb +401 -388
  546. data/lib/twilio-ruby/rest/verify/v2/service/rate_limit.rb +420 -384
  547. data/lib/twilio-ruby/rest/verify/v2/service/verification.rb +380 -359
  548. data/lib/twilio-ruby/rest/verify/v2/service/verification_check.rb +218 -198
  549. data/lib/twilio-ruby/rest/verify/v2/service/webhook.rb +447 -420
  550. data/lib/twilio-ruby/rest/verify/v2/service.rb +782 -770
  551. data/lib/twilio-ruby/rest/verify/v2/template.rb +221 -198
  552. data/lib/twilio-ruby/rest/verify/v2/verification_attempt.rb +372 -319
  553. data/lib/twilio-ruby/rest/verify/v2/verification_attempts_summary.rb +247 -0
  554. data/lib/twilio-ruby/rest/verify/v2.rb +99 -78
  555. data/lib/twilio-ruby/rest/verify.rb +23 -36
  556. data/lib/twilio-ruby/rest/verify_base.rb +38 -0
  557. data/lib/twilio-ruby/rest/video/v1/composition.rb +477 -486
  558. data/lib/twilio-ruby/rest/video/v1/composition_hook.rb +525 -647
  559. data/lib/twilio-ruby/rest/video/v1/composition_settings.rb +281 -261
  560. data/lib/twilio-ruby/rest/video/v1/recording.rb +426 -405
  561. data/lib/twilio-ruby/rest/video/v1/recording_settings.rb +281 -261
  562. data/lib/twilio-ruby/rest/video/v1/room/participant/anonymize.rb +259 -0
  563. data/lib/twilio-ruby/rest/video/v1/room/participant/published_track.rb +331 -0
  564. data/lib/twilio-ruby/rest/video/v1/room/participant/subscribe_rules.rb +181 -0
  565. data/lib/twilio-ruby/rest/video/v1/room/participant/subscribed_track.rb +338 -0
  566. data/lib/twilio-ruby/rest/video/v1/room/participant.rb +498 -0
  567. data/lib/twilio-ruby/rest/video/v1/room/recording_rules.rb +170 -0
  568. data/lib/twilio-ruby/rest/video/v1/room/room_recording.rb +423 -0
  569. data/lib/twilio-ruby/rest/video/v1/room.rb +606 -567
  570. data/lib/twilio-ruby/rest/video/v1.rb +99 -99
  571. data/lib/twilio-ruby/rest/video.rb +7 -34
  572. data/lib/twilio-ruby/rest/video_base.rb +38 -0
  573. data/lib/twilio-ruby/rest/voice/v1/archived_call.rb +168 -0
  574. data/lib/twilio-ruby/rest/voice/v1/byoc_trunk.rb +501 -486
  575. data/lib/twilio-ruby/rest/voice/v1/connection_policy/connection_policy_target.rb +440 -434
  576. data/lib/twilio-ruby/rest/voice/v1/connection_policy.rb +391 -352
  577. data/lib/twilio-ruby/rest/voice/v1/dialing_permissions/bulk_country_update.rb +135 -121
  578. data/lib/twilio-ruby/rest/voice/v1/dialing_permissions/country/highrisk_special_prefix.rb +195 -183
  579. data/lib/twilio-ruby/rest/voice/v1/dialing_permissions/country.rb +375 -397
  580. data/lib/twilio-ruby/rest/voice/v1/dialing_permissions/settings.rb +217 -190
  581. data/lib/twilio-ruby/rest/voice/v1/dialing_permissions.rb +122 -121
  582. data/lib/twilio-ruby/rest/voice/v1/ip_record.rb +377 -339
  583. data/lib/twilio-ruby/rest/voice/v1/source_ip_mapping.rb +360 -319
  584. data/lib/twilio-ruby/rest/voice/v1.rb +130 -96
  585. data/lib/twilio-ruby/rest/voice.rb +12 -31
  586. data/lib/twilio-ruby/rest/voice_base.rb +38 -0
  587. data/lib/twilio-ruby/rest/wireless/v1/command.rb +408 -406
  588. data/lib/twilio-ruby/rest/wireless/v1/rate_plan.rb +463 -436
  589. data/lib/twilio-ruby/rest/wireless/v1/sim/data_session.rb +298 -284
  590. data/lib/twilio-ruby/rest/wireless/v1/sim/usage_record.rb +239 -243
  591. data/lib/twilio-ruby/rest/wireless/v1/sim.rb +634 -647
  592. data/lib/twilio-ruby/rest/wireless/v1/usage_record.rb +226 -221
  593. data/lib/twilio-ruby/rest/wireless/v1.rb +78 -76
  594. data/lib/twilio-ruby/rest/wireless.rb +5 -34
  595. data/lib/twilio-ruby/rest/wireless_base.rb +38 -0
  596. data/lib/twilio-ruby/rest.rb +1 -0
  597. data/lib/twilio-ruby/security/request_validator.rb +1 -1
  598. data/lib/twilio-ruby/twiml/voice_response.rb +209 -42
  599. data/lib/twilio-ruby/version.rb +1 -1
  600. data/lib/twilio-ruby.rb +1 -1
  601. data/sonar-project.properties +2 -2
  602. data/twilio-ruby.gemspec +2 -3
  603. metadata +155 -98
  604. data/.github/workflows/deploy.yml +0 -65
  605. data/.github/workflows/test.yml +0 -52
  606. data/conf/cacert.pem +0 -3376
  607. data/lib/twilio-ruby/framework/twilio_response.rb +0 -19
  608. data/lib/twilio-ruby/rest/api/v2010/account/available_phone_number/local.rb +0 -500
  609. data/lib/twilio-ruby/rest/api/v2010/account/available_phone_number/machine_to_machine.rb +0 -500
  610. data/lib/twilio-ruby/rest/api/v2010/account/available_phone_number/mobile.rb +0 -500
  611. data/lib/twilio-ruby/rest/api/v2010/account/available_phone_number/national.rb +0 -500
  612. data/lib/twilio-ruby/rest/api/v2010/account/available_phone_number/shared_cost.rb +0 -500
  613. data/lib/twilio-ruby/rest/api/v2010/account/available_phone_number/toll_free.rb +0 -500
  614. data/lib/twilio-ruby/rest/api/v2010/account/available_phone_number/voip.rb +0 -500
  615. data/lib/twilio-ruby/rest/api/v2010/account/available_phone_number.rb +0 -464
  616. data/lib/twilio-ruby/rest/api/v2010/account/sip/domain/auth_types/auth_calls_mapping/auth_calls_credential_list_mapping.rb +0 -348
  617. data/lib/twilio-ruby/rest/api/v2010/account/sip/domain/auth_types/auth_calls_mapping.rb +0 -163
  618. data/lib/twilio-ruby/rest/api/v2010/account/sip/domain/auth_types/auth_registrations_mapping.rb +0 -137
  619. data/lib/twilio-ruby/rest/autopilot/v1/assistant/defaults.rb +0 -220
  620. data/lib/twilio-ruby/rest/autopilot/v1/assistant/dialogue.rb +0 -214
  621. data/lib/twilio-ruby/rest/autopilot/v1/assistant/field_type/field_value.rb +0 -399
  622. data/lib/twilio-ruby/rest/autopilot/v1/assistant/field_type.rb +0 -418
  623. data/lib/twilio-ruby/rest/autopilot/v1/assistant/model_build.rb +0 -392
  624. data/lib/twilio-ruby/rest/autopilot/v1/assistant/query.rb +0 -469
  625. data/lib/twilio-ruby/rest/autopilot/v1/assistant/style_sheet.rb +0 -218
  626. data/lib/twilio-ruby/rest/autopilot/v1/assistant/task/field.rb +0 -386
  627. data/lib/twilio-ruby/rest/autopilot/v1/assistant/task/sample.rb +0 -456
  628. data/lib/twilio-ruby/rest/autopilot/v1/assistant/task/task_actions.rb +0 -255
  629. data/lib/twilio-ruby/rest/autopilot/v1/assistant/task/task_statistics.rb +0 -237
  630. data/lib/twilio-ruby/rest/autopilot/v1/assistant/task.rb +0 -507
  631. data/lib/twilio-ruby/rest/autopilot/v1/assistant/webhook.rb +0 -420
  632. data/lib/twilio-ruby/rest/autopilot/v1/assistant.rb +0 -650
  633. data/lib/twilio-ruby/rest/autopilot/v1/restore_assistant.rb +0 -194
  634. data/lib/twilio-ruby/rest/autopilot/v1.rb +0 -52
  635. data/lib/twilio-ruby/rest/autopilot.rb +0 -53
  636. data/lib/twilio-ruby/rest/events/v1/schema/version.rb +0 -290
  637. data/lib/twilio-ruby/rest/fax/v1/fax/fax_media.rb +0 -314
  638. data/lib/twilio-ruby/rest/fax/v1/fax.rb +0 -536
  639. data/lib/twilio-ruby/rest/fax/v1.rb +0 -45
  640. data/lib/twilio-ruby/rest/fax.rb +0 -47
  641. data/lib/twilio-ruby/rest/insights/v1/call/summary.rb +0 -307
  642. data/lib/twilio-ruby/rest/messaging/v1/deactivation.rb +0 -164
  643. data/lib/twilio-ruby/rest/preview/bulk_exports/export/day.rb +0 -294
  644. data/lib/twilio-ruby/rest/preview/bulk_exports/export/export_custom_job.rb +0 -275
  645. data/lib/twilio-ruby/rest/preview/bulk_exports/export/job.rb +0 -249
  646. data/lib/twilio-ruby/rest/preview/bulk_exports/export.rb +0 -251
  647. data/lib/twilio-ruby/rest/preview/bulk_exports/export_configuration.rb +0 -234
  648. data/lib/twilio-ruby/rest/preview/bulk_exports.rb +0 -62
  649. data/lib/twilio-ruby/rest/preview/trusted_comms/branded_channel/channel.rb +0 -165
  650. data/lib/twilio-ruby/rest/preview/trusted_comms/branded_channel.rb +0 -225
  651. data/lib/twilio-ruby/rest/preview/trusted_comms/brands_information.rb +0 -195
  652. data/lib/twilio-ruby/rest/preview/trusted_comms/cps.rb +0 -186
  653. data/lib/twilio-ruby/rest/preview/trusted_comms/current_call.rb +0 -277
  654. data/lib/twilio-ruby/rest/preview/trusted_comms.rb +0 -65
  655. data/lib/twilio-ruby/rest/preview/understand/assistant/assistant_fallback_actions.rb +0 -212
  656. data/lib/twilio-ruby/rest/preview/understand/assistant/assistant_initiation_actions.rb +0 -212
  657. data/lib/twilio-ruby/rest/preview/understand/assistant/dialogue.rb +0 -206
  658. data/lib/twilio-ruby/rest/preview/understand/assistant/field_type/field_value.rb +0 -386
  659. data/lib/twilio-ruby/rest/preview/understand/assistant/field_type.rb +0 -407
  660. data/lib/twilio-ruby/rest/preview/understand/assistant/model_build.rb +0 -380
  661. data/lib/twilio-ruby/rest/preview/understand/assistant/query.rb +0 -437
  662. data/lib/twilio-ruby/rest/preview/understand/assistant/style_sheet.rb +0 -212
  663. data/lib/twilio-ruby/rest/preview/understand/assistant/task/field.rb +0 -373
  664. data/lib/twilio-ruby/rest/preview/understand/assistant/task/sample.rb +0 -428
  665. data/lib/twilio-ruby/rest/preview/understand/assistant/task/task_actions.rb +0 -241
  666. data/lib/twilio-ruby/rest/preview/understand/assistant/task/task_statistics.rb +0 -225
  667. data/lib/twilio-ruby/rest/preview/understand/assistant/task.rb +0 -495
  668. data/lib/twilio-ruby/rest/preview/understand/assistant.rb +0 -629
  669. data/lib/twilio-ruby/rest/preview/understand.rb +0 -45
  670. data/lib/twilio-ruby/rest/studio/v2/flow/test_user.rb +0 -199
  671. data/lib/twilio-ruby/rest/supersim/v1/command.rb +0 -368
  672. data/lib/twilio-ruby/rest/video/v1/room/recording.rb +0 -406
  673. data/lib/twilio-ruby/rest/video/v1/room/room_participant/room_participant_published_track.rb +0 -335
  674. data/lib/twilio-ruby/rest/video/v1/room/room_participant/room_participant_subscribe_rule.rb +0 -175
  675. data/lib/twilio-ruby/rest/video/v1/room/room_participant/room_participant_subscribed_track.rb +0 -340
  676. data/lib/twilio-ruby/rest/video/v1/room/room_participant.rb +0 -483
  677. data/lib/twilio-ruby/rest/video/v1/room/room_recording_rule.rb +0 -144
@@ -1,657 +1,535 @@
1
1
  ##
2
- # This code was generated by
3
- # \ / _ _ _| _ _
4
- # | (_)\/(_)(_|\/| |(/_ v1.0.0
5
- # / /
2
+ # This code was generated by
3
+ # ___ _ _ _ _ _ _ ____ ____ ____ _ ____ ____ _ _ ____ ____ ____ ___ __ __
4
+ # | | | | | | | | | __ | | |__| | __ | __ |___ |\ | |___ |__/ |__| | | | |__/
5
+ # | |_|_| | |___ | |__| |__| | | | |__] |___ | \| |___ | \ | | | |__| | \
6
+ #
7
+ # Twilio - Video
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.
6
13
  #
7
- # frozen_string_literal: true
14
+
8
15
 
9
16
  module Twilio
10
- module REST
11
- class Video < Domain
12
- class V1 < Version
13
- class CompositionHookList < ListResource
14
- ##
15
- # Initialize the CompositionHookList
16
- # @param [Version] version Version that contains the resource
17
- # @return [CompositionHookList] CompositionHookList
18
- def initialize(version)
19
- super(version)
20
-
21
- # Path Solution
22
- @solution = {}
23
- @uri = "/CompositionHooks"
24
- end
25
-
26
- ##
27
- # Lists CompositionHookInstance records from the API as a list.
28
- # Unlike stream(), this operation is eager and will load `limit` records into
29
- # memory before returning.
30
- # @param [Boolean] enabled Read only CompositionHook resources with an `enabled`
31
- # value that matches this parameter.
32
- # @param [Time] date_created_after Read only CompositionHook resources created on
33
- # or after this {ISO 8601}[https://en.wikipedia.org/wiki/ISO_8601] datetime with
34
- # time zone.
35
- # @param [Time] date_created_before Read only CompositionHook resources created
36
- # before this {ISO 8601}[https://en.wikipedia.org/wiki/ISO_8601] datetime with
37
- # time zone.
38
- # @param [String] friendly_name Read only CompositionHook resources with friendly
39
- # names that match this string. The match is not case sensitive and can include
40
- # asterisk `*` characters as wildcard match.
41
- # @param [Integer] limit Upper limit for the number of records to return. stream()
42
- # guarantees to never return more than limit. Default is no limit
43
- # @param [Integer] page_size Number of records to fetch per request, when
44
- # not set will use the default value of 50 records. If no page_size is defined
45
- # but a limit is defined, stream() will attempt to read the limit with the most
46
- # efficient page size, i.e. min(limit, 1000)
47
- # @return [Array] Array of up to limit results
48
- def list(enabled: :unset, date_created_after: :unset, date_created_before: :unset, friendly_name: :unset, limit: nil, page_size: nil)
49
- self.stream(
50
- enabled: enabled,
51
- date_created_after: date_created_after,
52
- date_created_before: date_created_before,
53
- friendly_name: friendly_name,
54
- limit: limit,
55
- page_size: page_size
56
- ).entries
57
- end
58
-
59
- ##
60
- # Streams CompositionHookInstance records from the API as an Enumerable.
61
- # This operation lazily loads records as efficiently as possible until the limit
62
- # is reached.
63
- # @param [Boolean] enabled Read only CompositionHook resources with an `enabled`
64
- # value that matches this parameter.
65
- # @param [Time] date_created_after Read only CompositionHook resources created on
66
- # or after this {ISO 8601}[https://en.wikipedia.org/wiki/ISO_8601] datetime with
67
- # time zone.
68
- # @param [Time] date_created_before Read only CompositionHook resources created
69
- # before this {ISO 8601}[https://en.wikipedia.org/wiki/ISO_8601] datetime with
70
- # time zone.
71
- # @param [String] friendly_name Read only CompositionHook resources with friendly
72
- # names that match this string. The match is not case sensitive and can include
73
- # asterisk `*` characters as wildcard match.
74
- # @param [Integer] limit Upper limit for the number of records to return. stream()
75
- # guarantees to never return more than limit. Default is no limit.
76
- # @param [Integer] page_size Number of records to fetch per request, when
77
- # not set will use the default value of 50 records. If no page_size is defined
78
- # but a limit is defined, stream() will attempt to read the limit with the most
79
- # efficient page size, i.e. min(limit, 1000)
80
- # @return [Enumerable] Enumerable that will yield up to limit results
81
- def stream(enabled: :unset, date_created_after: :unset, date_created_before: :unset, friendly_name: :unset, limit: nil, page_size: nil)
82
- limits = @version.read_limits(limit, page_size)
83
-
84
- page = self.page(
85
- enabled: enabled,
86
- date_created_after: date_created_after,
87
- date_created_before: date_created_before,
88
- friendly_name: friendly_name,
89
- page_size: limits[:page_size],
90
- )
91
-
92
- @version.stream(page, limit: limits[:limit], page_limit: limits[:page_limit])
93
- end
94
-
95
- ##
96
- # When passed a block, yields CompositionHookInstance records from the API.
97
- # This operation lazily loads records as efficiently as possible until the limit
98
- # is reached.
99
- def each
100
- limits = @version.read_limits
101
-
102
- page = self.page(page_size: limits[:page_size], )
103
-
104
- @version.stream(page,
17
+ module REST
18
+ class Video < VideoBase
19
+ class V1 < Version
20
+ class CompositionHookList < ListResource
21
+ ##
22
+ # Initialize the CompositionHookList
23
+ # @param [Version] version Version that contains the resource
24
+ # @return [CompositionHookList] CompositionHookList
25
+ def initialize(version)
26
+ super(version)
27
+ # Path Solution
28
+ @solution = { }
29
+ @uri = "/CompositionHooks"
30
+
31
+ end
32
+ ##
33
+ # Create the CompositionHookInstance
34
+ # @param [String] friendly_name A descriptive string that you create to describe the resource. It can be up to 100 characters long and it must be unique within the account.
35
+ # @param [Boolean] enabled Whether the composition hook is active. When `true`, the composition hook will be triggered for every completed Group Room in the account. When `false`, the composition hook will never be triggered.
36
+ # @param [Object] video_layout An object that describes the video layout of the composition hook in terms of regions. See [Specifying Video Layouts](https://www.twilio.com/docs/video/api/compositions-resource#specifying-video-layouts) for more info.
37
+ # @param [Array[String]] audio_sources An array of track names from the same group room to merge into the compositions created by the composition hook. Can include zero or more track names. A composition triggered by the composition hook includes all audio sources specified in `audio_sources` except those specified in `audio_sources_excluded`. The track names in this parameter can include an asterisk as a wild card character, which matches zero or more characters in a track name. For example, `student*` includes tracks named `student` as well as `studentTeam`.
38
+ # @param [Array[String]] audio_sources_excluded An array of track names to exclude. A composition triggered by the composition hook includes all audio sources specified in `audio_sources` except for those specified in `audio_sources_excluded`. The track names in this parameter can include an asterisk as a wild card character, which matches zero or more characters in a track name. For example, `student*` excludes `student` as well as `studentTeam`. This parameter can also be empty.
39
+ # @param [String] resolution A string that describes the columns (width) and rows (height) of the generated composed video in pixels. Defaults to `640x480`. The string's format is `{width}x{height}` where: * 16 <= `{width}` <= 1280 * 16 <= `{height}` <= 1280 * `{width}` * `{height}` <= 921,600 Typical values are: * HD = `1280x720` * PAL = `1024x576` * VGA = `640x480` * CIF = `320x240` Note that the `resolution` imposes an aspect ratio to the resulting composition. When the original video tracks are constrained by the aspect ratio, they are scaled to fit. See [Specifying Video Layouts](https://www.twilio.com/docs/video/api/compositions-resource#specifying-video-layouts) for more info.
40
+ # @param [Format] format
41
+ # @param [String] status_callback The URL we should call using the `status_callback_method` to send status information to your application on every composition event. If not provided, status callback events will not be dispatched.
42
+ # @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`.
43
+ # @param [Boolean] trim Whether to clip the intervals where there is no active media in the Compositions triggered by the composition hook. The default is `true`. Compositions with `trim` enabled are shorter when the Room is created and no Participant joins for a while as well as if all the Participants leave the room and join later, because those gaps will be removed. See [Specifying Video Layouts](https://www.twilio.com/docs/video/api/compositions-resource#specifying-video-layouts) for more info.
44
+ # @return [CompositionHookInstance] Created CompositionHookInstance
45
+ def create(
46
+ friendly_name: nil,
47
+ enabled: :unset,
48
+ video_layout: :unset,
49
+ audio_sources: :unset,
50
+ audio_sources_excluded: :unset,
51
+ resolution: :unset,
52
+ format: :unset,
53
+ status_callback: :unset,
54
+ status_callback_method: :unset,
55
+ trim: :unset
56
+ )
57
+
58
+ data = Twilio::Values.of({
59
+ 'FriendlyName' => friendly_name,
60
+ 'Enabled' => enabled,
61
+ 'VideoLayout' => Twilio.serialize_object(video_layout),
62
+ 'AudioSources' => Twilio.serialize_list(audio_sources) { |e| e },
63
+ 'AudioSourcesExcluded' => Twilio.serialize_list(audio_sources_excluded) { |e| e },
64
+ 'Resolution' => resolution,
65
+ 'Format' => format,
66
+ 'StatusCallback' => status_callback,
67
+ 'StatusCallbackMethod' => status_callback_method,
68
+ 'Trim' => trim,
69
+ })
70
+
71
+ payload = @version.create('POST', @uri, data: data)
72
+ CompositionHookInstance.new(
73
+ @version,
74
+ payload,
75
+ )
76
+ end
77
+
78
+
79
+ ##
80
+ # Lists CompositionHookInstance records from the API as a list.
81
+ # Unlike stream(), this operation is eager and will load `limit` records into
82
+ # memory before returning.
83
+ # @param [Boolean] enabled Read only CompositionHook resources with an `enabled` value that matches this parameter.
84
+ # @param [Time] date_created_after Read only CompositionHook resources created on or after this [ISO 8601](https://en.wikipedia.org/wiki/ISO_8601) datetime with time zone.
85
+ # @param [Time] date_created_before Read only CompositionHook resources created before this [ISO 8601](https://en.wikipedia.org/wiki/ISO_8601) datetime with time zone.
86
+ # @param [String] friendly_name Read only CompositionHook resources with friendly names that match this string. The match is not case sensitive and can include asterisk `*` characters as wildcard match.
87
+ # @param [Integer] limit Upper limit for the number of records to return. stream()
88
+ # guarantees to never return more than limit. Default is no limit
89
+ # @param [Integer] page_size Number of records to fetch per request, when
90
+ # not set will use the default value of 50 records. If no page_size is defined
91
+ # but a limit is defined, stream() will attempt to read the limit with the most
92
+ # efficient page size, i.e. min(limit, 1000)
93
+ # @return [Array] Array of up to limit results
94
+ def list(enabled: :unset, date_created_after: :unset, date_created_before: :unset, friendly_name: :unset, limit: nil, page_size: nil)
95
+ self.stream(
96
+ enabled: enabled,
97
+ date_created_after: date_created_after,
98
+ date_created_before: date_created_before,
99
+ friendly_name: friendly_name,
100
+ limit: limit,
101
+ page_size: page_size
102
+ ).entries
103
+ end
104
+
105
+ ##
106
+ # Streams Instance records from the API as an Enumerable.
107
+ # This operation lazily loads records as efficiently as possible until the limit
108
+ # is reached.
109
+ # @param [Boolean] enabled Read only CompositionHook resources with an `enabled` value that matches this parameter.
110
+ # @param [Time] date_created_after Read only CompositionHook resources created on or after this [ISO 8601](https://en.wikipedia.org/wiki/ISO_8601) datetime with time zone.
111
+ # @param [Time] date_created_before Read only CompositionHook resources created before this [ISO 8601](https://en.wikipedia.org/wiki/ISO_8601) datetime with time zone.
112
+ # @param [String] friendly_name Read only CompositionHook resources with friendly names that match this string. The match is not case sensitive and can include asterisk `*` characters as wildcard match.
113
+ # @param [Integer] limit Upper limit for the number of records to return. stream()
114
+ # guarantees to never return more than limit. Default is no limit
115
+ # @param [Integer] page_size Number of records to fetch per request, when
116
+ # not set will use the default value of 50 records. If no page_size is defined
117
+ # but a limit is defined, stream() will attempt to read the limit with the most
118
+ # efficient page size, i.e. min(limit, 1000)
119
+ # @return [Enumerable] Enumerable that will yield up to limit results
120
+ def stream(enabled: :unset, date_created_after: :unset, date_created_before: :unset, friendly_name: :unset, limit: nil, page_size: nil)
121
+ limits = @version.read_limits(limit, page_size)
122
+
123
+ page = self.page(
124
+ enabled: enabled,
125
+ date_created_after: date_created_after,
126
+ date_created_before: date_created_before,
127
+ friendly_name: friendly_name,
128
+ page_size: limits[:page_size], )
129
+
130
+ @version.stream(page, limit: limits[:limit], page_limit: limits[:page_limit])
131
+ end
132
+
133
+ ##
134
+ # When passed a block, yields CompositionHookInstance records from the API.
135
+ # This operation lazily loads records as efficiently as possible until the limit
136
+ # is reached.
137
+ def each
138
+ limits = @version.read_limits
139
+
140
+ page = self.page(page_size: limits[:page_size], )
141
+
142
+ @version.stream(page,
105
143
  limit: limits[:limit],
106
144
  page_limit: limits[:page_limit]).each {|x| yield x}
107
- end
108
-
109
- ##
110
- # Retrieve a single page of CompositionHookInstance records from the API.
111
- # Request is executed immediately.
112
- # @param [Boolean] enabled Read only CompositionHook resources with an `enabled`
113
- # value that matches this parameter.
114
- # @param [Time] date_created_after Read only CompositionHook resources created on
115
- # or after this {ISO 8601}[https://en.wikipedia.org/wiki/ISO_8601] datetime with
116
- # time zone.
117
- # @param [Time] date_created_before Read only CompositionHook resources created
118
- # before this {ISO 8601}[https://en.wikipedia.org/wiki/ISO_8601] datetime with
119
- # time zone.
120
- # @param [String] friendly_name Read only CompositionHook resources with friendly
121
- # names that match this string. The match is not case sensitive and can include
122
- # asterisk `*` characters as wildcard match.
123
- # @param [String] page_token PageToken provided by the API
124
- # @param [Integer] page_number Page Number, this value is simply for client state
125
- # @param [Integer] page_size Number of records to return, defaults to 50
126
- # @return [Page] Page of CompositionHookInstance
127
- def page(enabled: :unset, date_created_after: :unset, date_created_before: :unset, friendly_name: :unset, page_token: :unset, page_number: :unset, page_size: :unset)
128
- params = Twilio::Values.of({
129
- 'Enabled' => enabled,
130
- 'DateCreatedAfter' => Twilio.serialize_iso8601_datetime(date_created_after),
131
- 'DateCreatedBefore' => Twilio.serialize_iso8601_datetime(date_created_before),
132
- 'FriendlyName' => friendly_name,
133
- 'PageToken' => page_token,
134
- 'Page' => page_number,
135
- 'PageSize' => page_size,
136
- })
137
-
138
- response = @version.page('GET', @uri, params: params)
139
-
140
- CompositionHookPage.new(@version, response, @solution)
141
- end
142
-
143
- ##
144
- # Retrieve a single page of CompositionHookInstance records from the API.
145
- # Request is executed immediately.
146
- # @param [String] target_url API-generated URL for the requested results page
147
- # @return [Page] Page of CompositionHookInstance
148
- def get_page(target_url)
149
- response = @version.domain.request(
150
- 'GET',
151
- target_url
152
- )
153
- CompositionHookPage.new(@version, response, @solution)
154
- end
155
-
156
- ##
157
- # Create the CompositionHookInstance
158
- # @param [String] friendly_name A descriptive string that you create to describe
159
- # the resource. It can be up to 100 characters long and it must be unique within
160
- # the account.
161
- # @param [Boolean] enabled Whether the composition hook is active. When `true`,
162
- # the composition hook will be triggered for every completed Group Room in the
163
- # account. When `false`, the composition hook will never be triggered.
164
- # @param [Hash] video_layout An object that describes the video layout of the
165
- # composition hook in terms of regions. See {Specifying Video
166
- # Layouts}[https://www.twilio.com/docs/video/api/compositions-resource#specifying-video-layouts]
167
- # for more info.
168
- # @param [Array[String]] audio_sources An array of track names from the same group
169
- # room to merge into the compositions created by the composition hook. Can include
170
- # zero or more track names. A composition triggered by the composition hook
171
- # includes all audio sources specified in `audio_sources` except those specified
172
- # in `audio_sources_excluded`. The track names in this parameter can include an
173
- # asterisk as a wild card character, which matches zero or more characters in a
174
- # track name. For example, `student*` includes tracks named `student` as well as
175
- # `studentTeam`.
176
- # @param [Array[String]] audio_sources_excluded An array of track names to
177
- # exclude. A composition triggered by the composition hook includes all audio
178
- # sources specified in `audio_sources` except for those specified in
179
- # `audio_sources_excluded`. The track names in this parameter can include an
180
- # asterisk as a wild card character, which matches zero or more characters in a
181
- # track name. For example, `student*` excludes `student` as well as `studentTeam`.
182
- # This parameter can also be empty.
183
- # @param [String] resolution A string that describes the columns (width) and rows
184
- # (height) of the generated composed video in pixels. Defaults to `640x480`.
185
- # The string's format is `{width}x{height}` where:
186
- #
187
- # * 16 <= `{width}` <= 1280
188
- # * 16 <= `{height}` <= 1280
189
- # * `{width}` * `{height}` <= 921,600
190
- #
191
- # Typical values are:
192
- #
193
- # * HD = `1280x720`
194
- # * PAL = `1024x576`
195
- # * VGA = `640x480`
196
- # * CIF = `320x240`
197
- #
198
- # Note that the `resolution` imposes an aspect ratio to the resulting composition.
199
- # When the original video tracks are constrained by the aspect ratio, they are
200
- # scaled to fit. See {Specifying Video
201
- # Layouts}[https://www.twilio.com/docs/video/api/compositions-resource#specifying-video-layouts]
202
- # for more info.
203
- # @param [composition_hook.Format] format The container format of the media files
204
- # used by the compositions created by the composition hook. Can be: `mp4` or
205
- # `webm` and the default is `webm`. If `mp4` or `webm`, `audio_sources` must have
206
- # one or more tracks and/or a `video_layout` element must contain a valid
207
- # `video_sources` list, otherwise an error occurs.
208
- # @param [String] status_callback The URL we should call using the
209
- # `status_callback_method` to send status information to your application on every
210
- # composition event. If not provided, status callback events will not be
211
- # dispatched.
212
- # @param [String] status_callback_method The HTTP method we should use to call
213
- # `status_callback`. Can be: `POST` or `GET` and the default is `POST`.
214
- # @param [Boolean] trim Whether to clip the intervals where there is no active
215
- # media in the Compositions triggered by the composition hook. The default is
216
- # `true`. Compositions with `trim` enabled are shorter when the Room is created
217
- # and no Participant joins for a while as well as if all the Participants leave
218
- # the room and join later, because those gaps will be removed. See {Specifying
219
- # Video
220
- # Layouts}[https://www.twilio.com/docs/video/api/compositions-resource#specifying-video-layouts]
221
- # for more info.
222
- # @return [CompositionHookInstance] Created CompositionHookInstance
223
- def create(friendly_name: nil, enabled: :unset, video_layout: :unset, audio_sources: :unset, audio_sources_excluded: :unset, resolution: :unset, format: :unset, status_callback: :unset, status_callback_method: :unset, trim: :unset)
224
- data = Twilio::Values.of({
225
- 'FriendlyName' => friendly_name,
226
- 'Enabled' => enabled,
227
- 'VideoLayout' => Twilio.serialize_object(video_layout),
228
- 'AudioSources' => Twilio.serialize_list(audio_sources) { |e| e },
229
- 'AudioSourcesExcluded' => Twilio.serialize_list(audio_sources_excluded) { |e| e },
230
- 'Resolution' => resolution,
231
- 'Format' => format,
232
- 'StatusCallback' => status_callback,
233
- 'StatusCallbackMethod' => status_callback_method,
234
- 'Trim' => trim,
235
- })
236
-
237
- payload = @version.create('POST', @uri, data: data)
238
-
239
- CompositionHookInstance.new(@version, payload, )
240
- end
241
-
242
- ##
243
- # Provide a user friendly representation
244
- def to_s
245
- '#<Twilio.Video.V1.CompositionHookList>'
246
- end
247
- end
248
-
249
- class CompositionHookPage < Page
250
- ##
251
- # Initialize the CompositionHookPage
252
- # @param [Version] version Version that contains the resource
253
- # @param [Response] response Response from the API
254
- # @param [Hash] solution Path solution for the resource
255
- # @return [CompositionHookPage] CompositionHookPage
256
- def initialize(version, response, solution)
257
- super(version, response)
258
-
259
- # Path Solution
260
- @solution = solution
261
- end
262
-
263
- ##
264
- # Build an instance of CompositionHookInstance
265
- # @param [Hash] payload Payload response from the API
266
- # @return [CompositionHookInstance] CompositionHookInstance
267
- def get_instance(payload)
268
- CompositionHookInstance.new(@version, payload, )
269
- end
270
-
271
- ##
272
- # Provide a user friendly representation
273
- def to_s
274
- '<Twilio.Video.V1.CompositionHookPage>'
275
- end
276
- end
277
-
278
- class CompositionHookContext < InstanceContext
279
- ##
280
- # Initialize the CompositionHookContext
281
- # @param [Version] version Version that contains the resource
282
- # @param [String] sid The SID of the CompositionHook resource to fetch.
283
- # @return [CompositionHookContext] CompositionHookContext
284
- def initialize(version, sid)
285
- super(version)
286
-
287
- # Path Solution
288
- @solution = {sid: sid, }
289
- @uri = "/CompositionHooks/#{@solution[:sid]}"
290
- end
291
-
292
- ##
293
- # Fetch the CompositionHookInstance
294
- # @return [CompositionHookInstance] Fetched CompositionHookInstance
295
- def fetch
296
- payload = @version.fetch('GET', @uri)
297
-
298
- CompositionHookInstance.new(@version, payload, sid: @solution[:sid], )
299
- end
300
-
301
- ##
302
- # Delete the CompositionHookInstance
303
- # @return [Boolean] true if delete succeeds, false otherwise
304
- def delete
305
- @version.delete('DELETE', @uri)
306
- end
307
-
308
- ##
309
- # Update the CompositionHookInstance
310
- # @param [String] friendly_name A descriptive string that you create to describe
311
- # the resource. It can be up to 100 characters long and it must be unique within
312
- # the account.
313
- # @param [Boolean] enabled Whether the composition hook is active. When `true`,
314
- # the composition hook will be triggered for every completed Group Room in the
315
- # account. When `false`, the composition hook never triggers.
316
- # @param [Hash] video_layout A JSON object that describes the video layout of the
317
- # composition hook in terms of regions. See {Specifying Video
318
- # Layouts}[https://www.twilio.com/docs/video/api/compositions-resource#specifying-video-layouts]
319
- # for more info.
320
- # @param [Array[String]] audio_sources An array of track names from the same group
321
- # room to merge into the compositions created by the composition hook. Can include
322
- # zero or more track names. A composition triggered by the composition hook
323
- # includes all audio sources specified in `audio_sources` except those specified
324
- # in `audio_sources_excluded`. The track names in this parameter can include an
325
- # asterisk as a wild card character, which matches zero or more characters in a
326
- # track name. For example, `student*` includes tracks named `student` as well as
327
- # `studentTeam`.
328
- # @param [Array[String]] audio_sources_excluded An array of track names to
329
- # exclude. A composition triggered by the composition hook includes all audio
330
- # sources specified in `audio_sources` except for those specified in
331
- # `audio_sources_excluded`. The track names in this parameter can include an
332
- # asterisk as a wild card character, which matches zero or more characters in a
333
- # track name. For example, `student*` excludes `student` as well as `studentTeam`.
334
- # This parameter can also be empty.
335
- # @param [Boolean] trim Whether to clip the intervals where there is no active
336
- # media in the compositions triggered by the composition hook. The default is
337
- # `true`. Compositions with `trim` enabled are shorter when the Room is created
338
- # and no Participant joins for a while as well as if all the Participants leave
339
- # the room and join later, because those gaps will be removed. See {Specifying
340
- # Video
341
- # Layouts}[https://www.twilio.com/docs/video/api/compositions-resource#specifying-video-layouts]
342
- # for more info.
343
- # @param [composition_hook.Format] format The container format of the media files
344
- # used by the compositions created by the composition hook. Can be: `mp4` or
345
- # `webm` and the default is `webm`. If `mp4` or `webm`, `audio_sources` must have
346
- # one or more tracks and/or a `video_layout` element must contain a valid
347
- # `video_sources` list, otherwise an error occurs.
348
- # @param [String] resolution A string that describes the columns (width) and rows
349
- # (height) of the generated composed video in pixels. Defaults to `640x480`.
350
- # The string's format is `{width}x{height}` where:
351
- #
352
- # * 16 <= `{width}` <= 1280
353
- # * 16 <= `{height}` <= 1280
354
- # * `{width}` * `{height}` <= 921,600
355
- #
356
- # Typical values are:
357
- #
358
- # * HD = `1280x720`
359
- # * PAL = `1024x576`
360
- # * VGA = `640x480`
361
- # * CIF = `320x240`
362
- #
363
- # Note that the `resolution` imposes an aspect ratio to the resulting composition.
364
- # When the original video tracks are constrained by the aspect ratio, they are
365
- # scaled to fit. See {Specifying Video
366
- # Layouts}[https://www.twilio.com/docs/video/api/compositions-resource#specifying-video-layouts]
367
- # for more info.
368
- # @param [String] status_callback The URL we should call using the
369
- # `status_callback_method` to send status information to your application on every
370
- # composition event. If not provided, status callback events will not be
371
- # dispatched.
372
- # @param [String] status_callback_method The HTTP method we should use to call
373
- # `status_callback`. Can be: `POST` or `GET` and the default is `POST`.
374
- # @return [CompositionHookInstance] Updated CompositionHookInstance
375
- def update(friendly_name: nil, enabled: :unset, video_layout: :unset, audio_sources: :unset, audio_sources_excluded: :unset, trim: :unset, format: :unset, resolution: :unset, status_callback: :unset, status_callback_method: :unset)
376
- data = Twilio::Values.of({
377
- 'FriendlyName' => friendly_name,
378
- 'Enabled' => enabled,
379
- 'VideoLayout' => Twilio.serialize_object(video_layout),
380
- 'AudioSources' => Twilio.serialize_list(audio_sources) { |e| e },
381
- 'AudioSourcesExcluded' => Twilio.serialize_list(audio_sources_excluded) { |e| e },
382
- 'Trim' => trim,
383
- 'Format' => format,
384
- 'Resolution' => resolution,
385
- 'StatusCallback' => status_callback,
386
- 'StatusCallbackMethod' => status_callback_method,
387
- })
388
-
389
- payload = @version.update('POST', @uri, data: data)
390
-
391
- CompositionHookInstance.new(@version, payload, sid: @solution[:sid], )
392
- end
393
-
394
- ##
395
- # Provide a user friendly representation
396
- def to_s
397
- context = @solution.map {|k, v| "#{k}: #{v}"}.join(',')
398
- "#<Twilio.Video.V1.CompositionHookContext #{context}>"
399
- end
400
-
401
- ##
402
- # Provide a detailed, user friendly representation
403
- def inspect
404
- context = @solution.map {|k, v| "#{k}: #{v}"}.join(',')
405
- "#<Twilio.Video.V1.CompositionHookContext #{context}>"
406
- end
407
- end
145
+ end
146
+
147
+ ##
148
+ # Retrieve a single page of CompositionHookInstance records from the API.
149
+ # Request is executed immediately.
150
+ # @param [Boolean] enabled Read only CompositionHook resources with an `enabled` value that matches this parameter.
151
+ # @param [Time] date_created_after Read only CompositionHook resources created on or after this [ISO 8601](https://en.wikipedia.org/wiki/ISO_8601) datetime with time zone.
152
+ # @param [Time] date_created_before Read only CompositionHook resources created before this [ISO 8601](https://en.wikipedia.org/wiki/ISO_8601) datetime with time zone.
153
+ # @param [String] friendly_name Read only CompositionHook resources with friendly names that match this string. The match is not case sensitive and can include asterisk `*` characters as wildcard match.
154
+ # @param [String] page_token PageToken provided by the API
155
+ # @param [Integer] page_number Page Number, this value is simply for client state
156
+ # @param [Integer] page_size Number of records to return, defaults to 50
157
+ # @return [Page] Page of CompositionHookInstance
158
+ def page(enabled: :unset, date_created_after: :unset, date_created_before: :unset, friendly_name: :unset, page_token: :unset, page_number: :unset, page_size: :unset)
159
+ params = Twilio::Values.of({
160
+ 'Enabled' => enabled,
161
+ 'DateCreatedAfter' => Twilio.serialize_iso8601_datetime(date_created_after),
162
+ 'DateCreatedBefore' => Twilio.serialize_iso8601_datetime(date_created_before),
163
+ 'FriendlyName' => friendly_name,
164
+ 'PageToken' => page_token,
165
+ 'Page' => page_number,
166
+ 'PageSize' => page_size,
167
+ })
168
+
169
+ response = @version.page('GET', @uri, params: params)
170
+
171
+ CompositionHookPage.new(@version, response, @solution)
172
+ end
173
+
174
+ ##
175
+ # Retrieve a single page of CompositionHookInstance records from the API.
176
+ # Request is executed immediately.
177
+ # @param [String] target_url API-generated URL for the requested results page
178
+ # @return [Page] Page of CompositionHookInstance
179
+ def get_page(target_url)
180
+ response = @version.domain.request(
181
+ 'GET',
182
+ target_url
183
+ )
184
+ CompositionHookPage.new(@version, response, @solution)
185
+ end
186
+
187
+
188
+
189
+ # Provide a user friendly representation
190
+ def to_s
191
+ '#<Twilio.Video.V1.CompositionHookList>'
192
+ end
193
+ end
194
+
195
+
196
+ class CompositionHookContext < InstanceContext
197
+ ##
198
+ # Initialize the CompositionHookContext
199
+ # @param [Version] version Version that contains the resource
200
+ # @param [String] sid The SID of the CompositionHook resource to update.
201
+ # @return [CompositionHookContext] CompositionHookContext
202
+ def initialize(version, sid)
203
+ super(version)
204
+
205
+ # Path Solution
206
+ @solution = { sid: sid, }
207
+ @uri = "/CompositionHooks/#{@solution[:sid]}"
208
+
209
+
210
+ end
211
+ ##
212
+ # Delete the CompositionHookInstance
213
+ # @return [Boolean] True if delete succeeds, false otherwise
214
+ def delete
215
+
216
+ @version.delete('DELETE', @uri)
217
+ end
218
+
219
+ ##
220
+ # Fetch the CompositionHookInstance
221
+ # @return [CompositionHookInstance] Fetched CompositionHookInstance
222
+ def fetch
223
+
224
+ payload = @version.fetch('GET', @uri)
225
+ CompositionHookInstance.new(
226
+ @version,
227
+ payload,
228
+ sid: @solution[:sid],
229
+ )
230
+ end
231
+
232
+ ##
233
+ # Update the CompositionHookInstance
234
+ # @param [String] friendly_name A descriptive string that you create to describe the resource. It can be up to 100 characters long and it must be unique within the account.
235
+ # @param [Boolean] enabled Whether the composition hook is active. When `true`, the composition hook will be triggered for every completed Group Room in the account. When `false`, the composition hook never triggers.
236
+ # @param [Object] video_layout A JSON object that describes the video layout of the composition hook in terms of regions. See [Specifying Video Layouts](https://www.twilio.com/docs/video/api/compositions-resource#specifying-video-layouts) for more info.
237
+ # @param [Array[String]] audio_sources An array of track names from the same group room to merge into the compositions created by the composition hook. Can include zero or more track names. A composition triggered by the composition hook includes all audio sources specified in `audio_sources` except those specified in `audio_sources_excluded`. The track names in this parameter can include an asterisk as a wild card character, which matches zero or more characters in a track name. For example, `student*` includes tracks named `student` as well as `studentTeam`.
238
+ # @param [Array[String]] audio_sources_excluded An array of track names to exclude. A composition triggered by the composition hook includes all audio sources specified in `audio_sources` except for those specified in `audio_sources_excluded`. The track names in this parameter can include an asterisk as a wild card character, which matches zero or more characters in a track name. For example, `student*` excludes `student` as well as `studentTeam`. This parameter can also be empty.
239
+ # @param [Boolean] trim Whether to clip the intervals where there is no active media in the compositions triggered by the composition hook. The default is `true`. Compositions with `trim` enabled are shorter when the Room is created and no Participant joins for a while as well as if all the Participants leave the room and join later, because those gaps will be removed. See [Specifying Video Layouts](https://www.twilio.com/docs/video/api/compositions-resource#specifying-video-layouts) for more info.
240
+ # @param [Format] format
241
+ # @param [String] resolution A string that describes the columns (width) and rows (height) of the generated composed video in pixels. Defaults to `640x480`. The string's format is `{width}x{height}` where: * 16 <= `{width}` <= 1280 * 16 <= `{height}` <= 1280 * `{width}` * `{height}` <= 921,600 Typical values are: * HD = `1280x720` * PAL = `1024x576` * VGA = `640x480` * CIF = `320x240` Note that the `resolution` imposes an aspect ratio to the resulting composition. When the original video tracks are constrained by the aspect ratio, they are scaled to fit. See [Specifying Video Layouts](https://www.twilio.com/docs/video/api/compositions-resource#specifying-video-layouts) for more info.
242
+ # @param [String] status_callback The URL we should call using the `status_callback_method` to send status information to your application on every composition event. If not provided, status callback events will not be dispatched.
243
+ # @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`.
244
+ # @return [CompositionHookInstance] Updated CompositionHookInstance
245
+ def update(
246
+ friendly_name: nil,
247
+ enabled: :unset,
248
+ video_layout: :unset,
249
+ audio_sources: :unset,
250
+ audio_sources_excluded: :unset,
251
+ trim: :unset,
252
+ format: :unset,
253
+ resolution: :unset,
254
+ status_callback: :unset,
255
+ status_callback_method: :unset
256
+ )
257
+
258
+ data = Twilio::Values.of({
259
+ 'FriendlyName' => friendly_name,
260
+ 'Enabled' => enabled,
261
+ 'VideoLayout' => Twilio.serialize_object(video_layout),
262
+ 'AudioSources' => Twilio.serialize_list(audio_sources) { |e| e },
263
+ 'AudioSourcesExcluded' => Twilio.serialize_list(audio_sources_excluded) { |e| e },
264
+ 'Trim' => trim,
265
+ 'Format' => format,
266
+ 'Resolution' => resolution,
267
+ 'StatusCallback' => status_callback,
268
+ 'StatusCallbackMethod' => status_callback_method,
269
+ })
270
+
271
+ payload = @version.update('POST', @uri, data: data)
272
+ CompositionHookInstance.new(
273
+ @version,
274
+ payload,
275
+ sid: @solution[:sid],
276
+ )
277
+ end
278
+
279
+
280
+ ##
281
+ # Provide a user friendly representation
282
+ def to_s
283
+ context = @solution.map{|k, v| "#{k}: #{v}"}.join(',')
284
+ "#<Twilio.Video.V1.CompositionHookContext #{context}>"
285
+ end
286
+
287
+ ##
288
+ # Provide a detailed, user friendly representation
289
+ def inspect
290
+ context = @solution.map{|k, v| "#{k}: #{v}"}.join(',')
291
+ "#<Twilio.Video.V1.CompositionHookContext #{context}>"
292
+ end
293
+ end
294
+
295
+ class CompositionHookPage < Page
296
+ ##
297
+ # Initialize the CompositionHookPage
298
+ # @param [Version] version Version that contains the resource
299
+ # @param [Response] response Response from the API
300
+ # @param [Hash] solution Path solution for the resource
301
+ # @return [CompositionHookPage] CompositionHookPage
302
+ def initialize(version, response, solution)
303
+ super(version, response)
304
+
305
+ # Path Solution
306
+ @solution = solution
307
+ end
308
+
309
+ ##
310
+ # Build an instance of CompositionHookInstance
311
+ # @param [Hash] payload Payload response from the API
312
+ # @return [CompositionHookInstance] CompositionHookInstance
313
+ def get_instance(payload)
314
+ CompositionHookInstance.new(@version, payload)
315
+ end
316
+
317
+ ##
318
+ # Provide a user friendly representation
319
+ def to_s
320
+ '<Twilio.Video.V1.CompositionHookPage>'
321
+ end
322
+ end
323
+ class CompositionHookInstance < InstanceResource
324
+ ##
325
+ # Initialize the CompositionHookInstance
326
+ # @param [Version] version Version that contains the resource
327
+ # @param [Hash] payload payload that contains response from Twilio
328
+ # @param [String] account_sid The SID of the
329
+ # {Account}[https://www.twilio.com/docs/iam/api/account] that created this CompositionHook
330
+ # resource.
331
+ # @param [String] sid The SID of the Call resource to fetch.
332
+ # @return [CompositionHookInstance] CompositionHookInstance
333
+ def initialize(version, payload , sid: nil)
334
+ super(version)
335
+
336
+ # Marshaled Properties
337
+ @properties = {
338
+ 'account_sid' => payload['account_sid'],
339
+ 'friendly_name' => payload['friendly_name'],
340
+ 'enabled' => payload['enabled'],
341
+ 'date_created' => Twilio.deserialize_iso8601_datetime(payload['date_created']),
342
+ 'date_updated' => Twilio.deserialize_iso8601_datetime(payload['date_updated']),
343
+ 'sid' => payload['sid'],
344
+ 'audio_sources' => payload['audio_sources'],
345
+ 'audio_sources_excluded' => payload['audio_sources_excluded'],
346
+ 'video_layout' => payload['video_layout'],
347
+ 'resolution' => payload['resolution'],
348
+ 'trim' => payload['trim'],
349
+ 'format' => payload['format'],
350
+ 'status_callback' => payload['status_callback'],
351
+ 'status_callback_method' => payload['status_callback_method'],
352
+ 'url' => payload['url'],
353
+ }
354
+
355
+ # Context
356
+ @instance_context = nil
357
+ @params = { 'sid' => sid || @properties['sid'] , }
358
+ end
359
+
360
+ ##
361
+ # Generate an instance context for the instance, the context is capable of
362
+ # performing various actions. All instance actions are proxied to the context
363
+ # @return [CompositionHookContext] CallContext for this CallInstance
364
+ def context
365
+ unless @instance_context
366
+ @instance_context = CompositionHookContext.new(@version , @params['sid'])
367
+ end
368
+ @instance_context
369
+ end
370
+
371
+ ##
372
+ # @return [String] The SID of the [Account](https://www.twilio.com/docs/iam/api/account) that created the CompositionHook resource.
373
+ def account_sid
374
+ @properties['account_sid']
375
+ end
376
+
377
+ ##
378
+ # @return [String] The string that you assigned to describe the resource. Can be up to 100 characters long and must be unique within the account.
379
+ def friendly_name
380
+ @properties['friendly_name']
381
+ end
382
+
383
+ ##
384
+ # @return [Boolean] Whether the CompositionHook is active. When `true`, the CompositionHook is triggered for every completed Group Room on the account. When `false`, the CompositionHook is never triggered.
385
+ def enabled
386
+ @properties['enabled']
387
+ end
388
+
389
+ ##
390
+ # @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.
391
+ def date_created
392
+ @properties['date_created']
393
+ end
394
+
395
+ ##
396
+ # @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.
397
+ def date_updated
398
+ @properties['date_updated']
399
+ end
400
+
401
+ ##
402
+ # @return [String] The unique string that we created to identify the CompositionHook resource.
403
+ def sid
404
+ @properties['sid']
405
+ end
406
+
407
+ ##
408
+ # @return [Array<String>] The array of track names to include in the compositions created by the composition hook. A composition triggered by the composition hook includes all audio sources specified in `audio_sources` except those specified in `audio_sources_excluded`. The track names in this property can include an asterisk as a wild card character, which matches zero or more characters in a track name. For example, `student*` includes tracks named `student` as well as `studentTeam`. Please, be aware that either video_layout or audio_sources have to be provided to get a valid creation request
409
+ def audio_sources
410
+ @properties['audio_sources']
411
+ end
412
+
413
+ ##
414
+ # @return [Array<String>] The array of track names to exclude from the compositions created by the composition hook. A composition triggered by the composition hook includes all audio sources specified in `audio_sources` except for those specified in `audio_sources_excluded`. The track names in this property can include an asterisk as a wild card character, which matches zero or more characters in a track name. For example, `student*` excludes `student` as well as `studentTeam`. This parameter can also be empty.
415
+ def audio_sources_excluded
416
+ @properties['audio_sources_excluded']
417
+ end
418
+
419
+ ##
420
+ # @return [Hash] A JSON object that describes the video layout of the composition in terms of regions as specified in the HTTP POST request that created the CompositionHook resource. See [POST Parameters](https://www.twilio.com/docs/video/api/compositions-resource#http-post-parameters) for more information. Please, be aware that either video_layout or audio_sources have to be provided to get a valid creation request
421
+ def video_layout
422
+ @properties['video_layout']
423
+ end
424
+
425
+ ##
426
+ # @return [String] The dimensions of the video image in pixels expressed as columns (width) and rows (height). The string's format is `{width}x{height}`, such as `640x480`.
427
+ def resolution
428
+ @properties['resolution']
429
+ end
430
+
431
+ ##
432
+ # @return [Boolean] Whether intervals with no media are clipped, as specified in the POST request that created the CompositionHook resource. Compositions with `trim` enabled are shorter when the Room is created and no Participant joins for a while as well as if all the Participants leave the room and join later, because those gaps will be removed. See [Specifying Video Layouts](https://www.twilio.com/docs/video/api/compositions-resource#specifying-video-layouts) for more info.
433
+ def trim
434
+ @properties['trim']
435
+ end
436
+
437
+ ##
438
+ # @return [Format]
439
+ def format
440
+ @properties['format']
441
+ end
442
+
443
+ ##
444
+ # @return [String] The URL we call using the `status_callback_method` to send status information to your application.
445
+ def status_callback
446
+ @properties['status_callback']
447
+ end
448
+
449
+ ##
450
+ # @return [String] The HTTP method we should use to call `status_callback`. Can be `POST` or `GET` and defaults to `POST`.
451
+ def status_callback_method
452
+ @properties['status_callback_method']
453
+ end
454
+
455
+ ##
456
+ # @return [String] The absolute URL of the resource.
457
+ def url
458
+ @properties['url']
459
+ end
460
+
461
+ ##
462
+ # Delete the CompositionHookInstance
463
+ # @return [Boolean] True if delete succeeds, false otherwise
464
+ def delete
465
+
466
+ context.delete
467
+ end
468
+
469
+ ##
470
+ # Fetch the CompositionHookInstance
471
+ # @return [CompositionHookInstance] Fetched CompositionHookInstance
472
+ def fetch
473
+
474
+ context.fetch
475
+ end
476
+
477
+ ##
478
+ # Update the CompositionHookInstance
479
+ # @param [String] friendly_name A descriptive string that you create to describe the resource. It can be up to 100 characters long and it must be unique within the account.
480
+ # @param [Boolean] enabled Whether the composition hook is active. When `true`, the composition hook will be triggered for every completed Group Room in the account. When `false`, the composition hook never triggers.
481
+ # @param [Object] video_layout A JSON object that describes the video layout of the composition hook in terms of regions. See [Specifying Video Layouts](https://www.twilio.com/docs/video/api/compositions-resource#specifying-video-layouts) for more info.
482
+ # @param [Array[String]] audio_sources An array of track names from the same group room to merge into the compositions created by the composition hook. Can include zero or more track names. A composition triggered by the composition hook includes all audio sources specified in `audio_sources` except those specified in `audio_sources_excluded`. The track names in this parameter can include an asterisk as a wild card character, which matches zero or more characters in a track name. For example, `student*` includes tracks named `student` as well as `studentTeam`.
483
+ # @param [Array[String]] audio_sources_excluded An array of track names to exclude. A composition triggered by the composition hook includes all audio sources specified in `audio_sources` except for those specified in `audio_sources_excluded`. The track names in this parameter can include an asterisk as a wild card character, which matches zero or more characters in a track name. For example, `student*` excludes `student` as well as `studentTeam`. This parameter can also be empty.
484
+ # @param [Boolean] trim Whether to clip the intervals where there is no active media in the compositions triggered by the composition hook. The default is `true`. Compositions with `trim` enabled are shorter when the Room is created and no Participant joins for a while as well as if all the Participants leave the room and join later, because those gaps will be removed. See [Specifying Video Layouts](https://www.twilio.com/docs/video/api/compositions-resource#specifying-video-layouts) for more info.
485
+ # @param [Format] format
486
+ # @param [String] resolution A string that describes the columns (width) and rows (height) of the generated composed video in pixels. Defaults to `640x480`. The string's format is `{width}x{height}` where: * 16 <= `{width}` <= 1280 * 16 <= `{height}` <= 1280 * `{width}` * `{height}` <= 921,600 Typical values are: * HD = `1280x720` * PAL = `1024x576` * VGA = `640x480` * CIF = `320x240` Note that the `resolution` imposes an aspect ratio to the resulting composition. When the original video tracks are constrained by the aspect ratio, they are scaled to fit. See [Specifying Video Layouts](https://www.twilio.com/docs/video/api/compositions-resource#specifying-video-layouts) for more info.
487
+ # @param [String] status_callback The URL we should call using the `status_callback_method` to send status information to your application on every composition event. If not provided, status callback events will not be dispatched.
488
+ # @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`.
489
+ # @return [CompositionHookInstance] Updated CompositionHookInstance
490
+ def update(
491
+ friendly_name: nil,
492
+ enabled: :unset,
493
+ video_layout: :unset,
494
+ audio_sources: :unset,
495
+ audio_sources_excluded: :unset,
496
+ trim: :unset,
497
+ format: :unset,
498
+ resolution: :unset,
499
+ status_callback: :unset,
500
+ status_callback_method: :unset
501
+ )
502
+
503
+ context.update(
504
+ friendly_name: friendly_name,
505
+ enabled: enabled,
506
+ video_layout: video_layout,
507
+ audio_sources: audio_sources,
508
+ audio_sources_excluded: audio_sources_excluded,
509
+ trim: trim,
510
+ format: format,
511
+ resolution: resolution,
512
+ status_callback: status_callback,
513
+ status_callback_method: status_callback_method,
514
+ )
515
+ end
516
+
517
+ ##
518
+ # Provide a user friendly representation
519
+ def to_s
520
+ values = @params.map{|k, v| "#{k}: #{v}"}.join(" ")
521
+ "<Twilio.Video.V1.CompositionHookInstance #{values}>"
522
+ end
523
+
524
+ ##
525
+ # Provide a detailed, user friendly representation
526
+ def inspect
527
+ values = @properties.map{|k, v| "#{k}: #{v}"}.join(" ")
528
+ "<Twilio.Video.V1.CompositionHookInstance #{values}>"
529
+ end
530
+ end
408
531
 
409
- class CompositionHookInstance < InstanceResource
410
- ##
411
- # Initialize the CompositionHookInstance
412
- # @param [Version] version Version that contains the resource
413
- # @param [Hash] payload payload that contains response from Twilio
414
- # @param [String] sid The SID of the CompositionHook resource to fetch.
415
- # @return [CompositionHookInstance] CompositionHookInstance
416
- def initialize(version, payload, sid: nil)
417
- super(version)
418
-
419
- # Marshaled Properties
420
- @properties = {
421
- 'account_sid' => payload['account_sid'],
422
- 'friendly_name' => payload['friendly_name'],
423
- 'enabled' => payload['enabled'],
424
- 'date_created' => Twilio.deserialize_iso8601_datetime(payload['date_created']),
425
- 'date_updated' => Twilio.deserialize_iso8601_datetime(payload['date_updated']),
426
- 'sid' => payload['sid'],
427
- 'audio_sources' => payload['audio_sources'],
428
- 'audio_sources_excluded' => payload['audio_sources_excluded'],
429
- 'video_layout' => payload['video_layout'],
430
- 'resolution' => payload['resolution'],
431
- 'trim' => payload['trim'],
432
- 'format' => payload['format'],
433
- 'status_callback' => payload['status_callback'],
434
- 'status_callback_method' => payload['status_callback_method'],
435
- 'url' => payload['url'],
436
- }
437
-
438
- # Context
439
- @instance_context = nil
440
- @params = {'sid' => sid || @properties['sid'], }
441
- end
442
-
443
- ##
444
- # Generate an instance context for the instance, the context is capable of
445
- # performing various actions. All instance actions are proxied to the context
446
- # @return [CompositionHookContext] CompositionHookContext for this CompositionHookInstance
447
- def context
448
- unless @instance_context
449
- @instance_context = CompositionHookContext.new(@version, @params['sid'], )
450
532
  end
451
- @instance_context
452
- end
453
-
454
- ##
455
- # @return [String] The SID of the Account that created the resource
456
- def account_sid
457
- @properties['account_sid']
458
- end
459
-
460
- ##
461
- # @return [String] The string that you assigned to describe the resource
462
- def friendly_name
463
- @properties['friendly_name']
464
- end
465
-
466
- ##
467
- # @return [Boolean] Whether the CompositionHook is active
468
- def enabled
469
- @properties['enabled']
470
- end
471
-
472
- ##
473
- # @return [Time] The ISO 8601 date and time in GMT when the resource was created
474
- def date_created
475
- @properties['date_created']
476
- end
477
-
478
- ##
479
- # @return [Time] The ISO 8601 date and time in GMT when the resource was last updated
480
- def date_updated
481
- @properties['date_updated']
482
- end
483
-
484
- ##
485
- # @return [String] The unique string that identifies the resource
486
- def sid
487
- @properties['sid']
488
- end
489
-
490
- ##
491
- # @return [Array[String]] The array of track names to include in the compositions created by the composition hook
492
- def audio_sources
493
- @properties['audio_sources']
494
- end
495
-
496
- ##
497
- # @return [Array[String]] The array of track names to exclude from the compositions created by the composition hook
498
- def audio_sources_excluded
499
- @properties['audio_sources_excluded']
500
- end
501
-
502
- ##
503
- # @return [Hash] A JSON object that describes the video layout of the Composition
504
- def video_layout
505
- @properties['video_layout']
506
- end
507
-
508
- ##
509
- # @return [String] The dimensions of the video image in pixels expressed as columns (width) and rows (height)
510
- def resolution
511
- @properties['resolution']
512
- end
513
-
514
- ##
515
- # @return [Boolean] Whether intervals with no media are clipped
516
- def trim
517
- @properties['trim']
518
- end
519
-
520
- ##
521
- # @return [composition_hook.Format] The container format of the media files used by the compositions created by the composition hook
522
- def format
523
- @properties['format']
524
- end
525
-
526
- ##
527
- # @return [String] The URL to send status information to your application
528
- def status_callback
529
- @properties['status_callback']
530
- end
531
-
532
- ##
533
- # @return [String] The HTTP method we should use to call status_callback
534
- def status_callback_method
535
- @properties['status_callback_method']
536
- end
537
-
538
- ##
539
- # @return [String] The absolute URL of the resource
540
- def url
541
- @properties['url']
542
- end
543
-
544
- ##
545
- # Fetch the CompositionHookInstance
546
- # @return [CompositionHookInstance] Fetched CompositionHookInstance
547
- def fetch
548
- context.fetch
549
- end
550
-
551
- ##
552
- # Delete the CompositionHookInstance
553
- # @return [Boolean] true if delete succeeds, false otherwise
554
- def delete
555
- context.delete
556
- end
557
-
558
- ##
559
- # Update the CompositionHookInstance
560
- # @param [String] friendly_name A descriptive string that you create to describe
561
- # the resource. It can be up to 100 characters long and it must be unique within
562
- # the account.
563
- # @param [Boolean] enabled Whether the composition hook is active. When `true`,
564
- # the composition hook will be triggered for every completed Group Room in the
565
- # account. When `false`, the composition hook never triggers.
566
- # @param [Hash] video_layout A JSON object that describes the video layout of the
567
- # composition hook in terms of regions. See {Specifying Video
568
- # Layouts}[https://www.twilio.com/docs/video/api/compositions-resource#specifying-video-layouts]
569
- # for more info.
570
- # @param [Array[String]] audio_sources An array of track names from the same group
571
- # room to merge into the compositions created by the composition hook. Can include
572
- # zero or more track names. A composition triggered by the composition hook
573
- # includes all audio sources specified in `audio_sources` except those specified
574
- # in `audio_sources_excluded`. The track names in this parameter can include an
575
- # asterisk as a wild card character, which matches zero or more characters in a
576
- # track name. For example, `student*` includes tracks named `student` as well as
577
- # `studentTeam`.
578
- # @param [Array[String]] audio_sources_excluded An array of track names to
579
- # exclude. A composition triggered by the composition hook includes all audio
580
- # sources specified in `audio_sources` except for those specified in
581
- # `audio_sources_excluded`. The track names in this parameter can include an
582
- # asterisk as a wild card character, which matches zero or more characters in a
583
- # track name. For example, `student*` excludes `student` as well as `studentTeam`.
584
- # This parameter can also be empty.
585
- # @param [Boolean] trim Whether to clip the intervals where there is no active
586
- # media in the compositions triggered by the composition hook. The default is
587
- # `true`. Compositions with `trim` enabled are shorter when the Room is created
588
- # and no Participant joins for a while as well as if all the Participants leave
589
- # the room and join later, because those gaps will be removed. See {Specifying
590
- # Video
591
- # Layouts}[https://www.twilio.com/docs/video/api/compositions-resource#specifying-video-layouts]
592
- # for more info.
593
- # @param [composition_hook.Format] format The container format of the media files
594
- # used by the compositions created by the composition hook. Can be: `mp4` or
595
- # `webm` and the default is `webm`. If `mp4` or `webm`, `audio_sources` must have
596
- # one or more tracks and/or a `video_layout` element must contain a valid
597
- # `video_sources` list, otherwise an error occurs.
598
- # @param [String] resolution A string that describes the columns (width) and rows
599
- # (height) of the generated composed video in pixels. Defaults to `640x480`.
600
- # The string's format is `{width}x{height}` where:
601
- #
602
- # * 16 <= `{width}` <= 1280
603
- # * 16 <= `{height}` <= 1280
604
- # * `{width}` * `{height}` <= 921,600
605
- #
606
- # Typical values are:
607
- #
608
- # * HD = `1280x720`
609
- # * PAL = `1024x576`
610
- # * VGA = `640x480`
611
- # * CIF = `320x240`
612
- #
613
- # Note that the `resolution` imposes an aspect ratio to the resulting composition.
614
- # When the original video tracks are constrained by the aspect ratio, they are
615
- # scaled to fit. See {Specifying Video
616
- # Layouts}[https://www.twilio.com/docs/video/api/compositions-resource#specifying-video-layouts]
617
- # for more info.
618
- # @param [String] status_callback The URL we should call using the
619
- # `status_callback_method` to send status information to your application on every
620
- # composition event. If not provided, status callback events will not be
621
- # dispatched.
622
- # @param [String] status_callback_method The HTTP method we should use to call
623
- # `status_callback`. Can be: `POST` or `GET` and the default is `POST`.
624
- # @return [CompositionHookInstance] Updated CompositionHookInstance
625
- def update(friendly_name: nil, enabled: :unset, video_layout: :unset, audio_sources: :unset, audio_sources_excluded: :unset, trim: :unset, format: :unset, resolution: :unset, status_callback: :unset, status_callback_method: :unset)
626
- context.update(
627
- friendly_name: friendly_name,
628
- enabled: enabled,
629
- video_layout: video_layout,
630
- audio_sources: audio_sources,
631
- audio_sources_excluded: audio_sources_excluded,
632
- trim: trim,
633
- format: format,
634
- resolution: resolution,
635
- status_callback: status_callback,
636
- status_callback_method: status_callback_method,
637
- )
638
- end
639
-
640
- ##
641
- # Provide a user friendly representation
642
- def to_s
643
- values = @params.map{|k, v| "#{k}: #{v}"}.join(" ")
644
- "<Twilio.Video.V1.CompositionHookInstance #{values}>"
645
- end
646
-
647
- ##
648
- # Provide a detailed, user friendly representation
649
- def inspect
650
- values = @properties.map{|k, v| "#{k}: #{v}"}.join(" ")
651
- "<Twilio.Video.V1.CompositionHookInstance #{values}>"
652
- end
653
533
  end
654
- end
655
534
  end
656
- end
657
- end
535
+ end