//go:generate mapstructure-to-hcl2 -type Config package null import ( "fmt" "github.com/hashicorp/packer/common" "github.com/hashicorp/packer/helper/communicator" "github.com/hashicorp/packer/helper/config" "github.com/hashicorp/packer/packer" "github.com/hashicorp/packer/template/interpolate" ) type Config struct { common.PackerConfig `mapstructure:",squash"` CommConfig communicator.Config `mapstructure:",squash"` } func (c *Config) Prepare(raws ...interface{}) ([]string, error) { err := config.Decode(&c, &config.DecodeOpts{ Interpolate: true, InterpolateFilter: &interpolate.RenderFilter{}, }, raws...) if err != nil { return nil, err } var errs *packer.MultiError if es := c.CommConfig.Prepare(nil); len(es) > 0 { errs = packer.MultiErrorAppend(errs, es...) } if c.CommConfig.Type != "none" { if c.CommConfig.Host() == "" { errs = packer.MultiErrorAppend(errs, fmt.Errorf("a Host must be specified, please reference your communicator documentation")) } if c.CommConfig.User() == "" { errs = packer.MultiErrorAppend(errs, fmt.Errorf("a Username must be specified, please reference your communicator documentation")) } if !c.CommConfig.SSHAgentAuth && c.CommConfig.Password() == "" && c.CommConfig.SSHPrivateKeyFile == "" { errs = packer.MultiErrorAppend(errs, fmt.Errorf("one authentication method must be specified, please reference your communicator documentation")) } if (c.CommConfig.SSHAgentAuth && (c.CommConfig.SSHPassword != "" || c.CommConfig.SSHPrivateKeyFile != "")) || (c.CommConfig.SSHPassword != "" && c.CommConfig.SSHPrivateKeyFile != "") { errs = packer.MultiErrorAppend(errs, fmt.Errorf("only one of ssh_agent_auth, ssh_password, and ssh_private_key_file must be specified")) } } if errs != nil && len(errs.Errors) > 0 { return nil, errs } return nil, nil }