2013-12-21 17:27:00 -05:00
|
|
|
package iso
|
2013-06-11 19:34:44 -04:00
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"github.com/mitchellh/multistep"
|
2013-12-21 18:00:48 -05:00
|
|
|
vboxcommon "github.com/mitchellh/packer/builder/virtualbox/common"
|
2013-06-11 19:34:44 -04:00
|
|
|
"github.com/mitchellh/packer/packer"
|
|
|
|
"path/filepath"
|
2013-06-23 23:43:40 -04:00
|
|
|
"strconv"
|
2013-06-11 19:34:44 -04:00
|
|
|
"strings"
|
|
|
|
)
|
|
|
|
|
|
|
|
// This step creates the virtual disk that will be used as the
|
|
|
|
// hard drive for the virtual machine.
|
2013-06-12 00:08:45 -04:00
|
|
|
type stepCreateDisk struct{}
|
2013-06-11 19:34:44 -04:00
|
|
|
|
2013-08-31 15:44:58 -04:00
|
|
|
func (s *stepCreateDisk) Run(state multistep.StateBag) multistep.StepAction {
|
2015-05-27 17:01:08 -04:00
|
|
|
config := state.Get("config").(*Config)
|
2013-12-21 18:00:48 -05:00
|
|
|
driver := state.Get("driver").(vboxcommon.Driver)
|
2013-08-31 15:44:58 -04:00
|
|
|
ui := state.Get("ui").(packer.Ui)
|
|
|
|
vmName := state.Get("vmName").(string)
|
2013-06-11 19:34:44 -04:00
|
|
|
|
|
|
|
format := "VDI"
|
|
|
|
path := filepath.Join(config.OutputDir, fmt.Sprintf("%s.%s", config.VMName, strings.ToLower(format)))
|
|
|
|
|
|
|
|
command := []string{
|
|
|
|
"createhd",
|
|
|
|
"--filename", path,
|
2013-06-23 23:43:40 -04:00
|
|
|
"--size", strconv.FormatUint(uint64(config.DiskSize), 10),
|
2013-06-11 19:34:44 -04:00
|
|
|
"--format", format,
|
|
|
|
"--variant", "Standard",
|
|
|
|
}
|
|
|
|
|
|
|
|
ui.Say("Creating hard drive...")
|
|
|
|
err := driver.VBoxManage(command...)
|
|
|
|
if err != nil {
|
2013-06-20 00:07:53 -04:00
|
|
|
err := fmt.Errorf("Error creating hard drive: %s", err)
|
2013-08-31 15:44:58 -04:00
|
|
|
state.Put("error", err)
|
2013-06-20 00:07:53 -04:00
|
|
|
ui.Error(err.Error())
|
2013-06-11 19:34:44 -04:00
|
|
|
return multistep.ActionHalt
|
|
|
|
}
|
|
|
|
|
2013-09-05 14:00:08 -04:00
|
|
|
// Add the IDE controller so we can later attach the disk.
|
|
|
|
// When the hard disk controller is not IDE, this device is still used
|
|
|
|
// by VirtualBox to deliver the guest extensions.
|
2014-05-23 21:14:24 -04:00
|
|
|
err = driver.VBoxManage("storagectl", vmName, "--name", "IDE Controller", "--add", "ide")
|
2013-06-11 19:44:43 -04:00
|
|
|
if err != nil {
|
2013-06-20 00:07:53 -04:00
|
|
|
err := fmt.Errorf("Error creating disk controller: %s", err)
|
2013-08-31 15:44:58 -04:00
|
|
|
state.Put("error", err)
|
2013-06-20 00:07:53 -04:00
|
|
|
ui.Error(err.Error())
|
2013-06-11 19:44:43 -04:00
|
|
|
return multistep.ActionHalt
|
|
|
|
}
|
|
|
|
|
2013-09-05 15:07:58 -04:00
|
|
|
// Add a SATA controller if we were asked to use SATA. We still attach
|
|
|
|
// the IDE controller above because some other things (disks) require
|
|
|
|
// that.
|
2014-05-23 21:14:24 -04:00
|
|
|
if config.HardDriveInterface == "sata" || config.ISOInterface == "sata" {
|
|
|
|
if err := driver.CreateSATAController(vmName, "SATA Controller"); err != nil {
|
2013-09-05 14:00:08 -04:00
|
|
|
err := fmt.Errorf("Error creating disk controller: %s", err)
|
|
|
|
state.Put("error", err)
|
|
|
|
ui.Error(err.Error())
|
|
|
|
return multistep.ActionHalt
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-01-16 11:34:12 -05:00
|
|
|
if config.HardDriveInterface == "scsi" {
|
|
|
|
if err := driver.CreateSCSIController(vmName, "SCSI Controller"); err != nil {
|
|
|
|
err := fmt.Errorf("Error creating disk controller: %s", err)
|
|
|
|
state.Put("error", err)
|
|
|
|
ui.Error(err.Error())
|
|
|
|
return multistep.ActionHalt
|
|
|
|
}
|
|
|
|
}
|
2015-01-15 20:53:01 -05:00
|
|
|
|
2013-06-11 19:44:43 -04:00
|
|
|
// Attach the disk to the controller
|
2014-05-23 21:14:24 -04:00
|
|
|
controllerName := "IDE Controller"
|
|
|
|
if config.HardDriveInterface == "sata" {
|
|
|
|
controllerName = "SATA Controller"
|
|
|
|
}
|
2015-01-16 11:34:12 -05:00
|
|
|
|
|
|
|
if config.HardDriveInterface == "scsi" {
|
|
|
|
controllerName = "SCSI Controller"
|
|
|
|
}
|
2014-05-23 21:14:24 -04:00
|
|
|
|
2013-06-11 19:44:43 -04:00
|
|
|
command = []string{
|
2013-06-11 19:48:01 -04:00
|
|
|
"storageattach", vmName,
|
2013-06-11 19:44:43 -04:00
|
|
|
"--storagectl", controllerName,
|
|
|
|
"--port", "0",
|
|
|
|
"--device", "0",
|
|
|
|
"--type", "hdd",
|
|
|
|
"--medium", path,
|
|
|
|
}
|
|
|
|
if err := driver.VBoxManage(command...); err != nil {
|
2013-06-20 00:07:53 -04:00
|
|
|
err := fmt.Errorf("Error attaching hard drive: %s", err)
|
2013-08-31 15:44:58 -04:00
|
|
|
state.Put("error", err)
|
2013-06-20 00:07:53 -04:00
|
|
|
ui.Error(err.Error())
|
2013-06-11 19:44:43 -04:00
|
|
|
return multistep.ActionHalt
|
|
|
|
}
|
|
|
|
|
2013-06-11 19:34:44 -04:00
|
|
|
return multistep.ActionContinue
|
|
|
|
}
|
|
|
|
|
2013-08-31 15:44:58 -04:00
|
|
|
func (s *stepCreateDisk) Cleanup(state multistep.StateBag) {}
|