JFIFxxC      C  " }!1AQa"q2#BR$3br %&'()*456789:CDEFGHIJSTUVWXYZcdefghijstuvwxyz w!1AQaq"2B #3RbraddBuiltIns($args); parent::__construct($args); } /** * 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'); } $accountId = null; if ($result->hasKey('AssumedRoleUser')) { $parsedArn = ArnParser::parse($result->get('AssumedRoleUser')['Arn']); $accountId = $parsedArn->getAccountId(); } elseif ($result->hasKey('FederatedUser')) { $parsedArn = ArnParser::parse($result->get('FederatedUser')['Arn']); $accountId = $parsedArn->getAccountId(); } $credentials = $result['Credentials']; $expiration = isset($credentials['Expiration']) && $credentials['Expiration'] instanceof \DateTimeInterface ? (int) $credentials['Expiration']->format('U') : null; return new Credentials( $credentials['AccessKeyId'], $credentials['SecretAccessKey'], isset($credentials['SessionToken']) ? $credentials['SessionToken'] : null, $expiration, $accountId ); } /** * Adds service-specific client built-in value * * @return void */ private function addBuiltIns($args) { $key = 'AWS::STS::UseGlobalEndpoint'; $result = $args['sts_regional_endpoints'] instanceof \Closure ? $args['sts_regional_endpoints']()->wait() : $args['sts_regional_endpoints']; if (is_string($result)) { if ($result === 'regional') { $value = false; } else if ($result === 'legacy') { $value = true; } else { return; } } else { if ($result->getEndpointsType() === 'regional') { $value = false; } else { $value = true; } } $this->clientBuiltIns[$key] = $value; } }