2013-12-25 13:13:32 -05:00
|
|
|
package fix
|
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/mitchellh/mapstructure"
|
|
|
|
)
|
|
|
|
|
2020-05-28 17:37:29 -04:00
|
|
|
// FixerVMwareRename changes "vmware" builders to "vmware-iso"
|
2013-12-25 13:13:32 -05:00
|
|
|
type FixerVMwareRename struct{}
|
|
|
|
|
2020-10-09 20:01:55 -04:00
|
|
|
func (FixerVMwareRename) DeprecatedOptions() map[string][]string {
|
|
|
|
return map[string][]string{}
|
2020-05-28 17:37:29 -04:00
|
|
|
}
|
|
|
|
|
2013-12-25 13:13:32 -05:00
|
|
|
func (FixerVMwareRename) Fix(input map[string]interface{}) (map[string]interface{}, error) {
|
|
|
|
// The type we'll decode into; we only care about builders
|
|
|
|
type template struct {
|
|
|
|
Builders []map[string]interface{}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Decode the input into our structure, if we can
|
|
|
|
var tpl template
|
|
|
|
if err := mapstructure.Decode(input, &tpl); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, builder := range tpl.Builders {
|
|
|
|
builderTypeRaw, ok := builder["type"]
|
|
|
|
if !ok {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
|
|
|
|
builderType, ok := builderTypeRaw.(string)
|
|
|
|
if !ok {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
|
|
|
|
if builderType != "vmware" {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
|
|
|
|
builder["type"] = "vmware-iso"
|
|
|
|
}
|
|
|
|
|
|
|
|
input["builders"] = tpl.Builders
|
|
|
|
return input, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (FixerVMwareRename) Synopsis() string {
|
|
|
|
return `Updates "vmware" builders to "vmware-iso"`
|
|
|
|
}
|