Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
P
packer
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Kristopher Ruzic
packer
Commits
cdc02db9
Commit
cdc02db9
authored
Dec 21, 2013
by
Mitchell Hashimoto
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
builder/virtualbox/common: Move Driver here
parent
14eede26
Changes
20
Show whitespace changes
Inline
Side-by-side
Showing
20 changed files
with
125 additions
and
93 deletions
+125
-93
builder/virtualbox/common/driver.go
builder/virtualbox/common/driver.go
+77
-0
builder/virtualbox/common/driver_4_2.go
builder/virtualbox/common/driver_4_2.go
+1
-33
builder/virtualbox/common/driver_4_2_test.go
builder/virtualbox/common/driver_4_2_test.go
+9
-0
builder/virtualbox/iso/builder.go
builder/virtualbox/iso/builder.go
+1
-39
builder/virtualbox/iso/step_attach_floppy.go
builder/virtualbox/iso/step_attach_floppy.go
+3
-2
builder/virtualbox/iso/step_attach_guest_additions.go
builder/virtualbox/iso/step_attach_guest_additions.go
+3
-2
builder/virtualbox/iso/step_attach_iso.go
builder/virtualbox/iso/step_attach_iso.go
+3
-2
builder/virtualbox/iso/step_create_disk.go
builder/virtualbox/iso/step_create_disk.go
+2
-1
builder/virtualbox/iso/step_create_vm.go
builder/virtualbox/iso/step_create_vm.go
+3
-2
builder/virtualbox/iso/step_download_guest_additions.go
builder/virtualbox/iso/step_download_guest_additions.go
+2
-1
builder/virtualbox/iso/step_export.go
builder/virtualbox/iso/step_export.go
+2
-1
builder/virtualbox/iso/step_forward_ssh.go
builder/virtualbox/iso/step_forward_ssh.go
+2
-1
builder/virtualbox/iso/step_remove_devices.go
builder/virtualbox/iso/step_remove_devices.go
+2
-1
builder/virtualbox/iso/step_run.go
builder/virtualbox/iso/step_run.go
+3
-2
builder/virtualbox/iso/step_shutdown.go
builder/virtualbox/iso/step_shutdown.go
+2
-1
builder/virtualbox/iso/step_suppress_messages.go
builder/virtualbox/iso/step_suppress_messages.go
+2
-1
builder/virtualbox/iso/step_type_boot_command.go
builder/virtualbox/iso/step_type_boot_command.go
+2
-1
builder/virtualbox/iso/step_upload_guest_additions.go
builder/virtualbox/iso/step_upload_guest_additions.go
+2
-1
builder/virtualbox/iso/step_upload_version.go
builder/virtualbox/iso/step_upload_version.go
+2
-1
builder/virtualbox/iso/step_vboxmanage.go
builder/virtualbox/iso/step_vboxmanage.go
+2
-1
No files found.
builder/virtualbox/common/driver.go
0 → 100644
View file @
cdc02db9
package
common
import
(
"log"
"os"
"os/exec"
"path/filepath"
"runtime"
"strings"
)
// A driver is able to talk to VirtualBox and perform certain
// operations with it. Some of the operations on here may seem overly
// specific, but they were built specifically in mind to handle features
// of the VirtualBox builder for Packer, and to abstract differences in
// versions out of the builder steps, so sometimes the methods are
// extremely specific.
type
Driver
interface
{
// Create a SATA controller.
CreateSATAController
(
vm
string
,
controller
string
)
error
// Checks if the VM with the given name is running.
IsRunning
(
string
)
(
bool
,
error
)
// Stop stops a running machine, forcefully.
Stop
(
string
)
error
// SuppressMessages should do what needs to be done in order to
// suppress any annoying popups from VirtualBox.
SuppressMessages
()
error
// VBoxManage executes the given VBoxManage command
VBoxManage
(
...
string
)
error
// Verify checks to make sure that this driver should function
// properly. If there is any indication the driver can't function,
// this will return an error.
Verify
()
error
// Version reads the version of VirtualBox that is installed.
Version
()
(
string
,
error
)
}
func
NewDriver
()
(
Driver
,
error
)
{
var
vboxmanagePath
string
// On Windows, we check VBOX_INSTALL_PATH env var for the path
if
runtime
.
GOOS
==
"windows"
{
if
installPath
:=
os
.
Getenv
(
"VBOX_INSTALL_PATH"
);
installPath
!=
""
{
log
.
Printf
(
"[DEBUG] builder/virtualbox: VBOX_INSTALL_PATH: %s"
,
installPath
)
for
_
,
path
:=
range
strings
.
Split
(
installPath
,
";"
)
{
path
=
filepath
.
Join
(
path
,
"VBoxManage.exe"
)
if
_
,
err
:=
os
.
Stat
(
path
);
err
==
nil
{
vboxmanagePath
=
path
break
}
}
}
}
if
vboxmanagePath
==
""
{
var
err
error
vboxmanagePath
,
err
=
exec
.
LookPath
(
"VBoxManage"
)
if
err
!=
nil
{
return
nil
,
err
}
}
log
.
Printf
(
"VBoxManage path: %s"
,
vboxmanagePath
)
driver
:=
&
VBox42Driver
{
vboxmanagePath
}
if
err
:=
driver
.
Verify
();
err
!=
nil
{
return
nil
,
err
}
return
driver
,
nil
}
builder/virtualbox/
iso/driver
.go
→
builder/virtualbox/
common/driver_4_2
.go
View file @
cdc02db9
package
iso
package
common
import
(
import
(
"bytes"
"bytes"
...
@@ -10,38 +10,6 @@ import (
...
@@ -10,38 +10,6 @@ import (
"time"
"time"
)
)
// A driver is able to talk to VirtualBox and perform certain
// operations with it. Some of the operations on here may seem overly
// specific, but they were built specifically in mind to handle features
// of the VirtualBox builder for Packer, and to abstract differences in
// versions out of the builder steps, so sometimes the methods are
// extremely specific.
type
Driver
interface
{
// Create a SATA controller.
CreateSATAController
(
vm
string
,
controller
string
)
error
// Checks if the VM with the given name is running.
IsRunning
(
string
)
(
bool
,
error
)
// Stop stops a running machine, forcefully.
Stop
(
string
)
error
// SuppressMessages should do what needs to be done in order to
// suppress any annoying popups from VirtualBox.
SuppressMessages
()
error
// VBoxManage executes the given VBoxManage command
VBoxManage
(
...
string
)
error
// Verify checks to make sure that this driver should function
// properly. If there is any indication the driver can't function,
// this will return an error.
Verify
()
error
// Version reads the version of VirtualBox that is installed.
Version
()
(
string
,
error
)
}
type
VBox42Driver
struct
{
type
VBox42Driver
struct
{
// This is the path to the "VBoxManage" application.
// This is the path to the "VBoxManage" application.
VBoxManagePath
string
VBoxManagePath
string
...
...
builder/virtualbox/common/driver_4_2_test.go
0 → 100644
View file @
cdc02db9
package
common
import
(
"testing"
)
func
TestVBox42Driver_impl
(
t
*
testing
.
T
)
{
var
_
Driver
=
new
(
VBox42Driver
)
}
builder/virtualbox/iso/builder.go
View file @
cdc02db9
...
@@ -9,9 +9,6 @@ import (
...
@@ -9,9 +9,6 @@ import (
"github.com/mitchellh/packer/packer"
"github.com/mitchellh/packer/packer"
"log"
"log"
"os"
"os"
"os/exec"
"path/filepath"
"runtime"
"strings"
"strings"
"time"
"time"
)
)
...
@@ -382,7 +379,7 @@ func (b *Builder) Prepare(raws ...interface{}) ([]string, error) {
...
@@ -382,7 +379,7 @@ func (b *Builder) Prepare(raws ...interface{}) ([]string, error) {
func
(
b
*
Builder
)
Run
(
ui
packer
.
Ui
,
hook
packer
.
Hook
,
cache
packer
.
Cache
)
(
packer
.
Artifact
,
error
)
{
func
(
b
*
Builder
)
Run
(
ui
packer
.
Ui
,
hook
packer
.
Hook
,
cache
packer
.
Cache
)
(
packer
.
Artifact
,
error
)
{
// Create the driver that we'll use to communicate with VirtualBox
// Create the driver that we'll use to communicate with VirtualBox
driver
,
err
:=
b
.
n
ewDriver
()
driver
,
err
:=
vboxcommon
.
N
ewDriver
()
if
err
!=
nil
{
if
err
!=
nil
{
return
nil
,
fmt
.
Errorf
(
"Failed creating VirtualBox driver: %s"
,
err
)
return
nil
,
fmt
.
Errorf
(
"Failed creating VirtualBox driver: %s"
,
err
)
}
}
...
@@ -467,38 +464,3 @@ func (b *Builder) Cancel() {
...
@@ -467,38 +464,3 @@ func (b *Builder) Cancel() {
b
.
runner
.
Cancel
()
b
.
runner
.
Cancel
()
}
}
}
}
func
(
b
*
Builder
)
newDriver
()
(
Driver
,
error
)
{
var
vboxmanagePath
string
if
runtime
.
GOOS
==
"windows"
{
// On Windows, we check VBOX_INSTALL_PATH env var for the path
if
installPath
:=
os
.
Getenv
(
"VBOX_INSTALL_PATH"
);
installPath
!=
""
{
log
.
Printf
(
"[DEBUG] builder/virtualbox: VBOX_INSTALL_PATH: %s"
,
installPath
)
for
_
,
path
:=
range
strings
.
Split
(
installPath
,
";"
)
{
path
=
filepath
.
Join
(
path
,
"VBoxManage.exe"
)
if
_
,
err
:=
os
.
Stat
(
path
);
err
==
nil
{
vboxmanagePath
=
path
break
}
}
}
}
if
vboxmanagePath
==
""
{
var
err
error
vboxmanagePath
,
err
=
exec
.
LookPath
(
"VBoxManage"
)
if
err
!=
nil
{
return
nil
,
err
}
}
log
.
Printf
(
"VBoxManage path: %s"
,
vboxmanagePath
)
driver
:=
&
VBox42Driver
{
vboxmanagePath
}
if
err
:=
driver
.
Verify
();
err
!=
nil
{
return
nil
,
err
}
return
driver
,
nil
}
builder/virtualbox/iso/step_attach_floppy.go
View file @
cdc02db9
...
@@ -3,6 +3,7 @@ package iso
...
@@ -3,6 +3,7 @@ package iso
import
(
import
(
"fmt"
"fmt"
"github.com/mitchellh/multistep"
"github.com/mitchellh/multistep"
vboxcommon
"github.com/mitchellh/packer/builder/virtualbox/common"
"github.com/mitchellh/packer/packer"
"github.com/mitchellh/packer/packer"
"io"
"io"
"io/ioutil"
"io/ioutil"
...
@@ -39,7 +40,7 @@ func (s *stepAttachFloppy) Run(state multistep.StateBag) multistep.StepAction {
...
@@ -39,7 +40,7 @@ func (s *stepAttachFloppy) Run(state multistep.StateBag) multistep.StepAction {
return
multistep
.
ActionHalt
return
multistep
.
ActionHalt
}
}
driver
:=
state
.
Get
(
"driver"
)
.
(
Driver
)
driver
:=
state
.
Get
(
"driver"
)
.
(
vboxcommon
.
Driver
)
ui
:=
state
.
Get
(
"ui"
)
.
(
packer
.
Ui
)
ui
:=
state
.
Get
(
"ui"
)
.
(
packer
.
Ui
)
vmName
:=
state
.
Get
(
"vmName"
)
.
(
string
)
vmName
:=
state
.
Get
(
"vmName"
)
.
(
string
)
...
@@ -84,7 +85,7 @@ func (s *stepAttachFloppy) Cleanup(state multistep.StateBag) {
...
@@ -84,7 +85,7 @@ func (s *stepAttachFloppy) Cleanup(state multistep.StateBag) {
// Delete the floppy disk
// Delete the floppy disk
defer
os
.
Remove
(
s
.
floppyPath
)
defer
os
.
Remove
(
s
.
floppyPath
)
driver
:=
state
.
Get
(
"driver"
)
.
(
Driver
)
driver
:=
state
.
Get
(
"driver"
)
.
(
vboxcommon
.
Driver
)
vmName
:=
state
.
Get
(
"vmName"
)
.
(
string
)
vmName
:=
state
.
Get
(
"vmName"
)
.
(
string
)
command
:=
[]
string
{
command
:=
[]
string
{
...
...
builder/virtualbox/iso/step_attach_guest_additions.go
View file @
cdc02db9
...
@@ -3,6 +3,7 @@ package iso
...
@@ -3,6 +3,7 @@ package iso
import
(
import
(
"fmt"
"fmt"
"github.com/mitchellh/multistep"
"github.com/mitchellh/multistep"
vboxcommon
"github.com/mitchellh/packer/builder/virtualbox/common"
"github.com/mitchellh/packer/packer"
"github.com/mitchellh/packer/packer"
"log"
"log"
)
)
...
@@ -24,7 +25,7 @@ type stepAttachGuestAdditions struct {
...
@@ -24,7 +25,7 @@ type stepAttachGuestAdditions struct {
func
(
s
*
stepAttachGuestAdditions
)
Run
(
state
multistep
.
StateBag
)
multistep
.
StepAction
{
func
(
s
*
stepAttachGuestAdditions
)
Run
(
state
multistep
.
StateBag
)
multistep
.
StepAction
{
config
:=
state
.
Get
(
"config"
)
.
(
*
config
)
config
:=
state
.
Get
(
"config"
)
.
(
*
config
)
driver
:=
state
.
Get
(
"driver"
)
.
(
Driver
)
driver
:=
state
.
Get
(
"driver"
)
.
(
vboxcommon
.
Driver
)
ui
:=
state
.
Get
(
"ui"
)
.
(
packer
.
Ui
)
ui
:=
state
.
Get
(
"ui"
)
.
(
packer
.
Ui
)
vmName
:=
state
.
Get
(
"vmName"
)
.
(
string
)
vmName
:=
state
.
Get
(
"vmName"
)
.
(
string
)
...
@@ -65,7 +66,7 @@ func (s *stepAttachGuestAdditions) Cleanup(state multistep.StateBag) {
...
@@ -65,7 +66,7 @@ func (s *stepAttachGuestAdditions) Cleanup(state multistep.StateBag) {
return
return
}
}
driver
:=
state
.
Get
(
"driver"
)
.
(
Driver
)
driver
:=
state
.
Get
(
"driver"
)
.
(
vboxcommon
.
Driver
)
ui
:=
state
.
Get
(
"ui"
)
.
(
packer
.
Ui
)
ui
:=
state
.
Get
(
"ui"
)
.
(
packer
.
Ui
)
vmName
:=
state
.
Get
(
"vmName"
)
.
(
string
)
vmName
:=
state
.
Get
(
"vmName"
)
.
(
string
)
...
...
builder/virtualbox/iso/step_attach_iso.go
View file @
cdc02db9
...
@@ -3,6 +3,7 @@ package iso
...
@@ -3,6 +3,7 @@ package iso
import
(
import
(
"fmt"
"fmt"
"github.com/mitchellh/multistep"
"github.com/mitchellh/multistep"
vboxcommon
"github.com/mitchellh/packer/builder/virtualbox/common"
"github.com/mitchellh/packer/packer"
"github.com/mitchellh/packer/packer"
)
)
...
@@ -16,7 +17,7 @@ type stepAttachISO struct {
...
@@ -16,7 +17,7 @@ type stepAttachISO struct {
}
}
func
(
s
*
stepAttachISO
)
Run
(
state
multistep
.
StateBag
)
multistep
.
StepAction
{
func
(
s
*
stepAttachISO
)
Run
(
state
multistep
.
StateBag
)
multistep
.
StepAction
{
driver
:=
state
.
Get
(
"driver"
)
.
(
Driver
)
driver
:=
state
.
Get
(
"driver"
)
.
(
vboxcommon
.
Driver
)
isoPath
:=
state
.
Get
(
"iso_path"
)
.
(
string
)
isoPath
:=
state
.
Get
(
"iso_path"
)
.
(
string
)
ui
:=
state
.
Get
(
"ui"
)
.
(
packer
.
Ui
)
ui
:=
state
.
Get
(
"ui"
)
.
(
packer
.
Ui
)
vmName
:=
state
.
Get
(
"vmName"
)
.
(
string
)
vmName
:=
state
.
Get
(
"vmName"
)
.
(
string
)
...
@@ -48,7 +49,7 @@ func (s *stepAttachISO) Cleanup(state multistep.StateBag) {
...
@@ -48,7 +49,7 @@ func (s *stepAttachISO) Cleanup(state multistep.StateBag) {
return
return
}
}
driver
:=
state
.
Get
(
"driver"
)
.
(
Driver
)
driver
:=
state
.
Get
(
"driver"
)
.
(
vboxcommon
.
Driver
)
vmName
:=
state
.
Get
(
"vmName"
)
.
(
string
)
vmName
:=
state
.
Get
(
"vmName"
)
.
(
string
)
command
:=
[]
string
{
command
:=
[]
string
{
...
...
builder/virtualbox/iso/step_create_disk.go
View file @
cdc02db9
...
@@ -3,6 +3,7 @@ package iso
...
@@ -3,6 +3,7 @@ package iso
import
(
import
(
"fmt"
"fmt"
"github.com/mitchellh/multistep"
"github.com/mitchellh/multistep"
vboxcommon
"github.com/mitchellh/packer/builder/virtualbox/common"
"github.com/mitchellh/packer/packer"
"github.com/mitchellh/packer/packer"
"path/filepath"
"path/filepath"
"strconv"
"strconv"
...
@@ -15,7 +16,7 @@ type stepCreateDisk struct{}
...
@@ -15,7 +16,7 @@ type stepCreateDisk struct{}
func
(
s
*
stepCreateDisk
)
Run
(
state
multistep
.
StateBag
)
multistep
.
StepAction
{
func
(
s
*
stepCreateDisk
)
Run
(
state
multistep
.
StateBag
)
multistep
.
StepAction
{
config
:=
state
.
Get
(
"config"
)
.
(
*
config
)
config
:=
state
.
Get
(
"config"
)
.
(
*
config
)
driver
:=
state
.
Get
(
"driver"
)
.
(
Driver
)
driver
:=
state
.
Get
(
"driver"
)
.
(
vboxcommon
.
Driver
)
ui
:=
state
.
Get
(
"ui"
)
.
(
packer
.
Ui
)
ui
:=
state
.
Get
(
"ui"
)
.
(
packer
.
Ui
)
vmName
:=
state
.
Get
(
"vmName"
)
.
(
string
)
vmName
:=
state
.
Get
(
"vmName"
)
.
(
string
)
...
...
builder/virtualbox/iso/step_create_vm.go
View file @
cdc02db9
...
@@ -3,6 +3,7 @@ package iso
...
@@ -3,6 +3,7 @@ package iso
import
(
import
(
"fmt"
"fmt"
"github.com/mitchellh/multistep"
"github.com/mitchellh/multistep"
vboxcommon
"github.com/mitchellh/packer/builder/virtualbox/common"
"github.com/mitchellh/packer/packer"
"github.com/mitchellh/packer/packer"
)
)
...
@@ -16,7 +17,7 @@ type stepCreateVM struct {
...
@@ -16,7 +17,7 @@ type stepCreateVM struct {
func
(
s
*
stepCreateVM
)
Run
(
state
multistep
.
StateBag
)
multistep
.
StepAction
{
func
(
s
*
stepCreateVM
)
Run
(
state
multistep
.
StateBag
)
multistep
.
StepAction
{
config
:=
state
.
Get
(
"config"
)
.
(
*
config
)
config
:=
state
.
Get
(
"config"
)
.
(
*
config
)
driver
:=
state
.
Get
(
"driver"
)
.
(
Driver
)
driver
:=
state
.
Get
(
"driver"
)
.
(
vboxcommon
.
Driver
)
ui
:=
state
.
Get
(
"ui"
)
.
(
packer
.
Ui
)
ui
:=
state
.
Get
(
"ui"
)
.
(
packer
.
Ui
)
name
:=
config
.
VMName
name
:=
config
.
VMName
...
@@ -60,7 +61,7 @@ func (s *stepCreateVM) Cleanup(state multistep.StateBag) {
...
@@ -60,7 +61,7 @@ func (s *stepCreateVM) Cleanup(state multistep.StateBag) {
return
return
}
}
driver
:=
state
.
Get
(
"driver"
)
.
(
Driver
)
driver
:=
state
.
Get
(
"driver"
)
.
(
vboxcommon
.
Driver
)
ui
:=
state
.
Get
(
"ui"
)
.
(
packer
.
Ui
)
ui
:=
state
.
Get
(
"ui"
)
.
(
packer
.
Ui
)
ui
.
Say
(
"Unregistering and deleting virtual machine..."
)
ui
.
Say
(
"Unregistering and deleting virtual machine..."
)
...
...
builder/virtualbox/iso/step_download_guest_additions.go
View file @
cdc02db9
...
@@ -4,6 +4,7 @@ import (
...
@@ -4,6 +4,7 @@ import (
"bytes"
"bytes"
"fmt"
"fmt"
"github.com/mitchellh/multistep"
"github.com/mitchellh/multistep"
vboxcommon
"github.com/mitchellh/packer/builder/virtualbox/common"
"github.com/mitchellh/packer/common"
"github.com/mitchellh/packer/common"
"github.com/mitchellh/packer/packer"
"github.com/mitchellh/packer/packer"
"io"
"io"
...
@@ -31,7 +32,7 @@ type stepDownloadGuestAdditions struct{}
...
@@ -31,7 +32,7 @@ type stepDownloadGuestAdditions struct{}
func
(
s
*
stepDownloadGuestAdditions
)
Run
(
state
multistep
.
StateBag
)
multistep
.
StepAction
{
func
(
s
*
stepDownloadGuestAdditions
)
Run
(
state
multistep
.
StateBag
)
multistep
.
StepAction
{
var
action
multistep
.
StepAction
var
action
multistep
.
StepAction
driver
:=
state
.
Get
(
"driver"
)
.
(
Driver
)
driver
:=
state
.
Get
(
"driver"
)
.
(
vboxcommon
.
Driver
)
ui
:=
state
.
Get
(
"ui"
)
.
(
packer
.
Ui
)
ui
:=
state
.
Get
(
"ui"
)
.
(
packer
.
Ui
)
config
:=
state
.
Get
(
"config"
)
.
(
*
config
)
config
:=
state
.
Get
(
"config"
)
.
(
*
config
)
...
...
builder/virtualbox/iso/step_export.go
View file @
cdc02db9
...
@@ -3,6 +3,7 @@ package iso
...
@@ -3,6 +3,7 @@ package iso
import
(
import
(
"fmt"
"fmt"
"github.com/mitchellh/multistep"
"github.com/mitchellh/multistep"
vboxcommon
"github.com/mitchellh/packer/builder/virtualbox/common"
"github.com/mitchellh/packer/packer"
"github.com/mitchellh/packer/packer"
"log"
"log"
"path/filepath"
"path/filepath"
...
@@ -19,7 +20,7 @@ type stepExport struct{}
...
@@ -19,7 +20,7 @@ type stepExport struct{}
func
(
s
*
stepExport
)
Run
(
state
multistep
.
StateBag
)
multistep
.
StepAction
{
func
(
s
*
stepExport
)
Run
(
state
multistep
.
StateBag
)
multistep
.
StepAction
{
config
:=
state
.
Get
(
"config"
)
.
(
*
config
)
config
:=
state
.
Get
(
"config"
)
.
(
*
config
)
driver
:=
state
.
Get
(
"driver"
)
.
(
Driver
)
driver
:=
state
.
Get
(
"driver"
)
.
(
vboxcommon
.
Driver
)
ui
:=
state
.
Get
(
"ui"
)
.
(
packer
.
Ui
)
ui
:=
state
.
Get
(
"ui"
)
.
(
packer
.
Ui
)
vmName
:=
state
.
Get
(
"vmName"
)
.
(
string
)
vmName
:=
state
.
Get
(
"vmName"
)
.
(
string
)
...
...
builder/virtualbox/iso/step_forward_ssh.go
View file @
cdc02db9
...
@@ -3,6 +3,7 @@ package iso
...
@@ -3,6 +3,7 @@ package iso
import
(
import
(
"fmt"
"fmt"
"github.com/mitchellh/multistep"
"github.com/mitchellh/multistep"
vboxcommon
"github.com/mitchellh/packer/builder/virtualbox/common"
"github.com/mitchellh/packer/packer"
"github.com/mitchellh/packer/packer"
"log"
"log"
"math/rand"
"math/rand"
...
@@ -19,7 +20,7 @@ type stepForwardSSH struct{}
...
@@ -19,7 +20,7 @@ type stepForwardSSH struct{}
func
(
s
*
stepForwardSSH
)
Run
(
state
multistep
.
StateBag
)
multistep
.
StepAction
{
func
(
s
*
stepForwardSSH
)
Run
(
state
multistep
.
StateBag
)
multistep
.
StepAction
{
config
:=
state
.
Get
(
"config"
)
.
(
*
config
)
config
:=
state
.
Get
(
"config"
)
.
(
*
config
)
driver
:=
state
.
Get
(
"driver"
)
.
(
Driver
)
driver
:=
state
.
Get
(
"driver"
)
.
(
vboxcommon
.
Driver
)
ui
:=
state
.
Get
(
"ui"
)
.
(
packer
.
Ui
)
ui
:=
state
.
Get
(
"ui"
)
.
(
packer
.
Ui
)
vmName
:=
state
.
Get
(
"vmName"
)
.
(
string
)
vmName
:=
state
.
Get
(
"vmName"
)
.
(
string
)
...
...
builder/virtualbox/iso/step_remove_devices.go
View file @
cdc02db9
...
@@ -3,6 +3,7 @@ package iso
...
@@ -3,6 +3,7 @@ package iso
import
(
import
(
"fmt"
"fmt"
"github.com/mitchellh/multistep"
"github.com/mitchellh/multistep"
vboxcommon
"github.com/mitchellh/packer/builder/virtualbox/common"
"github.com/mitchellh/packer/packer"
"github.com/mitchellh/packer/packer"
)
)
...
@@ -15,7 +16,7 @@ import (
...
@@ -15,7 +16,7 @@ import (
type
stepRemoveDevices
struct
{}
type
stepRemoveDevices
struct
{}
func
(
s
*
stepRemoveDevices
)
Run
(
state
multistep
.
StateBag
)
multistep
.
StepAction
{
func
(
s
*
stepRemoveDevices
)
Run
(
state
multistep
.
StateBag
)
multistep
.
StepAction
{
driver
:=
state
.
Get
(
"driver"
)
.
(
Driver
)
driver
:=
state
.
Get
(
"driver"
)
.
(
vboxcommon
.
Driver
)
ui
:=
state
.
Get
(
"ui"
)
.
(
packer
.
Ui
)
ui
:=
state
.
Get
(
"ui"
)
.
(
packer
.
Ui
)
vmName
:=
state
.
Get
(
"vmName"
)
.
(
string
)
vmName
:=
state
.
Get
(
"vmName"
)
.
(
string
)
...
...
builder/virtualbox/iso/step_run.go
View file @
cdc02db9
...
@@ -3,6 +3,7 @@ package iso
...
@@ -3,6 +3,7 @@ package iso
import
(
import
(
"fmt"
"fmt"
"github.com/mitchellh/multistep"
"github.com/mitchellh/multistep"
vboxcommon
"github.com/mitchellh/packer/builder/virtualbox/common"
"github.com/mitchellh/packer/packer"
"github.com/mitchellh/packer/packer"
"time"
"time"
)
)
...
@@ -18,7 +19,7 @@ type stepRun struct {
...
@@ -18,7 +19,7 @@ type stepRun struct {
func
(
s
*
stepRun
)
Run
(
state
multistep
.
StateBag
)
multistep
.
StepAction
{
func
(
s
*
stepRun
)
Run
(
state
multistep
.
StateBag
)
multistep
.
StepAction
{
config
:=
state
.
Get
(
"config"
)
.
(
*
config
)
config
:=
state
.
Get
(
"config"
)
.
(
*
config
)
driver
:=
state
.
Get
(
"driver"
)
.
(
Driver
)
driver
:=
state
.
Get
(
"driver"
)
.
(
vboxcommon
.
Driver
)
ui
:=
state
.
Get
(
"ui"
)
.
(
packer
.
Ui
)
ui
:=
state
.
Get
(
"ui"
)
.
(
packer
.
Ui
)
vmName
:=
state
.
Get
(
"vmName"
)
.
(
string
)
vmName
:=
state
.
Get
(
"vmName"
)
.
(
string
)
...
@@ -64,7 +65,7 @@ func (s *stepRun) Cleanup(state multistep.StateBag) {
...
@@ -64,7 +65,7 @@ func (s *stepRun) Cleanup(state multistep.StateBag) {
return
return
}
}
driver
:=
state
.
Get
(
"driver"
)
.
(
Driver
)
driver
:=
state
.
Get
(
"driver"
)
.
(
vboxcommon
.
Driver
)
ui
:=
state
.
Get
(
"ui"
)
.
(
packer
.
Ui
)
ui
:=
state
.
Get
(
"ui"
)
.
(
packer
.
Ui
)
if
running
,
_
:=
driver
.
IsRunning
(
s
.
vmName
);
running
{
if
running
,
_
:=
driver
.
IsRunning
(
s
.
vmName
);
running
{
...
...
builder/virtualbox/iso/step_shutdown.go
View file @
cdc02db9
...
@@ -4,6 +4,7 @@ import (
...
@@ -4,6 +4,7 @@ import (
"errors"
"errors"
"fmt"
"fmt"
"github.com/mitchellh/multistep"
"github.com/mitchellh/multistep"
vboxcommon
"github.com/mitchellh/packer/builder/virtualbox/common"
"github.com/mitchellh/packer/packer"
"github.com/mitchellh/packer/packer"
"log"
"log"
"time"
"time"
...
@@ -26,7 +27,7 @@ type stepShutdown struct{}
...
@@ -26,7 +27,7 @@ type stepShutdown struct{}
func
(
s
*
stepShutdown
)
Run
(
state
multistep
.
StateBag
)
multistep
.
StepAction
{
func
(
s
*
stepShutdown
)
Run
(
state
multistep
.
StateBag
)
multistep
.
StepAction
{
comm
:=
state
.
Get
(
"communicator"
)
.
(
packer
.
Communicator
)
comm
:=
state
.
Get
(
"communicator"
)
.
(
packer
.
Communicator
)
config
:=
state
.
Get
(
"config"
)
.
(
*
config
)
config
:=
state
.
Get
(
"config"
)
.
(
*
config
)
driver
:=
state
.
Get
(
"driver"
)
.
(
Driver
)
driver
:=
state
.
Get
(
"driver"
)
.
(
vboxcommon
.
Driver
)
ui
:=
state
.
Get
(
"ui"
)
.
(
packer
.
Ui
)
ui
:=
state
.
Get
(
"ui"
)
.
(
packer
.
Ui
)
vmName
:=
state
.
Get
(
"vmName"
)
.
(
string
)
vmName
:=
state
.
Get
(
"vmName"
)
.
(
string
)
...
...
builder/virtualbox/iso/step_suppress_messages.go
View file @
cdc02db9
...
@@ -3,6 +3,7 @@ package iso
...
@@ -3,6 +3,7 @@ package iso
import
(
import
(
"fmt"
"fmt"
"github.com/mitchellh/multistep"
"github.com/mitchellh/multistep"
vboxcommon
"github.com/mitchellh/packer/builder/virtualbox/common"
"github.com/mitchellh/packer/packer"
"github.com/mitchellh/packer/packer"
"log"
"log"
)
)
...
@@ -12,7 +13,7 @@ import (
...
@@ -12,7 +13,7 @@ import (
type
stepSuppressMessages
struct
{}
type
stepSuppressMessages
struct
{}
func
(
stepSuppressMessages
)
Run
(
state
multistep
.
StateBag
)
multistep
.
StepAction
{
func
(
stepSuppressMessages
)
Run
(
state
multistep
.
StateBag
)
multistep
.
StepAction
{
driver
:=
state
.
Get
(
"driver"
)
.
(
Driver
)
driver
:=
state
.
Get
(
"driver"
)
.
(
vboxcommon
.
Driver
)
ui
:=
state
.
Get
(
"ui"
)
.
(
packer
.
Ui
)
ui
:=
state
.
Get
(
"ui"
)
.
(
packer
.
Ui
)
log
.
Println
(
"Suppressing annoying messages in VirtualBox"
)
log
.
Println
(
"Suppressing annoying messages in VirtualBox"
)
...
...
builder/virtualbox/iso/step_type_boot_command.go
View file @
cdc02db9
...
@@ -3,6 +3,7 @@ package iso
...
@@ -3,6 +3,7 @@ package iso
import
(
import
(
"fmt"
"fmt"
"github.com/mitchellh/multistep"
"github.com/mitchellh/multistep"
vboxcommon
"github.com/mitchellh/packer/builder/virtualbox/common"
"github.com/mitchellh/packer/packer"
"github.com/mitchellh/packer/packer"
"log"
"log"
"strings"
"strings"
...
@@ -34,7 +35,7 @@ type stepTypeBootCommand struct{}
...
@@ -34,7 +35,7 @@ type stepTypeBootCommand struct{}
func
(
s
*
stepTypeBootCommand
)
Run
(
state
multistep
.
StateBag
)
multistep
.
StepAction
{
func
(
s
*
stepTypeBootCommand
)
Run
(
state
multistep
.
StateBag
)
multistep
.
StepAction
{
config
:=
state
.
Get
(
"config"
)
.
(
*
config
)
config
:=
state
.
Get
(
"config"
)
.
(
*
config
)
driver
:=
state
.
Get
(
"driver"
)
.
(
Driver
)
driver
:=
state
.
Get
(
"driver"
)
.
(
vboxcommon
.
Driver
)
httpPort
:=
state
.
Get
(
"http_port"
)
.
(
uint
)
httpPort
:=
state
.
Get
(
"http_port"
)
.
(
uint
)
ui
:=
state
.
Get
(
"ui"
)
.
(
packer
.
Ui
)
ui
:=
state
.
Get
(
"ui"
)
.
(
packer
.
Ui
)
vmName
:=
state
.
Get
(
"vmName"
)
.
(
string
)
vmName
:=
state
.
Get
(
"vmName"
)
.
(
string
)
...
...
builder/virtualbox/iso/step_upload_guest_additions.go
View file @
cdc02db9
...
@@ -3,6 +3,7 @@ package iso
...
@@ -3,6 +3,7 @@ package iso
import
(
import
(
"fmt"
"fmt"
"github.com/mitchellh/multistep"
"github.com/mitchellh/multistep"
vboxcommon
"github.com/mitchellh/packer/builder/virtualbox/common"
"github.com/mitchellh/packer/packer"
"github.com/mitchellh/packer/packer"
"log"
"log"
"os"
"os"
...
@@ -18,7 +19,7 @@ type stepUploadGuestAdditions struct{}
...
@@ -18,7 +19,7 @@ type stepUploadGuestAdditions struct{}
func
(
s
*
stepUploadGuestAdditions
)
Run
(
state
multistep
.
StateBag
)
multistep
.
StepAction
{
func
(
s
*
stepUploadGuestAdditions
)
Run
(
state
multistep
.
StateBag
)
multistep
.
StepAction
{
comm
:=
state
.
Get
(
"communicator"
)
.
(
packer
.
Communicator
)
comm
:=
state
.
Get
(
"communicator"
)
.
(
packer
.
Communicator
)
config
:=
state
.
Get
(
"config"
)
.
(
*
config
)
config
:=
state
.
Get
(
"config"
)
.
(
*
config
)
driver
:=
state
.
Get
(
"driver"
)
.
(
Driver
)
driver
:=
state
.
Get
(
"driver"
)
.
(
vboxcommon
.
Driver
)
ui
:=
state
.
Get
(
"ui"
)
.
(
packer
.
Ui
)
ui
:=
state
.
Get
(
"ui"
)
.
(
packer
.
Ui
)
// If we're attaching then don't do this, since we attached.
// If we're attaching then don't do this, since we attached.
...
...
builder/virtualbox/iso/step_upload_version.go
View file @
cdc02db9
...
@@ -4,6 +4,7 @@ import (
...
@@ -4,6 +4,7 @@ import (
"bytes"
"bytes"
"fmt"
"fmt"
"github.com/mitchellh/multistep"
"github.com/mitchellh/multistep"
vboxcommon
"github.com/mitchellh/packer/builder/virtualbox/common"
"github.com/mitchellh/packer/packer"
"github.com/mitchellh/packer/packer"
"log"
"log"
)
)
...
@@ -15,7 +16,7 @@ type stepUploadVersion struct{}
...
@@ -15,7 +16,7 @@ type stepUploadVersion struct{}
func
(
s
*
stepUploadVersion
)
Run
(
state
multistep
.
StateBag
)
multistep
.
StepAction
{
func
(
s
*
stepUploadVersion
)
Run
(
state
multistep
.
StateBag
)
multistep
.
StepAction
{
comm
:=
state
.
Get
(
"communicator"
)
.
(
packer
.
Communicator
)
comm
:=
state
.
Get
(
"communicator"
)
.
(
packer
.
Communicator
)
config
:=
state
.
Get
(
"config"
)
.
(
*
config
)
config
:=
state
.
Get
(
"config"
)
.
(
*
config
)
driver
:=
state
.
Get
(
"driver"
)
.
(
Driver
)
driver
:=
state
.
Get
(
"driver"
)
.
(
vboxcommon
.
Driver
)
ui
:=
state
.
Get
(
"ui"
)
.
(
packer
.
Ui
)
ui
:=
state
.
Get
(
"ui"
)
.
(
packer
.
Ui
)
if
config
.
VBoxVersionFile
==
""
{
if
config
.
VBoxVersionFile
==
""
{
...
...
builder/virtualbox/iso/step_vboxmanage.go
View file @
cdc02db9
...
@@ -3,6 +3,7 @@ package iso
...
@@ -3,6 +3,7 @@ package iso
import
(
import
(
"fmt"
"fmt"
"github.com/mitchellh/multistep"
"github.com/mitchellh/multistep"
vboxcommon
"github.com/mitchellh/packer/builder/virtualbox/common"
"github.com/mitchellh/packer/packer"
"github.com/mitchellh/packer/packer"
"strings"
"strings"
)
)
...
@@ -21,7 +22,7 @@ type stepVBoxManage struct{}
...
@@ -21,7 +22,7 @@ type stepVBoxManage struct{}
func
(
s
*
stepVBoxManage
)
Run
(
state
multistep
.
StateBag
)
multistep
.
StepAction
{
func
(
s
*
stepVBoxManage
)
Run
(
state
multistep
.
StateBag
)
multistep
.
StepAction
{
config
:=
state
.
Get
(
"config"
)
.
(
*
config
)
config
:=
state
.
Get
(
"config"
)
.
(
*
config
)
driver
:=
state
.
Get
(
"driver"
)
.
(
Driver
)
driver
:=
state
.
Get
(
"driver"
)
.
(
vboxcommon
.
Driver
)
ui
:=
state
.
Get
(
"ui"
)
.
(
packer
.
Ui
)
ui
:=
state
.
Get
(
"ui"
)
.
(
packer
.
Ui
)
vmName
:=
state
.
Get
(
"vmName"
)
.
(
string
)
vmName
:=
state
.
Get
(
"vmName"
)
.
(
string
)
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment