twilio-ruby 5.39.3 → 5.40.4

Sign up to get free protection for your applications and to get access to all the features.
Files changed (328) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGES.md +112 -1
  3. data/CONTRIBUTING.md +2 -2
  4. data/README.md +2 -3
  5. data/lib/twilio-ruby/framework/version.rb +4 -8
  6. data/lib/twilio-ruby/rest/api.rb +1 -1
  7. data/lib/twilio-ruby/rest/api/v2010/account/address.rb +3 -3
  8. data/lib/twilio-ruby/rest/api/v2010/account/address/dependent_phone_number.rb +2 -2
  9. data/lib/twilio-ruby/rest/api/v2010/account/application.rb +9 -7
  10. data/lib/twilio-ruby/rest/api/v2010/account/authorized_connect_app.rb +3 -3
  11. data/lib/twilio-ruby/rest/api/v2010/account/available_phone_number.rb +3 -3
  12. data/lib/twilio-ruby/rest/api/v2010/account/available_phone_number/local.rb +32 -23
  13. data/lib/twilio-ruby/rest/api/v2010/account/available_phone_number/machine_to_machine.rb +32 -23
  14. data/lib/twilio-ruby/rest/api/v2010/account/available_phone_number/mobile.rb +32 -23
  15. data/lib/twilio-ruby/rest/api/v2010/account/available_phone_number/national.rb +32 -23
  16. data/lib/twilio-ruby/rest/api/v2010/account/available_phone_number/shared_cost.rb +32 -23
  17. data/lib/twilio-ruby/rest/api/v2010/account/available_phone_number/toll_free.rb +32 -23
  18. data/lib/twilio-ruby/rest/api/v2010/account/available_phone_number/voip.rb +32 -23
  19. data/lib/twilio-ruby/rest/api/v2010/account/call.rb +21 -20
  20. data/lib/twilio-ruby/rest/api/v2010/account/call/feedback.rb +3 -3
  21. data/lib/twilio-ruby/rest/api/v2010/account/call/feedback_summary.rb +3 -3
  22. data/lib/twilio-ruby/rest/api/v2010/account/call/notification.rb +6 -6
  23. data/lib/twilio-ruby/rest/api/v2010/account/call/payment.rb +20 -14
  24. data/lib/twilio-ruby/rest/api/v2010/account/call/recording.rb +8 -8
  25. data/lib/twilio-ruby/rest/api/v2010/account/conference.rb +3 -3
  26. data/lib/twilio-ruby/rest/api/v2010/account/conference/participant.rb +29 -22
  27. data/lib/twilio-ruby/rest/api/v2010/account/conference/recording.rb +3 -3
  28. data/lib/twilio-ruby/rest/api/v2010/account/connect_app.rb +3 -3
  29. data/lib/twilio-ruby/rest/api/v2010/account/incoming_phone_number.rb +10 -10
  30. data/lib/twilio-ruby/rest/api/v2010/account/incoming_phone_number/assigned_add_on.rb +3 -3
  31. data/lib/twilio-ruby/rest/api/v2010/account/incoming_phone_number/assigned_add_on/assigned_add_on_extension.rb +3 -3
  32. data/lib/twilio-ruby/rest/api/v2010/account/incoming_phone_number/local.rb +3 -3
  33. data/lib/twilio-ruby/rest/api/v2010/account/incoming_phone_number/mobile.rb +3 -3
  34. data/lib/twilio-ruby/rest/api/v2010/account/incoming_phone_number/toll_free.rb +3 -3
  35. data/lib/twilio-ruby/rest/api/v2010/account/key.rb +1 -1
  36. data/lib/twilio-ruby/rest/api/v2010/account/message.rb +28 -21
  37. data/lib/twilio-ruby/rest/api/v2010/account/message/feedback.rb +6 -4
  38. data/lib/twilio-ruby/rest/api/v2010/account/message/media.rb +3 -3
  39. data/lib/twilio-ruby/rest/api/v2010/account/notification.rb +3 -3
  40. data/lib/twilio-ruby/rest/api/v2010/account/outgoing_caller_id.rb +3 -3
  41. data/lib/twilio-ruby/rest/api/v2010/account/queue.rb +3 -3
  42. data/lib/twilio-ruby/rest/api/v2010/account/queue/member.rb +5 -5
  43. data/lib/twilio-ruby/rest/api/v2010/account/recording.rb +6 -6
  44. data/lib/twilio-ruby/rest/api/v2010/account/recording/add_on_result.rb +3 -3
  45. data/lib/twilio-ruby/rest/api/v2010/account/recording/add_on_result/payload.rb +3 -3
  46. data/lib/twilio-ruby/rest/api/v2010/account/recording/transcription.rb +6 -6
  47. data/lib/twilio-ruby/rest/api/v2010/account/short_code.rb +3 -3
  48. data/lib/twilio-ruby/rest/api/v2010/account/sip/domain.rb +1 -1
  49. data/lib/twilio-ruby/rest/api/v2010/account/sip/domain/auth_types.rb +2 -2
  50. data/lib/twilio-ruby/rest/api/v2010/account/sip/domain/auth_types/auth_calls_mapping.rb +2 -2
  51. data/lib/twilio-ruby/rest/api/v2010/account/sip/domain/auth_types/auth_calls_mapping/auth_calls_credential_list_mapping.rb +3 -3
  52. data/lib/twilio-ruby/rest/api/v2010/account/sip/domain/auth_types/auth_calls_mapping/auth_calls_ip_access_control_list_mapping.rb +3 -3
  53. data/lib/twilio-ruby/rest/api/v2010/account/sip/domain/auth_types/auth_registrations_mapping.rb +2 -2
  54. data/lib/twilio-ruby/rest/api/v2010/account/sip/domain/auth_types/auth_registrations_mapping/auth_registrations_credential_list_mapping.rb +3 -3
  55. data/lib/twilio-ruby/rest/api/v2010/account/sip/domain/credential_list_mapping.rb +1 -1
  56. data/lib/twilio-ruby/rest/api/v2010/account/sip/ip_access_control_list.rb +1 -1
  57. data/lib/twilio-ruby/rest/api/v2010/account/sip/ip_access_control_list/ip_address.rb +1 -1
  58. data/lib/twilio-ruby/rest/api/v2010/account/token.rb +2 -2
  59. data/lib/twilio-ruby/rest/api/v2010/account/transcription.rb +3 -3
  60. data/lib/twilio-ruby/rest/api/v2010/account/usage/record.rb +6 -6
  61. data/lib/twilio-ruby/rest/api/v2010/account/usage/record/all_time.rb +6 -6
  62. data/lib/twilio-ruby/rest/api/v2010/account/usage/record/daily.rb +6 -6
  63. data/lib/twilio-ruby/rest/api/v2010/account/usage/record/last_month.rb +6 -6
  64. data/lib/twilio-ruby/rest/api/v2010/account/usage/record/monthly.rb +6 -6
  65. data/lib/twilio-ruby/rest/api/v2010/account/usage/record/this_month.rb +6 -6
  66. data/lib/twilio-ruby/rest/api/v2010/account/usage/record/today.rb +6 -6
  67. data/lib/twilio-ruby/rest/api/v2010/account/usage/record/yearly.rb +6 -6
  68. data/lib/twilio-ruby/rest/api/v2010/account/usage/record/yesterday.rb +6 -6
  69. data/lib/twilio-ruby/rest/api/v2010/account/usage/trigger.rb +19 -18
  70. data/lib/twilio-ruby/rest/api/v2010/account/validation_request.rb +3 -3
  71. data/lib/twilio-ruby/rest/autopilot/v1/assistant.rb +12 -12
  72. data/lib/twilio-ruby/rest/autopilot/v1/assistant/defaults.rb +3 -3
  73. data/lib/twilio-ruby/rest/autopilot/v1/assistant/dialogue.rb +3 -3
  74. data/lib/twilio-ruby/rest/autopilot/v1/assistant/field_type.rb +3 -3
  75. data/lib/twilio-ruby/rest/autopilot/v1/assistant/field_type/field_value.rb +15 -11
  76. data/lib/twilio-ruby/rest/autopilot/v1/assistant/model_build.rb +3 -3
  77. data/lib/twilio-ruby/rest/autopilot/v1/assistant/query.rb +33 -26
  78. data/lib/twilio-ruby/rest/autopilot/v1/assistant/style_sheet.rb +3 -3
  79. data/lib/twilio-ruby/rest/autopilot/v1/assistant/task.rb +6 -6
  80. data/lib/twilio-ruby/rest/autopilot/v1/assistant/task/field.rb +9 -9
  81. data/lib/twilio-ruby/rest/autopilot/v1/assistant/task/sample.rb +31 -24
  82. data/lib/twilio-ruby/rest/autopilot/v1/assistant/task/task_actions.rb +8 -8
  83. data/lib/twilio-ruby/rest/autopilot/v1/assistant/task/task_statistics.rb +6 -6
  84. data/lib/twilio-ruby/rest/autopilot/v1/assistant/webhook.rb +3 -3
  85. data/lib/twilio-ruby/rest/chat/v1/service.rb +36 -36
  86. data/lib/twilio-ruby/rest/chat/v1/service/channel.rb +3 -3
  87. data/lib/twilio-ruby/rest/chat/v1/service/channel/invite.rb +19 -19
  88. data/lib/twilio-ruby/rest/chat/v1/service/channel/member.rb +28 -28
  89. data/lib/twilio-ruby/rest/chat/v1/service/channel/message.rb +7 -7
  90. data/lib/twilio-ruby/rest/chat/v1/service/role.rb +5 -5
  91. data/lib/twilio-ruby/rest/chat/v1/service/user.rb +8 -8
  92. data/lib/twilio-ruby/rest/chat/v1/service/user/user_channel.rb +2 -2
  93. data/lib/twilio-ruby/rest/chat/v2/service.rb +36 -36
  94. data/lib/twilio-ruby/rest/chat/v2/service/binding.rb +18 -18
  95. data/lib/twilio-ruby/rest/chat/v2/service/channel.rb +15 -15
  96. data/lib/twilio-ruby/rest/chat/v2/service/channel/invite.rb +19 -19
  97. data/lib/twilio-ruby/rest/chat/v2/service/channel/member.rb +54 -54
  98. data/lib/twilio-ruby/rest/chat/v2/service/channel/message.rb +25 -25
  99. data/lib/twilio-ruby/rest/chat/v2/service/channel/webhook.rb +15 -15
  100. data/lib/twilio-ruby/rest/chat/v2/service/role.rb +5 -5
  101. data/lib/twilio-ruby/rest/chat/v2/service/user.rb +8 -8
  102. data/lib/twilio-ruby/rest/chat/v2/service/user/user_binding.rb +18 -18
  103. data/lib/twilio-ruby/rest/chat/v2/service/user/user_channel.rb +20 -20
  104. data/lib/twilio-ruby/rest/client.rb +8 -1
  105. data/lib/twilio-ruby/rest/conversations.rb +39 -3
  106. data/lib/twilio-ruby/rest/conversations/v1.rb +68 -5
  107. data/lib/twilio-ruby/rest/conversations/v1/configuration.rb +260 -0
  108. data/lib/twilio-ruby/rest/conversations/v1/configuration/webhook.rb +254 -0
  109. data/lib/twilio-ruby/rest/conversations/v1/conversation.rb +24 -21
  110. data/lib/twilio-ruby/rest/conversations/v1/conversation/message.rb +15 -20
  111. data/lib/twilio-ruby/rest/conversations/v1/conversation/message/delivery_receipt.rb +35 -28
  112. data/lib/twilio-ruby/rest/conversations/v1/conversation/participant.rb +48 -40
  113. data/lib/twilio-ruby/rest/conversations/v1/conversation/webhook.rb +14 -19
  114. data/lib/twilio-ruby/rest/conversations/v1/credential.rb +419 -0
  115. data/lib/twilio-ruby/rest/conversations/v1/role.rb +366 -0
  116. data/lib/twilio-ruby/rest/conversations/v1/service.rb +434 -0
  117. data/lib/twilio-ruby/rest/conversations/v1/service/binding.rb +380 -0
  118. data/lib/twilio-ruby/rest/conversations/v1/service/configuration.rb +263 -0
  119. data/lib/twilio-ruby/rest/conversations/v1/service/configuration/notification.rb +307 -0
  120. data/lib/twilio-ruby/rest/conversations/v1/service/conversation.rb +578 -0
  121. data/lib/twilio-ruby/rest/conversations/v1/service/conversation/message.rb +541 -0
  122. data/lib/twilio-ruby/rest/conversations/v1/service/conversation/message/delivery_receipt.rb +386 -0
  123. data/lib/twilio-ruby/rest/conversations/v1/service/conversation/participant.rb +511 -0
  124. data/lib/twilio-ruby/rest/conversations/v1/service/conversation/webhook.rb +449 -0
  125. data/lib/twilio-ruby/rest/conversations/v1/service/role.rb +387 -0
  126. data/lib/twilio-ruby/rest/conversations/v1/service/user.rb +430 -0
  127. data/lib/twilio-ruby/rest/conversations/v1/user.rb +409 -0
  128. data/lib/twilio-ruby/rest/events.rb +72 -0
  129. data/lib/twilio-ruby/rest/events/v1.rb +90 -0
  130. data/lib/twilio-ruby/rest/events/v1/event_type.rb +291 -0
  131. data/lib/twilio-ruby/rest/events/v1/schema.rb +226 -0
  132. data/lib/twilio-ruby/rest/events/v1/schema/schema_version.rb +290 -0
  133. data/lib/twilio-ruby/rest/events/v1/sink.rb +380 -0
  134. data/lib/twilio-ruby/rest/events/v1/sink/sink_test.rb +115 -0
  135. data/lib/twilio-ruby/rest/events/v1/sink/sink_validate.rb +119 -0
  136. data/lib/twilio-ruby/rest/events/v1/subscription.rb +383 -0
  137. data/lib/twilio-ruby/rest/events/v1/subscription/subscribed_event.rb +216 -0
  138. data/lib/twilio-ruby/rest/fax/v1/fax.rb +28 -27
  139. data/lib/twilio-ruby/rest/ip_messaging/v1/service.rb +36 -36
  140. data/lib/twilio-ruby/rest/ip_messaging/v1/service/channel.rb +3 -3
  141. data/lib/twilio-ruby/rest/ip_messaging/v1/service/channel/invite.rb +19 -19
  142. data/lib/twilio-ruby/rest/ip_messaging/v1/service/channel/member.rb +28 -28
  143. data/lib/twilio-ruby/rest/ip_messaging/v1/service/channel/message.rb +7 -7
  144. data/lib/twilio-ruby/rest/ip_messaging/v1/service/role.rb +5 -5
  145. data/lib/twilio-ruby/rest/ip_messaging/v1/service/user.rb +8 -8
  146. data/lib/twilio-ruby/rest/ip_messaging/v1/service/user/user_channel.rb +2 -2
  147. data/lib/twilio-ruby/rest/ip_messaging/v2/service.rb +36 -36
  148. data/lib/twilio-ruby/rest/ip_messaging/v2/service/binding.rb +18 -18
  149. data/lib/twilio-ruby/rest/ip_messaging/v2/service/channel.rb +15 -15
  150. data/lib/twilio-ruby/rest/ip_messaging/v2/service/channel/invite.rb +19 -19
  151. data/lib/twilio-ruby/rest/ip_messaging/v2/service/channel/member.rb +54 -54
  152. data/lib/twilio-ruby/rest/ip_messaging/v2/service/channel/message.rb +25 -25
  153. data/lib/twilio-ruby/rest/ip_messaging/v2/service/channel/webhook.rb +15 -15
  154. data/lib/twilio-ruby/rest/ip_messaging/v2/service/role.rb +5 -5
  155. data/lib/twilio-ruby/rest/ip_messaging/v2/service/user.rb +8 -8
  156. data/lib/twilio-ruby/rest/ip_messaging/v2/service/user/user_binding.rb +18 -18
  157. data/lib/twilio-ruby/rest/ip_messaging/v2/service/user/user_channel.rb +20 -20
  158. data/lib/twilio-ruby/rest/lookups.rb +1 -1
  159. data/lib/twilio-ruby/rest/lookups/v1.rb +1 -1
  160. data/lib/twilio-ruby/rest/lookups/v1/phone_number.rb +10 -10
  161. data/lib/twilio-ruby/rest/messaging.rb +6 -0
  162. data/lib/twilio-ruby/rest/messaging/v1.rb +7 -0
  163. data/lib/twilio-ruby/rest/messaging/v1/deactivation.rb +164 -0
  164. data/lib/twilio-ruby/rest/messaging/v1/service.rb +39 -36
  165. data/lib/twilio-ruby/rest/messaging/v1/service/alpha_sender.rb +3 -3
  166. data/lib/twilio-ruby/rest/messaging/v1/service/phone_number.rb +3 -3
  167. data/lib/twilio-ruby/rest/messaging/v1/service/short_code.rb +3 -3
  168. data/lib/twilio-ruby/rest/monitor/v1/event.rb +15 -15
  169. data/lib/twilio-ruby/rest/notify/v1/credential.rb +12 -6
  170. data/lib/twilio-ruby/rest/notify/v1/service.rb +24 -24
  171. data/lib/twilio-ruby/rest/notify/v1/service/binding.rb +10 -10
  172. data/lib/twilio-ruby/rest/notify/v1/service/notification.rb +23 -15
  173. data/lib/twilio-ruby/rest/numbers/v2/regulatory_compliance.rb +3 -3
  174. data/lib/twilio-ruby/rest/numbers/v2/regulatory_compliance/end_user.rb +16 -2
  175. data/lib/twilio-ruby/rest/numbers/v2/regulatory_compliance/supporting_document.rb +18 -4
  176. data/lib/twilio-ruby/rest/preview/hosted_numbers/authorization_document.rb +15 -10
  177. data/lib/twilio-ruby/rest/preview/hosted_numbers/authorization_document/dependent_hosted_number_order.rb +9 -6
  178. data/lib/twilio-ruby/rest/preview/hosted_numbers/hosted_number_order.rb +1 -1
  179. data/lib/twilio-ruby/rest/preview/trusted_comms/branded_call.rb +4 -4
  180. data/lib/twilio-ruby/rest/preview/trusted_comms/business/insights.rb +1 -4
  181. data/lib/twilio-ruby/rest/preview/trusted_comms/current_call.rb +4 -4
  182. data/lib/twilio-ruby/rest/preview/trusted_comms/phone_call.rb +52 -52
  183. data/lib/twilio-ruby/rest/preview/understand/assistant/task/field.rb +2 -2
  184. data/lib/twilio-ruby/rest/pricing/v1/messaging.rb +2 -2
  185. data/lib/twilio-ruby/rest/pricing/v1/messaging/country.rb +4 -4
  186. data/lib/twilio-ruby/rest/pricing/v1/phone_number.rb +2 -2
  187. data/lib/twilio-ruby/rest/pricing/v1/phone_number/country.rb +4 -4
  188. data/lib/twilio-ruby/rest/pricing/v1/voice.rb +2 -2
  189. data/lib/twilio-ruby/rest/pricing/v1/voice/country.rb +4 -4
  190. data/lib/twilio-ruby/rest/pricing/v2/voice.rb +3 -3
  191. data/lib/twilio-ruby/rest/pricing/v2/voice/country.rb +4 -4
  192. data/lib/twilio-ruby/rest/pricing/v2/voice/number.rb +4 -4
  193. data/lib/twilio-ruby/rest/proxy/v1/service.rb +15 -15
  194. data/lib/twilio-ruby/rest/proxy/v1/service/phone_number.rb +13 -11
  195. data/lib/twilio-ruby/rest/proxy/v1/service/session.rb +42 -23
  196. data/lib/twilio-ruby/rest/proxy/v1/service/session/interaction.rb +6 -6
  197. data/lib/twilio-ruby/rest/proxy/v1/service/session/participant.rb +20 -7
  198. data/lib/twilio-ruby/rest/proxy/v1/service/session/participant/message_interaction.rb +9 -9
  199. data/lib/twilio-ruby/rest/proxy/v1/service/short_code.rb +8 -8
  200. data/lib/twilio-ruby/rest/serverless/v1/service.rb +13 -13
  201. data/lib/twilio-ruby/rest/serverless/v1/service/asset.rb +6 -6
  202. data/lib/twilio-ruby/rest/serverless/v1/service/asset/asset_version.rb +5 -5
  203. data/lib/twilio-ruby/rest/serverless/v1/service/build.rb +33 -8
  204. data/lib/twilio-ruby/rest/serverless/v1/service/build/build_status.rb +219 -0
  205. data/lib/twilio-ruby/rest/serverless/v1/service/environment.rb +6 -8
  206. data/lib/twilio-ruby/rest/serverless/v1/service/environment/deployment.rb +8 -8
  207. data/lib/twilio-ruby/rest/serverless/v1/service/environment/variable.rb +14 -14
  208. data/lib/twilio-ruby/rest/serverless/v1/service/function.rb +4 -4
  209. data/lib/twilio-ruby/rest/serverless/v1/service/function/function_version.rb +7 -7
  210. data/lib/twilio-ruby/rest/serverless/v1/service/function/function_version/function_version_content.rb +1 -1
  211. data/lib/twilio-ruby/rest/studio/v1/flow/execution.rb +6 -6
  212. data/lib/twilio-ruby/rest/studio/v2/flow/execution.rb +6 -6
  213. data/lib/twilio-ruby/rest/supersim/v1/command.rb +7 -7
  214. data/lib/twilio-ruby/rest/supersim/v1/fleet.rb +12 -11
  215. data/lib/twilio-ruby/rest/supersim/v1/network.rb +6 -6
  216. data/lib/twilio-ruby/rest/supersim/v1/sim.rb +22 -12
  217. data/lib/twilio-ruby/rest/supersim/v1/usage_record.rb +81 -15
  218. data/lib/twilio-ruby/rest/sync/v1/service.rb +3 -3
  219. data/lib/twilio-ruby/rest/sync/v1/service/document.rb +6 -6
  220. data/lib/twilio-ruby/rest/sync/v1/service/document/document_permission.rb +6 -6
  221. data/lib/twilio-ruby/rest/sync/v1/service/sync_list.rb +6 -6
  222. data/lib/twilio-ruby/rest/sync/v1/service/sync_list/sync_list_item.rb +6 -6
  223. data/lib/twilio-ruby/rest/sync/v1/service/sync_list/sync_list_permission.rb +6 -6
  224. data/lib/twilio-ruby/rest/sync/v1/service/sync_map.rb +6 -6
  225. data/lib/twilio-ruby/rest/sync/v1/service/sync_map/sync_map_item.rb +12 -12
  226. data/lib/twilio-ruby/rest/sync/v1/service/sync_map/sync_map_permission.rb +6 -6
  227. data/lib/twilio-ruby/rest/sync/v1/service/sync_stream.rb +6 -6
  228. data/lib/twilio-ruby/rest/sync/v1/service/sync_stream/stream_message.rb +4 -4
  229. data/lib/twilio-ruby/rest/taskrouter/v1/workspace.rb +4 -4
  230. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/activity.rb +2 -1
  231. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/event.rb +6 -6
  232. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/task/reservation.rb +16 -12
  233. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/task_queue.rb +8 -8
  234. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/task_queue/task_queue_cumulative_statistics.rb +6 -6
  235. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/task_queue/task_queue_statistics.rb +6 -6
  236. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/task_queue/task_queues_statistics.rb +9 -9
  237. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/worker.rb +4 -7
  238. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/worker/reservation.rb +16 -12
  239. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/worker/worker_statistics.rb +4 -4
  240. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/worker/workers_cumulative_statistics.rb +4 -4
  241. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/worker/workers_statistics.rb +6 -6
  242. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/workflow.rb +12 -12
  243. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/workflow/workflow_cumulative_statistics.rb +4 -4
  244. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/workflow/workflow_statistics.rb +6 -6
  245. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/workspace_cumulative_statistics.rb +4 -4
  246. data/lib/twilio-ruby/rest/taskrouter/v1/workspace/workspace_statistics.rb +6 -6
  247. data/lib/twilio-ruby/rest/trunking/v1/trunk.rb +62 -47
  248. data/lib/twilio-ruby/rest/trunking/v1/trunk/credential_list.rb +2 -2
  249. data/lib/twilio-ruby/rest/trunking/v1/trunk/ip_access_control_list.rb +3 -2
  250. data/lib/twilio-ruby/rest/trunking/v1/trunk/phone_number.rb +3 -2
  251. data/lib/twilio-ruby/rest/trunking/v1/trunk/recording.rb +201 -0
  252. data/lib/twilio-ruby/rest/verify/v2/service.rb +3 -3
  253. data/lib/twilio-ruby/rest/verify/v2/service/entity/challenge.rb +3 -3
  254. data/lib/twilio-ruby/rest/verify/v2/service/entity/factor.rb +2 -6
  255. data/lib/twilio-ruby/rest/verify/v2/service/messaging_configuration.rb +12 -12
  256. data/lib/twilio-ruby/rest/verify/v2/service/rate_limit.rb +3 -3
  257. data/lib/twilio-ruby/rest/verify/v2/service/rate_limit/bucket.rb +3 -3
  258. data/lib/twilio-ruby/rest/verify/v2/service/verification.rb +14 -12
  259. data/lib/twilio-ruby/rest/verify/v2/service/verification_check.rb +5 -5
  260. data/lib/twilio-ruby/rest/video/v1/composition.rb +13 -9
  261. data/lib/twilio-ruby/rest/video/v1/composition_hook.rb +33 -24
  262. data/lib/twilio-ruby/rest/video/v1/recording.rb +6 -6
  263. data/lib/twilio-ruby/rest/video/v1/room.rb +7 -9
  264. data/lib/twilio-ruby/rest/video/v1/room/recording.rb +6 -6
  265. data/lib/twilio-ruby/rest/video/v1/room/room_participant.rb +9 -9
  266. data/lib/twilio-ruby/rest/video/v1/room/room_participant/room_participant_subscribe_rule.rb +2 -8
  267. data/lib/twilio-ruby/rest/voice/v1/byoc_trunk.rb +9 -9
  268. data/lib/twilio-ruby/rest/voice/v1/dialing_permissions.rb +3 -6
  269. data/lib/twilio-ruby/rest/voice/v1/dialing_permissions/country.rb +22 -22
  270. data/lib/twilio-ruby/rest/voice/v1/dialing_permissions/country/highrisk_special_prefix.rb +4 -4
  271. data/lib/twilio-ruby/rest/voice/v1/ip_record.rb +2 -2
  272. data/lib/twilio-ruby/rest/wireless/v1/command.rb +7 -7
  273. data/lib/twilio-ruby/rest/wireless/v1/rate_plan.rb +8 -7
  274. data/lib/twilio-ruby/rest/wireless/v1/sim.rb +22 -22
  275. data/lib/twilio-ruby/rest/wireless/v1/sim/data_session.rb +9 -23
  276. data/lib/twilio-ruby/rest/wireless/v1/sim/usage_record.rb +10 -10
  277. data/lib/twilio-ruby/rest/wireless/v1/usage_record.rb +6 -6
  278. data/lib/twilio-ruby/version.rb +1 -1
  279. data/spec/framework/version_spec.rb +53 -0
  280. data/spec/holodeck/holodeck.rb +3 -3
  281. data/spec/integration/api/v2010/account/conference/participant_spec.rb +30 -0
  282. data/spec/integration/bulkexports/v1/export/day_spec.rb +5 -5
  283. data/spec/integration/bulkexports/v1/export_configuration_spec.rb +4 -4
  284. data/spec/integration/bulkexports/v1/export_spec.rb +3 -3
  285. data/spec/integration/conversations/v1/{webhook_spec.rb → configuration/webhook_spec.rb} +12 -8
  286. data/spec/integration/conversations/v1/configuration_spec.rb +87 -0
  287. data/spec/integration/conversations/v1/conversation/message/delivery_receipt_spec.rb +4 -0
  288. data/spec/integration/conversations/v1/conversation/participant_spec.rb +6 -6
  289. data/spec/integration/conversations/v1/conversation_spec.rb +5 -0
  290. data/spec/integration/conversations/v1/credential_spec.rb +219 -0
  291. data/spec/integration/conversations/v1/role_spec.rb +249 -0
  292. data/spec/integration/conversations/v1/service/binding_spec.rb +166 -0
  293. data/spec/integration/conversations/v1/service/configuration/notification_spec.rb +115 -0
  294. data/spec/integration/conversations/v1/service/configuration_spec.rb +87 -0
  295. data/spec/integration/conversations/v1/service/conversation/message/delivery_receipt_spec.rb +144 -0
  296. data/spec/integration/conversations/v1/service/conversation/message_spec.rb +429 -0
  297. data/spec/integration/conversations/v1/service/conversation/participant_spec.rb +407 -0
  298. data/spec/integration/conversations/v1/service/conversation/webhook_spec.rb +299 -0
  299. data/spec/integration/conversations/v1/service/conversation_spec.rb +289 -0
  300. data/spec/integration/conversations/v1/service/role_spec.rb +260 -0
  301. data/spec/integration/conversations/v1/service/user_spec.rb +236 -0
  302. data/spec/integration/conversations/v1/service_spec.rb +174 -0
  303. data/spec/integration/conversations/v1/user_spec.rb +226 -0
  304. data/spec/integration/events/v1/event_type_spec.rb +133 -0
  305. data/spec/integration/events/v1/schema/schema_version_spec.rb +126 -0
  306. data/spec/integration/events/v1/schema_spec.rb +46 -0
  307. data/spec/integration/events/v1/sink/sink_test_spec.rb +42 -0
  308. data/spec/integration/events/v1/sink/sink_validate_spec.rb +44 -0
  309. data/spec/integration/events/v1/sink_spec.rb +217 -0
  310. data/spec/integration/events/v1/subscription/subscribed_event_spec.rb +91 -0
  311. data/spec/integration/events/v1/subscription_spec.rb +243 -0
  312. data/spec/integration/messaging/v1/deactivation_spec.rb +40 -0
  313. data/spec/integration/numbers/v2/regulatory_compliance/end_user_spec.rb +27 -0
  314. data/spec/integration/numbers/v2/regulatory_compliance/supporting_document_spec.rb +27 -0
  315. data/spec/integration/serverless/v1/service/build/build_status_spec.rb +48 -0
  316. data/spec/integration/serverless/v1/service/build_spec.rb +8 -2
  317. data/spec/integration/studio/v1/flow/execution/execution_step_spec.rb +1 -0
  318. data/spec/integration/studio/v2/flow/execution/execution_step_spec.rb +1 -0
  319. data/spec/integration/supersim/v1/sim_spec.rb +23 -0
  320. data/spec/integration/supersim/v1/usage_record_spec.rb +463 -18
  321. data/spec/integration/trunking/v1/trunk/recording_spec.rb +79 -0
  322. data/spec/integration/trunking/v1/trunk_spec.rb +4 -0
  323. data/spec/integration/verify/v2/service/entity/factor_spec.rb +2 -2
  324. data/spec/integration/video/v1/room_spec.rb +37 -0
  325. data/spec/integration/wireless/v1/sim/data_session_spec.rb +2 -2
  326. data/spec/spec_helper.rb +1 -1
  327. metadata +85 -5
  328. data/lib/twilio-ruby/rest/conversations/v1/webhook.rb +0 -262
