From a667cd10055221aa853e0762092bf40ada72b9c1 Mon Sep 17 00:00:00 2001 From: Jay Deokar <23660509+jaydeokar@users.noreply.github.com> Date: Wed, 11 Sep 2024 22:58:12 -0700 Subject: [PATCH] Remove hard failure for not getting global STS endpoint (#467) --- pkg/aws/ec2/api/wrapper.go | 23 ++++++++++++----------- 1 file changed, 12 insertions(+), 11 deletions(-) diff --git a/pkg/aws/ec2/api/wrapper.go b/pkg/aws/ec2/api/wrapper.go index ef3c7d1e..b1fbe3e9 100644 --- a/pkg/aws/ec2/api/wrapper.go +++ b/pkg/aws/ec2/api/wrapper.go @@ -537,22 +537,23 @@ func (e *ec2Wrapper) getClientUsingAssumedRole(instanceRegion, roleARN, clusterN // TODO: we should revisit the global sts endpoint and check if we should remove global endpoint // we are not using it since the concern on availability and performance // https://docs.aws.amazon.com/IAM/latest/UserGuide/id_credentials_temp_enable-regions.html + globalSTSEndpoint, err := endpoints.DefaultResolver(). EndpointFor("sts", aws.StringValue(userStsSession.Config.Region)) if err != nil { - return nil, fmt.Errorf("failed to get the global sts endoint for region %s: %v", - *userStsSession.Config.Region, err) - } - - // If the regional STS endpoint is different than the global STS endpoint then add the global sts endpoint - if regionalSTSEndpoint.URL != globalSTSEndpoint.URL { - globalProvider := &stscreds.AssumeRoleProvider{ - Client: e.createSTSClient(userStsSession, client, regionalSTSEndpoint, sourceAcct, sourceArn), - RoleARN: roleARN, - Duration: time.Minute * 60, + e.log.Info("failed to get the global STS Endpoint, ignoring", "roleARN", roleARN) + } else { + // If the regional STS endpoint is different than the global STS endpoint then add the global sts endpoint + if regionalSTSEndpoint.URL != globalSTSEndpoint.URL { + globalProvider := &stscreds.AssumeRoleProvider{ + Client: e.createSTSClient(userStsSession, client, regionalSTSEndpoint, sourceAcct, sourceArn), + RoleARN: roleARN, + Duration: time.Minute * 60, + } + providers = append(providers, globalProvider) } - providers = append(providers, globalProvider) } + e.log.Info("initialized the regional/global providers", "roleARN", roleARN) userStsSession.Config.Credentials = credentials.NewChainCredentials(providers)