-
Notifications
You must be signed in to change notification settings - Fork 618
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Implement credentials chain for aws-sdk-go-v2 #4424
Conversation
f3ec026
to
3a636c9
Compare
ecs-agent/credentials/providers/rotating_shared_credentials_provider_v2.go
Outdated
Show resolved
Hide resolved
Thank you for updating these. I have some general question for my own clarity:
|
Rotating creds are used with ECS-A. amazon-ecs-agent/ecs-init/docker/docker.go Lines 463 to 466 in ea4ffcd
If the credentials provider is wrapped in a credentials cache and the creds have expired, the cache will retrieve the creds again.
Without a credentials cache, "the SDK will attempt to retrieve the credentials for every request". I forgot to wrap the credentials provider that fetches preflight creds in a cache. I've updated it in 0395026.
Yes, wherever we're using an SDKv1 client, we need to use the v1 credentials provider because there's no inter-compatibility between v1 and v2 interfaces. But it's ok to mix v1 and v2 creds because they're ultimately being fetched from the same underlying source (IAM role, shared creds file, env vars, etc.). The underlying source is responsible for rotating creds when they expire, if that's something it supports. The credentials provider is responsible for retrieving creds from the underlying source when the cached creds are expired. But if the creds from the underlying source expire and are never refreshed, the provider will end up returning invalid creds. |
ecs-agent/credentials/providers/rotating_shared_credentials_provider_v2.go
Show resolved
Hide resolved
ecs-agent/credentials/providers/instance_credentials_provider_windows.go
Show resolved
Hide resolved
38644ef
to
b014caf
Compare
This reverts commit c24cdae.
This reverts commit c24cdae.
This reverts commit c24cdae.
This reverts commit c24cdae.
…)"" This reverts commit 1834778.
…)"" This reverts commit 1834778.
Summary
This PR implements a credentials chain that is compatible with aws-sdk-go-v2. It is a prerequisite for migrating our clients to aws-sdk-go-v2 because the credentials interface has changed between v1 and v2 of the SDK, and v1 clients/credentials are not compatible with v2 clients/credentials and vice versa.
RotatingSharedCredentialsProviderV2
is the v2 implementation ofRotatingSharedCredentialsProvider
.InstanceCredentialsProvider
(Linux version and Windows version) is the v2 implementation ofinstancecreds.GetCredentials
(Linux version and Windows version).For now, we only use the v2 credential providers when fetching preflight creds during container instance registration.
Note: There may be changes in Agent behavior caused by small changes between v1 and v2 of the SDK, such as changing the order of precedence of env vars that determine config values. Unless these changes are known to break existing functionality in Agent, we will consume them as-is.
Implementation details
RotatingSharedCredentialsProviderV2
amazon-ecs-agent/ecs-agent/credentials/providers/rotating_shared_credentials_provider.go
Lines 56 to 58 in ea4ffcd
The
SharedCredentialsProvider
from v1 does not exist as a standalone credentials provider in v2. To load shared credentials in aws-sdk-go-v2, useconfig.LoadSharedConfigProfile
.The docs use
to load shared creds and configs from non-default locations, but
config.LoadDefaultConfig
checks env vars before shared config and credentials files, which we do not want in this case.InstanceCredentialsProvider
Linux and non-ECS-A Windows
This is a credentials chain that consists of the default credentials chain plus
RotatingSharedCredentialsProviderV2
.amazon-ecs-agent/ecs-agent/credentials/instancecreds/instancecreds_linux.go
Lines 38 to 43 in ea4ffcd
The default credentials chain was accessible in v1 via
default.CredProviders
, but it is not directly accessible in v2. To access it in v2, callconfig.LoadDefaultConfig
and use theConfig.Credentials
field. Per the docs,credentials.ChainProvider
no longer exists in v2, so we reimplement it inInstanceCredentialsProvider.Retreive
.ECS-A Windows
The credentials chain tries
RotatingSharedCredentialsProviderV2
before the shared credentials file. Our existing implementation accomplishes this by reordering the default credentials chain, inserting the rotating shared creds before the default shared creds.As previously mentioned, we can't directly access the default credentials chain in v2, so we have to manually load credentials from various sources in the desired order:
EnvConfig.Credentials
RotatingSharedCredentialsProviderV2
SharedConfig.Credentials
- We loadEnvConfig
(again, separately from step 1) beforeSharedConfig
in caseAWS_PROFILE
andAWS_SHARED_CREDENTIALS_FILE
are set becauseLoadSharedConfigProfile
does not automatically check these env vars. It only loads from the files explicitly provided as args or~/.aws
if none are provided.ec2rolecreds.Provider
Testing
RotatingSharedCredentialsProviderV2
to test parity with the v1 implementation.InstanceCredentialsProvider
to test parity with the v1 implementation, plus new tests for ECS-A, creds from an EC2 role, creds from the rotating shared creds file, credential chain ordering, and no valid creds./rotatingcreds/credentials
.AWS_ACCESS_KEY_ID
andAWS_SECRET_ACCESS_KEY
were set in/etc/ecs.config
."Successfully got ECS instance credentials from provider"
and checking the logged provider.)New tests cover the changes: yes
Description for the changelog
Implement credentials chain for aws-sdk-go-v2.
Licensing
By submitting this pull request, I confirm that my contribution is made under the terms of the Apache 2.0 license.