reorder terms and define an intermediate variable
(cherry picked from commit d0251f9741cf4d7659ecb4496d103f99a0e4184a) (cherry picked from commit dab1b903ad88af0e3e40168634c1eb227078b4eb)
This commit is contained in:
parent
5b2e447d09
commit
5eb497a2c5
|
@ -26,6 +26,9 @@ type Config struct {
|
||||||
// Additional arguments to pass when executing Puppet
|
// Additional arguments to pass when executing Puppet
|
||||||
ExtraArguments []string `mapstructure:"extra_arguments"`
|
ExtraArguments []string `mapstructure:"extra_arguments"`
|
||||||
|
|
||||||
|
// The Guest OS Type (unix or windows)
|
||||||
|
GuestOSType string `mapstructure:"guest_os_type"`
|
||||||
|
|
||||||
// Additional facts to set when executing Puppet
|
// Additional facts to set when executing Puppet
|
||||||
Facter map[string]string
|
Facter map[string]string
|
||||||
|
|
||||||
|
@ -82,10 +85,11 @@ var guestOSTypeConfigs = map[string]guestOSTypeConfig{
|
||||||
`{{if ne .FacterVars ""}}{{.FacterVars}} {{end}}` +
|
`{{if ne .FacterVars ""}}{{.FacterVars}} {{end}}` +
|
||||||
"{{if .Sudo}}sudo -E {{end}}" +
|
"{{if .Sudo}}sudo -E {{end}}" +
|
||||||
`{{if ne .PuppetBinDir ""}}{{.PuppetBinDir}}/{{end}}` +
|
`{{if ne .PuppetBinDir ""}}{{.PuppetBinDir}}/{{end}}` +
|
||||||
`puppet apply --verbose --modulepath='{{.ModulePath}}' ` +
|
"puppet apply --detailed-exitcodes " +
|
||||||
|
"{{if .Debug}}--debug {{end}}" +
|
||||||
|
`{{if ne .ModulePath ""}}--modulepath='{{.ModulePath}}' {{end}}` +
|
||||||
`{{if ne .HieraConfigPath ""}}--hiera_config='{{.HieraConfigPath}}' {{end}}` +
|
`{{if ne .HieraConfigPath ""}}--hiera_config='{{.HieraConfigPath}}' {{end}}` +
|
||||||
`{{if ne .ManifestDir ""}}--manifestdir='{{.ManifestDir}}' {{end}}` +
|
`{{if ne .ManifestDir ""}}--manifestdir='{{.ManifestDir}}' {{end}}` +
|
||||||
"--detailed-exitcodes " +
|
|
||||||
`{{if ne .ExtraArguments ""}}{{.ExtraArguments}} {{end}}` +
|
`{{if ne .ExtraArguments ""}}{{.ExtraArguments}} {{end}}` +
|
||||||
"{{.ManifestFile}}",
|
"{{.ManifestFile}}",
|
||||||
facterVarsFmt: "FACTER_%s='%s'",
|
facterVarsFmt: "FACTER_%s='%s'",
|
||||||
|
@ -97,10 +101,11 @@ var guestOSTypeConfigs = map[string]guestOSTypeConfig{
|
||||||
executeCommand: "cd {{.WorkingDir}} && " +
|
executeCommand: "cd {{.WorkingDir}} && " +
|
||||||
"{{.FacterVars}} && " +
|
"{{.FacterVars}} && " +
|
||||||
`{{if ne .PuppetBinDir ""}}{{.PuppetBinDir}}/{{end}}` +
|
`{{if ne .PuppetBinDir ""}}{{.PuppetBinDir}}/{{end}}` +
|
||||||
`puppet apply --verbose --modulepath='{{.ModulePath}}' ` +
|
"puppet apply --detailed-exitcodes " +
|
||||||
|
"{{if .Debug}}--debug {{end}}" +
|
||||||
|
`{{if ne .ModulePath ""}}--modulepath='{{.ModulePath}}' {{end}}` +
|
||||||
`{{if ne .HieraConfigPath ""}}--hiera_config='{{.HieraConfigPath}}' {{end}}` +
|
`{{if ne .HieraConfigPath ""}}--hiera_config='{{.HieraConfigPath}}' {{end}}` +
|
||||||
`{{if ne .ManifestDir ""}}--manifestdir='{{.ManifestDir}}' {{end}}` +
|
`{{if ne .ManifestDir ""}}--manifestdir='{{.ManifestDir}}' {{end}}` +
|
||||||
"--detailed-exitcodes " +
|
|
||||||
`{{if ne .ExtraArguments ""}}{{.ExtraArguments}} {{end}}` +
|
`{{if ne .ExtraArguments ""}}{{.ExtraArguments}} {{end}}` +
|
||||||
"{{.ManifestFile}}",
|
"{{.ManifestFile}}",
|
||||||
facterVarsFmt: `SET "FACTER_%s=%s"`,
|
facterVarsFmt: `SET "FACTER_%s=%s"`,
|
||||||
|
@ -124,6 +129,8 @@ type ExecuteTemplate struct {
|
||||||
ManifestDir string
|
ManifestDir string
|
||||||
PuppetBinDir string
|
PuppetBinDir string
|
||||||
Sudo bool
|
Sudo bool
|
||||||
|
WorkingDir string
|
||||||
|
Debug bool
|
||||||
ExtraArguments string
|
ExtraArguments string
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -134,6 +141,7 @@ func (p *Provisioner) Prepare(raws ...interface{}) error {
|
||||||
InterpolateFilter: &interpolate.RenderFilter{
|
InterpolateFilter: &interpolate.RenderFilter{
|
||||||
Exclude: []string{
|
Exclude: []string{
|
||||||
"execute_command",
|
"execute_command",
|
||||||
|
"extra_arguments",
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
}, raws...)
|
}, raws...)
|
||||||
|
@ -286,8 +294,7 @@ func (p *Provisioner) Provision(ui packer.Ui, comm packer.Communicator) error {
|
||||||
facterVars = append(facterVars, fmt.Sprintf(p.guestOSTypeConfig.facterVarsFmt, k, v))
|
facterVars = append(facterVars, fmt.Sprintf(p.guestOSTypeConfig.facterVarsFmt, k, v))
|
||||||
}
|
}
|
||||||
|
|
||||||
// Execute Puppet
|
data := ExecuteTemplate{
|
||||||
p.config.ctx.Data = &ExecuteTemplate{
|
|
||||||
FacterVars: strings.Join(facterVars, p.guestOSTypeConfig.facterVarsJoiner),
|
FacterVars: strings.Join(facterVars, p.guestOSTypeConfig.facterVarsJoiner),
|
||||||
HieraConfigPath: remoteHieraConfigPath,
|
HieraConfigPath: remoteHieraConfigPath,
|
||||||
ManifestDir: remoteManifestDir,
|
ManifestDir: remoteManifestDir,
|
||||||
|
@ -296,8 +303,16 @@ func (p *Provisioner) Provision(ui packer.Ui, comm packer.Communicator) error {
|
||||||
PuppetBinDir: p.config.PuppetBinDir,
|
PuppetBinDir: p.config.PuppetBinDir,
|
||||||
Sudo: !p.config.PreventSudo,
|
Sudo: !p.config.PreventSudo,
|
||||||
WorkingDir: p.config.WorkingDir,
|
WorkingDir: p.config.WorkingDir,
|
||||||
ExtraArguments: strings.Join(p.config.ExtraArguments, " "),
|
ExtraArguments: "",
|
||||||
}
|
}
|
||||||
|
|
||||||
|
p.config.ctx.Data = &data
|
||||||
|
_ExtraArguments, err := interpolate.Render(strings.Join(p.config.ExtraArguments, " "), &p.config.ctx)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
data.ExtraArguments = _ExtraArguments
|
||||||
|
|
||||||
command, err := interpolate.Render(p.config.ExecuteCommand, &p.config.ctx)
|
command, err := interpolate.Render(p.config.ExecuteCommand, &p.config.ctx)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
|
|
|
@ -59,6 +59,9 @@ type Config struct {
|
||||||
// The command used to execute Puppet.
|
// The command used to execute Puppet.
|
||||||
ExecuteCommand string `mapstructure:"execute_command"`
|
ExecuteCommand string `mapstructure:"execute_command"`
|
||||||
|
|
||||||
|
// Additional argument to pass when executing Puppet.
|
||||||
|
ExtraArguments []string `mapstructure:"extra_arguments"`
|
||||||
|
|
||||||
// The Guest OS Type (unix or windows)
|
// The Guest OS Type (unix or windows)
|
||||||
GuestOSType string `mapstructure:"guest_os_type"`
|
GuestOSType string `mapstructure:"guest_os_type"`
|
||||||
|
|
||||||
|
@ -77,9 +80,6 @@ type Config struct {
|
||||||
// The hostname of the Puppet server.
|
// The hostname of the Puppet server.
|
||||||
PuppetServer string `mapstructure:"puppet_server"`
|
PuppetServer string `mapstructure:"puppet_server"`
|
||||||
|
|
||||||
// Additional options to be passed to `puppet agent`.
|
|
||||||
Options string `mapstructure:"options"`
|
|
||||||
|
|
||||||
// If true, `sudo` will NOT be used to execute Puppet.
|
// If true, `sudo` will NOT be used to execute Puppet.
|
||||||
PreventSudo bool `mapstructure:"prevent_sudo"`
|
PreventSudo bool `mapstructure:"prevent_sudo"`
|
||||||
|
|
||||||
|
@ -95,6 +95,50 @@ type Config struct {
|
||||||
IgnoreExitCodes bool `mapstructure:"ignore_exit_codes"`
|
IgnoreExitCodes bool `mapstructure:"ignore_exit_codes"`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type guestOSTypeConfig struct {
|
||||||
|
tempDir string
|
||||||
|
stagingDir string
|
||||||
|
executeCommand string
|
||||||
|
facterVarsFmt string
|
||||||
|
facterVarsJoiner string
|
||||||
|
}
|
||||||
|
|
||||||
|
var guestOSTypeConfigs = map[string]guestOSTypeConfig{
|
||||||
|
provisioner.UnixOSType: {
|
||||||
|
tempDir: "/tmp",
|
||||||
|
stagingDir: "/tmp/packer-puppet-server",
|
||||||
|
executeCommand: "cd {{.WorkingDir}} && " +
|
||||||
|
"{{.FacterVars}}" +
|
||||||
|
"{{if .Sudo}}sudo -E {{end}}" +
|
||||||
|
`{{if ne .PuppetBinDir ""}}{{.PuppetBinDir}}/{{end}}` +
|
||||||
|
"puppet agent --onetime --no-daemonize --detailed-exitcodes " +
|
||||||
|
"{{if .Debug}}--debug {{end}}" +
|
||||||
|
`{{if ne .PuppetServer ""}}--server='{{.PuppetServer}}' {{end}}` +
|
||||||
|
`{{if ne .PuppetNode ""}}--certname={{.PuppetNode}} {{end}}` +
|
||||||
|
`{{if ne .ClientCertPath ""}}--certdir='{{.ClientCertPath}}' {{end}}` +
|
||||||
|
`{{if ne .ClientPrivateKeyPath ""}}--privatekeydir='{{.ClientPrivateKeyPath}}' {{end}}` +
|
||||||
|
`{{if ne .ExtraArguments ""}}{{.ExtraArguments}} {{end}}`,
|
||||||
|
facterVarsFmt: "FACTER_%s='%s'",
|
||||||
|
facterVarsJoiner: " ",
|
||||||
|
},
|
||||||
|
provisioner.WindowsOSType: {
|
||||||
|
tempDir: path.filepath.ToSlash(os.Getenv("TEMP")),
|
||||||
|
stagingDir: path.filepath.ToSlash(os.Getenv("SYSTEMROOT")) + "/Temp/packer-puppet-server",
|
||||||
|
executeCommand: "cd {{.WorkingDir}} && " +
|
||||||
|
"{{.FacterVars}} " +
|
||||||
|
`{{if ne .PuppetBinDir ""}}{{.PuppetBinDir}}/{{end}}` +
|
||||||
|
"puppet agent --onetime --no-daemonize --detailed-exitcodes " +
|
||||||
|
"{{if .Debug}}--debug {{end}}" +
|
||||||
|
`{{if ne .PuppetServer ""}}--server='{{.PuppetServer}}' {{end}}` +
|
||||||
|
`{{if ne .PuppetNode ""}}--certname={{.PuppetNode}} {{end}}` +
|
||||||
|
`{{if ne .ClientCertPath ""}}--certdir='{{.ClientCertPath}}' {{end}}` +
|
||||||
|
`{{if ne .ClientPrivateKeyPath ""}}--privatekeydir='{{.ClientPrivateKeyPath}}' {{end}}` +
|
||||||
|
`{{if ne .ExtraArguments ""}}{{.ExtraArguments}} {{end}}`,
|
||||||
|
facterVarsFmt: `SET "FACTER_%s=%s"`,
|
||||||
|
facterVarsJoiner: " & ",
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
type Provisioner struct {
|
type Provisioner struct {
|
||||||
config Config
|
config Config
|
||||||
guestOSTypeConfig guestOSTypeConfig
|
guestOSTypeConfig guestOSTypeConfig
|
||||||
|
@ -107,7 +151,7 @@ type ExecuteTemplate struct {
|
||||||
ClientPrivateKeyPath string
|
ClientPrivateKeyPath string
|
||||||
PuppetNode string
|
PuppetNode string
|
||||||
PuppetServer string
|
PuppetServer string
|
||||||
Options string
|
ExtraArguments string
|
||||||
PuppetBinDir string
|
PuppetBinDir string
|
||||||
Sudo bool
|
Sudo bool
|
||||||
}
|
}
|
||||||
|
@ -119,6 +163,7 @@ func (p *Provisioner) Prepare(raws ...interface{}) error {
|
||||||
InterpolateFilter: &interpolate.RenderFilter{
|
InterpolateFilter: &interpolate.RenderFilter{
|
||||||
Exclude: []string{
|
Exclude: []string{
|
||||||
"execute_command",
|
"execute_command",
|
||||||
|
"extra_arguments",
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
}, raws...)
|
}, raws...)
|
||||||
|
@ -223,8 +268,7 @@ func (p *Provisioner) Provision(ui packer.Ui, comm packer.Communicator) error {
|
||||||
facterVars = append(facterVars, fmt.Sprintf(p.guestOSTypeConfig.facterVarsFmt, k, v))
|
facterVars = append(facterVars, fmt.Sprintf(p.guestOSTypeConfig.facterVarsFmt, k, v))
|
||||||
}
|
}
|
||||||
|
|
||||||
// Execute Puppet
|
data := ExecuteTemplate{
|
||||||
p.config.ctx.Data = &ExecuteTemplate{
|
|
||||||
FacterVars: strings.Join(facterVars, p.guestOSTypeConfig.facterVarsJoiner),
|
FacterVars: strings.Join(facterVars, p.guestOSTypeConfig.facterVarsJoiner),
|
||||||
ClientCertPath: remoteClientCertPath,
|
ClientCertPath: remoteClientCertPath,
|
||||||
ClientPrivateKeyPath: remoteClientPrivateKeyPath,
|
ClientPrivateKeyPath: remoteClientPrivateKeyPath,
|
||||||
|
@ -233,7 +277,17 @@ func (p *Provisioner) Provision(ui packer.Ui, comm packer.Communicator) error {
|
||||||
Options: p.config.Options,
|
Options: p.config.Options,
|
||||||
PuppetBinDir: p.config.PuppetBinDir,
|
PuppetBinDir: p.config.PuppetBinDir,
|
||||||
Sudo: !p.config.PreventSudo,
|
Sudo: !p.config.PreventSudo,
|
||||||
|
WorkingDir: p.config.WorkingDir,
|
||||||
|
ExtraArguments: "",
|
||||||
}
|
}
|
||||||
|
|
||||||
|
p.config.ctx.Data = &data
|
||||||
|
_ExtraArguments, err := interpolate.Render(strings.Join(p.config.ExtraArguments, " "), &p.config.ctx)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
data.ExtraArguments = _ExtraArguments
|
||||||
|
|
||||||
command, err := interpolate.Render(p.config.ExecuteCommand, &p.config.ctx)
|
command, err := interpolate.Render(p.config.ExecuteCommand, &p.config.ctx)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
|
|
Loading…
Reference in New Issue