add skip_image_validation arg to use an expired image as the soure image
Signed-off-by: haoshuwei <haoshuwei24@gmail.com>
This commit is contained in:
parent
c31bbcf4cf
commit
37dc411f30
|
@ -26,6 +26,9 @@ type AlicloudAccessConfig struct {
|
||||||
// The region validation can be skipped if this value is true, the default
|
// The region validation can be skipped if this value is true, the default
|
||||||
// value is false.
|
// value is false.
|
||||||
AlicloudSkipValidation bool `mapstructure:"skip_region_validation" required:"false"`
|
AlicloudSkipValidation bool `mapstructure:"skip_region_validation" required:"false"`
|
||||||
|
// The image validation can be skipped if this value is true, the default
|
||||||
|
// value is false.
|
||||||
|
AlicloudSkipImageValidation bool `mapstructure:"skip_image_validation" required:"false"`
|
||||||
// STS access token, can be set through template or by exporting as
|
// STS access token, can be set through template or by exporting as
|
||||||
// environment variable such as `export SECURITY_TOKEN=value`.
|
// environment variable such as `export SECURITY_TOKEN=value`.
|
||||||
SecurityToken string `mapstructure:"security_token" required:"false"`
|
SecurityToken string `mapstructure:"security_token" required:"false"`
|
||||||
|
|
|
@ -54,6 +54,7 @@ type FlatConfig struct {
|
||||||
AlicloudSecretKey *string `mapstructure:"secret_key" required:"true" cty:"secret_key"`
|
AlicloudSecretKey *string `mapstructure:"secret_key" required:"true" cty:"secret_key"`
|
||||||
AlicloudRegion *string `mapstructure:"region" required:"true" cty:"region"`
|
AlicloudRegion *string `mapstructure:"region" required:"true" cty:"region"`
|
||||||
AlicloudSkipValidation *bool `mapstructure:"skip_region_validation" required:"false" cty:"skip_region_validation"`
|
AlicloudSkipValidation *bool `mapstructure:"skip_region_validation" required:"false" cty:"skip_region_validation"`
|
||||||
|
AlicloudSkipImageValidation *bool `mapstructure:"skip_image_validation" required:"false" cty:"skip_image_validation"`
|
||||||
SecurityToken *string `mapstructure:"security_token" required:"false" cty:"security_token"`
|
SecurityToken *string `mapstructure:"security_token" required:"false" cty:"security_token"`
|
||||||
AlicloudImageName *string `mapstructure:"image_name" required:"true" cty:"image_name"`
|
AlicloudImageName *string `mapstructure:"image_name" required:"true" cty:"image_name"`
|
||||||
AlicloudImageVersion *string `mapstructure:"image_version" required:"false" cty:"image_version"`
|
AlicloudImageVersion *string `mapstructure:"image_version" required:"false" cty:"image_version"`
|
||||||
|
@ -154,6 +155,7 @@ func (*FlatConfig) HCL2Spec() map[string]hcldec.Spec {
|
||||||
"secret_key": &hcldec.AttrSpec{Name: "secret_key", Type: cty.String, Required: false},
|
"secret_key": &hcldec.AttrSpec{Name: "secret_key", Type: cty.String, Required: false},
|
||||||
"region": &hcldec.AttrSpec{Name: "region", Type: cty.String, Required: false},
|
"region": &hcldec.AttrSpec{Name: "region", Type: cty.String, Required: false},
|
||||||
"skip_region_validation": &hcldec.AttrSpec{Name: "skip_region_validation", Type: cty.Bool, Required: false},
|
"skip_region_validation": &hcldec.AttrSpec{Name: "skip_region_validation", Type: cty.Bool, Required: false},
|
||||||
|
"skip_image_validation": &hcldec.AttrSpec{Name: "skip_image_validation", Type: cty.Bool, Required: false},
|
||||||
"security_token": &hcldec.AttrSpec{Name: "security_token", Type: cty.String, Required: false},
|
"security_token": &hcldec.AttrSpec{Name: "security_token", Type: cty.String, Required: false},
|
||||||
"image_name": &hcldec.AttrSpec{Name: "image_name", Type: cty.String, Required: false},
|
"image_name": &hcldec.AttrSpec{Name: "image_name", Type: cty.String, Required: false},
|
||||||
"image_version": &hcldec.AttrSpec{Name: "image_version", Type: cty.String, Required: false},
|
"image_version": &hcldec.AttrSpec{Name: "image_version", Type: cty.String, Required: false},
|
||||||
|
|
|
@ -21,6 +21,9 @@ func (s *stepCheckAlicloudSourceImage) Run(ctx context.Context, state multistep.
|
||||||
describeImagesRequest := ecs.CreateDescribeImagesRequest()
|
describeImagesRequest := ecs.CreateDescribeImagesRequest()
|
||||||
describeImagesRequest.RegionId = config.AlicloudRegion
|
describeImagesRequest.RegionId = config.AlicloudRegion
|
||||||
describeImagesRequest.ImageId = config.AlicloudSourceImage
|
describeImagesRequest.ImageId = config.AlicloudSourceImage
|
||||||
|
if config.AlicloudSkipImageValidation {
|
||||||
|
describeImagesRequest.ShowExpired = "true"
|
||||||
|
}
|
||||||
imagesResponse, err := client.DescribeImages(describeImagesRequest)
|
imagesResponse, err := client.DescribeImages(describeImagesRequest)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return halt(state, err, "Error querying alicloud image")
|
return halt(state, err, "Error querying alicloud image")
|
||||||
|
|
|
@ -21,6 +21,7 @@ type FlatConfig struct {
|
||||||
AlicloudSecretKey *string `mapstructure:"secret_key" required:"true" cty:"secret_key"`
|
AlicloudSecretKey *string `mapstructure:"secret_key" required:"true" cty:"secret_key"`
|
||||||
AlicloudRegion *string `mapstructure:"region" required:"true" cty:"region"`
|
AlicloudRegion *string `mapstructure:"region" required:"true" cty:"region"`
|
||||||
AlicloudSkipValidation *bool `mapstructure:"skip_region_validation" required:"false" cty:"skip_region_validation"`
|
AlicloudSkipValidation *bool `mapstructure:"skip_region_validation" required:"false" cty:"skip_region_validation"`
|
||||||
|
AlicloudSkipImageValidation *bool `mapstructure:"skip_image_validation" required:"false" cty:"skip_image_validation"`
|
||||||
SecurityToken *string `mapstructure:"security_token" required:"false" cty:"security_token"`
|
SecurityToken *string `mapstructure:"security_token" required:"false" cty:"security_token"`
|
||||||
AlicloudImageName *string `mapstructure:"image_name" required:"true" cty:"image_name"`
|
AlicloudImageName *string `mapstructure:"image_name" required:"true" cty:"image_name"`
|
||||||
AlicloudImageVersion *string `mapstructure:"image_version" required:"false" cty:"image_version"`
|
AlicloudImageVersion *string `mapstructure:"image_version" required:"false" cty:"image_version"`
|
||||||
|
@ -129,6 +130,7 @@ func (*FlatConfig) HCL2Spec() map[string]hcldec.Spec {
|
||||||
"secret_key": &hcldec.AttrSpec{Name: "secret_key", Type: cty.String, Required: false},
|
"secret_key": &hcldec.AttrSpec{Name: "secret_key", Type: cty.String, Required: false},
|
||||||
"region": &hcldec.AttrSpec{Name: "region", Type: cty.String, Required: false},
|
"region": &hcldec.AttrSpec{Name: "region", Type: cty.String, Required: false},
|
||||||
"skip_region_validation": &hcldec.AttrSpec{Name: "skip_region_validation", Type: cty.Bool, Required: false},
|
"skip_region_validation": &hcldec.AttrSpec{Name: "skip_region_validation", Type: cty.Bool, Required: false},
|
||||||
|
"skip_image_validation": &hcldec.AttrSpec{Name: "skip_image_validation", Type: cty.Bool, Required: false},
|
||||||
"security_token": &hcldec.AttrSpec{Name: "security_token", Type: cty.String, Required: false},
|
"security_token": &hcldec.AttrSpec{Name: "security_token", Type: cty.String, Required: false},
|
||||||
"image_name": &hcldec.AttrSpec{Name: "image_name", Type: cty.String, Required: false},
|
"image_name": &hcldec.AttrSpec{Name: "image_name", Type: cty.String, Required: false},
|
||||||
"image_version": &hcldec.AttrSpec{Name: "image_version", Type: cty.String, Required: false},
|
"image_version": &hcldec.AttrSpec{Name: "image_version", Type: cty.String, Required: false},
|
||||||
|
|
|
@ -3,6 +3,9 @@
|
||||||
- `skip_region_validation` (bool) - The region validation can be skipped if this value is true, the default
|
- `skip_region_validation` (bool) - The region validation can be skipped if this value is true, the default
|
||||||
value is false.
|
value is false.
|
||||||
|
|
||||||
|
- `skip_image_validation` (bool) - The image validation can be skipped if this value is true, the default
|
||||||
|
value is false.
|
||||||
|
|
||||||
- `security_token` (string) - STS access token, can be set through template or by exporting as
|
- `security_token` (string) - STS access token, can be set through template or by exporting as
|
||||||
environment variable such as `export SECURITY_TOKEN=value`.
|
environment variable such as `export SECURITY_TOKEN=value`.
|
||||||
|
|
Loading…
Reference in New Issue