Merge pull request #8307 from hashicorp/fix_8116
delete amazon import post-processor intermediary snapshots
This commit is contained in:
commit
fcb65ee422
|
@ -85,15 +85,10 @@ func (a *Artifact) Destroy() error {
|
||||||
errors = append(errors, err)
|
errors = append(errors, err)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Deregister ami
|
err = DestroyAMIs([]*string{&imageId}, regionConn)
|
||||||
input := &ec2.DeregisterImageInput{
|
if err != nil {
|
||||||
ImageId: &imageId,
|
|
||||||
}
|
|
||||||
if _, err := regionConn.DeregisterImage(input); err != nil {
|
|
||||||
errors = append(errors, err)
|
errors = append(errors, err)
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO(mitchellh): Delete the snapshots associated with an AMI too
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if len(errors) > 0 {
|
if len(errors) > 0 {
|
||||||
|
|
|
@ -0,0 +1,49 @@
|
||||||
|
package common
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"log"
|
||||||
|
|
||||||
|
"github.com/aws/aws-sdk-go/aws"
|
||||||
|
"github.com/aws/aws-sdk-go/service/ec2"
|
||||||
|
)
|
||||||
|
|
||||||
|
func DestroyAMIs(imageids []*string, ec2conn *ec2.EC2) error {
|
||||||
|
resp, err := ec2conn.DescribeImages(&ec2.DescribeImagesInput{
|
||||||
|
ImageIds: imageids,
|
||||||
|
})
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
err := fmt.Errorf("Error describing AMI: %s", err)
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
// Deregister image by name.
|
||||||
|
for _, i := range resp.Images {
|
||||||
|
_, err := ec2conn.DeregisterImage(&ec2.DeregisterImageInput{
|
||||||
|
ImageId: i.ImageId,
|
||||||
|
})
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
err := fmt.Errorf("Error deregistering existing AMI: %s", err)
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
log.Printf("Deregistered AMI id: %s", *i.ImageId)
|
||||||
|
|
||||||
|
// Delete snapshot(s) by image
|
||||||
|
for _, b := range i.BlockDeviceMappings {
|
||||||
|
if b.Ebs != nil && aws.StringValue(b.Ebs.SnapshotId) != "" {
|
||||||
|
_, err := ec2conn.DeleteSnapshot(&ec2.DeleteSnapshotInput{
|
||||||
|
SnapshotId: b.Ebs.SnapshotId,
|
||||||
|
})
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
err := fmt.Errorf("Error deleting existing snapshot: %s", err)
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
log.Printf("Deleted snapshot: %s", *b.Ebs.SnapshotId)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
|
@ -159,49 +159,12 @@ func (s *StepAMIRegionCopy) Cleanup(state multistep.StateBag) {
|
||||||
// Delete the unencrypted amis and snapshots
|
// Delete the unencrypted amis and snapshots
|
||||||
ui.Say("Deregistering the AMI and deleting unencrypted temporary " +
|
ui.Say("Deregistering the AMI and deleting unencrypted temporary " +
|
||||||
"AMIs and snapshots")
|
"AMIs and snapshots")
|
||||||
|
err := DestroyAMIs([]*string{&s.toDelete}, ec2conn)
|
||||||
resp, err := ec2conn.DescribeImages(&ec2.DescribeImagesInput{
|
|
||||||
ImageIds: []*string{&s.toDelete},
|
|
||||||
})
|
|
||||||
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
err := fmt.Errorf("Error describing AMI: %s", err)
|
|
||||||
state.Put("error", err)
|
state.Put("error", err)
|
||||||
ui.Error(err.Error())
|
ui.Error(err.Error())
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
// Deregister image by name.
|
|
||||||
for _, i := range resp.Images {
|
|
||||||
_, err := ec2conn.DeregisterImage(&ec2.DeregisterImageInput{
|
|
||||||
ImageId: i.ImageId,
|
|
||||||
})
|
|
||||||
|
|
||||||
if err != nil {
|
|
||||||
err := fmt.Errorf("Error deregistering existing AMI: %s", err)
|
|
||||||
state.Put("error", err)
|
|
||||||
ui.Error(err.Error())
|
|
||||||
return
|
|
||||||
}
|
|
||||||
ui.Say(fmt.Sprintf("Deregistered AMI id: %s", *i.ImageId))
|
|
||||||
|
|
||||||
// Delete snapshot(s) by image
|
|
||||||
for _, b := range i.BlockDeviceMappings {
|
|
||||||
if b.Ebs != nil && aws.StringValue(b.Ebs.SnapshotId) != "" {
|
|
||||||
_, err := ec2conn.DeleteSnapshot(&ec2.DeleteSnapshotInput{
|
|
||||||
SnapshotId: b.Ebs.SnapshotId,
|
|
||||||
})
|
|
||||||
|
|
||||||
if err != nil {
|
|
||||||
err := fmt.Errorf("Error deleting existing snapshot: %s", err)
|
|
||||||
state.Put("error", err)
|
|
||||||
ui.Error(err.Error())
|
|
||||||
return
|
|
||||||
}
|
|
||||||
ui.Say(fmt.Sprintf("Deleted snapshot: %s", *b.Ebs.SnapshotId))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func getRegionConn(config *AccessConfig, target string) (ec2iface.EC2API, error) {
|
func getRegionConn(config *AccessConfig, target string) (ec2iface.EC2API, error) {
|
||||||
|
|
|
@ -299,10 +299,9 @@ func (p *PostProcessor) PostProcess(ctx context.Context, ui packer.Ui, artifact
|
||||||
return nil, false, false, fmt.Errorf("Error waiting for AMI (%s): %s", *resp.ImageId, err)
|
return nil, false, false, fmt.Errorf("Error waiting for AMI (%s): %s", *resp.ImageId, err)
|
||||||
}
|
}
|
||||||
|
|
||||||
_, err = ec2conn.DeregisterImage(&ec2.DeregisterImageInput{
|
// Clean up intermediary image now that it has successfully been renamed.
|
||||||
ImageId: &createdami,
|
ui.Message("Destroying intermediary AMI...")
|
||||||
})
|
err = awscommon.DestroyAMIs([]*string{&createdami}, ec2conn)
|
||||||
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, false, false, fmt.Errorf("Error deregistering existing AMI: %s", err)
|
return nil, false, false, fmt.Errorf("Error deregistering existing AMI: %s", err)
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue