Allow ecr login with default aws credential chain

This commit is contained in:
Andres Koetsier 2017-11-01 16:09:11 +01:00
parent 88ae029815
commit dae59f2400
1 changed files with 7 additions and 8 deletions

View File

@ -11,7 +11,6 @@ import (
"github.com/aws/aws-sdk-go/aws" "github.com/aws/aws-sdk-go/aws"
"github.com/aws/aws-sdk-go/aws/awserr" "github.com/aws/aws-sdk-go/aws/awserr"
"github.com/aws/aws-sdk-go/aws/credentials"
"github.com/aws/aws-sdk-go/aws/session" "github.com/aws/aws-sdk-go/aws/session"
"github.com/aws/aws-sdk-go/service/ecr" "github.com/aws/aws-sdk-go/service/ecr"
) )
@ -32,14 +31,14 @@ func main() {
region = defaultRegion region = defaultRegion
} }
os.Setenv("AWS_ACCESS_KEY_ID", key)
os.Setenv("AWS_SECRET_ACCESS_KEY", secret)
os.Setenv("AWS_REGION", region) os.Setenv("AWS_REGION", region)
sess, err := session.NewSession(&aws.Config{ if key != "" && secret != "" {
Credentials: credentials.NewEnvCredentials(), os.Setenv("AWS_ACCESS_KEY_ID", key)
Region: &region, os.Setenv("AWS_SECRET_ACCESS_KEY", secret)
}) }
sess, err := session.NewSession(&aws.Config{Region: &region})
if err != nil { if err != nil {
log.Fatal(fmt.Sprintf("error creating aws session: %v", err)) log.Fatal(fmt.Sprintf("error creating aws session: %v", err))
@ -48,7 +47,7 @@ func main() {
svc := ecr.New(sess) svc := ecr.New(sess)
username, password, registry, err := getAuthInfo(svc) username, password, registry, err := getAuthInfo(svc)
if err != nil { if err != nil {
os.Exit(1) log.Fatal(fmt.Sprintf("error getting ECR auth: %v", err))
} }
if !strings.HasPrefix(repo, registry) { if !strings.HasPrefix(repo, registry) {