121 lines
3.4 KiB
PHP
Executable file
121 lines
3.4 KiB
PHP
Executable file
<?php
|
|
|
|
/**
|
|
* This code was generated by
|
|
* ___ _ _ _ _ _ _ ____ ____ ____ _ ____ ____ _ _ ____ ____ ____ ___ __ __
|
|
* | | | | | | | | | __ | | |__| | __ | __ |___ |\ | |___ |__/ |__| | | | |__/
|
|
* | |_|_| | |___ | |__| |__| | | | |__] |___ | \| |___ | \ | | | |__| | \
|
|
*
|
|
* Twilio - Conversations
|
|
* This is the public Twilio REST API.
|
|
*
|
|
* NOTE: This class is auto generated by OpenAPI Generator.
|
|
* https://openapi-generator.tech
|
|
* Do not edit the class manually.
|
|
*/
|
|
|
|
|
|
namespace Twilio\Rest\Conversations\V1;
|
|
|
|
use Twilio\Exceptions\TwilioException;
|
|
use Twilio\Values;
|
|
use Twilio\Version;
|
|
use Twilio\InstanceContext;
|
|
use Twilio\Serialize;
|
|
|
|
|
|
class RoleContext extends InstanceContext
|
|
{
|
|
/**
|
|
* Initialize the RoleContext
|
|
*
|
|
* @param Version $version Version that contains the resource
|
|
* @param string $sid The SID of the Role resource to delete.
|
|
*/
|
|
public function __construct(
|
|
Version $version,
|
|
$sid
|
|
) {
|
|
parent::__construct($version);
|
|
|
|
// Path Solution
|
|
$this->solution = [
|
|
'sid' =>
|
|
$sid,
|
|
];
|
|
|
|
$this->uri = '/Roles/' . \rawurlencode($sid)
|
|
.'';
|
|
}
|
|
|
|
/**
|
|
* Delete the RoleInstance
|
|
*
|
|
* @return bool True if delete succeeds, false otherwise
|
|
* @throws TwilioException When an HTTP error occurs.
|
|
*/
|
|
public function delete(): bool
|
|
{
|
|
|
|
return $this->version->delete('DELETE', $this->uri);
|
|
}
|
|
|
|
|
|
/**
|
|
* Fetch the RoleInstance
|
|
*
|
|
* @return RoleInstance Fetched RoleInstance
|
|
* @throws TwilioException When an HTTP error occurs.
|
|
*/
|
|
public function fetch(): RoleInstance
|
|
{
|
|
|
|
$payload = $this->version->fetch('GET', $this->uri);
|
|
|
|
return new RoleInstance(
|
|
$this->version,
|
|
$payload,
|
|
$this->solution['sid']
|
|
);
|
|
}
|
|
|
|
|
|
/**
|
|
* Update the RoleInstance
|
|
*
|
|
* @param string[] $permission A permission that you grant to the role. Only one permission can be granted per parameter. To assign more than one permission, repeat this parameter for each permission value. Note that the update action replaces all previously assigned permissions with those defined in the update action. To remove a permission, do not include it in the subsequent update action. The values for this parameter depend on the role's `type`.
|
|
* @return RoleInstance Updated RoleInstance
|
|
* @throws TwilioException When an HTTP error occurs.
|
|
*/
|
|
public function update(array $permission): RoleInstance
|
|
{
|
|
|
|
$data = Values::of([
|
|
'Permission' =>
|
|
Serialize::map($permission,function ($e) { return $e; }),
|
|
]);
|
|
|
|
$payload = $this->version->update('POST', $this->uri, [], $data);
|
|
|
|
return new RoleInstance(
|
|
$this->version,
|
|
$payload,
|
|
$this->solution['sid']
|
|
);
|
|
}
|
|
|
|
|
|
/**
|
|
* Provide a friendly representation
|
|
*
|
|
* @return string Machine friendly representation
|
|
*/
|
|
public function __toString(): string
|
|
{
|
|
$context = [];
|
|
foreach ($this->solution as $key => $value) {
|
|
$context[] = "$key=$value";
|
|
}
|
|
return '[Twilio.Conversations.V1.RoleContext ' . \implode(' ', $context) . ']';
|
|
}
|
|
}
|