2013-06-24 01:44:58 -04:00
|
|
|
package virtualbox
|
|
|
|
|
|
|
|
import (
|
|
|
|
"bytes"
|
|
|
|
"fmt"
|
|
|
|
"github.com/mitchellh/multistep"
|
|
|
|
"github.com/mitchellh/packer/packer"
|
2013-06-24 01:46:57 -04:00
|
|
|
"log"
|
2013-06-24 01:44:58 -04:00
|
|
|
)
|
|
|
|
|
|
|
|
// This step uploads a file containing the VirtualBox version, which
|
|
|
|
// can be useful for various provisioning reasons.
|
|
|
|
type stepUploadVersion struct{}
|
|
|
|
|
2013-08-31 15:44:58 -04:00
|
|
|
func (s *stepUploadVersion) Run(state multistep.StateBag) multistep.StepAction {
|
|
|
|
comm := state.Get("communicator").(packer.Communicator)
|
|
|
|
config := state.Get("config").(*config)
|
|
|
|
driver := state.Get("driver").(Driver)
|
|
|
|
ui := state.Get("ui").(packer.Ui)
|
2013-06-24 01:44:58 -04:00
|
|
|
|
2013-06-24 01:46:57 -04:00
|
|
|
if config.VBoxVersionFile == "" {
|
|
|
|
log.Println("VBoxVersionFile is empty. Not uploading.")
|
|
|
|
return multistep.ActionContinue
|
|
|
|
}
|
|
|
|
|
2013-06-24 01:44:58 -04:00
|
|
|
version, err := driver.Version()
|
|
|
|
if err != nil {
|
2013-08-31 15:44:58 -04:00
|
|
|
state.Put("error", fmt.Errorf("Error reading version for metadata upload: %s", err))
|
2013-06-24 01:44:58 -04:00
|
|
|
return multistep.ActionHalt
|
|
|
|
}
|
|
|
|
|
|
|
|
ui.Say(fmt.Sprintf("Uploading VirtualBox version info (%s)", version))
|
|
|
|
var data bytes.Buffer
|
|
|
|
data.WriteString(version)
|
|
|
|
if err := comm.Upload(config.VBoxVersionFile, &data); err != nil {
|
2013-08-31 15:44:58 -04:00
|
|
|
state.Put("error", fmt.Errorf("Error uploading VirtualBox version: %s", err))
|
2013-06-24 01:44:58 -04:00
|
|
|
return multistep.ActionHalt
|
|
|
|
}
|
|
|
|
|
|
|
|
return multistep.ActionContinue
|
|
|
|
}
|
|
|
|
|
2013-08-31 15:44:58 -04:00
|
|
|
func (s *stepUploadVersion) Cleanup(state multistep.StateBag) {}
|