AWSCredentialsProviderChain.cpp 4.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. /**
  2. * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
  3. * SPDX-License-Identifier: Apache-2.0.
  4. */
  5. #include <aws/core/auth/AWSCredentialsProviderChain.h>
  6. #include <aws/core/auth/STSCredentialsProvider.h>
  7. #include <aws/core/auth/SSOCredentialsProvider.h>
  8. #include <aws/core/platform/Environment.h>
  9. #include <aws/core/utils/memory/AWSMemory.h>
  10. #include <aws/core/utils/StringUtils.h>
  11. #include <aws/core/utils/logging/LogMacros.h>
  12. using namespace Aws::Auth;
  13. static const char AWS_ECS_CONTAINER_CREDENTIALS_RELATIVE_URI[] = "AWS_CONTAINER_CREDENTIALS_RELATIVE_URI";
  14. static const char AWS_ECS_CONTAINER_CREDENTIALS_FULL_URI[] = "AWS_CONTAINER_CREDENTIALS_FULL_URI";
  15. static const char AWS_ECS_CONTAINER_AUTHORIZATION_TOKEN[] = "AWS_CONTAINER_AUTHORIZATION_TOKEN";
  16. static const char AWS_EC2_METADATA_DISABLED[] = "AWS_EC2_METADATA_DISABLED";
  17. static const char DefaultCredentialsProviderChainTag[] = "DefaultAWSCredentialsProviderChain";
  18. AWSCredentials AWSCredentialsProviderChain::GetAWSCredentials()
  19. {
  20. for (auto&& credentialsProvider : m_providerChain)
  21. {
  22. AWSCredentials credentials = credentialsProvider->GetAWSCredentials();
  23. if (!credentials.GetAWSAccessKeyId().empty() && !credentials.GetAWSSecretKey().empty())
  24. {
  25. return credentials;
  26. }
  27. }
  28. return AWSCredentials();
  29. }
  30. DefaultAWSCredentialsProviderChain::DefaultAWSCredentialsProviderChain() : AWSCredentialsProviderChain()
  31. {
  32. AddProvider(Aws::MakeShared<EnvironmentAWSCredentialsProvider>(DefaultCredentialsProviderChainTag));
  33. AddProvider(Aws::MakeShared<ProfileConfigFileAWSCredentialsProvider>(DefaultCredentialsProviderChainTag));
  34. AddProvider(Aws::MakeShared<ProcessCredentialsProvider>(DefaultCredentialsProviderChainTag));
  35. AddProvider(Aws::MakeShared<STSAssumeRoleWebIdentityCredentialsProvider>(DefaultCredentialsProviderChainTag));
  36. AddProvider(Aws::MakeShared<SSOCredentialsProvider>(DefaultCredentialsProviderChainTag));
  37. //ECS TaskRole Credentials only available when ENVIRONMENT VARIABLE is set
  38. const auto relativeUri = Aws::Environment::GetEnv(AWS_ECS_CONTAINER_CREDENTIALS_RELATIVE_URI);
  39. AWS_LOGSTREAM_DEBUG(DefaultCredentialsProviderChainTag, "The environment variable value " << AWS_ECS_CONTAINER_CREDENTIALS_RELATIVE_URI
  40. << " is " << relativeUri);
  41. const auto absoluteUri = Aws::Environment::GetEnv(AWS_ECS_CONTAINER_CREDENTIALS_FULL_URI);
  42. AWS_LOGSTREAM_DEBUG(DefaultCredentialsProviderChainTag, "The environment variable value " << AWS_ECS_CONTAINER_CREDENTIALS_FULL_URI
  43. << " is " << absoluteUri);
  44. const auto ec2MetadataDisabled = Aws::Environment::GetEnv(AWS_EC2_METADATA_DISABLED);
  45. AWS_LOGSTREAM_DEBUG(DefaultCredentialsProviderChainTag, "The environment variable value " << AWS_EC2_METADATA_DISABLED
  46. << " is " << ec2MetadataDisabled);
  47. if (!relativeUri.empty())
  48. {
  49. AddProvider(Aws::MakeShared<TaskRoleCredentialsProvider>(DefaultCredentialsProviderChainTag, relativeUri.c_str()));
  50. AWS_LOGSTREAM_INFO(DefaultCredentialsProviderChainTag, "Added ECS metadata service credentials provider with relative path: ["
  51. << relativeUri << "] to the provider chain.");
  52. }
  53. else if (!absoluteUri.empty())
  54. {
  55. const auto token = Aws::Environment::GetEnv(AWS_ECS_CONTAINER_AUTHORIZATION_TOKEN);
  56. AddProvider(Aws::MakeShared<TaskRoleCredentialsProvider>(DefaultCredentialsProviderChainTag,
  57. absoluteUri.c_str(), token.c_str()));
  58. //DO NOT log the value of the authorization token for security purposes.
  59. AWS_LOGSTREAM_INFO(DefaultCredentialsProviderChainTag, "Added ECS credentials provider with URI: ["
  60. << absoluteUri << "] to the provider chain with a" << (token.empty() ? "n empty " : " non-empty ")
  61. << "authorization token.");
  62. }
  63. else if (Aws::Utils::StringUtils::ToLower(ec2MetadataDisabled.c_str()) != "true")
  64. {
  65. AddProvider(Aws::MakeShared<InstanceProfileCredentialsProvider>(DefaultCredentialsProviderChainTag));
  66. AWS_LOGSTREAM_INFO(DefaultCredentialsProviderChainTag, "Added EC2 metadata service credentials provider to the provider chain.");
  67. }
  68. }
  69. DefaultAWSCredentialsProviderChain::DefaultAWSCredentialsProviderChain(const DefaultAWSCredentialsProviderChain& chain) {
  70. for (const auto& provider: chain.GetProviders()) {
  71. AddProvider(provider);
  72. }
  73. }