builder/amazon/common: use new API for goamz to set AMI attributes

/cc @jmassara
This commit is contained in:
Mitchell Hashimoto 2013-08-08 22:43:29 -07:00
parent b0394c6d30
commit 1f53e047a3
1 changed files with 12 additions and 40 deletions

View File

@ -20,49 +20,21 @@ func (s *StepModifyAttributes) Run(state map[string]interface{}) multistep.StepA
amis := state["amis"].(map[string]string) amis := state["amis"].(map[string]string)
ami := amis[ec2conn.Region.Name] ami := amis[ec2conn.Region.Name]
if s.Description != "" { options := &ec2.ModifyImageAttribute{
ui.Say(fmt.Sprintf("Setting Description of AMI (%s) to '%s'...", ami, s.Description))
_, err := ec2conn.ModifyImageAttribute(ami, &ec2.ModifyImageAttribute{
Attribute: ec2.DescriptionAttribute,
Description: s.Description, Description: s.Description,
}) AddUsers: s.Users,
if err != nil { AddGroups: s.Groups,
err := fmt.Errorf("Error setting Description of AMI (%s): %s", ami, err)
state["error"] = err
ui.Error(err.Error())
return multistep.ActionHalt
}
}
if len(s.Users) > 0 || len(s.Groups) > 0 {
ui.Say(fmt.Sprintf("Setting Launch Permissions for AMI (%s)...", ami))
_, err := ec2conn.ModifyImageAttribute(ami, &ec2.ModifyImageAttribute{
Attribute: ec2.LaunchPermissionAttribute,
Operation: ec2.LaunchPermissionAdd,
Users: s.Users,
Groups: s.Groups,
})
if err != nil {
err := fmt.Errorf("Error setting Launch Permissions for AMI (%s): %s", ami, err)
state["error"] = err
ui.Error(err.Error())
return multistep.ActionHalt
}
}
if len(s.ProductCodes) > 0 {
ui.Say(fmt.Sprintf("Setting Product Code(s) for AMI (%s)...", ami))
_, err := ec2conn.ModifyImageAttribute(ami, &ec2.ModifyImageAttribute{
Attribute: ec2.ProductCodeAttribute,
ProductCodes: s.ProductCodes, ProductCodes: s.ProductCodes,
}) }
ui.Say("Modifying AMI attributes...")
_, err := ec2conn.ModifyImageAttribute(ami, options)
if err != nil { if err != nil {
err := fmt.Errorf("Error setting Product Code(s) for AMI (%s): %s", ami, err) err := fmt.Errorf("Error modify AMI attributes: %s", err)
state["error"] = err state["error"] = err
ui.Error(err.Error()) ui.Error(err.Error())
return multistep.ActionHalt return multistep.ActionHalt
} }
}
return multistep.ActionContinue return multistep.ActionContinue
} }