Commit 25af1c8b authored by Rafael Garcia's avatar Rafael Garcia

provisioner/shell: state of the art config decoding

parent 7af60a88
...@@ -7,12 +7,11 @@ import ( ...@@ -7,12 +7,11 @@ import (
"bytes" "bytes"
"errors" "errors"
"fmt" "fmt"
"github.com/mitchellh/mapstructure" "github.com/mitchellh/packer/common"
"github.com/mitchellh/packer/packer" "github.com/mitchellh/packer/packer"
"io/ioutil" "io/ioutil"
"log" "log"
"os" "os"
"sort"
"strings" "strings"
"text/template" "text/template"
) )
...@@ -61,37 +60,13 @@ type ExecuteCommandTemplate struct { ...@@ -61,37 +60,13 @@ type ExecuteCommandTemplate struct {
} }
func (p *Provisioner) Prepare(raws ...interface{}) error { func (p *Provisioner) Prepare(raws ...interface{}) error {
var md mapstructure.Metadata md, err := common.DecodeConfig(&p.config, raws...)
decoderConfig := &mapstructure.DecoderConfig{
Metadata: &md,
Result: &p.config,
}
decoder, err := mapstructure.NewDecoder(decoderConfig)
if err != nil { if err != nil {
return err return err
} }
for _, raw := range raws {
err := decoder.Decode(raw)
if err != nil {
return err
}
}
// Accumulate any errors // Accumulate any errors
errs := make([]error, 0) errs := common.CheckUnusedConfig(md)
// Unused keys are errors
if len(md.Unused) > 0 {
sort.Strings(md.Unused)
for _, unused := range md.Unused {
if unused != "type" && !strings.HasPrefix(unused, "packer_") {
errs = append(
errs, fmt.Errorf("Unknown configuration key: %s", unused))
}
}
}
if p.config.ExecuteCommand == "" { if p.config.ExecuteCommand == "" {
p.config.ExecuteCommand = "chmod +x {{.Path}}; {{.Vars}} {{.Path}}" p.config.ExecuteCommand = "chmod +x {{.Path}}; {{.Vars}} {{.Path}}"
...@@ -118,7 +93,8 @@ func (p *Provisioner) Prepare(raws ...interface{}) error { ...@@ -118,7 +93,8 @@ func (p *Provisioner) Prepare(raws ...interface{}) error {
} }
if p.config.Script != "" && len(p.config.Scripts) > 0 { if p.config.Script != "" && len(p.config.Scripts) > 0 {
errs = append(errs, errors.New("Only one of script or scripts can be specified.")) errs = packer.MultiErrorAppend(errs,
errors.New("Only one of script or scripts can be specified."))
} }
if p.config.Script != "" { if p.config.Script != "" {
...@@ -126,14 +102,17 @@ func (p *Provisioner) Prepare(raws ...interface{}) error { ...@@ -126,14 +102,17 @@ func (p *Provisioner) Prepare(raws ...interface{}) error {
} }
if len(p.config.Scripts) == 0 && p.config.Inline == nil { if len(p.config.Scripts) == 0 && p.config.Inline == nil {
errs = append(errs, errors.New("Either a script file or inline script must be specified.")) errs = packer.MultiErrorAppend(errs,
errors.New("Either a script file or inline script must be specified."))
} else if len(p.config.Scripts) > 0 && p.config.Inline != nil { } else if len(p.config.Scripts) > 0 && p.config.Inline != nil {
errs = append(errs, errors.New("Only a script file or an inline script can be specified, not both.")) errs = packer.MultiErrorAppend(errs,
errors.New("Only a script file or an inline script can be specified, not both."))
} }
for _, path := range p.config.Scripts { for _, path := range p.config.Scripts {
if _, err := os.Stat(path); err != nil { if _, err := os.Stat(path); err != nil {
errs = append(errs, fmt.Errorf("Bad script '%s': %s", path, err)) errs = packer.MultiErrorAppend(errs,
fmt.Errorf("Bad script '%s': %s", path, err))
} }
} }
...@@ -141,14 +120,13 @@ func (p *Provisioner) Prepare(raws ...interface{}) error { ...@@ -141,14 +120,13 @@ func (p *Provisioner) Prepare(raws ...interface{}) error {
for _, kv := range p.config.Vars { for _, kv := range p.config.Vars {
vs := strings.Split(kv, "=") vs := strings.Split(kv, "=")
if len(vs) != 2 || vs[0] == "" { if len(vs) != 2 || vs[0] == "" {
errs = append( errs = packer.MultiErrorAppend(errs,
errs,
fmt.Errorf("Environment variable not in format 'key=value': %s", kv)) fmt.Errorf("Environment variable not in format 'key=value': %s", kv))
} }
} }
if len(errs) > 0 { if errs != nil && len(errs.Errors) > 0 {
return &packer.MultiError{errs} return errs
} }
return nil return nil
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment