Merge branch 'ameir-chef-client-client_key'
This commit is contained in:
commit
a1f1834789
|
@ -37,6 +37,7 @@ type Config struct {
|
||||||
SkipCleanNode bool `mapstructure:"skip_clean_node"`
|
SkipCleanNode bool `mapstructure:"skip_clean_node"`
|
||||||
SkipInstall bool `mapstructure:"skip_install"`
|
SkipInstall bool `mapstructure:"skip_install"`
|
||||||
StagingDir string `mapstructure:"staging_directory"`
|
StagingDir string `mapstructure:"staging_directory"`
|
||||||
|
ClientKey string `mapstructure:"client_key"`
|
||||||
ValidationKeyPath string `mapstructure:"validation_key_path"`
|
ValidationKeyPath string `mapstructure:"validation_key_path"`
|
||||||
ValidationClientName string `mapstructure:"validation_client_name"`
|
ValidationClientName string `mapstructure:"validation_client_name"`
|
||||||
|
|
||||||
|
@ -50,6 +51,7 @@ type Provisioner struct {
|
||||||
type ConfigTemplate struct {
|
type ConfigTemplate struct {
|
||||||
NodeName string
|
NodeName string
|
||||||
ServerUrl string
|
ServerUrl string
|
||||||
|
ClientKey string
|
||||||
ValidationKeyPath string
|
ValidationKeyPath string
|
||||||
ValidationClientName string
|
ValidationClientName string
|
||||||
ChefEnvironment string
|
ChefEnvironment string
|
||||||
|
@ -162,6 +164,10 @@ func (p *Provisioner) Provision(ui packer.Ui, comm packer.Communicator) error {
|
||||||
return fmt.Errorf("Error creating staging directory: %s", err)
|
return fmt.Errorf("Error creating staging directory: %s", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if p.config.ClientKey == "" {
|
||||||
|
p.config.ClientKey = fmt.Sprintf("%s/client.pem", p.config.StagingDir)
|
||||||
|
}
|
||||||
|
|
||||||
if p.config.ValidationKeyPath != "" {
|
if p.config.ValidationKeyPath != "" {
|
||||||
remoteValidationKeyPath = fmt.Sprintf("%s/validation.pem", p.config.StagingDir)
|
remoteValidationKeyPath = fmt.Sprintf("%s/validation.pem", p.config.StagingDir)
|
||||||
if err := p.copyValidationKey(ui, comm, remoteValidationKeyPath); err != nil {
|
if err := p.copyValidationKey(ui, comm, remoteValidationKeyPath); err != nil {
|
||||||
|
@ -170,7 +176,7 @@ func (p *Provisioner) Provision(ui packer.Ui, comm packer.Communicator) error {
|
||||||
}
|
}
|
||||||
|
|
||||||
configPath, err := p.createConfig(
|
configPath, err := p.createConfig(
|
||||||
ui, comm, nodeName, serverUrl, remoteValidationKeyPath, p.config.ValidationClientName, p.config.ChefEnvironment, p.config.SslVerifyMode)
|
ui, comm, nodeName, serverUrl, p.config.ClientKey, remoteValidationKeyPath, p.config.ValidationClientName, p.config.ChefEnvironment, p.config.SslVerifyMode)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return fmt.Errorf("Error creating Chef config file: %s", err)
|
return fmt.Errorf("Error creating Chef config file: %s", err)
|
||||||
}
|
}
|
||||||
|
@ -224,7 +230,7 @@ func (p *Provisioner) uploadDirectory(ui packer.Ui, comm packer.Communicator, ds
|
||||||
return comm.UploadDir(dst, src, nil)
|
return comm.UploadDir(dst, src, nil)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (p *Provisioner) createConfig(ui packer.Ui, comm packer.Communicator, nodeName string, serverUrl string, remoteKeyPath string, validationClientName string, chefEnvironment string, sslVerifyMode string) (string, error) {
|
func (p *Provisioner) createConfig(ui packer.Ui, comm packer.Communicator, nodeName string, serverUrl string, clientKey string, remoteKeyPath string, validationClientName string, chefEnvironment string, sslVerifyMode string) (string, error) {
|
||||||
ui.Message("Creating configuration file 'client.rb'")
|
ui.Message("Creating configuration file 'client.rb'")
|
||||||
|
|
||||||
// Read the template
|
// Read the template
|
||||||
|
@ -248,6 +254,7 @@ func (p *Provisioner) createConfig(ui packer.Ui, comm packer.Communicator, nodeN
|
||||||
ctx.Data = &ConfigTemplate{
|
ctx.Data = &ConfigTemplate{
|
||||||
NodeName: nodeName,
|
NodeName: nodeName,
|
||||||
ServerUrl: serverUrl,
|
ServerUrl: serverUrl,
|
||||||
|
ClientKey: clientKey,
|
||||||
ValidationKeyPath: remoteKeyPath,
|
ValidationKeyPath: remoteKeyPath,
|
||||||
ValidationClientName: validationClientName,
|
ValidationClientName: validationClientName,
|
||||||
ChefEnvironment: chefEnvironment,
|
ChefEnvironment: chefEnvironment,
|
||||||
|
@ -524,6 +531,7 @@ var DefaultConfigTemplate = `
|
||||||
log_level :info
|
log_level :info
|
||||||
log_location STDOUT
|
log_location STDOUT
|
||||||
chef_server_url "{{.ServerUrl}}"
|
chef_server_url "{{.ServerUrl}}"
|
||||||
|
client_key "{{.ClientKey}}"
|
||||||
{{if ne .ValidationClientName ""}}
|
{{if ne .ValidationClientName ""}}
|
||||||
validation_client_name "{{.ValidationClientName}}"
|
validation_client_name "{{.ValidationClientName}}"
|
||||||
{{else}}
|
{{else}}
|
||||||
|
|
|
@ -88,6 +88,9 @@ configuration is actually required.
|
||||||
this folder. If the permissions are not correct, use a shell provisioner
|
this folder. If the permissions are not correct, use a shell provisioner
|
||||||
prior to this to configure it properly.
|
prior to this to configure it properly.
|
||||||
|
|
||||||
|
* `client_key` (string) - Path to client key. If not set, this defaults to a file
|
||||||
|
named client.pem in `staging_directory`.
|
||||||
|
|
||||||
* `validation_client_name` (string) - Name of the validation client. If
|
* `validation_client_name` (string) - Name of the validation client. If
|
||||||
not set, this won't be set in the configuration and the default that Chef
|
not set, this won't be set in the configuration and the default that Chef
|
||||||
uses will be used.
|
uses will be used.
|
||||||
|
|
Loading…
Reference in New Issue