agent/asm/factory/factory.go (42 lines of code) (raw):

// Copyright Amazon.com Inc. or its affiliates. All Rights Reserved. // // Licensed under the Apache License, Version 2.0 (the "License"). You may // not use this file except in compliance with the License. A copy of the // License is located at // // http://aws.amazon.com/apache2.0/ // // or in the "license" file accompanying this file. This file is distributed // on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either // express or implied. See the License for the specific language governing // permissions and limitations under the License. package factory import ( "context" "time" "github.com/aws/amazon-ecs-agent/agent/asm" "github.com/aws/amazon-ecs-agent/agent/config" agentversion "github.com/aws/amazon-ecs-agent/agent/version" "github.com/aws/amazon-ecs-agent/ecs-agent/credentials" "github.com/aws/amazon-ecs-agent/ecs-agent/httpclient" awsconfig "github.com/aws/aws-sdk-go-v2/config" awscreds "github.com/aws/aws-sdk-go-v2/credentials" "github.com/aws/aws-sdk-go-v2/service/secretsmanager" ) const ( roundtripTimeout = 5 * time.Second ) type ClientCreator interface { NewASMClient(region string, creds credentials.IAMRoleCredentials) (asm.SecretsManagerAPI, error) } func NewClientCreator() ClientCreator { return &asmClientCreator{} } type asmClientCreator struct{} func (*asmClientCreator) NewASMClient(region string, creds credentials.IAMRoleCredentials) (asm.SecretsManagerAPI, error) { cfg, err := awsconfig.LoadDefaultConfig( context.TODO(), awsconfig.WithRegion(region), awsconfig.WithHTTPClient(httpclient.New(roundtripTimeout, false, agentversion.String(), config.OSType)), awsconfig.WithCredentialsProvider( awscreds.NewStaticCredentialsProvider( creds.AccessKeyID, creds.SecretAccessKey, creds.SessionToken, ), ), ) if err != nil { return nil, err } return secretsmanager.NewFromConfig(cfg), nil }