packer-cn/fix/fixer_hyperv_cpu_and_ram_na...

64 lines
1.4 KiB
Go

package fix
import (
"github.com/mitchellh/mapstructure"
)
// FizerHypervCPUandRAM changes `cpu` to `cpus` and `ram_size` to `memory`
type FizerHypervCPUandRAM struct{}
func (FizerHypervCPUandRAM) DeprecatedOptions() map[string][]string {
return map[string][]string{
"MSOpenTech.hyperv": []string{"cpu", "ram_size"},
}
}
func (FizerHypervCPUandRAM) 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 != "hyperv-vmcx" && builderType != "hyperv-iso" {
continue
}
ncpus, ok := builder["cpu"]
if ok {
delete(builder, "cpu")
builder["cpus"] = ncpus
}
memory, ok := builder["ram_size"]
if ok {
delete(builder, "ram_size")
builder["memory"] = memory
}
}
input["builders"] = tpl.Builders
return input, nil
}
func (FizerHypervCPUandRAM) Synopsis() string {
return `Replaces "cpu" with "cpus" and "ram_size" with "memory"` +
`in Hyper-V VMCX builder templates`
}