package common import ( "fmt" "strings" "github.com/hashicorp/packer/packer" "github.com/hashicorp/packer/template/interpolate" "github.com/mitchellh/multistep" ) type commandTemplate struct { Name string } // This step executes additional VBoxManage commands as specified by the // template. // // Uses: // driver Driver // ui packer.Ui // vmName string // // Produces: type StepVBoxManage struct { Commands [][]string Ctx interpolate.Context } func (s *StepVBoxManage) Run(state multistep.StateBag) multistep.StepAction { driver := state.Get("driver").(Driver) ui := state.Get("ui").(packer.Ui) vmName := state.Get("vmName").(string) if len(s.Commands) > 0 { ui.Say("Executing custom VBoxManage commands...") } s.Ctx.Data = &commandTemplate{ Name: vmName, } for _, originalCommand := range s.Commands { command := make([]string, len(originalCommand)) copy(command, originalCommand) for i, arg := range command { var err error command[i], err = interpolate.Render(arg, &s.Ctx) if err != nil { err := fmt.Errorf("Error preparing vboxmanage command: %s", err) state.Put("error", err) ui.Error(err.Error()) return multistep.ActionHalt } } ui.Message(fmt.Sprintf("Executing: %s", strings.Join(command, " "))) if err := driver.VBoxManage(command...); err != nil { err := fmt.Errorf("Error executing command: %s", err) state.Put("error", err) ui.Error(err.Error()) return multistep.ActionHalt } } return multistep.ActionContinue } func (s *StepVBoxManage) Cleanup(state multistep.StateBag) {}