Вход Регистрация
Файл: sngine-v2.8/Script/includes/libs/Twilio/Rest/Proxy/V1/Service/SessionOptions.php
Строк: 338
<?php

/**
 * This code was generated by
 *  / _    _  _|   _  _
 * | (_)/(_)(_|/| |(/_  v1.0.0
 * /       /
 */

namespace TwilioRestProxyV1Service;

use 
TwilioOptions;
use 
TwilioValues;

/**
 * PLEASE NOTE that this class contains beta products that are subject to change. Use them with caution.
 */
abstract class SessionOptions {
    
/**
     * @param string $uniqueName An application-defined string that uniquely
     *                           identifies the resource
     * @param DateTime $dateExpiry The ISO 8601 date when the Session should expire
     * @param int $ttl When the session will expire
     * @param string $mode The Mode of the Session
     * @param string $status Session status
     * @param array[] $participants The Participant objects to include in the new
     *                              session
     * @return CreateSessionOptions Options builder
     */
    
public static function create(string $uniqueName Values::NONEDateTime $dateExpiry Values::NONEint $ttl Values::NONEstring $mode Values::NONEstring $status Values::NONE, array $participants Values::ARRAY_NONE): CreateSessionOptions {
        return new 
CreateSessionOptions($uniqueName$dateExpiry$ttl$mode$status$participants);
    }

    
/**
     * @param DateTime $dateExpiry The ISO 8601 date when the Session should expire
     * @param int $ttl When the session will expire
     * @param string $status The new status of the resource
     * @return UpdateSessionOptions Options builder
     */
    
public static function update(DateTime $dateExpiry Values::NONEint $ttl Values::NONEstring $status Values::NONE): UpdateSessionOptions {
        return new 
UpdateSessionOptions($dateExpiry$ttl$status);
    }
}

class 
CreateSessionOptions extends Options {
    
/**
     * @param string $uniqueName An application-defined string that uniquely
     *                           identifies the resource
     * @param DateTime $dateExpiry The ISO 8601 date when the Session should expire
     * @param int $ttl When the session will expire
     * @param string $mode The Mode of the Session
     * @param string $status Session status
     * @param array[] $participants The Participant objects to include in the new
     *                              session
     */
    
public function __construct(string $uniqueName Values::NONEDateTime $dateExpiry Values::NONEint $ttl Values::NONEstring $mode Values::NONEstring $status Values::NONE, array $participants Values::ARRAY_NONE) {
        
$this->options['uniqueName'] = $uniqueName;
        
$this->options['dateExpiry'] = $dateExpiry;
        
$this->options['ttl'] = $ttl;
        
$this->options['mode'] = $mode;
        
$this->options['status'] = $status;
        
$this->options['participants'] = $participants;
    }

    
/**
     * An application-defined string that uniquely identifies the resource. This value must be 191 characters or fewer in length and be unique. **This value should not have PII.**
     *
     * @param string $uniqueName An application-defined string that uniquely
     *                           identifies the resource
     * @return $this Fluent Builder
     */
    
public function setUniqueName(string $uniqueName): self {
        
$this->options['uniqueName'] = $uniqueName;
        return 
$this;
    }

    
/**
     * The [ISO 8601](https://en.wikipedia.org/wiki/ISO_8601) date when the Session should expire. If this is value is present, it overrides the `ttl` value.
     *
     * @param DateTime $dateExpiry The ISO 8601 date when the Session should expire
     * @return $this Fluent Builder
     */
    
public function setDateExpiry(DateTime $dateExpiry): self {
        
$this->options['dateExpiry'] = $dateExpiry;
        return 
$this;
    }

    
/**
     * The time, in seconds, when the session will expire. The time is measured from the last Session create or the Session's last Interaction.
     *
     * @param int $ttl When the session will expire
     * @return $this Fluent Builder
     */
    
public function setTtl(int $ttl): self {
        
$this->options['ttl'] = $ttl;
        return 
$this;
    }

    
/**
     * The Mode of the Session. Can be: `message-only`, `voice-only`, or `voice-and-message` and the default value is `voice-and-message`.
     *
     * @param string $mode The Mode of the Session
     * @return $this Fluent Builder
     */
    
public function setMode(string $mode): self {
        
$this->options['mode'] = $mode;
        return 
$this;
    }

    
/**
     * The initial status of the Session. Can be: `open`, `in-progress`, `closed`, `failed`, or `unknown`. The default is `open` on create.
     *
     * @param string $status Session status
     * @return $this Fluent Builder
     */
    
public function setStatus(string $status): self {
        
$this->options['status'] = $status;
        return 
$this;
    }

    
/**
     * The Participant objects to include in the new session.
     *
     * @param array[] $participants The Participant objects to include in the new
     *                              session
     * @return $this Fluent Builder
     */
    
public function setParticipants(array $participants): self {
        
$this->options['participants'] = $participants;
        return 
$this;
    }

    
/**
     * Provide a friendly representation
     *
     * @return string Machine friendly representation
     */
    
public function __toString(): string {
        
$options http_build_query(Values::of($this->options), ''' ');
        return 
'[Twilio.Proxy.V1.CreateSessionOptions ' $options ']';
    }
}

class 
UpdateSessionOptions extends Options {
    
/**
     * @param DateTime $dateExpiry The ISO 8601 date when the Session should expire
     * @param int $ttl When the session will expire
     * @param string $status The new status of the resource
     */
    
public function __construct(DateTime $dateExpiry Values::NONEint $ttl Values::NONEstring $status Values::NONE) {
        
$this->options['dateExpiry'] = $dateExpiry;
        
$this->options['ttl'] = $ttl;
        
$this->options['status'] = $status;
    }

    
/**
     * The [ISO 8601](https://en.wikipedia.org/wiki/ISO_8601) date when the Session should expire. If this is value is present, it overrides the `ttl` value.
     *
     * @param DateTime $dateExpiry The ISO 8601 date when the Session should expire
     * @return $this Fluent Builder
     */
    
public function setDateExpiry(DateTime $dateExpiry): self {
        
$this->options['dateExpiry'] = $dateExpiry;
        return 
$this;
    }

    
/**
     * The time, in seconds, when the session will expire. The time is measured from the last Session create or the Session's last Interaction.
     *
     * @param int $ttl When the session will expire
     * @return $this Fluent Builder
     */
    
public function setTtl(int $ttl): self {
        
$this->options['ttl'] = $ttl;
        return 
$this;
    }

    
/**
     * The new status of the resource. Can be: `in-progress` to re-open a session or `closed` to close a session.
     *
     * @param string $status The new status of the resource
     * @return $this Fluent Builder
     */
    
public function setStatus(string $status): self {
        
$this->options['status'] = $status;
        return 
$this;
    }

    
/**
     * Provide a friendly representation
     *
     * @return string Machine friendly representation
     */
    
public function __toString(): string {
        
$options http_build_query(Values::of($this->options), ''' ');
        return 
'[Twilio.Proxy.V1.UpdateSessionOptions ' $options ']';
    }
}
Онлайн: 1
Реклама