| 
<?phpnamespace Aws\Sts;
 
 use Aws\AwsClient;
 use Aws\Result;
 use Aws\Credentials\Credentials;
 
 /**
 * This client is used to interact with the **AWS Security Token Service (AWS STS)**.
 *
 * @method \Aws\Result assumeRole(array $args = [])
 * @method \GuzzleHttp\Promise\Promise assumeRoleAsync(array $args = [])
 * @method \Aws\Result assumeRoleWithSAML(array $args = [])
 * @method \GuzzleHttp\Promise\Promise assumeRoleWithSAMLAsync(array $args = [])
 * @method \Aws\Result assumeRoleWithWebIdentity(array $args = [])
 * @method \GuzzleHttp\Promise\Promise assumeRoleWithWebIdentityAsync(array $args = [])
 * @method \Aws\Result decodeAuthorizationMessage(array $args = [])
 * @method \GuzzleHttp\Promise\Promise decodeAuthorizationMessageAsync(array $args = [])
 * @method \Aws\Result getFederationToken(array $args = [])
 * @method \GuzzleHttp\Promise\Promise getFederationTokenAsync(array $args = [])
 * @method \Aws\Result getSessionToken(array $args = [])
 * @method \GuzzleHttp\Promise\Promise getSessionTokenAsync(array $args = [])
 */
 class StsClient extends AwsClient
 {
 /**
 * Creates credentials from the result of an STS operations
 *
 * @param Result $result Result of an STS operation
 *
 * @return Credentials
 * @throws \InvalidArgumentException if the result contains no credentials
 */
 public function createCredentials(Result $result)
 {
 if (!$result->hasKey('Credentials')) {
 throw new \InvalidArgumentException('Result contains no credentials');
 }
 
 $c = $result['Credentials'];
 
 return new Credentials(
 $c['AccessKeyId'],
 $c['SecretAccessKey'],
 isset($c['SessionToken']) ? $c['SessionToken'] : null,
 isset($c['Expiration']) && $c['Expiration'] instanceof \DateTimeInterface
 ? (int) $c['Expiration']->format('U')
 : null
 );
 }
 }
 
 |