/src/Twilio/Rest/Taskrouter/V1/Workspace/Task/ReservationOptions.php

http://github.com/twilio/twilio-php · PHP · 986 lines · 303 code · 64 blank · 619 comment · 0 complexity · 9c12b78c6ef48f1f6c978e8fdb60392a MD5 · raw file

Large files are truncated click here to view the full file

  1. <?php
  2. /**
  3. * This code was generated by
  4. * \ / _ _ _| _ _
  5. * | (_)\/(_)(_|\/| |(/_ v1.0.0
  6. * / /
  7. */
  8. namespace Twilio\Rest\Taskrouter\V1\Workspace\Task;
  9. use Twilio\Options;
  10. use Twilio\Values;
  11. abstract class ReservationOptions {
  12. /**
  13. * @param string $reservationStatus Returns the list of reservations for a task
  14. * with a specified ReservationStatus
  15. * @return ReadReservationOptions Options builder
  16. */
  17. public static function read(string $reservationStatus = Values::NONE): ReadReservationOptions {
  18. return new ReadReservationOptions($reservationStatus);
  19. }
  20. /**
  21. * @param string $reservationStatus The new status of the reservation
  22. * @param string $workerActivitySid The new worker activity SID if rejecting a
  23. * reservation
  24. * @param string $instruction The assignment instruction for reservation
  25. * @param string $dequeuePostWorkActivitySid The SID of the Activity resource
  26. * to start after executing a Dequeue
  27. * instruction
  28. * @param string $dequeueFrom The Caller ID of the call to the worker when
  29. * executing a Dequeue instruction
  30. * @param string $dequeueRecord Whether to record both legs of a call when
  31. * executing a Dequeue instruction
  32. * @param int $dequeueTimeout Timeout for call when executing a Dequeue
  33. * instruction
  34. * @param string $dequeueTo The Contact URI of the worker when executing a
  35. * Dequeue instruction
  36. * @param string $dequeueStatusCallbackUrl The Callback URL for completed call
  37. * event when executing a Dequeue
  38. * instruction
  39. * @param string $callFrom The Caller ID of the outbound call when executing a
  40. * Call instruction
  41. * @param string $callRecord Whether to record both legs of a call when
  42. * executing a Call instruction
  43. * @param int $callTimeout Timeout for call when executing a Call instruction
  44. * @param string $callTo The Contact URI of the worker when executing a Call
  45. * instruction
  46. * @param string $callUrl TwiML URI executed on answering the worker's leg as a
  47. * result of the Call instruction
  48. * @param string $callStatusCallbackUrl The URL to call for the completed call
  49. * event when executing a Call instruction
  50. * @param bool $callAccept Whether to accept a reservation when executing a
  51. * Call instruction
  52. * @param string $redirectCallSid The Call SID of the call parked in the queue
  53. * when executing a Redirect instruction
  54. * @param bool $redirectAccept Whether the reservation should be accepted when
  55. * executing a Redirect instruction
  56. * @param string $redirectUrl TwiML URI to redirect the call to when executing
  57. * the Redirect instruction
  58. * @param string $to The Contact URI of the worker when executing a Conference
  59. * instruction
  60. * @param string $from The Caller ID of the call to the worker when executing a
  61. * Conference instruction
  62. * @param string $statusCallback The URL we should call to send status
  63. * information to your application
  64. * @param string $statusCallbackMethod The HTTP method we should use to call
  65. * status_callback
  66. * @param string[] $statusCallbackEvent The call progress events that we will
  67. * send to status_callback
  68. * @param int $timeout Timeout for call when executing a Conference instruction
  69. * @param bool $record Whether to record the participant and their conferences
  70. * @param bool $muted Whether to mute the agent
  71. * @param string $beep Whether to play a notification beep when the participant
  72. * joins
  73. * @param bool $startConferenceOnEnter Whether the conference starts when the
  74. * participant joins the conference
  75. * @param bool $endConferenceOnExit Whether to end the conference when the
  76. * agent leaves
  77. * @param string $waitUrl URL that hosts pre-conference hold music
  78. * @param string $waitMethod The HTTP method we should use to call `wait_url`
  79. * @param bool $earlyMedia Whether agents can hear the state of the outbound
  80. * call
  81. * @param int $maxParticipants The maximum number of agent conference
  82. * participants
  83. * @param string $conferenceStatusCallback The callback URL for conference
  84. * events
  85. * @param string $conferenceStatusCallbackMethod HTTP method for requesting
  86. * `conference_status_callback`
  87. * URL
  88. * @param string[] $conferenceStatusCallbackEvent The conference status events
  89. * that we will send to
  90. * conference_status_callback
  91. * @param string $conferenceRecord Whether to record the conference the
  92. * participant is joining
  93. * @param string $conferenceTrim How to trim leading and trailing silence from
  94. * your recorded conference audio files
  95. * @param string $recordingChannels Specify `mono` or `dual` recording channels
  96. * @param string $recordingStatusCallback The URL that we should call using the
  97. * `recording_status_callback_method`
  98. * when the recording status changes
  99. * @param string $recordingStatusCallbackMethod The HTTP method we should use
  100. * when we call
  101. * `recording_status_callback`
  102. * @param string $conferenceRecordingStatusCallback The URL we should call
  103. * using the
  104. * `conference_recording_status_callback_method` when the conference recording is available
  105. * @param string $conferenceRecordingStatusCallbackMethod The HTTP method we
  106. * should use to call
  107. * `conference_recording_status_callback`
  108. * @param string $region The region where we should mix the conference audio
  109. * @param string $sipAuthUsername The SIP username used for authentication
  110. * @param string $sipAuthPassword The SIP password for authentication
  111. * @param string[] $dequeueStatusCallbackEvent The Call progress events sent
  112. * via webhooks as a result of a
  113. * Dequeue instruction
  114. * @param string $postWorkActivitySid The new worker activity SID after
  115. * executing a Conference instruction
  116. * @param string $supervisorMode The Supervisor mode when executing the
  117. * Supervise instruction
  118. * @param string $supervisor The Supervisor SID/URI when executing the
  119. * Supervise instruction
  120. * @param bool $endConferenceOnCustomerExit Whether to end the conference when
  121. * the customer leaves
  122. * @param bool $beepOnCustomerEntrance Whether to play a notification beep when
  123. * the customer joins
  124. * @param string $ifMatch The If-Match HTTP request header
  125. * @return UpdateReservationOptions Options builder
  126. */
  127. public static function update(string $reservationStatus = Values::NONE, string $workerActivitySid = Values::NONE, string $instruction = Values::NONE, string $dequeuePostWorkActivitySid = Values::NONE, string $dequeueFrom = Values::NONE, string $dequeueRecord = Values::NONE, int $dequeueTimeout = Values::NONE, string $dequeueTo = Values::NONE, string $dequeueStatusCallbackUrl = Values::NONE, string $callFrom = Values::NONE, string $callRecord = Values::NONE, int $callTimeout = Values::NONE, string $callTo = Values::NONE, string $callUrl = Values::NONE, string $callStatusCallbackUrl = Values::NONE, bool $callAccept = Values::NONE, string $redirectCallSid = Values::NONE, bool $redirectAccept = Values::NONE, string $redirectUrl = Values::NONE, string $to = Values::NONE, string $from = Values::NONE, string $statusCallback = Values::NONE, string $statusCallbackMethod = Values::NONE, array $statusCallbackEvent = Values::ARRAY_NONE, int $timeout = Values::NONE, bool $record = Values::NONE, bool $muted = Values::NONE, string $beep = Values::NONE, bool $startConferenceOnEnter = Values::NONE, bool $endConferenceOnExit = Values::NONE, string $waitUrl = Values::NONE, string $waitMethod = Values::NONE, bool $earlyMedia = Values::NONE, int $maxParticipants = Values::NONE, string $conferenceStatusCallback = Values::NONE, string $conferenceStatusCallbackMethod = Values::NONE, array $conferenceStatusCallbackEvent = Values::ARRAY_NONE, string $conferenceRecord = Values::NONE, string $conferenceTrim = Values::NONE, string $recordingChannels = Values::NONE, string $recordingStatusCallback = Values::NONE, string $recordingStatusCallbackMethod = Values::NONE, string $conferenceRecordingStatusCallback = Values::NONE, string $conferenceRecordingStatusCallbackMethod = Values::NONE, string $region = Values::NONE, string $sipAuthUsername = Values::NONE, string $sipAuthPassword = Values::NONE, array $dequeueStatusCallbackEvent = Values::ARRAY_NONE, string $postWorkActivitySid = Values::NONE, string $supervisorMode = Values::NONE, string $supervisor = Values::NONE, bool $endConferenceOnCustomerExit = Values::NONE, bool $beepOnCustomerEntrance = Values::NONE, string $ifMatch = Values::NONE): UpdateReservationOptions {
  128. return new UpdateReservationOptions($reservationStatus, $workerActivitySid, $instruction, $dequeuePostWorkActivitySid, $dequeueFrom, $dequeueRecord, $dequeueTimeout, $dequeueTo, $dequeueStatusCallbackUrl, $callFrom, $callRecord, $callTimeout, $callTo, $callUrl, $callStatusCallbackUrl, $callAccept, $redirectCallSid, $redirectAccept, $redirectUrl, $to, $from, $statusCallback, $statusCallbackMethod, $statusCallbackEvent, $timeout, $record, $muted, $beep, $startConferenceOnEnter, $endConferenceOnExit, $waitUrl, $waitMethod, $earlyMedia, $maxParticipants, $conferenceStatusCallback, $conferenceStatusCallbackMethod, $conferenceStatusCallbackEvent, $conferenceRecord, $conferenceTrim, $recordingChannels, $recordingStatusCallback, $recordingStatusCallbackMethod, $conferenceRecordingStatusCallback, $conferenceRecordingStatusCallbackMethod, $region, $sipAuthUsername, $sipAuthPassword, $dequeueStatusCallbackEvent, $postWorkActivitySid, $supervisorMode, $supervisor, $endConferenceOnCustomerExit, $beepOnCustomerEntrance, $ifMatch);
  129. }
  130. }
  131. class ReadReservationOptions extends Options {
  132. /**
  133. * @param string $reservationStatus Returns the list of reservations for a task
  134. * with a specified ReservationStatus
  135. */
  136. public function __construct(string $reservationStatus = Values::NONE) {
  137. $this->options['reservationStatus'] = $reservationStatus;
  138. }
  139. /**
  140. * Returns the list of reservations for a task with a specified ReservationStatus. Can be: `pending`, `accepted`, `rejected`, or `timeout`.
  141. *
  142. * @param string $reservationStatus Returns the list of reservations for a task
  143. * with a specified ReservationStatus
  144. * @return $this Fluent Builder
  145. */
  146. public function setReservationStatus(string $reservationStatus): self {
  147. $this->options['reservationStatus'] = $reservationStatus;
  148. return $this;
  149. }
  150. /**
  151. * Provide a friendly representation
  152. *
  153. * @return string Machine friendly representation
  154. */
  155. public function __toString(): string {
  156. $options = \http_build_query(Values::of($this->options), '', ' ');
  157. return '[Twilio.Taskrouter.V1.ReadReservationOptions ' . $options . ']';
  158. }
  159. }
  160. class UpdateReservationOptions extends Options {
  161. /**
  162. * @param string $reservationStatus The new status of the reservation
  163. * @param string $workerActivitySid The new worker activity SID if rejecting a
  164. * reservation
  165. * @param string $instruction The assignment instruction for reservation
  166. * @param string $dequeuePostWorkActivitySid The SID of the Activity resource
  167. * to start after executing a Dequeue
  168. * instruction
  169. * @param string $dequeueFrom The Caller ID of the call to the worker when
  170. * executing a Dequeue instruction
  171. * @param string $dequeueRecord Whether to record both legs of a call when
  172. * executing a Dequeue instruction
  173. * @param int $dequeueTimeout Timeout for call when executing a Dequeue
  174. * instruction
  175. * @param string $dequeueTo The Contact URI of the worker when executing a
  176. * Dequeue instruction
  177. * @param string $dequeueStatusCallbackUrl The Callback URL for completed call
  178. * event when executing a Dequeue
  179. * instruction
  180. * @param string $callFrom The Caller ID of the outbound call when executing a
  181. * Call instruction
  182. * @param string $callRecord Whether to record both legs of a call when
  183. * executing a Call instruction
  184. * @param int $callTimeout Timeout for call when executing a Call instruction
  185. * @param string $callTo The Contact URI of the worker when executing a Call
  186. * instruction
  187. * @param string $callUrl TwiML URI executed on answering the worker's leg as a
  188. * result of the Call instruction
  189. * @param string $callStatusCallbackUrl The URL to call for the completed call
  190. * event when executing a Call instruction
  191. * @param bool $callAccept Whether to accept a reservation when executing a
  192. * Call instruction
  193. * @param string $redirectCallSid The Call SID of the call parked in the queue
  194. * when executing a Redirect instruction
  195. * @param bool $redirectAccept Whether the reservation should be accepted when
  196. * executing a Redirect instruction
  197. * @param string $redirectUrl TwiML URI to redirect the call to when executing
  198. * the Redirect instruction
  199. * @param string $to The Contact URI of the worker when executing a Conference
  200. * instruction
  201. * @param string $from The Caller ID of the call to the worker when executing a
  202. * Conference instruction
  203. * @param string $statusCallback The URL we should call to send status
  204. * information to your application
  205. * @param string $statusCallbackMethod The HTTP method we should use to call
  206. * status_callback
  207. * @param string[] $statusCallbackEvent The call progress events that we will
  208. * send to status_callback
  209. * @param int $timeout Timeout for call when executing a Conference instruction
  210. * @param bool $record Whether to record the participant and their conferences
  211. * @param bool $muted Whether to mute the agent
  212. * @param string $beep Whether to play a notification beep when the participant
  213. * joins
  214. * @param bool $startConferenceOnEnter Whether the conference starts when the
  215. * participant joins the conference
  216. * @param bool $endConferenceOnExit Whether to end the conference when the
  217. * agent leaves
  218. * @param string $waitUrl URL that hosts pre-conference hold music
  219. * @param string $waitMethod The HTTP method we should use to call `wait_url`
  220. * @param bool $earlyMedia Whether agents can hear the state of the outbound
  221. * call
  222. * @param int $maxParticipants The maximum number of agent conference
  223. * participants
  224. * @param string $conferenceStatusCallback The callback URL for conference
  225. * events
  226. * @param string $conferenceStatusCallbackMethod HTTP method for requesting
  227. * `conference_status_callback`
  228. * URL
  229. * @param string[] $conferenceStatusCallbackEvent The conference status events
  230. * that we will send to
  231. * conference_status_callback
  232. * @param string $conferenceRecord Whether to record the conference the
  233. * participant is joining
  234. * @param string $conferenceTrim How to trim leading and trailing silence from
  235. * your recorded conference audio files
  236. * @param string $recordingChannels Specify `mono` or `dual` recording channels
  237. * @param string $recordingStatusCallback The URL that we should call using the
  238. * `recording_status_callback_method`
  239. * when the recording status changes
  240. * @param string $recordingStatusCallbackMethod The HTTP method we should use
  241. * when we call
  242. * `recording_status_callback`
  243. * @param string $conferenceRecordingStatusCallback The URL we should call
  244. * using the
  245. * `conference_recording_status_callback_method` when the conference recording is available
  246. * @param string $conferenceRecordingStatusCallbackMethod The HTTP method we
  247. * should use to call
  248. * `conference_recording_status_callback`
  249. * @param string $region The region where we should mix the conference audio
  250. * @param string $sipAuthUsername The SIP username used for authentication
  251. * @param string $sipAuthPassword The SIP password for authentication
  252. * @param string[] $dequeueStatusCallbackEvent The Call progress events sent
  253. * via webhooks as a result of a
  254. * Dequeue instruction
  255. * @param string $postWorkActivitySid The new worker activity SID after
  256. * executing a Conference instruction
  257. * @param string $supervisorMode The Supervisor mode when executing the
  258. * Supervise instruction
  259. * @param string $supervisor The Supervisor SID/URI when executing the
  260. * Supervise instruction
  261. * @param bool $endConferenceOnCustomerExit Whether to end the conference when
  262. * the customer leaves
  263. * @param bool $beepOnCustomerEntrance Whether to play a notification beep when
  264. * the customer joins
  265. * @param string $ifMatch The If-Match HTTP request header
  266. */
  267. public function __construct(string $reservationStatus = Values::NONE, string $workerActivitySid = Values::NONE, string $instruction = Values::NONE, string $dequeuePostWorkActivitySid = Values::NONE, string $dequeueFrom = Values::NONE, string $dequeueRecord = Values::NONE, int $dequeueTimeout = Values::NONE, string $dequeueTo = Values::NONE, string $dequeueStatusCallbackUrl = Values::NONE, string $callFrom = Values::NONE, string $callRecord = Values::NONE, int $callTimeout = Values::NONE, string $callTo = Values::NONE, string $callUrl = Values::NONE, string $callStatusCallbackUrl = Values::NONE, bool $callAccept = Values::NONE, string $redirectCallSid = Values::NONE, bool $redirectAccept = Values::NONE, string $redirectUrl = Values::NONE, string $to = Values::NONE, string $from = Values::NONE, string $statusCallback = Values::NONE, string $statusCallbackMethod = Values::NONE, array $statusCallbackEvent = Values::ARRAY_NONE, int $timeout = Values::NONE, bool $record = Values::NONE, bool $muted = Values::NONE, string $beep = Values::NONE, bool $startConferenceOnEnter = Values::NONE, bool $endConferenceOnExit = Values::NONE, string $waitUrl = Values::NONE, string $waitMethod = Values::NONE, bool $earlyMedia = Values::NONE, int $maxParticipants = Values::NONE, string $conferenceStatusCallback = Values::NONE, string $conferenceStatusCallbackMethod = Values::NONE, array $conferenceStatusCallbackEvent = Values::ARRAY_NONE, string $conferenceRecord = Values::NONE, string $conferenceTrim = Values::NONE, string $recordingChannels = Values::NONE, string $recordingStatusCallback = Values::NONE, string $recordingStatusCallbackMethod = Values::NONE, string $conferenceRecordingStatusCallback = Values::NONE, string $conferenceRecordingStatusCallbackMethod = Values::NONE, string $region = Values::NONE, string $sipAuthUsername = Values::NONE, string $sipAuthPassword = Values::NONE, array $dequeueStatusCallbackEvent = Values::ARRAY_NONE, string $postWorkActivitySid = Values::NONE, string $supervisorMode = Values::NONE, string $supervisor = Values::NONE, bool $endConferenceOnCustomerExit = Values::NONE, bool $beepOnCustomerEntrance = Values::NONE, string $ifMatch = Values::NONE) {
  268. $this->options['reservationStatus'] = $reservationStatus;
  269. $this->options['workerActivitySid'] = $workerActivitySid;
  270. $this->options['instruction'] = $instruction;
  271. $this->options['dequeuePostWorkActivitySid'] = $dequeuePostWorkActivitySid;
  272. $this->options['dequeueFrom'] = $dequeueFrom;
  273. $this->options['dequeueRecord'] = $dequeueRecord;
  274. $this->options['dequeueTimeout'] = $dequeueTimeout;
  275. $this->options['dequeueTo'] = $dequeueTo;
  276. $this->options['dequeueStatusCallbackUrl'] = $dequeueStatusCallbackUrl;
  277. $this->options['callFrom'] = $callFrom;
  278. $this->options['callRecord'] = $callRecord;
  279. $this->options['callTimeout'] = $callTimeout;
  280. $this->options['callTo'] = $callTo;
  281. $this->options['callUrl'] = $callUrl;
  282. $this->options['callStatusCallbackUrl'] = $callStatusCallbackUrl;
  283. $this->options['callAccept'] = $callAccept;
  284. $this->options['redirectCallSid'] = $redirectCallSid;
  285. $this->options['redirectAccept'] = $redirectAccept;
  286. $this->options['redirectUrl'] = $redirectUrl;
  287. $this->options['to'] = $to;
  288. $this->options['from'] = $from;
  289. $this->options['statusCallback'] = $statusCallback;
  290. $this->options['statusCallbackMethod'] = $statusCallbackMethod;
  291. $this->options['statusCallbackEvent'] = $statusCallbackEvent;
  292. $this->options['timeout'] = $timeout;
  293. $this->options['record'] = $record;
  294. $this->options['muted'] = $muted;
  295. $this->options['beep'] = $beep;
  296. $this->options['startConferenceOnEnter'] = $startConferenceOnEnter;
  297. $this->options['endConferenceOnExit'] = $endConferenceOnExit;
  298. $this->options['waitUrl'] = $waitUrl;
  299. $this->options['waitMethod'] = $waitMethod;
  300. $this->options['earlyMedia'] = $earlyMedia;
  301. $this->options['maxParticipants'] = $maxParticipants;
  302. $this->options['conferenceStatusCallback'] = $conferenceStatusCallback;
  303. $this->options['conferenceStatusCallbackMethod'] = $conferenceStatusCallbackMethod;
  304. $this->options['conferenceStatusCallbackEvent'] = $conferenceStatusCallbackEvent;
  305. $this->options['conferenceRecord'] = $conferenceRecord;
  306. $this->options['conferenceTrim'] = $conferenceTrim;
  307. $this->options['recordingChannels'] = $recordingChannels;
  308. $this->options['recordingStatusCallback'] = $recordingStatusCallback;
  309. $this->options['recordingStatusCallbackMethod'] = $recordingStatusCallbackMethod;
  310. $this->options['conferenceRecordingStatusCallback'] = $conferenceRecordingStatusCallback;
  311. $this->options['conferenceRecordingStatusCallbackMethod'] = $conferenceRecordingStatusCallbackMethod;
  312. $this->options['region'] = $region;
  313. $this->options['sipAuthUsername'] = $sipAuthUsername;
  314. $this->options['sipAuthPassword'] = $sipAuthPassword;
  315. $this->options['dequeueStatusCallbackEvent'] = $dequeueStatusCallbackEvent;
  316. $this->options['postWorkActivitySid'] = $postWorkActivitySid;
  317. $this->options['supervisorMode'] = $supervisorMode;
  318. $this->options['supervisor'] = $supervisor;
  319. $this->options['endConferenceOnCustomerExit'] = $endConferenceOnCustomerExit;
  320. $this->options['beepOnCustomerEntrance'] = $beepOnCustomerEntrance;
  321. $this->options['ifMatch'] = $ifMatch;
  322. }
  323. /**
  324. * The new status of the reservation. Can be: `pending`, `accepted`, `rejected`, or `timeout`.
  325. *
  326. * @param string $reservationStatus The new status of the reservation
  327. * @return $this Fluent Builder
  328. */
  329. public function setReservationStatus(string $reservationStatus): self {
  330. $this->options['reservationStatus'] = $reservationStatus;
  331. return $this;
  332. }
  333. /**
  334. * The new worker activity SID if rejecting a reservation.
  335. *
  336. * @param string $workerActivitySid The new worker activity SID if rejecting a
  337. * reservation
  338. * @return $this Fluent Builder
  339. */
  340. public function setWorkerActivitySid(string $workerActivitySid): self {
  341. $this->options['workerActivitySid'] = $workerActivitySid;
  342. return $this;
  343. }
  344. /**
  345. * The assignment instruction for reservation.
  346. *
  347. * @param string $instruction The assignment instruction for reservation
  348. * @return $this Fluent Builder
  349. */
  350. public function setInstruction(string $instruction): self {
  351. $this->options['instruction'] = $instruction;
  352. return $this;
  353. }
  354. /**
  355. * The SID of the Activity resource to start after executing a Dequeue instruction.
  356. *
  357. * @param string $dequeuePostWorkActivitySid The SID of the Activity resource
  358. * to start after executing a Dequeue
  359. * instruction
  360. * @return $this Fluent Builder
  361. */
  362. public function setDequeuePostWorkActivitySid(string $dequeuePostWorkActivitySid): self {
  363. $this->options['dequeuePostWorkActivitySid'] = $dequeuePostWorkActivitySid;
  364. return $this;
  365. }
  366. /**
  367. * The Caller ID of the call to the worker when executing a Dequeue instruction.
  368. *
  369. * @param string $dequeueFrom The Caller ID of the call to the worker when
  370. * executing a Dequeue instruction
  371. * @return $this Fluent Builder
  372. */
  373. public function setDequeueFrom(string $dequeueFrom): self {
  374. $this->options['dequeueFrom'] = $dequeueFrom;
  375. return $this;
  376. }
  377. /**
  378. * Whether to record both legs of a call when executing a Dequeue instruction or which leg to record.
  379. *
  380. * @param string $dequeueRecord Whether to record both legs of a call when
  381. * executing a Dequeue instruction
  382. * @return $this Fluent Builder
  383. */
  384. public function setDequeueRecord(string $dequeueRecord): self {
  385. $this->options['dequeueRecord'] = $dequeueRecord;
  386. return $this;
  387. }
  388. /**
  389. * Timeout for call when executing a Dequeue instruction.
  390. *
  391. * @param int $dequeueTimeout Timeout for call when executing a Dequeue
  392. * instruction
  393. * @return $this Fluent Builder
  394. */
  395. public function setDequeueTimeout(int $dequeueTimeout): self {
  396. $this->options['dequeueTimeout'] = $dequeueTimeout;
  397. return $this;
  398. }
  399. /**
  400. * The Contact URI of the worker when executing a Dequeue instruction. Can be the URI of the Twilio Client, the SIP URI for Programmable SIP, or the [E.164](https://www.twilio.com/docs/glossary/what-e164) formatted phone number, depending on the destination.
  401. *
  402. * @param string $dequeueTo The Contact URI of the worker when executing a
  403. * Dequeue instruction
  404. * @return $this Fluent Builder
  405. */
  406. public function setDequeueTo(string $dequeueTo): self {
  407. $this->options['dequeueTo'] = $dequeueTo;
  408. return $this;
  409. }
  410. /**
  411. * The Callback URL for completed call event when executing a Dequeue instruction.
  412. *
  413. * @param string $dequeueStatusCallbackUrl The Callback URL for completed call
  414. * event when executing a Dequeue
  415. * instruction
  416. * @return $this Fluent Builder
  417. */
  418. public function setDequeueStatusCallbackUrl(string $dequeueStatusCallbackUrl): self {
  419. $this->options['dequeueStatusCallbackUrl'] = $dequeueStatusCallbackUrl;
  420. return $this;
  421. }
  422. /**
  423. * The Caller ID of the outbound call when executing a Call instruction.
  424. *
  425. * @param string $callFrom The Caller ID of the outbound call when executing a
  426. * Call instruction
  427. * @return $this Fluent Builder
  428. */
  429. public function setCallFrom(string $callFrom): self {
  430. $this->options['callFrom'] = $callFrom;
  431. return $this;
  432. }
  433. /**
  434. * Whether to record both legs of a call when executing a Call instruction or which leg to record.
  435. *
  436. * @param string $callRecord Whether to record both legs of a call when
  437. * executing a Call instruction
  438. * @return $this Fluent Builder
  439. */
  440. public function setCallRecord(string $callRecord): self {
  441. $this->options['callRecord'] = $callRecord;
  442. return $this;
  443. }
  444. /**
  445. * Timeout for call when executing a Call instruction.
  446. *
  447. * @param int $callTimeout Timeout for call when executing a Call instruction
  448. * @return $this Fluent Builder
  449. */
  450. public function setCallTimeout(int $callTimeout): self {
  451. $this->options['callTimeout'] = $callTimeout;
  452. return $this;
  453. }
  454. /**
  455. * The Contact URI of the worker when executing a Call instruction. Can be the URI of the Twilio Client, the SIP URI for Programmable SIP, or the [E.164](https://www.twilio.com/docs/glossary/what-e164) formatted phone number, depending on the destination.
  456. *
  457. * @param string $callTo The Contact URI of the worker when executing a Call
  458. * instruction
  459. * @return $this Fluent Builder
  460. */
  461. public function setCallTo(string $callTo): self {
  462. $this->options['callTo'] = $callTo;
  463. return $this;
  464. }
  465. /**
  466. * TwiML URI executed on answering the worker's leg as a result of the Call instruction.
  467. *
  468. * @param string $callUrl TwiML URI executed on answering the worker's leg as a
  469. * result of the Call instruction
  470. * @return $this Fluent Builder
  471. */
  472. public function setCallUrl(string $callUrl): self {
  473. $this->options['callUrl'] = $callUrl;
  474. return $this;
  475. }
  476. /**
  477. * The URL to call for the completed call event when executing a Call instruction.
  478. *
  479. * @param string $callStatusCallbackUrl The URL to call for the completed call
  480. * event when executing a Call instruction
  481. * @return $this Fluent Builder
  482. */
  483. public function setCallStatusCallbackUrl(string $callStatusCallbackUrl): self {
  484. $this->options['callStatusCallbackUrl'] = $callStatusCallbackUrl;
  485. return $this;
  486. }
  487. /**
  488. * Whether to accept a reservation when executing a Call instruction.
  489. *
  490. * @param bool $callAccept Whether to accept a reservation when executing a
  491. * Call instruction
  492. * @return $this Fluent Builder
  493. */
  494. public function setCallAccept(bool $callAccept): self {
  495. $this->options['callAccept'] = $callAccept;
  496. return $this;
  497. }
  498. /**
  499. * The Call SID of the call parked in the queue when executing a Redirect instruction.
  500. *
  501. * @param string $redirectCallSid The Call SID of the call parked in the queue
  502. * when executing a Redirect instruction
  503. * @return $this Fluent Builder
  504. */
  505. public function setRedirectCallSid(string $redirectCallSid): self {
  506. $this->options['redirectCallSid'] = $redirectCallSid;
  507. return $this;
  508. }
  509. /**
  510. * Whether the reservation should be accepted when executing a Redirect instruction.
  511. *
  512. * @param bool $redirectAccept Whether the reservation should be accepted when
  513. * executing a Redirect instruction
  514. * @return $this Fluent Builder
  515. */
  516. public function setRedirectAccept(bool $redirectAccept): self {
  517. $this->options['redirectAccept'] = $redirectAccept;
  518. return $this;
  519. }
  520. /**
  521. * TwiML URI to redirect the call to when executing the Redirect instruction.
  522. *
  523. * @param string $redirectUrl TwiML URI to redirect the call to when executing
  524. * the Redirect instruction
  525. * @return $this Fluent Builder
  526. */
  527. public function setRedirectUrl(string $redirectUrl): self {
  528. $this->options['redirectUrl'] = $redirectUrl;
  529. return $this;
  530. }
  531. /**
  532. * The Contact URI of the worker when executing a Conference instruction. Can be the URI of the Twilio Client, the SIP URI for Programmable SIP, or the [E.164](https://www.twilio.com/docs/glossary/what-e164) formatted phone number, depending on the destination.
  533. *
  534. * @param string $to The Contact URI of the worker when executing a Conference
  535. * instruction
  536. * @return $this Fluent Builder
  537. */
  538. public function setTo(string $to): self {
  539. $this->options['to'] = $to;
  540. return $this;
  541. }
  542. /**
  543. * The Caller ID of the call to the worker when executing a Conference instruction.
  544. *
  545. * @param string $from The Caller ID of the call to the worker when executing a
  546. * Conference instruction
  547. * @return $this Fluent Builder
  548. */
  549. public function setFrom(string $from): self {
  550. $this->options['from'] = $from;
  551. return $this;
  552. }
  553. /**
  554. * The URL we should call using the `status_callback_method` to send status information to your application.
  555. *
  556. * @param string $statusCallback The URL we should call to send status
  557. * information to your application
  558. * @return $this Fluent Builder
  559. */
  560. public function setStatusCallback(string $statusCallback): self {
  561. $this->options['statusCallback'] = $statusCallback;
  562. return $this;
  563. }
  564. /**
  565. * The HTTP method we should use to call `status_callback`. Can be: `POST` or `GET` and the default is `POST`.
  566. *
  567. * @param string $statusCallbackMethod The HTTP method we should use to call
  568. * status_callback
  569. * @return $this Fluent Builder
  570. */
  571. public function setStatusCallbackMethod(string $statusCallbackMethod): self {
  572. $this->options['statusCallbackMethod'] = $statusCallbackMethod;
  573. return $this;
  574. }
  575. /**
  576. * The call progress events that we will send to `status_callback`. Can be: `initiated`, `ringing`, `answered`, or `completed`.
  577. *
  578. * @param string[] $statusCallbackEvent The call progress events that we will
  579. * send to status_callback
  580. * @return $this Fluent Builder
  581. */
  582. public function setStatusCallbackEvent(array $statusCallbackEvent): self {
  583. $this->options['statusCallbackEvent'] = $statusCallbackEvent;
  584. return $this;
  585. }
  586. /**
  587. * Timeout for call when executing a Conference instruction.
  588. *
  589. * @param int $timeout Timeout for call when executing a Conference instruction
  590. * @return $this Fluent Builder
  591. */
  592. public function setTimeout(int $timeout): self {
  593. $this->options['timeout'] = $timeout;
  594. return $this;
  595. }
  596. /**
  597. * Whether to record the participant and their conferences, including the time between conferences. The default is `false`.
  598. *
  599. * @param bool $record Whether to record the participant and their conferences
  600. * @return $this Fluent Builder
  601. */
  602. public function setRecord(bool $record): self {
  603. $this->options['record'] = $record;
  604. return $this;
  605. }
  606. /**
  607. * Whether the agent is muted in the conference. The default is `false`.
  608. *
  609. * @param bool $muted Whether to mute the agent
  610. * @return $this Fluent Builder
  611. */
  612. public function setMuted(bool $muted): self {
  613. $this->options['muted'] = $muted;
  614. return $this;
  615. }
  616. /**
  617. * Whether to play a notification beep when the participant joins or when to play a beep. Can be: `true`, `false`, `onEnter`, or `onExit`. The default value is `true`.
  618. *
  619. * @param string $beep Whether to play a notification beep when the participant
  620. * joins
  621. * @return $this Fluent Builder
  622. */
  623. public function setBeep(string $beep): self {
  624. $this->options['beep'] = $beep;
  625. return $this;
  626. }
  627. /**
  628. * Whether to start the conference when the participant joins, if it has not already started. The default is `true`. If `false` and the conference has not started, the participant is muted and hears background music until another participant starts the conference.
  629. *
  630. * @param bool $startConferenceOnEnter Whether the conference starts when the
  631. * participant joins the conference
  632. * @return $this Fluent Builder
  633. */
  634. public function setStartConferenceOnEnter(bool $startConferenceOnEnter): self {
  635. $this->options['startConferenceOnEnter'] = $startConferenceOnEnter;
  636. return $this;
  637. }
  638. /**
  639. * Whether to end the conference when the agent leaves.
  640. *
  641. * @param bool $endConferenceOnExit Whether to end the conference when the
  642. * agent leaves
  643. * @return $this Fluent Builder
  644. */
  645. public function setEndConferenceOnExit(bool $endConferenceOnExit): self {
  646. $this->options['endConferenceOnExit'] = $endConferenceOnExit;
  647. return $this;
  648. }
  649. /**
  650. * The URL we should call using the `wait_method` for the music to play while participants are waiting for the conference to start. The default value is the URL of our standard hold music. [Learn more about hold music](https://www.twilio.com/labs/twimlets/holdmusic).
  651. *
  652. * @param string $waitUrl URL that hosts pre-conference hold music
  653. * @return $this Fluent Builder
  654. */
  655. public function setWaitUrl(string $waitUrl): self {
  656. $this->options['waitUrl'] = $waitUrl;
  657. return $this;
  658. }
  659. /**
  660. * The HTTP method we should use to call `wait_url`. Can be `GET` or `POST` and the default is `POST`. When using a static audio file, this should be `GET` so that we can cache the file.
  661. *
  662. * @param string $waitMethod The HTTP method we should use to call `wait_url`
  663. * @return $this Fluent Builder
  664. */
  665. public function setWaitMethod(string $waitMethod): self {
  666. $this->options['waitMethod'] = $waitMethod;
  667. return $this;
  668. }
  669. /**
  670. * Whether to allow an agent to hear the state of the outbound call, including ringing or disconnect messages. The default is `true`.
  671. *
  672. * @param bool $earlyMedia Whether agents can hear the state of the outbound
  673. * call
  674. * @return $this Fluent Builder
  675. */
  676. public function setEarlyMedia(bool $earlyMedia): self {
  677. $this->options['earlyMedia'] = $earlyMedia;
  678. return $this;
  679. }
  680. /**
  681. * The maximum number of participants in the conference. Can be a positive integer from `2` to `250`. The default value is `250`.
  682. *
  683. * @param int $maxParticipants The maximum number of agent conference
  684. * participants
  685. * @return $this Fluent Builder
  686. */
  687. public function setMaxParticipants(int $maxParticipants): self {
  688. $this->options['maxParticipants'] = $maxParticipants;
  689. return $this;
  690. }
  691. /**
  692. * The URL we should call using the `conference_status_callback_method` when the conference events in `conference_status_callback_event` occur. Only the value set by the first participant to join the conference is used. Subsequent `conference_status_callback` values are ignored.
  693. *
  694. * @param string $conferenceStatusCallback The callback URL for conference
  695. * events
  696. * @return $this Fluent Builder
  697. */
  698. public function setConferenceStatusCallback(string $conferenceStatusCallback): self {
  699. $this->options['conferenceStatusCallback'] = $conferenceStatusCallback;
  700. return $this;
  701. }
  702. /**
  703. * The HTTP method we should use to call `conference_status_callback`. Can be: `GET` or `POST` and defaults to `POST`.
  704. *
  705. * @param string $conferenceStatusCallbackMethod HTTP method for requesting
  706. * `conference_status_callback`
  707. * URL
  708. * @return $this Fluent Builder
  709. */
  710. public function setConferenceStatusCallbackMethod(string $conferenceStatusCallbackMethod): self {
  711. $this->options['conferenceStatusCallbackMethod'] = $conferenceStatusCallbackMethod;
  712. return $this;
  713. }
  714. /**
  715. * The conference status events that we will send to `conference_status_callback`. Can be: `start`, `end`, `join`, `leave`, `mute`, `hold`, `speaker`.
  716. *
  717. * @param string[] $conferenceStatusCallbackEvent The conference status events
  718. * that we will send to
  719. * conference_status_callback
  720. * @return $this Fluent Builder
  721. */
  722. public function setConferenceStatusCallbackEvent(array $conferenceStatusCallbackEvent): self {
  723. $this->options['conferenceStatusCallbackEvent'] = $conferenceStatusCallbackEvent;
  724. return $this;
  725. }
  726. /**
  727. * Whether to record the conference the participant is joining or when to record the conference. Can be: `true`, `false`, `record-from-start`, and `do-not-record`. The default value is `false`.
  728. *
  729. * @param string $conferenceRecord Whether to record the conference the
  730. * participant is joining
  731. * @return $this Fluent Builder
  732. */
  733. public function setConferenceRecord(string $conferenceRecord): self {
  734. $this->options['conferenceRecord'] = $conferenceRecord;
  735. return $this;
  736. }
  737. /**
  738. * How to trim the leading and trailing silence from your recorded conference audio files. Can be: `trim-silence` or `do-not-trim` and defaults to `trim-silence`.
  739. *
  740. * @param string $conferenceTrim How to trim leading and trailing silence from
  741. * your recorded conference audio files
  742. * @return $this Fluent Builder
  743. */
  744. public function setConferenceTrim(string $conferenceTrim): self {
  745. $this->options['conferenceTrim'] = $conferenceTrim;
  746. return $this;
  747. }
  748. /**
  749. * The recording channels for the final recording. Can be: `mono` or `dual` and the default is `mono`.
  750. *
  751. * @param string $recordingChannels Specify `mono` or `dual` recording channels
  752. * @return $this Fluent Builder
  753. */
  754. public function setRecordingChannels(string $recordingChannels): self {
  755. $this->options['recordingChannels'] = $recordingChannels;
  756. return $this;
  757. }
  758. /**
  759. * The URL that we should call using the `recording_status_callback_method` when the recording status changes.
  760. *
  761. * @param string $recordingStatusCallback The URL that we should call using the
  762. * `recording_status_callback_method`
  763. * when the recording status changes
  764. * @return $this Fluent Builder
  765. */
  766. public function setRecordingStatusCallback(string $recordingStatusCallback): self {
  767. $this->options['recordingStatusCallback'] = $recordingStatusCallback;
  768. return $this;
  769. }
  770. /**
  771. * The HTTP method we should use when we call `recording_status_callback`. Can be: `GET` or `POST` and defaults to `POST`.
  772. *
  773. * @param string $recordingStatusCallbackMethod The HTTP method we should use
  774. * when we call
  775. * `recording_status_callback`
  776. * @return $this Fluent Builder
  777. */
  778. public function setRecordingStatusCallbackMethod(string $recordingStatusCallbackMethod): self {
  779. $this->options['recordingStatusCallbackMethod'] = $recordingStatusCallbackMethod;
  780. return $this;
  781. }
  782. /**
  783. * The URL we should call using the `conference_recording_status_callback_method` when the conference recording is available.
  784. *
  785. * @param string $conferenceRecordingStatusCallback The URL we should call
  786. * using the
  787. * `conference_recording_status_callback_method` when the conference recording is available
  788. * @return $this Fluent Builder
  789. */
  790. public function setConferenceRecordingStatusCallback(string $conferenceRecordingStatusCallback): self {
  791. $this->options['conferenceRecordingStatusCallback'] = $conferenceRecordingStatusCallback;
  792. return $this;
  793. }
  794. /**
  795. * The HTTP method we should use to call `conference_recording_status_callback`. Can be: `GET` or `POST` and defaults to `POST`.
  796. *
  797. * @param string $conferenceRecordingStatusCallbackMethod The HTTP method we
  798. * should use to call
  799. * `conference_recording_status_callback`
  800. * @return $this Fluent Builder
  801. */
  802. public function setConferenceRecordingStatusCallbackMethod(string $conferenceRecordingStatusCallbackMethod): self {
  803. $this->options['conferenceRecordingStatusCallbackMethod'] = $conferenceRecordingStatusCallbackMethod;
  804. return $this;
  805. }
  806. /**
  807. * The [region](https://support.twilio.com/hc/en-us/articles/223132167-How-global-low-latency-routing-and-region-selection-work-for-conferences-and-Client-calls) where we should mix the recorded audio. Can be:`us1`, `ie1`, `de1`, `sg1`, `br1`, `au1`, or `jp1`.
  808. *
  809. * @param string $region The region where we should mix the conference audio
  810. * @return $this Fluent Builder
  811. */
  812. public function setRegion(string $region): self {
  813. $this->options['region'] = $region;
  814. return $this;
  815. }
  816. /**
  817. * The SIP username used for authentication.
  818. *
  819. * @param string $sipAuthUsername The SIP username used for authentication
  820. * @return $this Fluent Builder
  821. */
  822. public function setSipAuthUsername(string $sipAuthUsername): self {
  823. $this->options['sipAuthUsername'] = $sipAuthUsername;
  824. return $this;
  825. }
  826. /**
  827. * The SIP password for authentication.
  828. *
  829. * @param string $sipAuthPassword The SIP password for authentication
  830. * @return $this Fluent Builder
  831. */
  832. public function setSipAuthPassword(string $sipAuthPassword): self {
  833. $this->options['sipAuthPassword'] = $sipAuthPassword;
  834. return $this;
  835. }
  836. /**
  837. * The Call progress events sent via webhooks as a result of a Dequeue instruction.
  838. *
  839. * @param string[] $dequeueStatusCallbackEvent The Call progress events sent
  840. * via webhooks as a result of a
  841. * Dequeue instruction
  842. * @return $this Fluent Builder
  843. */
  844. public function setDequeueStatusCallbackEvent(array $dequeueStatusCallbackEvent): self {
  845. $this->options['dequeueStatusCallbackEvent'] = $dequeueStatusCallbackEvent;
  846. return $this;
  847. }
  848. /**
  849. * The new worker activity SID after executing a Conference instruction.
  850. *
  851. * @param string $postWorkActivitySid The new worker activity SID after
  852. * executing a Conference instruction
  853. * @return $this Fluent Builder
  854. */
  855. pu