2016-11-09 17:42:26 -05:00
|
|
|
package ebsvolume
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"log"
|
|
|
|
"sort"
|
|
|
|
"strings"
|
|
|
|
|
|
|
|
"github.com/aws/aws-sdk-go/service/ec2"
|
2020-12-17 16:29:25 -05:00
|
|
|
packersdk "github.com/hashicorp/packer-plugin-sdk/packer"
|
2016-11-09 17:42:26 -05:00
|
|
|
)
|
|
|
|
|
|
|
|
// map of region to list of volume IDs
|
|
|
|
type EbsVolumes map[string][]string
|
|
|
|
|
2020-10-01 00:23:09 -04:00
|
|
|
// map of region to list of snapshot IDs
|
|
|
|
type EbsSnapshots map[string][]string
|
|
|
|
|
2016-11-09 17:42:26 -05:00
|
|
|
// Artifact is an artifact implementation that contains built AMIs.
|
|
|
|
type Artifact struct {
|
|
|
|
// A map of regions to EBS Volume IDs.
|
|
|
|
Volumes EbsVolumes
|
2020-10-01 00:23:09 -04:00
|
|
|
// A map of regions to EBS Snapshot IDs.
|
|
|
|
Snapshots EbsSnapshots
|
2016-11-09 17:42:26 -05:00
|
|
|
// BuilderId is the unique ID for the builder that created this AMI
|
|
|
|
BuilderIdValue string
|
|
|
|
|
2020-01-30 05:27:58 -05:00
|
|
|
// StateData should store data such as GeneratedData
|
2020-01-16 06:04:03 -05:00
|
|
|
// to be shared with post-processors
|
|
|
|
StateData map[string]interface{}
|
|
|
|
|
2016-11-09 17:42:26 -05:00
|
|
|
// EC2 connection for performing API stuff.
|
|
|
|
Conn *ec2.EC2
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a *Artifact) BuilderId() string {
|
|
|
|
return a.BuilderIdValue
|
|
|
|
}
|
|
|
|
|
|
|
|
func (*Artifact) Files() []string {
|
|
|
|
// We have no files
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// returns a sorted list of region:ID pairs
|
|
|
|
func (a *Artifact) idList() []string {
|
2020-10-01 00:23:09 -04:00
|
|
|
|
|
|
|
parts := make([]string, 0, len(a.Volumes)+len(a.Snapshots))
|
|
|
|
|
2016-11-09 17:42:26 -05:00
|
|
|
for region, volumeIDs := range a.Volumes {
|
|
|
|
for _, volumeID := range volumeIDs {
|
|
|
|
parts = append(parts, fmt.Sprintf("%s:%s", region, volumeID))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-10-01 00:23:09 -04:00
|
|
|
for region, snapshotIDs := range a.Snapshots {
|
|
|
|
for _, snapshotID := range snapshotIDs {
|
|
|
|
parts = append(parts, fmt.Sprintf("%s:%s", region, snapshotID))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-11-09 17:42:26 -05:00
|
|
|
sort.Strings(parts)
|
|
|
|
return parts
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a *Artifact) Id() string {
|
|
|
|
return strings.Join(a.idList(), ",")
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a *Artifact) String() string {
|
|
|
|
return fmt.Sprintf("EBS Volumes were created:\n\n%s", strings.Join(a.idList(), "\n"))
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a *Artifact) State(name string) interface{} {
|
2020-01-16 06:04:03 -05:00
|
|
|
if _, ok := a.StateData[name]; ok {
|
|
|
|
return a.StateData[name]
|
|
|
|
}
|
2016-11-09 17:42:26 -05:00
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (a *Artifact) Destroy() error {
|
|
|
|
errors := make([]error, 0)
|
|
|
|
|
|
|
|
for region, volumeIDs := range a.Volumes {
|
|
|
|
for _, volumeID := range volumeIDs {
|
|
|
|
log.Printf("Deregistering Volume ID (%s) from region (%s)", volumeID, region)
|
|
|
|
|
|
|
|
input := &ec2.DeleteVolumeInput{
|
|
|
|
VolumeId: &volumeID,
|
|
|
|
}
|
|
|
|
if _, err := a.Conn.DeleteVolume(input); err != nil {
|
|
|
|
errors = append(errors, err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if len(errors) > 0 {
|
|
|
|
if len(errors) == 1 {
|
|
|
|
return errors[0]
|
|
|
|
} else {
|
2020-11-19 15:07:02 -05:00
|
|
|
return &packersdk.MultiError{Errors: errors}
|
2016-11-09 17:42:26 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|