Add 'skip_create_ami' option to the amazon-ebs builder (#10531)
This commit is contained in:
parent
a5a1344948
commit
782cf058b5
|
@ -24,6 +24,7 @@ type StepAMIRegionCopy struct {
|
||||||
|
|
||||||
toDelete string
|
toDelete string
|
||||||
getRegionConn func(*AccessConfig, string) (ec2iface.EC2API, error)
|
getRegionConn func(*AccessConfig, string) (ec2iface.EC2API, error)
|
||||||
|
AMISkipCreateImage bool
|
||||||
AMISkipBuildRegion bool
|
AMISkipBuildRegion bool
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -63,6 +64,12 @@ func (s *StepAMIRegionCopy) DeduplicateRegions(intermediary bool) {
|
||||||
|
|
||||||
func (s *StepAMIRegionCopy) Run(ctx context.Context, state multistep.StateBag) multistep.StepAction {
|
func (s *StepAMIRegionCopy) Run(ctx context.Context, state multistep.StateBag) multistep.StepAction {
|
||||||
ui := state.Get("ui").(packersdk.Ui)
|
ui := state.Get("ui").(packersdk.Ui)
|
||||||
|
|
||||||
|
if s.AMISkipCreateImage {
|
||||||
|
ui.Say("Skipping AMI region copy...")
|
||||||
|
return multistep.ActionContinue
|
||||||
|
}
|
||||||
|
|
||||||
amis := state.Get("amis").(map[string]string)
|
amis := state.Get("amis").(map[string]string)
|
||||||
snapshots := state.Get("snapshots").(map[string][]string)
|
snapshots := state.Get("snapshots").(map[string][]string)
|
||||||
intermediary, _ := state.Get("intermediary_image").(bool)
|
intermediary, _ := state.Get("intermediary_image").(bool)
|
||||||
|
|
|
@ -16,6 +16,8 @@ import (
|
||||||
)
|
)
|
||||||
|
|
||||||
type StepCreateTags struct {
|
type StepCreateTags struct {
|
||||||
|
AMISkipCreateImage bool
|
||||||
|
|
||||||
Tags map[string]string
|
Tags map[string]string
|
||||||
SnapshotTags map[string]string
|
SnapshotTags map[string]string
|
||||||
Ctx interpolate.Context
|
Ctx interpolate.Context
|
||||||
|
@ -25,6 +27,12 @@ func (s *StepCreateTags) Run(ctx context.Context, state multistep.StateBag) mult
|
||||||
ec2conn := state.Get("ec2").(*ec2.EC2)
|
ec2conn := state.Get("ec2").(*ec2.EC2)
|
||||||
session := state.Get("awsSession").(*session.Session)
|
session := state.Get("awsSession").(*session.Session)
|
||||||
ui := state.Get("ui").(packersdk.Ui)
|
ui := state.Get("ui").(packersdk.Ui)
|
||||||
|
|
||||||
|
if s.AMISkipCreateImage {
|
||||||
|
ui.Say("Skipping AMI create tags...")
|
||||||
|
return multistep.ActionContinue
|
||||||
|
}
|
||||||
|
|
||||||
amis := state.Get("amis").(map[string]string)
|
amis := state.Get("amis").(map[string]string)
|
||||||
|
|
||||||
if len(s.Tags) == 0 && len(s.SnapshotTags) == 0 {
|
if len(s.Tags) == 0 && len(s.SnapshotTags) == 0 {
|
||||||
|
|
|
@ -14,6 +14,8 @@ import (
|
||||||
)
|
)
|
||||||
|
|
||||||
type StepModifyAMIAttributes struct {
|
type StepModifyAMIAttributes struct {
|
||||||
|
AMISkipCreateImage bool
|
||||||
|
|
||||||
Users []string
|
Users []string
|
||||||
Groups []string
|
Groups []string
|
||||||
SnapshotUsers []string
|
SnapshotUsers []string
|
||||||
|
@ -29,6 +31,12 @@ func (s *StepModifyAMIAttributes) Run(ctx context.Context, state multistep.State
|
||||||
ec2conn := state.Get("ec2").(*ec2.EC2)
|
ec2conn := state.Get("ec2").(*ec2.EC2)
|
||||||
session := state.Get("awsSession").(*session.Session)
|
session := state.Get("awsSession").(*session.Session)
|
||||||
ui := state.Get("ui").(packersdk.Ui)
|
ui := state.Get("ui").(packersdk.Ui)
|
||||||
|
|
||||||
|
if s.AMISkipCreateImage {
|
||||||
|
ui.Say("Skipping AMI modify attributes...")
|
||||||
|
return multistep.ActionContinue
|
||||||
|
}
|
||||||
|
|
||||||
amis := state.Get("amis").(map[string]string)
|
amis := state.Get("amis").(map[string]string)
|
||||||
snapshots := state.Get("snapshots").(map[string][]string)
|
snapshots := state.Get("snapshots").(map[string][]string)
|
||||||
|
|
||||||
|
|
|
@ -34,6 +34,9 @@ type Config struct {
|
||||||
awscommon.AccessConfig `mapstructure:",squash"`
|
awscommon.AccessConfig `mapstructure:",squash"`
|
||||||
awscommon.AMIConfig `mapstructure:",squash"`
|
awscommon.AMIConfig `mapstructure:",squash"`
|
||||||
awscommon.RunConfig `mapstructure:",squash"`
|
awscommon.RunConfig `mapstructure:",squash"`
|
||||||
|
// If true, Packer will not create the AMI. Useful for setting to `true`
|
||||||
|
// during a build test stage. Default `false`.
|
||||||
|
AMISkipCreateImage bool `mapstructure:"skip_create_ami" required:"false"`
|
||||||
// Add one or more block device mappings to the AMI. These will be attached
|
// Add one or more block device mappings to the AMI. These will be attached
|
||||||
// when booting a new instance from your AMI. To add a block device during
|
// when booting a new instance from your AMI. To add a block device during
|
||||||
// the Packer build see `launch_block_device_mappings` below. Your options
|
// the Packer build see `launch_block_device_mappings` below. Your options
|
||||||
|
@ -319,6 +322,7 @@ func (b *Builder) Run(ctx context.Context, ui packersdk.Ui, hook packersdk.Hook)
|
||||||
Regions: b.config.AMIRegions,
|
Regions: b.config.AMIRegions,
|
||||||
},
|
},
|
||||||
&stepCreateAMI{
|
&stepCreateAMI{
|
||||||
|
AMISkipCreateImage: b.config.AMISkipCreateImage,
|
||||||
AMISkipBuildRegion: b.config.AMISkipBuildRegion,
|
AMISkipBuildRegion: b.config.AMISkipBuildRegion,
|
||||||
PollingConfig: b.config.PollingConfig,
|
PollingConfig: b.config.PollingConfig,
|
||||||
},
|
},
|
||||||
|
@ -330,22 +334,25 @@ func (b *Builder) Run(ctx context.Context, ui packersdk.Ui, hook packersdk.Hook)
|
||||||
EncryptBootVolume: b.config.AMIEncryptBootVolume,
|
EncryptBootVolume: b.config.AMIEncryptBootVolume,
|
||||||
Name: b.config.AMIName,
|
Name: b.config.AMIName,
|
||||||
OriginalRegion: *ec2conn.Config.Region,
|
OriginalRegion: *ec2conn.Config.Region,
|
||||||
|
AMISkipCreateImage: b.config.AMISkipCreateImage,
|
||||||
AMISkipBuildRegion: b.config.AMISkipBuildRegion,
|
AMISkipBuildRegion: b.config.AMISkipBuildRegion,
|
||||||
},
|
},
|
||||||
&awscommon.StepModifyAMIAttributes{
|
&awscommon.StepModifyAMIAttributes{
|
||||||
Description: b.config.AMIDescription,
|
AMISkipCreateImage: b.config.AMISkipCreateImage,
|
||||||
Users: b.config.AMIUsers,
|
Description: b.config.AMIDescription,
|
||||||
Groups: b.config.AMIGroups,
|
Users: b.config.AMIUsers,
|
||||||
ProductCodes: b.config.AMIProductCodes,
|
Groups: b.config.AMIGroups,
|
||||||
SnapshotUsers: b.config.SnapshotUsers,
|
ProductCodes: b.config.AMIProductCodes,
|
||||||
SnapshotGroups: b.config.SnapshotGroups,
|
SnapshotUsers: b.config.SnapshotUsers,
|
||||||
Ctx: b.config.ctx,
|
SnapshotGroups: b.config.SnapshotGroups,
|
||||||
GeneratedData: generatedData,
|
Ctx: b.config.ctx,
|
||||||
|
GeneratedData: generatedData,
|
||||||
},
|
},
|
||||||
&awscommon.StepCreateTags{
|
&awscommon.StepCreateTags{
|
||||||
Tags: b.config.AMITags,
|
AMISkipCreateImage: b.config.AMISkipCreateImage,
|
||||||
SnapshotTags: b.config.SnapshotTags,
|
Tags: b.config.AMITags,
|
||||||
Ctx: b.config.ctx,
|
SnapshotTags: b.config.SnapshotTags,
|
||||||
|
Ctx: b.config.ctx,
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -142,6 +142,7 @@ type FlatConfig struct {
|
||||||
SSHInterface *string `mapstructure:"ssh_interface" cty:"ssh_interface" hcl:"ssh_interface"`
|
SSHInterface *string `mapstructure:"ssh_interface" cty:"ssh_interface" hcl:"ssh_interface"`
|
||||||
PauseBeforeSSM *string `mapstructure:"pause_before_ssm" cty:"pause_before_ssm" hcl:"pause_before_ssm"`
|
PauseBeforeSSM *string `mapstructure:"pause_before_ssm" cty:"pause_before_ssm" hcl:"pause_before_ssm"`
|
||||||
SessionManagerPort *int `mapstructure:"session_manager_port" cty:"session_manager_port" hcl:"session_manager_port"`
|
SessionManagerPort *int `mapstructure:"session_manager_port" cty:"session_manager_port" hcl:"session_manager_port"`
|
||||||
|
AMISkipCreateImage *bool `mapstructure:"skip_create_ami" required:"false" cty:"skip_create_ami" hcl:"skip_create_ami"`
|
||||||
AMIMappings []common.FlatBlockDevice `mapstructure:"ami_block_device_mappings" required:"false" cty:"ami_block_device_mappings" hcl:"ami_block_device_mappings"`
|
AMIMappings []common.FlatBlockDevice `mapstructure:"ami_block_device_mappings" required:"false" cty:"ami_block_device_mappings" hcl:"ami_block_device_mappings"`
|
||||||
LaunchMappings []common.FlatBlockDevice `mapstructure:"launch_block_device_mappings" required:"false" cty:"launch_block_device_mappings" hcl:"launch_block_device_mappings"`
|
LaunchMappings []common.FlatBlockDevice `mapstructure:"launch_block_device_mappings" required:"false" cty:"launch_block_device_mappings" hcl:"launch_block_device_mappings"`
|
||||||
VolumeRunTags map[string]string `mapstructure:"run_volume_tags" cty:"run_volume_tags" hcl:"run_volume_tags"`
|
VolumeRunTags map[string]string `mapstructure:"run_volume_tags" cty:"run_volume_tags" hcl:"run_volume_tags"`
|
||||||
|
@ -291,6 +292,7 @@ func (*FlatConfig) HCL2Spec() map[string]hcldec.Spec {
|
||||||
"ssh_interface": &hcldec.AttrSpec{Name: "ssh_interface", Type: cty.String, Required: false},
|
"ssh_interface": &hcldec.AttrSpec{Name: "ssh_interface", Type: cty.String, Required: false},
|
||||||
"pause_before_ssm": &hcldec.AttrSpec{Name: "pause_before_ssm", Type: cty.String, Required: false},
|
"pause_before_ssm": &hcldec.AttrSpec{Name: "pause_before_ssm", Type: cty.String, Required: false},
|
||||||
"session_manager_port": &hcldec.AttrSpec{Name: "session_manager_port", Type: cty.Number, Required: false},
|
"session_manager_port": &hcldec.AttrSpec{Name: "session_manager_port", Type: cty.Number, Required: false},
|
||||||
|
"skip_create_ami": &hcldec.AttrSpec{Name: "skip_create_ami", Type: cty.Bool, Required: false},
|
||||||
"ami_block_device_mappings": &hcldec.BlockListSpec{TypeName: "ami_block_device_mappings", Nested: hcldec.ObjectSpec((*common.FlatBlockDevice)(nil).HCL2Spec())},
|
"ami_block_device_mappings": &hcldec.BlockListSpec{TypeName: "ami_block_device_mappings", Nested: hcldec.ObjectSpec((*common.FlatBlockDevice)(nil).HCL2Spec())},
|
||||||
"launch_block_device_mappings": &hcldec.BlockListSpec{TypeName: "launch_block_device_mappings", Nested: hcldec.ObjectSpec((*common.FlatBlockDevice)(nil).HCL2Spec())},
|
"launch_block_device_mappings": &hcldec.BlockListSpec{TypeName: "launch_block_device_mappings", Nested: hcldec.ObjectSpec((*common.FlatBlockDevice)(nil).HCL2Spec())},
|
||||||
"run_volume_tags": &hcldec.AttrSpec{Name: "run_volume_tags", Type: cty.Map(cty.String), Required: false},
|
"run_volume_tags": &hcldec.AttrSpec{Name: "run_volume_tags", Type: cty.Map(cty.String), Required: false},
|
||||||
|
|
|
@ -19,6 +19,7 @@ import (
|
||||||
type stepCreateAMI struct {
|
type stepCreateAMI struct {
|
||||||
PollingConfig *awscommon.AWSPollingConfig
|
PollingConfig *awscommon.AWSPollingConfig
|
||||||
image *ec2.Image
|
image *ec2.Image
|
||||||
|
AMISkipCreateImage bool
|
||||||
AMISkipBuildRegion bool
|
AMISkipBuildRegion bool
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -28,6 +29,11 @@ func (s *stepCreateAMI) Run(ctx context.Context, state multistep.StateBag) multi
|
||||||
instance := state.Get("instance").(*ec2.Instance)
|
instance := state.Get("instance").(*ec2.Instance)
|
||||||
ui := state.Get("ui").(packersdk.Ui)
|
ui := state.Get("ui").(packersdk.Ui)
|
||||||
|
|
||||||
|
if s.AMISkipCreateImage {
|
||||||
|
ui.Say("Skipping AMI creation...")
|
||||||
|
return multistep.ActionContinue
|
||||||
|
}
|
||||||
|
|
||||||
// Create the image
|
// Create the image
|
||||||
amiName := config.AMIName
|
amiName := config.AMIName
|
||||||
state.Put("intermediary_image", false)
|
state.Put("intermediary_image", false)
|
||||||
|
|
|
@ -1,5 +1,8 @@
|
||||||
<!-- Code generated from the comments of the Config struct in builder/amazon/ebs/builder.go; DO NOT EDIT MANUALLY -->
|
<!-- Code generated from the comments of the Config struct in builder/amazon/ebs/builder.go; DO NOT EDIT MANUALLY -->
|
||||||
|
|
||||||
|
- `skip_create_ami` (bool) - If true, Packer will not create the AMI. Useful for setting to `true`
|
||||||
|
during a build test stage. Default `false`.
|
||||||
|
|
||||||
- `ami_block_device_mappings` (awscommon.BlockDevices) - Add one or more block device mappings to the AMI. These will be attached
|
- `ami_block_device_mappings` (awscommon.BlockDevices) - Add one or more block device mappings to the AMI. These will be attached
|
||||||
when booting a new instance from your AMI. To add a block device during
|
when booting a new instance from your AMI. To add a block device during
|
||||||
the Packer build see `launch_block_device_mappings` below. Your options
|
the Packer build see `launch_block_device_mappings` below. Your options
|
||||||
|
|
Loading…
Reference in New Issue