@@ -0,0 +1,449 @@
1
+ ##
2
+ # This code was generated by
3
+ # \ / _ _ _| _ _
4
+ # | (_)\/(_)(_|\/| |(/_ v1.0.0
5
+ # / /
6
+ #
7
+ # frozen_string_literal: true
8
+
9
+ module Twilio
10
+ module REST
11
+ class Conversations < Domain
12
+ class V1 < Version
13
+ class ServiceContext < InstanceContext
14
+ class ConversationContext < InstanceContext
15
+ class WebhookList < ListResource
16
+ ##
17
+ # Initialize the WebhookList
18
+ # @param [Version] version Version that contains the resource
19
+ # @param [String] chat_service_sid The SID of the {Conversation
20
+ # Service}[https://www.twilio.com/docs/conversations/api/service-resource] the
21
+ # Participant resource is associated with.
22
+ # @param [String] conversation_sid The unique ID of the
23
+ # {Conversation}[https://www.twilio.com/docs/conversations/api/conversation-resource]
24
+ # for this webhook.
25
+ # @return [WebhookList] WebhookList
26
+ def initialize(version, chat_service_sid: nil, conversation_sid: nil)
27
+ super(version)
28
+
29
+ # Path Solution
30
+ @solution = {chat_service_sid: chat_service_sid, conversation_sid: conversation_sid}
31
+ @uri = "/Services/#{@solution[:chat_service_sid]}/Conversations/#{@solution[:conversation_sid]}/Webhooks"
32
+ end
33
+
34
+ ##
35
+ # Create the WebhookInstance
36
+ # @param [webhook.Target] target The target of this webhook: `webhook`, `studio`,
37
+ # `trigger`
38
+ # @param [String] configuration_url The absolute url the webhook request should be
39
+ # sent to.
40
+ # @param [webhook.Method] configuration_method The HTTP method to be used when
41
+ # sending a webhook request.
42
+ # @param [String] configuration_filters The list of events, firing webhook event
43
+ # for this Conversation.
44
+ # @param [String] configuration_triggers The list of keywords, firing webhook
45
+ # event for this Conversation.
46
+ # @param [String] configuration_flow_sid The studio flow SID, where the webhook
47
+ # should be sent to.
48
+ # @param [String] configuration_replay_after The message index for which and it's
49
+ # successors the webhook will be replayed. Not set by default
50
+ # @return [WebhookInstance] Created WebhookInstance
51
+ def create(target: nil, configuration_url: :unset, configuration_method: :unset, configuration_filters: :unset, configuration_triggers: :unset, configuration_flow_sid: :unset, configuration_replay_after: :unset)
52
+ data = Twilio::Values.of({
53
+ 'Target' => target,
54
+ 'Configuration.Url' => configuration_url,
55
+ 'Configuration.Method' => configuration_method,
56
+ 'Configuration.Filters' => Twilio.serialize_list(configuration_filters) { |e| e },
57
+ 'Configuration.Triggers' => Twilio.serialize_list(configuration_triggers) { |e| e },
58
+ 'Configuration.FlowSid' => configuration_flow_sid,
59
+ 'Configuration.ReplayAfter' => configuration_replay_after,
60
+ })
61
+
62
+ payload = @version.create('POST', @uri, data: data)
63
+
64
+ WebhookInstance.new(
65
+ @version,
66
+ payload,
67
+ chat_service_sid: @solution[:chat_service_sid],
68
+ conversation_sid: @solution[:conversation_sid],
69
+ )
70
+ end
71
+
72
+ ##
73
+ # Lists WebhookInstance records from the API as a list.
74
+ # Unlike stream(), this operation is eager and will load `limit` records into
75
+ # memory before returning.
76
+ # @param [Integer] limit Upper limit for the number of records to return. stream()
77
+ # guarantees to never return more than limit. Default is no limit
78
+ # @param [Integer] page_size Number of records to fetch per request, when
79
+ # not set will use the default value of 50 records. If no page_size is defined
80
+ # but a limit is defined, stream() will attempt to read the limit with the most
81
+ # efficient page size, i.e. min(limit, 1000)
82
+ # @return [Array] Array of up to limit results
83
+ def list(limit: nil, page_size: nil)
84
+ self.stream(limit: limit, page_size: page_size).entries
85
+ end
86
+
87
+ ##
88
+ # Streams WebhookInstance records from the API as an Enumerable.
89
+ # This operation lazily loads records as efficiently as possible until the limit
90
+ # is reached.
91
+ # @param [Integer] limit Upper limit for the number of records to return. stream()
92
+ # guarantees to never return more than limit. Default is no limit.
93
+ # @param [Integer] page_size Number of records to fetch per request, when
94
+ # not set will use the default value of 50 records. If no page_size is defined
95
+ # but a limit is defined, stream() will attempt to read the limit with the most
96
+ # efficient page size, i.e. min(limit, 1000)
97
+ # @return [Enumerable] Enumerable that will yield up to limit results
98
+ def stream(limit: nil, page_size: nil)
99
+ limits = @version.read_limits(limit, page_size)
100
+
101
+ page = self.page(page_size: limits[:page_size], )
102
+
103
+ @version.stream(page, limit: limits[:limit], page_limit: limits[:page_limit])
104
+ end
105
+
106
+ ##
107
+ # When passed a block, yields WebhookInstance records from the API.
108
+ # This operation lazily loads records as efficiently as possible until the limit
109
+ # is reached.
110
+ def each
111
+ limits = @version.read_limits
112
+
113
+ page = self.page(page_size: limits[:page_size], )
114
+
115
+ @version.stream(page,
116
+ limit: limits[:limit],
117
+ page_limit: limits[:page_limit]).each {|x| yield x}
118
+ end
119
+
120
+ ##
121
+ # Retrieve a single page of WebhookInstance records from the API.
122
+ # Request is executed immediately.
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 WebhookInstance
127
+ def page(page_token: :unset, page_number: :unset, page_size: :unset)
128
+ params = Twilio::Values.of({
129
+ 'PageToken' => page_token,
130
+ 'Page' => page_number,
131
+ 'PageSize' => page_size,
132
+ })
133
+
134
+ response = @version.page('GET', @uri, params: params)
135
+
136
+ WebhookPage.new(@version, response, @solution)
137
+ end
138
+
139
+ ##
140
+ # Retrieve a single page of WebhookInstance records from the API.
141
+ # Request is executed immediately.
142
+ # @param [String] target_url API-generated URL for the requested results page
143
+ # @return [Page] Page of WebhookInstance
144
+ def get_page(target_url)
145
+ response = @version.domain.request(
146
+ 'GET',
147
+ target_url
148
+ )
149
+ WebhookPage.new(@version, response, @solution)
150
+ end
151
+
152
+ ##
153
+ # Provide a user friendly representation
154
+ def to_s
155
+ '#<Twilio.Conversations.V1.WebhookList>'
156
+ end
157
+ end
158
+
159
+ class WebhookPage < Page
160
+ ##
161
+ # Initialize the WebhookPage
162
+ # @param [Version] version Version that contains the resource
163
+ # @param [Response] response Response from the API
164
+ # @param [Hash] solution Path solution for the resource
165
+ # @return [WebhookPage] WebhookPage
166
+ def initialize(version, response, solution)
167
+ super(version, response)
168
+
169
+ # Path Solution
170
+ @solution = solution
171
+ end
172
+
173
+ ##
174
+ # Build an instance of WebhookInstance
175
+ # @param [Hash] payload Payload response from the API
176
+ # @return [WebhookInstance] WebhookInstance
177
+ def get_instance(payload)
178
+ WebhookInstance.new(
179
+ @version,
180
+ payload,
181
+ chat_service_sid: @solution[:chat_service_sid],
182
+ conversation_sid: @solution[:conversation_sid],
183
+ )
184
+ end
185
+
186
+ ##
187
+ # Provide a user friendly representation
188
+ def to_s
189
+ '<Twilio.Conversations.V1.WebhookPage>'
190
+ end
191
+ end
192
+
193
+ class WebhookContext < InstanceContext
194
+ ##
195
+ # Initialize the WebhookContext
196
+ # @param [Version] version Version that contains the resource
197
+ # @param [String] chat_service_sid The SID of the {Conversation
198
+ # Service}[https://www.twilio.com/docs/conversations/api/service-resource] the
199
+ # Participant resource is associated with.
200
+ # @param [String] conversation_sid The unique ID of the
201
+ # {Conversation}[https://www.twilio.com/docs/conversations/api/conversation-resource]
202
+ # for this webhook.
203
+ # @param [String] sid A 34 character string that uniquely identifies this
204
+ # resource.
205
+ # @return [WebhookContext] WebhookContext
206
+ def initialize(version, chat_service_sid, conversation_sid, sid)
207
+ super(version)
208
+
209
+ # Path Solution
210
+ @solution = {chat_service_sid: chat_service_sid, conversation_sid: conversation_sid, sid: sid, }
211
+ @uri = "/Services/#{@solution[:chat_service_sid]}/Conversations/#{@solution[:conversation_sid]}/Webhooks/#{@solution[:sid]}"
212
+ end
213
+
214
+ ##
215
+ # Update the WebhookInstance
216
+ # @param [String] configuration_url The absolute url the webhook request should be
217
+ # sent to.
218
+ # @param [webhook.Method] configuration_method The HTTP method to be used when
219
+ # sending a webhook request.
220
+ # @param [String] configuration_filters The list of events, firing webhook event
221
+ # for this Conversation.
222
+ # @param [String] configuration_triggers The list of keywords, firing webhook
223
+ # event for this Conversation.
224
+ # @param [String] configuration_flow_sid The studio flow SID, where the webhook
225
+ # should be sent to.
226
+ # @return [WebhookInstance] Updated WebhookInstance
227
+ def update(configuration_url: :unset, configuration_method: :unset, configuration_filters: :unset, configuration_triggers: :unset, configuration_flow_sid: :unset)
228
+ data = Twilio::Values.of({
229
+ 'Configuration.Url' => configuration_url,
230
+ 'Configuration.Method' => configuration_method,
231
+ 'Configuration.Filters' => Twilio.serialize_list(configuration_filters) { |e| e },
232
+ 'Configuration.Triggers' => Twilio.serialize_list(configuration_triggers) { |e| e },
233
+ 'Configuration.FlowSid' => configuration_flow_sid,
234
+ })
235
+
236
+ payload = @version.update('POST', @uri, data: data)
237
+
238
+ WebhookInstance.new(
239
+ @version,
240
+ payload,
241
+ chat_service_sid: @solution[:chat_service_sid],
242
+ conversation_sid: @solution[:conversation_sid],
243
+ sid: @solution[:sid],
244
+ )
245
+ end
246
+
247
+ ##
248
+ # Delete the WebhookInstance
249
+ # @return [Boolean] true if delete succeeds, false otherwise
250
+ def delete
251
+ @version.delete('DELETE', @uri)
252
+ end
253
+
254
+ ##
255
+ # Fetch the WebhookInstance
256
+ # @return [WebhookInstance] Fetched WebhookInstance
257
+ def fetch
258
+ payload = @version.fetch('GET', @uri)
259
+
260
+ WebhookInstance.new(
261
+ @version,
262
+ payload,
263
+ chat_service_sid: @solution[:chat_service_sid],
264
+ conversation_sid: @solution[:conversation_sid],
265
+ sid: @solution[:sid],
266
+ )
267
+ end
268
+
269
+ ##
270
+ # Provide a user friendly representation
271
+ def to_s
272
+ context = @solution.map {|k, v| "#{k}: #{v}"}.join(',')
273
+ "#<Twilio.Conversations.V1.WebhookContext #{context}>"
274
+ end
275
+
276
+ ##
277
+ # Provide a detailed, user friendly representation
278
+ def inspect
279
+ context = @solution.map {|k, v| "#{k}: #{v}"}.join(',')
280
+ "#<Twilio.Conversations.V1.WebhookContext #{context}>"
281
+ end
282
+ end
283
+
284
+ class WebhookInstance < InstanceResource
285
+ ##
286
+ # Initialize the WebhookInstance
287
+ # @param [Version] version Version that contains the resource
288
+ # @param [Hash] payload payload that contains response from Twilio
289
+ # @param [String] chat_service_sid The SID of the {Conversation
290
+ # Service}[https://www.twilio.com/docs/conversations/api/service-resource] the
291
+ # Participant resource is associated with.
292
+ # @param [String] conversation_sid The unique ID of the
293
+ # {Conversation}[https://www.twilio.com/docs/conversations/api/conversation-resource]
294
+ # for this webhook.
295
+ # @param [String] sid A 34 character string that uniquely identifies this
296
+ # resource.
297
+ # @return [WebhookInstance] WebhookInstance
298
+ def initialize(version, payload, chat_service_sid: nil, conversation_sid: nil, sid: nil)
299
+ super(version)
300
+
301
+ # Marshaled Properties
302
+ @properties = {
303
+ 'sid' => payload['sid'],
304
+ 'account_sid' => payload['account_sid'],
305
+ 'chat_service_sid' => payload['chat_service_sid'],
306
+ 'conversation_sid' => payload['conversation_sid'],
307
+ 'target' => payload['target'],
308
+ 'url' => payload['url'],
309
+ 'configuration' => payload['configuration'],
310
+ 'date_created' => Twilio.deserialize_iso8601_datetime(payload['date_created']),
311
+ 'date_updated' => Twilio.deserialize_iso8601_datetime(payload['date_updated']),
312
+ }
313
+
314
+ # Context
315
+ @instance_context = nil
316
+ @params = {
317
+ 'chat_service_sid' => chat_service_sid,
318
+ 'conversation_sid' => conversation_sid,
319
+ 'sid' => sid || @properties['sid'],
320
+ }
321
+ end
322
+
323
+ ##
324
+ # Generate an instance context for the instance, the context is capable of
325
+ # performing various actions. All instance actions are proxied to the context
326
+ # @return [WebhookContext] WebhookContext for this WebhookInstance
327
+ def context
328
+ unless @instance_context
329
+ @instance_context = WebhookContext.new(
330
+ @version,
331
+ @params['chat_service_sid'],
332
+ @params['conversation_sid'],
333
+ @params['sid'],
334
+ )
335
+ end
336
+ @instance_context
337
+ end
338
+
339
+ ##
340
+ # @return [String] A 34 character string that uniquely identifies this resource.
341
+ def sid
342
+ @properties['sid']
343
+ end
344
+
345
+ ##
346
+ # @return [String] The unique ID of the Account responsible for this conversation.
347
+ def account_sid
348
+ @properties['account_sid']
349
+ end
350
+
351
+ ##
352
+ # @return [String] The SID of the Conversation Service that the resource is associated with.
353
+ def chat_service_sid
354
+ @properties['chat_service_sid']
355
+ end
356
+
357
+ ##
358
+ # @return [String] The unique ID of the Conversation for this webhook.
359
+ def conversation_sid
360
+ @properties['conversation_sid']
361
+ end
362
+
363
+ ##
364
+ # @return [String] The target of this webhook.
365
+ def target
366
+ @properties['target']
367
+ end
368
+
369
+ ##
370
+ # @return [String] An absolute URL for this webhook.
371
+ def url
372
+ @properties['url']
373
+ end
374
+
375
+ ##
376
+ # @return [Hash] The configuration of this webhook.
377
+ def configuration
378
+ @properties['configuration']
379
+ end
380
+
381
+ ##
382
+ # @return [Time] The date that this resource was created.
383
+ def date_created
384
+ @properties['date_created']
385
+ end
386
+
387
+ ##
388
+ # @return [Time] The date that this resource was last updated.
389
+ def date_updated
390
+ @properties['date_updated']
391
+ end
392
+
393
+ ##
394
+ # Update the WebhookInstance
395
+ # @param [String] configuration_url The absolute url the webhook request should be
396
+ # sent to.
397
+ # @param [webhook.Method] configuration_method The HTTP method to be used when
398
+ # sending a webhook request.
399
+ # @param [String] configuration_filters The list of events, firing webhook event
400
+ # for this Conversation.
401
+ # @param [String] configuration_triggers The list of keywords, firing webhook
402
+ # event for this Conversation.
403
+ # @param [String] configuration_flow_sid The studio flow SID, where the webhook
404
+ # should be sent to.
405
+ # @return [WebhookInstance] Updated WebhookInstance
406
+ def update(configuration_url: :unset, configuration_method: :unset, configuration_filters: :unset, configuration_triggers: :unset, configuration_flow_sid: :unset)
407
+ context.update(
408
+ configuration_url: configuration_url,
409
+ configuration_method: configuration_method,
410
+ configuration_filters: configuration_filters,
411
+ configuration_triggers: configuration_triggers,
412
+ configuration_flow_sid: configuration_flow_sid,
413
+ )
414
+ end
415
+
416
+ ##
417
+ # Delete the WebhookInstance
418
+ # @return [Boolean] true if delete succeeds, false otherwise
419
+ def delete
420
+ context.delete
421
+ end
422
+
423
+ ##
424
+ # Fetch the WebhookInstance
425
+ # @return [WebhookInstance] Fetched WebhookInstance
426
+ def fetch
427
+ context.fetch
428
+ end
429
+
430
+ ##
431
+ # Provide a user friendly representation
432
+ def to_s
433
+ values = @params.map{|k, v| "#{k}: #{v}"}.join(" ")
434
+ "<Twilio.Conversations.V1.WebhookInstance #{values}>"
435
+ end
436
+
437
+ ##
438
+ # Provide a detailed, user friendly representation
439
+ def inspect
440
+ values = @properties.map{|k, v| "#{k}: #{v}"}.join(" ")
441
+ "<Twilio.Conversations.V1.WebhookInstance #{values}>"
442
+ end
443
+ end
444
+ end
445
+ end
446
+ end
447
+ end
448
+ end
449
+ end
@@ -0,0 +1,387 @@
1
+ ##
2
+ # This code was generated by
3
+ # \ / _ _ _| _ _
4
+ # | (_)\/(_)(_|\/| |(/_ v1.0.0
5
+ # / /
6
+ #
7
+ # frozen_string_literal: true
8
+
9
+ module Twilio
10
+ module REST
11
+ class Conversations < Domain
12
+ class V1 < Version
13
+ class ServiceContext < InstanceContext
14
+ class RoleList < ListResource
15
+ ##
16
+ # Initialize the RoleList
17
+ # @param [Version] version Version that contains the resource
18
+ # @param [String] chat_service_sid The SID of the {Conversation
19
+ # Service}[https://www.twilio.com/docs/conversations/api/service-resource] the
20
+ # Role resource is associated with.
21
+ # @return [RoleList] RoleList
22
+ def initialize(version, chat_service_sid: nil)
23
+ super(version)
24
+
25
+ # Path Solution
26
+ @solution = {chat_service_sid: chat_service_sid}
27
+ @uri = "/Services/#{@solution[:chat_service_sid]}/Roles"
28
+ end
29
+
30
+ ##
31
+ # Create the RoleInstance
32
+ # @param [String] friendly_name A descriptive string that you create to describe
33
+ # the new resource. It can be up to 64 characters long.
34
+ # @param [role.RoleType] type The type of role. Can be: `conversation` for
35
+ # {Conversation}[https://www.twilio.com/docs/conversations/api/conversation-resource]
36
+ # roles or `service` for {Conversation
37
+ # Service}[https://www.twilio.com/docs/conversations/api/service-resource] roles.
38
+ # @param [String] permission A permission that you grant to the new role. Only one
39
+ # permission can be granted per parameter. To assign more than one permission,
40
+ # repeat this parameter for each permission value. The values for this parameter
41
+ # depend on the role's `type`.
42
+ # @return [RoleInstance] Created RoleInstance
43
+ def create(friendly_name: nil, type: nil, permission: nil)
44
+ data = Twilio::Values.of({
45
+ 'FriendlyName' => friendly_name,
46
+ 'Type' => type,
47
+ 'Permission' => Twilio.serialize_list(permission) { |e| e },
48
+ })
49
+
50
+ payload = @version.create('POST', @uri, data: data)
51
+
52
+ RoleInstance.new(@version, payload, chat_service_sid: @solution[:chat_service_sid], )
53
+ end
54
+
55
+ ##
56
+ # Lists RoleInstance records from the API as a list.
57
+ # Unlike stream(), this operation is eager and will load `limit` records into
58
+ # memory before returning.
59
+ # @param [Integer] limit Upper limit for the number of records to return. stream()
60
+ # guarantees to never return more than limit. Default is no limit
61
+ # @param [Integer] page_size Number of records to fetch per request, when
62
+ # not set will use the default value of 50 records. If no page_size is defined
63
+ # but a limit is defined, stream() will attempt to read the limit with the most
64
+ # efficient page size, i.e. min(limit, 1000)
65
+ # @return [Array] Array of up to limit results
66
+ def list(limit: nil, page_size: nil)
67
+ self.stream(limit: limit, page_size: page_size).entries
68
+ end
69
+
70
+ ##
71
+ # Streams RoleInstance records from the API as an Enumerable.
72
+ # This operation lazily loads records as efficiently as possible until the limit
73
+ # is reached.
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(limit: nil, page_size: nil)
82
+ limits = @version.read_limits(limit, page_size)
83
+
84
+ page = self.page(page_size: limits[:page_size], )
85
+
86
+ @version.stream(page, limit: limits[:limit], page_limit: limits[:page_limit])
87
+ end
88
+
89
+ ##
90
+ # When passed a block, yields RoleInstance records from the API.
91
+ # This operation lazily loads records as efficiently as possible until the limit
92
+ # is reached.
93
+ def each
94
+ limits = @version.read_limits
95
+
96
+ page = self.page(page_size: limits[:page_size], )
97
+
98
+ @version.stream(page,
99
+ limit: limits[:limit],
100
+ page_limit: limits[:page_limit]).each {|x| yield x}
101
+ end
102
+
103
+ ##
104
+ # Retrieve a single page of RoleInstance records from the API.
105
+ # Request is executed immediately.
106
+ # @param [String] page_token PageToken provided by the API
107
+ # @param [Integer] page_number Page Number, this value is simply for client state
108
+ # @param [Integer] page_size Number of records to return, defaults to 50
109
+ # @return [Page] Page of RoleInstance
110
+ def page(page_token: :unset, page_number: :unset, page_size: :unset)
111
+ params = Twilio::Values.of({
112
+ 'PageToken' => page_token,
113
+ 'Page' => page_number,
114
+ 'PageSize' => page_size,
115
+ })
116
+
117
+ response = @version.page('GET', @uri, params: params)
118
+
119
+ RolePage.new(@version, response, @solution)
120
+ end
121
+
122
+ ##
123
+ # Retrieve a single page of RoleInstance records from the API.
124
+ # Request is executed immediately.
125
+ # @param [String] target_url API-generated URL for the requested results page
126
+ # @return [Page] Page of RoleInstance
127
+ def get_page(target_url)
128
+ response = @version.domain.request(
129
+ 'GET',
130
+ target_url
131
+ )
132
+ RolePage.new(@version, response, @solution)
133
+ end
134
+
135
+ ##
136
+ # Provide a user friendly representation
137
+ def to_s
138
+ '#<Twilio.Conversations.V1.RoleList>'
139
+ end
140
+ end
141
+
142
+ class RolePage < Page
143
+ ##
144
+ # Initialize the RolePage
145
+ # @param [Version] version Version that contains the resource
146
+ # @param [Response] response Response from the API
147
+ # @param [Hash] solution Path solution for the resource
148
+ # @return [RolePage] RolePage
149
+ def initialize(version, response, solution)
150
+ super(version, response)
151
+
152
+ # Path Solution
153
+ @solution = solution
154
+ end
155
+
156
+ ##
157
+ # Build an instance of RoleInstance
158
+ # @param [Hash] payload Payload response from the API
159
+ # @return [RoleInstance] RoleInstance
160
+ def get_instance(payload)
161
+ RoleInstance.new(@version, payload, chat_service_sid: @solution[:chat_service_sid], )
162
+ end
163
+
164
+ ##
165
+ # Provide a user friendly representation
166
+ def to_s
167
+ '<Twilio.Conversations.V1.RolePage>'
168
+ end
169
+ end
170
+
171
+ class RoleContext < InstanceContext
172
+ ##
173
+ # Initialize the RoleContext
174
+ # @param [Version] version Version that contains the resource
175
+ # @param [String] chat_service_sid The SID of the {Conversation
176
+ # Service}[https://www.twilio.com/docs/conversations/api/service-resource] to
177
+ # fetch the Role resource from.
178
+ # @param [String] sid The SID of the Role resource to fetch.
179
+ # @return [RoleContext] RoleContext
180
+ def initialize(version, chat_service_sid, sid)
181
+ super(version)
182
+
183
+ # Path Solution
184
+ @solution = {chat_service_sid: chat_service_sid, sid: sid, }
185
+ @uri = "/Services/#{@solution[:chat_service_sid]}/Roles/#{@solution[:sid]}"
186
+ end
187
+
188
+ ##
189
+ # Update the RoleInstance
190
+ # @param [String] permission A permission that you grant to the role. Only one
191
+ # permission can be granted per parameter. To assign more than one permission,
192
+ # repeat this parameter for each permission value. Note that the update action
193
+ # replaces all previously assigned permissions with those defined in the update
194
+ # action. To remove a permission, do not include it in the subsequent update
195
+ # action. The values for this parameter depend on the role's `type`.
196
+ # @return [RoleInstance] Updated RoleInstance
197
+ def update(permission: nil)
198
+ data = Twilio::Values.of({'Permission' => Twilio.serialize_list(permission) { |e| e }, })
199
+
200
+ payload = @version.update('POST', @uri, data: data)
201
+
202
+ RoleInstance.new(
203
+ @version,
204
+ payload,
205
+ chat_service_sid: @solution[:chat_service_sid],
206
+ sid: @solution[:sid],
207
+ )
208
+ end
209
+
210
+ ##
211
+ # Delete the RoleInstance
212
+ # @return [Boolean] true if delete succeeds, false otherwise
213
+ def delete
214
+ @version.delete('DELETE', @uri)
215
+ end
216
+
217
+ ##
218
+ # Fetch the RoleInstance
219
+ # @return [RoleInstance] Fetched RoleInstance
220
+ def fetch
221
+ payload = @version.fetch('GET', @uri)
222
+
223
+ RoleInstance.new(
224
+ @version,
225
+ payload,
226
+ chat_service_sid: @solution[:chat_service_sid],
227
+ sid: @solution[:sid],
228
+ )
229
+ end
230
+
231
+ ##
232
+ # Provide a user friendly representation
233
+ def to_s
234
+ context = @solution.map {|k, v| "#{k}: #{v}"}.join(',')
235
+ "#<Twilio.Conversations.V1.RoleContext #{context}>"
236
+ end
237
+
238
+ ##
239
+ # Provide a detailed, user friendly representation
240
+ def inspect
241
+ context = @solution.map {|k, v| "#{k}: #{v}"}.join(',')
242
+ "#<Twilio.Conversations.V1.RoleContext #{context}>"
243
+ end
244
+ end
245
+
246
+ class RoleInstance < InstanceResource
247
+ ##
248
+ # Initialize the RoleInstance
249
+ # @param [Version] version Version that contains the resource
250
+ # @param [Hash] payload payload that contains response from Twilio
251
+ # @param [String] chat_service_sid The SID of the {Conversation
252
+ # Service}[https://www.twilio.com/docs/conversations/api/service-resource] the
253
+ # Role resource is associated with.
254
+ # @param [String] sid The SID of the Role resource to fetch.
255
+ # @return [RoleInstance] RoleInstance
256
+ def initialize(version, payload, chat_service_sid: nil, sid: nil)
257
+ super(version)
258
+
259
+ # Marshaled Properties
260
+ @properties = {
261
+ 'sid' => payload['sid'],
262
+ 'account_sid' => payload['account_sid'],
263
+ 'chat_service_sid' => payload['chat_service_sid'],
264
+ 'friendly_name' => payload['friendly_name'],
265
+ 'type' => payload['type'],
266
+ 'permissions' => payload['permissions'],
267
+ 'date_created' => Twilio.deserialize_iso8601_datetime(payload['date_created']),
268
+ 'date_updated' => Twilio.deserialize_iso8601_datetime(payload['date_updated']),
269
+ 'url' => payload['url'],
270
+ }
271
+
272
+ # Context
273
+ @instance_context = nil
274
+ @params = {'chat_service_sid' => chat_service_sid, 'sid' => sid || @properties['sid'], }
275
+ end
276
+
277
+ ##
278
+ # Generate an instance context for the instance, the context is capable of
279
+ # performing various actions. All instance actions are proxied to the context
280
+ # @return [RoleContext] RoleContext for this RoleInstance
281
+ def context
282
+ unless @instance_context
283
+ @instance_context = RoleContext.new(@version, @params['chat_service_sid'], @params['sid'], )
284
+ end
285
+ @instance_context
286
+ end
287
+
288
+ ##
289
+ # @return [String] The unique string that identifies the resource
290
+ def sid
291
+ @properties['sid']
292
+ end
293
+
294
+ ##
295
+ # @return [String] The SID of the Account that created the resource
296
+ def account_sid
297
+ @properties['account_sid']
298
+ end
299
+
300
+ ##
301
+ # @return [String] The SID of the Conversation Service that the resource is associated with
302
+ def chat_service_sid
303
+ @properties['chat_service_sid']
304
+ end
305
+
306
+ ##
307
+ # @return [String] The string that you assigned to describe the resource
308
+ def friendly_name
309
+ @properties['friendly_name']
310
+ end
311
+
312
+ ##
313
+ # @return [role.RoleType] The type of role
314
+ def type
315
+ @properties['type']
316
+ end
317
+
318
+ ##
319
+ # @return [String] An array of the permissions the role has been granted
320
+ def permissions
321
+ @properties['permissions']
322
+ end
323
+
324
+ ##
325
+ # @return [Time] The ISO 8601 date and time in GMT when the resource was created
326
+ def date_created
327
+ @properties['date_created']
328
+ end
329
+
330
+ ##
331
+ # @return [Time] The ISO 8601 date and time in GMT when the resource was last updated
332
+ def date_updated
333
+ @properties['date_updated']
334
+ end
335
+
336
+ ##
337
+ # @return [String] An absolute URL for this user role.
338
+ def url
339
+ @properties['url']
340
+ end
341
+
342
+ ##
343
+ # Update the RoleInstance
344
+ # @param [String] permission A permission that you grant to the role. Only one
345
+ # permission can be granted per parameter. To assign more than one permission,
346
+ # repeat this parameter for each permission value. Note that the update action
347
+ # replaces all previously assigned permissions with those defined in the update
348
+ # action. To remove a permission, do not include it in the subsequent update
349
+ # action. The values for this parameter depend on the role's `type`.
350
+ # @return [RoleInstance] Updated RoleInstance
351
+ def update(permission: nil)
352
+ context.update(permission: permission, )
353
+ end
354
+
355
+ ##
356
+ # Delete the RoleInstance
357
+ # @return [Boolean] true if delete succeeds, false otherwise
358
+ def delete
359
+ context.delete
360
+ end
361
+
362
+ ##
363
+ # Fetch the RoleInstance
364
+ # @return [RoleInstance] Fetched RoleInstance
365
+ def fetch
366
+ context.fetch
367
+ end
368
+
369
+ ##
370
+ # Provide a user friendly representation
371
+ def to_s
372
+ values = @params.map{|k, v| "#{k}: #{v}"}.join(" ")
373
+ "<Twilio.Conversations.V1.RoleInstance #{values}>"
374
+ end
375
+
376
+ ##
377
+ # Provide a detailed, user friendly representation
378
+ def inspect
379
+ values = @properties.map{|k, v| "#{k}: #{v}"}.join(" ")
380
+ "<Twilio.Conversations.V1.RoleInstance #{values}>"
381
+ end
382
+ end
383
+ end
384
+ end
385
+ end
386
+ end
387
+ end