Don't set region from metadata if profile is set.

This commit is contained in:
Matthew Hooker 2017-11-07 14:03:52 -08:00
parent 52fc0100eb
commit c106e7c26c
No known key found for this signature in database
GPG Key ID: 7B5F933D9CE8C6A1
2 changed files with 20 additions and 22 deletions

View File

@ -34,15 +34,15 @@ func (c *AccessConfig) Session() (*session.Session, error) {
return c.session, nil return c.session, nil
} }
config := aws.NewConfig().WithMaxRetries(11).WithCredentialsChainVerboseErrors(true)
if c.ProfileName != "" { if c.ProfileName != "" {
if err := os.Setenv("AWS_PROFILE", c.ProfileName); err != nil { if err := os.Setenv("AWS_PROFILE", c.ProfileName); err != nil {
return nil, fmt.Errorf("Set env error: %s", err) return nil, fmt.Errorf("Set env error: %s", err)
} }
} } else if c.RawRegion != "" {
config = config.WithRegion(c.RawRegion)
config := aws.NewConfig().WithMaxRetries(11).WithCredentialsChainVerboseErrors(true) } else if region := c.metadataRegion(); region != "" {
if region := c.region(); region != "" {
config = config.WithRegion(region) config = config.WithRegion(region)
} }
@ -68,25 +68,26 @@ func (c *AccessConfig) Session() (*session.Session, error) {
SharedConfigState: session.SharedConfigEnable, SharedConfigState: session.SharedConfigEnable,
Config: *config, Config: *config,
} }
if c.MFACode != "" { if c.MFACode != "" {
opts.AssumeRoleTokenProvider = func() (string, error) { opts.AssumeRoleTokenProvider = func() (string, error) {
return c.MFACode, nil return c.MFACode, nil
} }
} }
var err error
c.session, err = session.NewSessionWithOptions(opts) if session, err := session.NewSessionWithOptions(opts); err != nil {
if err != nil {
return nil, err return nil, err
} else if *session.Config.Region == "" {
return nil, fmt.Errorf("Could not find AWS region, make sure it's set.")
} else {
c.session = session
} }
return c.session, nil return c.session, nil
} }
// region returns either the region from config or region from metadata service // metadataRegion returns the region from the metadata service
func (c *AccessConfig) region() string { func (c *AccessConfig) metadataRegion() string {
if c.RawRegion != "" {
return c.RawRegion
}
client := cleanhttp.DefaultClient() client := cleanhttp.DefaultClient()
@ -112,9 +113,5 @@ func (c *AccessConfig) Prepare(ctx *interpolate.Context) []error {
} }
} }
if len(errs) > 0 {
return errs return errs
} }
return nil
}

View File

@ -45,12 +45,13 @@ func (c *AMIConfig) Prepare(accessConfig *AccessConfig, ctx *interpolate.Context
session, err := accessConfig.Session() session, err := accessConfig.Session()
if err != nil { if err != nil {
errs = append(errs, err) errs = append(errs, err)
} } else {
region := *session.Config.Region region := *session.Config.Region
if stringInSlice(c.AMIRegions, region) { if stringInSlice(c.AMIRegions, region) {
errs = append(errs, fmt.Errorf("Cannot copy AMI to AWS session region '%s', please remove it from `ami_regions`.", region)) errs = append(errs, fmt.Errorf("Cannot copy AMI to AWS session region '%s', please remove it from `ami_regions`.", region))
} }
} }
}
if c.AMIName == "" { if c.AMIName == "" {
errs = append(errs, fmt.Errorf("ami_name must be specified")) errs = append(errs, fmt.Errorf("ami_name must be specified"))