/src/Twilio/Rest/Preview/TrustedComms/PhoneCallOptions.php

http://github.com/twilio/twilio-php · PHP · 431 lines · 142 code · 31 blank · 258 comment · 0 complexity · 09b9cc3f2a39045e4fee007222b845ca MD5 · raw file

  1. <?php
  2. /**
  3. * This code was generated by
  4. * \ / _ _ _| _ _
  5. * | (_)\/(_)(_|\/| |(/_ v1.0.0
  6. * / /
  7. */
  8. namespace Twilio\Rest\Preview\TrustedComms;
  9. use Twilio\Options;
  10. use Twilio\Values;
  11. /**
  12. * PLEASE NOTE that this class contains preview products that are subject to change. Use them with caution. If you currently do not have developer preview access, please contact help@twilio.com.
  13. */
  14. abstract class PhoneCallOptions {
  15. /**
  16. * @param string $reason The business reason for this phone call
  17. * @param string $applicationSid Refers to the Voice API Initiate Call parameter
  18. * @param string $callerId Refers to the Voice API Initiate Call parameter
  19. * @param string $fallbackMethod Refers to the Voice API Initiate Call parameter
  20. * @param string $fallbackUrl Refers to the Voice API Initiate Call parameter
  21. * @param string $machineDetection Refers to the Voice API Initiate Call
  22. * parameter
  23. * @param int $machineDetectionSilenceTimeout Refers to the Voice API Initiate
  24. * Call parameter
  25. * @param int $machineDetectionSpeechEndThreshold Refers to the Voice API
  26. * Initiate Call parameter
  27. * @param int $machineDetectionSpeechThreshold Refers to the Voice API Initiate
  28. * Call parameter
  29. * @param int $machineDetectionTimeout Refers to the Voice API Initiate Call
  30. * parameter
  31. * @param string $method Refers to the Voice API Initiate Call parameter
  32. * @param bool $record Refers to the Voice API Initiate Call parameter
  33. * @param string $recordingChannels Refers to the Voice API Initiate Call
  34. * parameter
  35. * @param string $recordingStatusCallback Refers to the Voice API Initiate Call
  36. * parameter
  37. * @param string[] $recordingStatusCallbackEvent Refers to the Voice API
  38. * Initiate Call parameter
  39. * @param string $recordingStatusCallbackMethod Refers to the Voice API
  40. * Initiate Call parameter
  41. * @param string $sendDigits Refers to the Voice API Initiate Call parameter
  42. * @param string $sipAuthPassword Refers to the Voice API Initiate Call
  43. * parameter
  44. * @param string $sipAuthUsername Refers to the Voice API Initiate Call
  45. * parameter
  46. * @param string $statusCallback Refers to the Voice API Initiate Call parameter
  47. * @param string[] $statusCallbackEvent Refers to the Voice API Initiate Call
  48. * parameter
  49. * @param string $statusCallbackMethod Refers to the Voice API Initiate Call
  50. * parameter
  51. * @param int $timeout Refers to the Voice API Initiate Call parameter
  52. * @param string $trim Refers to the Voice API Initiate Call parameter
  53. * @param string $url Refers to the Voice API Initiate Call parameter
  54. * @return CreatePhoneCallOptions Options builder
  55. */
  56. public static function create(string $reason = Values::NONE, string $applicationSid = Values::NONE, string $callerId = Values::NONE, string $fallbackMethod = Values::NONE, string $fallbackUrl = Values::NONE, string $machineDetection = Values::NONE, int $machineDetectionSilenceTimeout = Values::NONE, int $machineDetectionSpeechEndThreshold = Values::NONE, int $machineDetectionSpeechThreshold = Values::NONE, int $machineDetectionTimeout = Values::NONE, string $method = Values::NONE, bool $record = Values::NONE, string $recordingChannels = Values::NONE, string $recordingStatusCallback = Values::NONE, array $recordingStatusCallbackEvent = Values::ARRAY_NONE, string $recordingStatusCallbackMethod = Values::NONE, string $sendDigits = Values::NONE, string $sipAuthPassword = Values::NONE, string $sipAuthUsername = Values::NONE, string $statusCallback = Values::NONE, array $statusCallbackEvent = Values::ARRAY_NONE, string $statusCallbackMethod = Values::NONE, int $timeout = Values::NONE, string $trim = Values::NONE, string $url = Values::NONE): CreatePhoneCallOptions {
  57. return new CreatePhoneCallOptions($reason, $applicationSid, $callerId, $fallbackMethod, $fallbackUrl, $machineDetection, $machineDetectionSilenceTimeout, $machineDetectionSpeechEndThreshold, $machineDetectionSpeechThreshold, $machineDetectionTimeout, $method, $record, $recordingChannels, $recordingStatusCallback, $recordingStatusCallbackEvent, $recordingStatusCallbackMethod, $sendDigits, $sipAuthPassword, $sipAuthUsername, $statusCallback, $statusCallbackEvent, $statusCallbackMethod, $timeout, $trim, $url);
  58. }
  59. }
  60. class CreatePhoneCallOptions extends Options {
  61. /**
  62. * @param string $reason The business reason for this phone call
  63. * @param string $applicationSid Refers to the Voice API Initiate Call parameter
  64. * @param string $callerId Refers to the Voice API Initiate Call parameter
  65. * @param string $fallbackMethod Refers to the Voice API Initiate Call parameter
  66. * @param string $fallbackUrl Refers to the Voice API Initiate Call parameter
  67. * @param string $machineDetection Refers to the Voice API Initiate Call
  68. * parameter
  69. * @param int $machineDetectionSilenceTimeout Refers to the Voice API Initiate
  70. * Call parameter
  71. * @param int $machineDetectionSpeechEndThreshold Refers to the Voice API
  72. * Initiate Call parameter
  73. * @param int $machineDetectionSpeechThreshold Refers to the Voice API Initiate
  74. * Call parameter
  75. * @param int $machineDetectionTimeout Refers to the Voice API Initiate Call
  76. * parameter
  77. * @param string $method Refers to the Voice API Initiate Call parameter
  78. * @param bool $record Refers to the Voice API Initiate Call parameter
  79. * @param string $recordingChannels Refers to the Voice API Initiate Call
  80. * parameter
  81. * @param string $recordingStatusCallback Refers to the Voice API Initiate Call
  82. * parameter
  83. * @param string[] $recordingStatusCallbackEvent Refers to the Voice API
  84. * Initiate Call parameter
  85. * @param string $recordingStatusCallbackMethod Refers to the Voice API
  86. * Initiate Call parameter
  87. * @param string $sendDigits Refers to the Voice API Initiate Call parameter
  88. * @param string $sipAuthPassword Refers to the Voice API Initiate Call
  89. * parameter
  90. * @param string $sipAuthUsername Refers to the Voice API Initiate Call
  91. * parameter
  92. * @param string $statusCallback Refers to the Voice API Initiate Call parameter
  93. * @param string[] $statusCallbackEvent Refers to the Voice API Initiate Call
  94. * parameter
  95. * @param string $statusCallbackMethod Refers to the Voice API Initiate Call
  96. * parameter
  97. * @param int $timeout Refers to the Voice API Initiate Call parameter
  98. * @param string $trim Refers to the Voice API Initiate Call parameter
  99. * @param string $url Refers to the Voice API Initiate Call parameter
  100. */
  101. public function __construct(string $reason = Values::NONE, string $applicationSid = Values::NONE, string $callerId = Values::NONE, string $fallbackMethod = Values::NONE, string $fallbackUrl = Values::NONE, string $machineDetection = Values::NONE, int $machineDetectionSilenceTimeout = Values::NONE, int $machineDetectionSpeechEndThreshold = Values::NONE, int $machineDetectionSpeechThreshold = Values::NONE, int $machineDetectionTimeout = Values::NONE, string $method = Values::NONE, bool $record = Values::NONE, string $recordingChannels = Values::NONE, string $recordingStatusCallback = Values::NONE, array $recordingStatusCallbackEvent = Values::ARRAY_NONE, string $recordingStatusCallbackMethod = Values::NONE, string $sendDigits = Values::NONE, string $sipAuthPassword = Values::NONE, string $sipAuthUsername = Values::NONE, string $statusCallback = Values::NONE, array $statusCallbackEvent = Values::ARRAY_NONE, string $statusCallbackMethod = Values::NONE, int $timeout = Values::NONE, string $trim = Values::NONE, string $url = Values::NONE) {
  102. $this->options['reason'] = $reason;
  103. $this->options['applicationSid'] = $applicationSid;
  104. $this->options['callerId'] = $callerId;
  105. $this->options['fallbackMethod'] = $fallbackMethod;
  106. $this->options['fallbackUrl'] = $fallbackUrl;
  107. $this->options['machineDetection'] = $machineDetection;
  108. $this->options['machineDetectionSilenceTimeout'] = $machineDetectionSilenceTimeout;
  109. $this->options['machineDetectionSpeechEndThreshold'] = $machineDetectionSpeechEndThreshold;
  110. $this->options['machineDetectionSpeechThreshold'] = $machineDetectionSpeechThreshold;
  111. $this->options['machineDetectionTimeout'] = $machineDetectionTimeout;
  112. $this->options['method'] = $method;
  113. $this->options['record'] = $record;
  114. $this->options['recordingChannels'] = $recordingChannels;
  115. $this->options['recordingStatusCallback'] = $recordingStatusCallback;
  116. $this->options['recordingStatusCallbackEvent'] = $recordingStatusCallbackEvent;
  117. $this->options['recordingStatusCallbackMethod'] = $recordingStatusCallbackMethod;
  118. $this->options['sendDigits'] = $sendDigits;
  119. $this->options['sipAuthPassword'] = $sipAuthPassword;
  120. $this->options['sipAuthUsername'] = $sipAuthUsername;
  121. $this->options['statusCallback'] = $statusCallback;
  122. $this->options['statusCallbackEvent'] = $statusCallbackEvent;
  123. $this->options['statusCallbackMethod'] = $statusCallbackMethod;
  124. $this->options['timeout'] = $timeout;
  125. $this->options['trim'] = $trim;
  126. $this->options['url'] = $url;
  127. }
  128. /**
  129. * The business reason for this phone call that will appear in the terminating device's screen. Max 50 characters.
  130. *
  131. * @param string $reason The business reason for this phone call
  132. * @return $this Fluent Builder
  133. */
  134. public function setReason(string $reason): self {
  135. $this->options['reason'] = $reason;
  136. return $this;
  137. }
  138. /**
  139. * Refers to the parameter with the same name when [initiating a call via Voice API](https://www.twilio.com/docs/voice/api/call#create-a-call-resource)
  140. *
  141. * @param string $applicationSid Refers to the Voice API Initiate Call parameter
  142. * @return $this Fluent Builder
  143. */
  144. public function setApplicationSid(string $applicationSid): self {
  145. $this->options['applicationSid'] = $applicationSid;
  146. return $this;
  147. }
  148. /**
  149. * Refers to the parameter with the same name when [initiating a call via Voice API](https://www.twilio.com/docs/voice/api/call#create-a-call-resource)
  150. *
  151. * @param string $callerId Refers to the Voice API Initiate Call parameter
  152. * @return $this Fluent Builder
  153. */
  154. public function setCallerId(string $callerId): self {
  155. $this->options['callerId'] = $callerId;
  156. return $this;
  157. }
  158. /**
  159. * Refers to the parameter with the same name when [initiating a call via Voice API](https://www.twilio.com/docs/voice/api/call#create-a-call-resource)
  160. *
  161. * @param string $fallbackMethod Refers to the Voice API Initiate Call parameter
  162. * @return $this Fluent Builder
  163. */
  164. public function setFallbackMethod(string $fallbackMethod): self {
  165. $this->options['fallbackMethod'] = $fallbackMethod;
  166. return $this;
  167. }
  168. /**
  169. * Refers to the parameter with the same name when [initiating a call via Voice API](https://www.twilio.com/docs/voice/api/call#create-a-call-resource)
  170. *
  171. * @param string $fallbackUrl Refers to the Voice API Initiate Call parameter
  172. * @return $this Fluent Builder
  173. */
  174. public function setFallbackUrl(string $fallbackUrl): self {
  175. $this->options['fallbackUrl'] = $fallbackUrl;
  176. return $this;
  177. }
  178. /**
  179. * Refers to the parameter with the same name when [initiating a call via Voice API](https://www.twilio.com/docs/voice/api/call#create-a-call-resource)
  180. *
  181. * @param string $machineDetection Refers to the Voice API Initiate Call
  182. * parameter
  183. * @return $this Fluent Builder
  184. */
  185. public function setMachineDetection(string $machineDetection): self {
  186. $this->options['machineDetection'] = $machineDetection;
  187. return $this;
  188. }
  189. /**
  190. * Refers to the parameter with the same name when [initiating a call via Voice API](https://www.twilio.com/docs/voice/api/call#create-a-call-resource)
  191. *
  192. * @param int $machineDetectionSilenceTimeout Refers to the Voice API Initiate
  193. * Call parameter
  194. * @return $this Fluent Builder
  195. */
  196. public function setMachineDetectionSilenceTimeout(int $machineDetectionSilenceTimeout): self {
  197. $this->options['machineDetectionSilenceTimeout'] = $machineDetectionSilenceTimeout;
  198. return $this;
  199. }
  200. /**
  201. * Refers to the parameter with the same name when [initiating a call via Voice API](https://www.twilio.com/docs/voice/api/call#create-a-call-resource)
  202. *
  203. * @param int $machineDetectionSpeechEndThreshold Refers to the Voice API
  204. * Initiate Call parameter
  205. * @return $this Fluent Builder
  206. */
  207. public function setMachineDetectionSpeechEndThreshold(int $machineDetectionSpeechEndThreshold): self {
  208. $this->options['machineDetectionSpeechEndThreshold'] = $machineDetectionSpeechEndThreshold;
  209. return $this;
  210. }
  211. /**
  212. * Refers to the parameter with the same name when [initiating a call via Voice API](https://www.twilio.com/docs/voice/api/call#create-a-call-resource)
  213. *
  214. * @param int $machineDetectionSpeechThreshold Refers to the Voice API Initiate
  215. * Call parameter
  216. * @return $this Fluent Builder
  217. */
  218. public function setMachineDetectionSpeechThreshold(int $machineDetectionSpeechThreshold): self {
  219. $this->options['machineDetectionSpeechThreshold'] = $machineDetectionSpeechThreshold;
  220. return $this;
  221. }
  222. /**
  223. * Refers to the parameter with the same name when [initiating a call via Voice API](https://www.twilio.com/docs/voice/api/call#create-a-call-resource)
  224. *
  225. * @param int $machineDetectionTimeout Refers to the Voice API Initiate Call
  226. * parameter
  227. * @return $this Fluent Builder
  228. */
  229. public function setMachineDetectionTimeout(int $machineDetectionTimeout): self {
  230. $this->options['machineDetectionTimeout'] = $machineDetectionTimeout;
  231. return $this;
  232. }
  233. /**
  234. * Refers to the parameter with the same name when [initiating a call via Voice API](https://www.twilio.com/docs/voice/api/call#create-a-call-resource)
  235. *
  236. * @param string $method Refers to the Voice API Initiate Call parameter
  237. * @return $this Fluent Builder
  238. */
  239. public function setMethod(string $method): self {
  240. $this->options['method'] = $method;
  241. return $this;
  242. }
  243. /**
  244. * Refers to the parameter with the same name when [initiating a call via Voice API](https://www.twilio.com/docs/voice/api/call#create-a-call-resource)
  245. *
  246. * @param bool $record Refers to the Voice API Initiate Call parameter
  247. * @return $this Fluent Builder
  248. */
  249. public function setRecord(bool $record): self {
  250. $this->options['record'] = $record;
  251. return $this;
  252. }
  253. /**
  254. * Refers to the parameter with the same name when [initiating a call via Voice API](https://www.twilio.com/docs/voice/api/call#create-a-call-resource)
  255. *
  256. * @param string $recordingChannels Refers to the Voice API Initiate Call
  257. * parameter
  258. * @return $this Fluent Builder
  259. */
  260. public function setRecordingChannels(string $recordingChannels): self {
  261. $this->options['recordingChannels'] = $recordingChannels;
  262. return $this;
  263. }
  264. /**
  265. * Refers to the parameter with the same name when [initiating a call via Voice API](https://www.twilio.com/docs/voice/api/call#create-a-call-resource)
  266. *
  267. * @param string $recordingStatusCallback Refers to the Voice API Initiate Call
  268. * parameter
  269. * @return $this Fluent Builder
  270. */
  271. public function setRecordingStatusCallback(string $recordingStatusCallback): self {
  272. $this->options['recordingStatusCallback'] = $recordingStatusCallback;
  273. return $this;
  274. }
  275. /**
  276. * Refers to the parameter with the same name when [initiating a call via Voice API](https://www.twilio.com/docs/voice/api/call#create-a-call-resource)
  277. *
  278. * @param string[] $recordingStatusCallbackEvent Refers to the Voice API
  279. * Initiate Call parameter
  280. * @return $this Fluent Builder
  281. */
  282. public function setRecordingStatusCallbackEvent(array $recordingStatusCallbackEvent): self {
  283. $this->options['recordingStatusCallbackEvent'] = $recordingStatusCallbackEvent;
  284. return $this;
  285. }
  286. /**
  287. * Refers to the parameter with the same name when [initiating a call via Voice API](https://www.twilio.com/docs/voice/api/call#create-a-call-resource)
  288. *
  289. * @param string $recordingStatusCallbackMethod Refers to the Voice API
  290. * Initiate Call parameter
  291. * @return $this Fluent Builder
  292. */
  293. public function setRecordingStatusCallbackMethod(string $recordingStatusCallbackMethod): self {
  294. $this->options['recordingStatusCallbackMethod'] = $recordingStatusCallbackMethod;
  295. return $this;
  296. }
  297. /**
  298. * Refers to the parameter with the same name when [initiating a call via Voice API](https://www.twilio.com/docs/voice/api/call#create-a-call-resource)
  299. *
  300. * @param string $sendDigits Refers to the Voice API Initiate Call parameter
  301. * @return $this Fluent Builder
  302. */
  303. public function setSendDigits(string $sendDigits): self {
  304. $this->options['sendDigits'] = $sendDigits;
  305. return $this;
  306. }
  307. /**
  308. * Refers to the parameter with the same name when [initiating a call via Voice API](https://www.twilio.com/docs/voice/api/call#create-a-call-resource)
  309. *
  310. * @param string $sipAuthPassword Refers to the Voice API Initiate Call
  311. * parameter
  312. * @return $this Fluent Builder
  313. */
  314. public function setSipAuthPassword(string $sipAuthPassword): self {
  315. $this->options['sipAuthPassword'] = $sipAuthPassword;
  316. return $this;
  317. }
  318. /**
  319. * Refers to the parameter with the same name when [initiating a call via Voice API](https://www.twilio.com/docs/voice/api/call#create-a-call-resource)
  320. *
  321. * @param string $sipAuthUsername Refers to the Voice API Initiate Call
  322. * parameter
  323. * @return $this Fluent Builder
  324. */
  325. public function setSipAuthUsername(string $sipAuthUsername): self {
  326. $this->options['sipAuthUsername'] = $sipAuthUsername;
  327. return $this;
  328. }
  329. /**
  330. * Refers to the parameter with the same name when [initiating a call via Voice API](https://www.twilio.com/docs/voice/api/call#create-a-call-resource)
  331. *
  332. * @param string $statusCallback Refers to the Voice API Initiate Call parameter
  333. * @return $this Fluent Builder
  334. */
  335. public function setStatusCallback(string $statusCallback): self {
  336. $this->options['statusCallback'] = $statusCallback;
  337. return $this;
  338. }
  339. /**
  340. * Refers to the parameter with the same name when [initiating a call via Voice API](https://www.twilio.com/docs/voice/api/call#create-a-call-resource)
  341. *
  342. * @param string[] $statusCallbackEvent Refers to the Voice API Initiate Call
  343. * parameter
  344. * @return $this Fluent Builder
  345. */
  346. public function setStatusCallbackEvent(array $statusCallbackEvent): self {
  347. $this->options['statusCallbackEvent'] = $statusCallbackEvent;
  348. return $this;
  349. }
  350. /**
  351. * Refers to the parameter with the same name when [initiating a call via Voice API](https://www.twilio.com/docs/voice/api/call#create-a-call-resource)
  352. *
  353. * @param string $statusCallbackMethod Refers to the Voice API Initiate Call
  354. * parameter
  355. * @return $this Fluent Builder
  356. */
  357. public function setStatusCallbackMethod(string $statusCallbackMethod): self {
  358. $this->options['statusCallbackMethod'] = $statusCallbackMethod;
  359. return $this;
  360. }
  361. /**
  362. * Refers to the parameter with the same name when [initiating a call via Voice API](https://www.twilio.com/docs/voice/api/call#create-a-call-resource)
  363. *
  364. * @param int $timeout Refers to the Voice API Initiate Call parameter
  365. * @return $this Fluent Builder
  366. */
  367. public function setTimeout(int $timeout): self {
  368. $this->options['timeout'] = $timeout;
  369. return $this;
  370. }
  371. /**
  372. * Refers to the parameter with the same name when [initiating a call via Voice API](https://www.twilio.com/docs/voice/api/call#create-a-call-resource)
  373. *
  374. * @param string $trim Refers to the Voice API Initiate Call parameter
  375. * @return $this Fluent Builder
  376. */
  377. public function setTrim(string $trim): self {
  378. $this->options['trim'] = $trim;
  379. return $this;
  380. }
  381. /**
  382. * Refers to the parameter with the same name when [initiating a call via Voice API](https://www.twilio.com/docs/voice/api/call#create-a-call-resource)
  383. *
  384. * @param string $url Refers to the Voice API Initiate Call parameter
  385. * @return $this Fluent Builder
  386. */
  387. public function setUrl(string $url): self {
  388. $this->options['url'] = $url;
  389. return $this;
  390. }
  391. /**
  392. * Provide a friendly representation
  393. *
  394. * @return string Machine friendly representation
  395. */
  396. public function __toString(): string {
  397. $options = \http_build_query(Values::of($this->options), '', ' ');
  398. return '[Twilio.Preview.TrustedComms.CreatePhoneCallOptions ' . $options . ']';
  399. }
  400. }