![]() Server : Apache System : Linux server2.corals.io 4.18.0-348.2.1.el8_5.x86_64 #1 SMP Mon Nov 15 09:17:08 EST 2021 x86_64 User : corals ( 1002) PHP Version : 7.4.33 Disable Function : exec,passthru,shell_exec,system Directory : /home/corals/old/vendor/aws/aws-sdk-php/src/Credentials/ |
<?php namespace Aws\Credentials; use Aws\Exception\CredentialsException; use GuzzleHttp\Exception\GuzzleException; use GuzzleHttp\Psr7\Request; use GuzzleHttp\Promise\PromiseInterface; use Psr\Http\Message\ResponseInterface; /** * Credential provider that fetches container credentials with GET request. * container environment variables are used in constructing request URI. */ class EcsCredentialProvider { const SERVER_URI = 'http://169.254.170.2'; const ENV_URI = "AWS_CONTAINER_CREDENTIALS_RELATIVE_URI"; const ENV_FULL_URI = "AWS_CONTAINER_CREDENTIALS_FULL_URI"; const ENV_AUTH_TOKEN = "AWS_CONTAINER_AUTHORIZATION_TOKEN"; const ENV_AUTH_TOKEN_FILE = "AWS_CONTAINER_AUTHORIZATION_TOKEN_FILE"; const ENV_TIMEOUT = 'AWS_METADATA_SERVICE_TIMEOUT'; const EKS_SERVER_HOST_IPV4 = '169.254.170.23'; const EKS_SERVER_HOST_IPV6 = 'fd00:ec2::23'; /** @var callable */ private $client; /** @var float|mixed */ private $timeout; /** * The constructor accepts following options: * - timeout: (optional) Connection timeout, in seconds, default 1.0 * - client: An EcsClient to make request from * * @param array $config Configuration options */ public function __construct(array $config = []) { $timeout = getenv(self::ENV_TIMEOUT); if (!$timeout) { $timeout = $_SERVER[self::ENV_TIMEOUT] ?? ($config['timeout'] ?? 1.0); } $this->timeout = (float) $timeout; $this->client = $config['client'] ?? \Aws\default_http_handler(); } /** * Load container credentials. * * @return PromiseInterface * @throws GuzzleException */ public function __invoke() { $client = $this->client; $uri = self::getEcsUri(); if ($this->isCompatibleUri($uri)) { $request = new Request('GET', $uri); $headers = $this->getHeadersForAuthToken(); return $client( $request, [ 'timeout' => $this->timeout, 'proxy' => '', 'headers' => $headers ] )->then(function (ResponseInterface $response) { $result = $this->decodeResult((string) $response->getBody()); return new Credentials( $result['AccessKeyId'], $result['SecretAccessKey'], $result['Token'], strtotime($result['Expiration']) ); })->otherwise(function ($reason) { $reason = is_array($reason) ? $reason['exception'] : $reason; $msg = $reason->getMessage(); throw new CredentialsException( "Error retrieving credentials from container metadata ($msg)" ); }); } throw new CredentialsException("Uri '{$uri}' contains an unsupported host."); } /** * Retrieves authorization token. * * @return array|false|string */ private function getEcsAuthToken() { if (!empty($path = getenv(self::ENV_AUTH_TOKEN_FILE))) { if (is_readable($path)) { return file_get_contents($path); } throw new CredentialsException( "Failed to read authorization token from '{$path}': no such file or directory." ); } return getenv(self::ENV_AUTH_TOKEN); } /** * Provides headers for credential metadata request. * * @return array|array[]|string[] */ private function getHeadersForAuthToken() { $authToken = self::getEcsAuthToken(); $headers = []; if (!empty($authToken)) $headers = ['Authorization' => $authToken]; return $headers; } /** @deprecated */ public function setHeaderForAuthToken() { $authToken = self::getEcsAuthToken(); $headers = []; if (!empty($authToken)) $headers = ['Authorization' => $authToken]; return $headers; } /** * Fetch container metadata URI from container environment variable. * * @return string Returns container metadata URI */ private function getEcsUri() { $credsUri = getenv(self::ENV_URI); if ($credsUri === false) { $credsUri = $_SERVER[self::ENV_URI] ?? ''; } if (empty($credsUri)){ $credFullUri = getenv(self::ENV_FULL_URI); if ($credFullUri === false){ $credFullUri = $_SERVER[self::ENV_FULL_URI] ?? ''; } if (!empty($credFullUri)) return $credFullUri; } return self::SERVER_URI . $credsUri; } private function decodeResult($response) { $result = json_decode($response, true); if (!isset($result['AccessKeyId'])) { throw new CredentialsException('Unexpected container metadata credentials value'); } return $result; } /** * Determines whether or not a given request URI is a valid * container credential request URI. * * @param $uri * * @return bool */ private function isCompatibleUri($uri) { $parsed = parse_url($uri); if ($parsed['scheme'] !== 'https') { $host = trim($parsed['host'], '[]'); $ecsHost = parse_url(self::SERVER_URI)['host']; $eksHost = self::EKS_SERVER_HOST_IPV4; if ($host !== $ecsHost && $host !== $eksHost && $host !== self::EKS_SERVER_HOST_IPV6 && !CredentialsUtils::isLoopBackAddress(gethostbyname($host)) ) { return false; } } return true; } }