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
76c2d2cb
Commit
76c2d2cb
authored
May 27, 2015
by
Mitchell Hashimoto
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
builder/parallels/iso: new interpolation
parent
3e76547b
Changes
15
Hide whitespace changes
Inline
Side-by-side
Showing
15 changed files
with
80 additions
and
210 deletions
+80
-210
builder/parallels/common/floppy_config.go
builder/parallels/common/floppy_config.go
+3
-15
builder/parallels/common/output_config.go
builder/parallels/common/output_config.go
+5
-16
builder/parallels/common/prlctl_config.go
builder/parallels/common/prlctl_config.go
+3
-14
builder/parallels/common/prlctl_version_config.go
builder/parallels/common/prlctl_version_config.go
+3
-17
builder/parallels/common/run_config.go
builder/parallels/common/run_config.go
+5
-17
builder/parallels/common/shutdown_config.go
builder/parallels/common/shutdown_config.go
+4
-16
builder/parallels/common/ssh_config.go
builder/parallels/common/ssh_config.go
+3
-18
builder/parallels/common/step_prlctl.go
builder/parallels/common/step_prlctl.go
+6
-4
builder/parallels/common/step_type_boot_command.go
builder/parallels/common/step_type_boot_command.go
+4
-3
builder/parallels/common/step_upload_parallels_tools.go
builder/parallels/common/step_upload_parallels_tools.go
+7
-5
builder/parallels/common/tools_config.go
builder/parallels/common/tools_config.go
+4
-21
builder/parallels/iso/builder.go
builder/parallels/iso/builder.go
+30
-61
builder/parallels/iso/step_create_disk.go
builder/parallels/iso/step_create_disk.go
+1
-1
builder/parallels/iso/step_create_vm.go
builder/parallels/iso/step_create_vm.go
+1
-1
builder/parallels/iso/step_http_server.go
builder/parallels/iso/step_http_server.go
+1
-1
No files found.
builder/parallels/common/floppy_config.go
View file @
76c2d2cb
package
common
package
common
import
(
import
(
"fmt"
"github.com/mitchellh/packer/template/interpolate"
"github.com/mitchellh/packer/packer"
)
)
// FloppyConfig is configuration related to created floppy disks and attaching
// FloppyConfig is configuration related to created floppy disks and attaching
...
@@ -12,20 +10,10 @@ type FloppyConfig struct {
...
@@ -12,20 +10,10 @@ type FloppyConfig struct {
FloppyFiles
[]
string
`mapstructure:"floppy_files"`
FloppyFiles
[]
string
`mapstructure:"floppy_files"`
}
}
func
(
c
*
FloppyConfig
)
Prepare
(
t
*
packer
.
ConfigTemplate
)
[]
error
{
func
(
c
*
FloppyConfig
)
Prepare
(
ctx
*
interpolate
.
Context
)
[]
error
{
if
c
.
FloppyFiles
==
nil
{
if
c
.
FloppyFiles
==
nil
{
c
.
FloppyFiles
=
make
([]
string
,
0
)
c
.
FloppyFiles
=
make
([]
string
,
0
)
}
}
errs
:=
make
([]
error
,
0
)
return
nil
for
i
,
file
:=
range
c
.
FloppyFiles
{
var
err
error
c
.
FloppyFiles
[
i
],
err
=
t
.
Process
(
file
,
nil
)
if
err
!=
nil
{
errs
=
append
(
errs
,
fmt
.
Errorf
(
"Error processing floppy_files[%d]: %s"
,
i
,
err
))
}
}
return
errs
}
}
builder/parallels/common/output_config.go
View file @
76c2d2cb
...
@@ -2,33 +2,22 @@ package common
...
@@ -2,33 +2,22 @@ package common
import
(
import
(
"fmt"
"fmt"
"github.com/mitchellh/packer/common"
"github.com/mitchellh/packer/packer"
"os"
"os"
"github.com/mitchellh/packer/common"
"github.com/mitchellh/packer/template/interpolate"
)
)
type
OutputConfig
struct
{
type
OutputConfig
struct
{
OutputDir
string
`mapstructure:"output_directory"`
OutputDir
string
`mapstructure:"output_directory"`
}
}
func
(
c
*
OutputConfig
)
Prepare
(
t
*
packer
.
ConfigTemplate
,
pc
*
common
.
PackerConfig
)
[]
error
{
func
(
c
*
OutputConfig
)
Prepare
(
ctx
*
interpolate
.
Context
,
pc
*
common
.
PackerConfig
)
[]
error
{
if
c
.
OutputDir
==
""
{
if
c
.
OutputDir
==
""
{
c
.
OutputDir
=
fmt
.
Sprintf
(
"output-%s"
,
pc
.
PackerBuildName
)
c
.
OutputDir
=
fmt
.
Sprintf
(
"output-%s"
,
pc
.
PackerBuildName
)
}
}
templates
:=
map
[
string
]
*
string
{
var
errs
[]
error
"output_directory"
:
&
c
.
OutputDir
,
}
errs
:=
make
([]
error
,
0
)
for
n
,
ptr
:=
range
templates
{
var
err
error
*
ptr
,
err
=
t
.
Process
(
*
ptr
,
nil
)
if
err
!=
nil
{
errs
=
append
(
errs
,
fmt
.
Errorf
(
"Error processing %s: %s"
,
n
,
err
))
}
}
if
!
pc
.
PackerForce
{
if
!
pc
.
PackerForce
{
if
_
,
err
:=
os
.
Stat
(
c
.
OutputDir
);
err
==
nil
{
if
_
,
err
:=
os
.
Stat
(
c
.
OutputDir
);
err
==
nil
{
errs
=
append
(
errs
,
fmt
.
Errorf
(
errs
=
append
(
errs
,
fmt
.
Errorf
(
...
...
builder/parallels/common/prlctl_config.go
View file @
76c2d2cb
package
common
package
common
import
(
import
(
"fmt"
"github.com/mitchellh/packer/template/interpolate"
"github.com/mitchellh/packer/packer"
)
)
type
PrlctlConfig
struct
{
type
PrlctlConfig
struct
{
Prlctl
[][]
string
`mapstructure:"prlctl"`
Prlctl
[][]
string
`mapstructure:"prlctl"`
}
}
func
(
c
*
PrlctlConfig
)
Prepare
(
t
*
packer
.
ConfigTemplate
)
[]
error
{
func
(
c
*
PrlctlConfig
)
Prepare
(
ctx
*
interpolate
.
Context
)
[]
error
{
if
c
.
Prlctl
==
nil
{
if
c
.
Prlctl
==
nil
{
c
.
Prlctl
=
make
([][]
string
,
0
)
c
.
Prlctl
=
make
([][]
string
,
0
)
}
}
errs
:=
make
([]
error
,
0
)
return
nil
for
i
,
args
:=
range
c
.
Prlctl
{
for
j
,
arg
:=
range
args
{
if
err
:=
t
.
Validate
(
arg
);
err
!=
nil
{
errs
=
append
(
errs
,
fmt
.
Errorf
(
"Error processing prlctl[%d][%d]: %s"
,
i
,
j
,
err
))
}
}
}
return
errs
}
}
builder/parallels/common/prlctl_version_config.go
View file @
76c2d2cb
package
common
package
common
import
(
import
(
"fmt"
"github.com/mitchellh/packer/template/interpolate"
"github.com/mitchellh/packer/packer"
)
)
type
PrlctlVersionConfig
struct
{
type
PrlctlVersionConfig
struct
{
PrlctlVersionFile
string
`mapstructure:"prlctl_version_file"`
PrlctlVersionFile
string
`mapstructure:"prlctl_version_file"`
}
}
func
(
c
*
PrlctlVersionConfig
)
Prepare
(
t
*
packer
.
ConfigTemplate
)
[]
error
{
func
(
c
*
PrlctlVersionConfig
)
Prepare
(
ctx
*
interpolate
.
Context
)
[]
error
{
if
c
.
PrlctlVersionFile
==
""
{
if
c
.
PrlctlVersionFile
==
""
{
c
.
PrlctlVersionFile
=
".prlctl_version"
c
.
PrlctlVersionFile
=
".prlctl_version"
}
}
templates
:=
map
[
string
]
*
string
{
return
nil
"prlctl_version_file"
:
&
c
.
PrlctlVersionFile
,
}
errs
:=
make
([]
error
,
0
)
for
n
,
ptr
:=
range
templates
{
var
err
error
*
ptr
,
err
=
t
.
Process
(
*
ptr
,
nil
)
if
err
!=
nil
{
errs
=
append
(
errs
,
fmt
.
Errorf
(
"Error processing %s: %s"
,
n
,
err
))
}
}
return
errs
}
}
builder/parallels/common/run_config.go
View file @
76c2d2cb
...
@@ -2,8 +2,9 @@ package common
...
@@ -2,8 +2,9 @@ package common
import
(
import
(
"fmt"
"fmt"
"github.com/mitchellh/packer/packer"
"time"
"time"
"github.com/mitchellh/packer/template/interpolate"
)
)
type
RunConfig
struct
{
type
RunConfig
struct
{
...
@@ -13,29 +14,16 @@ type RunConfig struct {
...
@@ -13,29 +14,16 @@ type RunConfig struct {
BootWait
time
.
Duration
``
BootWait
time
.
Duration
``
}
}
func
(
c
*
RunConfig
)
Prepare
(
t
*
packer
.
ConfigTemplate
)
[]
error
{
func
(
c
*
RunConfig
)
Prepare
(
ctx
*
interpolate
.
Context
)
[]
error
{
if
c
.
RawBootWait
==
""
{
if
c
.
RawBootWait
==
""
{
c
.
RawBootWait
=
"10s"
c
.
RawBootWait
=
"10s"
}
}
templates
:=
map
[
string
]
*
string
{
"boot_wait"
:
&
c
.
RawBootWait
,
}
errs
:=
make
([]
error
,
0
)
for
n
,
ptr
:=
range
templates
{
var
err
error
*
ptr
,
err
=
t
.
Process
(
*
ptr
,
nil
)
if
err
!=
nil
{
errs
=
append
(
errs
,
fmt
.
Errorf
(
"Error processing %s: %s"
,
n
,
err
))
}
}
var
err
error
var
err
error
c
.
BootWait
,
err
=
time
.
ParseDuration
(
c
.
RawBootWait
)
c
.
BootWait
,
err
=
time
.
ParseDuration
(
c
.
RawBootWait
)
if
err
!=
nil
{
if
err
!=
nil
{
errs
=
append
(
errs
,
fmt
.
Errorf
(
"Failed parsing boot_wait: %s"
,
err
))
return
[]
error
{
fmt
.
Errorf
(
"Failed parsing boot_wait: %s"
,
err
)}
}
}
return
errs
return
nil
}
}
builder/parallels/common/shutdown_config.go
View file @
76c2d2cb
...
@@ -2,8 +2,9 @@ package common
...
@@ -2,8 +2,9 @@ package common
import
(
import
(
"fmt"
"fmt"
"github.com/mitchellh/packer/packer"
"time"
"time"
"github.com/mitchellh/packer/template/interpolate"
)
)
type
ShutdownConfig
struct
{
type
ShutdownConfig
struct
{
...
@@ -13,25 +14,12 @@ type ShutdownConfig struct {
...
@@ -13,25 +14,12 @@ type ShutdownConfig struct {
ShutdownTimeout
time
.
Duration
``
ShutdownTimeout
time
.
Duration
``
}
}
func
(
c
*
ShutdownConfig
)
Prepare
(
t
*
packer
.
ConfigTemplate
)
[]
error
{
func
(
c
*
ShutdownConfig
)
Prepare
(
ctx
*
interpolate
.
Context
)
[]
error
{
if
c
.
RawShutdownTimeout
==
""
{
if
c
.
RawShutdownTimeout
==
""
{
c
.
RawShutdownTimeout
=
"5m"
c
.
RawShutdownTimeout
=
"5m"
}
}
templates
:=
map
[
string
]
*
string
{
var
errs
[]
error
"shutdown_command"
:
&
c
.
ShutdownCommand
,
"shutdown_timeout"
:
&
c
.
RawShutdownTimeout
,
}
errs
:=
make
([]
error
,
0
)
for
n
,
ptr
:=
range
templates
{
var
err
error
*
ptr
,
err
=
t
.
Process
(
*
ptr
,
nil
)
if
err
!=
nil
{
errs
=
append
(
errs
,
fmt
.
Errorf
(
"Error processing %s: %s"
,
n
,
err
))
}
}
var
err
error
var
err
error
c
.
ShutdownTimeout
,
err
=
time
.
ParseDuration
(
c
.
RawShutdownTimeout
)
c
.
ShutdownTimeout
,
err
=
time
.
ParseDuration
(
c
.
RawShutdownTimeout
)
if
err
!=
nil
{
if
err
!=
nil
{
...
...
builder/parallels/common/ssh_config.go
View file @
76c2d2cb
...
@@ -7,7 +7,7 @@ import (
...
@@ -7,7 +7,7 @@ import (
"time"
"time"
commonssh
"github.com/mitchellh/packer/common/ssh"
commonssh
"github.com/mitchellh/packer/common/ssh"
"github.com/mitchellh/packer/
packer
"
"github.com/mitchellh/packer/
template/interpolate
"
)
)
type
SSHConfig
struct
{
type
SSHConfig
struct
{
...
@@ -20,7 +20,7 @@ type SSHConfig struct {
...
@@ -20,7 +20,7 @@ type SSHConfig struct {
SSHWaitTimeout
time
.
Duration
SSHWaitTimeout
time
.
Duration
}
}
func
(
c
*
SSHConfig
)
Prepare
(
t
*
packer
.
ConfigTemplate
)
[]
error
{
func
(
c
*
SSHConfig
)
Prepare
(
ctx
*
interpolate
.
Context
)
[]
error
{
if
c
.
SSHPort
==
0
{
if
c
.
SSHPort
==
0
{
c
.
SSHPort
=
22
c
.
SSHPort
=
22
}
}
...
@@ -29,22 +29,7 @@ func (c *SSHConfig) Prepare(t *packer.ConfigTemplate) []error {
...
@@ -29,22 +29,7 @@ func (c *SSHConfig) Prepare(t *packer.ConfigTemplate) []error {
c
.
RawSSHWaitTimeout
=
"20m"
c
.
RawSSHWaitTimeout
=
"20m"
}
}
templates
:=
map
[
string
]
*
string
{
var
errs
[]
error
"ssh_key_path"
:
&
c
.
SSHKeyPath
,
"ssh_password"
:
&
c
.
SSHPassword
,
"ssh_username"
:
&
c
.
SSHUser
,
"ssh_wait_timeout"
:
&
c
.
RawSSHWaitTimeout
,
}
errs
:=
make
([]
error
,
0
)
for
n
,
ptr
:=
range
templates
{
var
err
error
*
ptr
,
err
=
t
.
Process
(
*
ptr
,
nil
)
if
err
!=
nil
{
errs
=
append
(
errs
,
fmt
.
Errorf
(
"Error processing %s: %s"
,
n
,
err
))
}
}
if
c
.
SSHKeyPath
!=
""
{
if
c
.
SSHKeyPath
!=
""
{
if
_
,
err
:=
os
.
Stat
(
c
.
SSHKeyPath
);
err
!=
nil
{
if
_
,
err
:=
os
.
Stat
(
c
.
SSHKeyPath
);
err
!=
nil
{
errs
=
append
(
errs
,
fmt
.
Errorf
(
"ssh_key_path is invalid: %s"
,
err
))
errs
=
append
(
errs
,
fmt
.
Errorf
(
"ssh_key_path is invalid: %s"
,
err
))
...
...
builder/parallels/common/step_prlctl.go
View file @
76c2d2cb
...
@@ -2,9 +2,11 @@ package common
...
@@ -2,9 +2,11 @@ package common
import
(
import
(
"fmt"
"fmt"
"strings"
"github.com/mitchellh/multistep"
"github.com/mitchellh/multistep"
"github.com/mitchellh/packer/packer"
"github.com/mitchellh/packer/packer"
"
strings
"
"
github.com/mitchellh/packer/template/interpolate
"
)
)
type
commandTemplate
struct
{
type
commandTemplate
struct
{
...
@@ -22,7 +24,7 @@ type commandTemplate struct {
...
@@ -22,7 +24,7 @@ type commandTemplate struct {
// Produces:
// Produces:
type
StepPrlctl
struct
{
type
StepPrlctl
struct
{
Commands
[][]
string
Commands
[][]
string
Tpl
*
packer
.
ConfigTemplate
Ctx
interpolate
.
Context
}
}
func
(
s
*
StepPrlctl
)
Run
(
state
multistep
.
StateBag
)
multistep
.
StepAction
{
func
(
s
*
StepPrlctl
)
Run
(
state
multistep
.
StateBag
)
multistep
.
StepAction
{
...
@@ -34,7 +36,7 @@ func (s *StepPrlctl) Run(state multistep.StateBag) multistep.StepAction {
...
@@ -34,7 +36,7 @@ func (s *StepPrlctl) Run(state multistep.StateBag) multistep.StepAction {
ui
.
Say
(
"Executing custom prlctl commands..."
)
ui
.
Say
(
"Executing custom prlctl commands..."
)
}
}
tplData
:
=
&
commandTemplate
{
s
.
Ctx
.
Data
=
&
commandTemplate
{
Name
:
vmName
,
Name
:
vmName
,
}
}
...
@@ -44,7 +46,7 @@ func (s *StepPrlctl) Run(state multistep.StateBag) multistep.StepAction {
...
@@ -44,7 +46,7 @@ func (s *StepPrlctl) Run(state multistep.StateBag) multistep.StepAction {
for
i
,
arg
:=
range
command
{
for
i
,
arg
:=
range
command
{
var
err
error
var
err
error
command
[
i
],
err
=
s
.
Tpl
.
Process
(
arg
,
tplData
)
command
[
i
],
err
=
interpolate
.
Render
(
arg
,
&
s
.
Ctx
)
if
err
!=
nil
{
if
err
!=
nil
{
err
:=
fmt
.
Errorf
(
"Error preparing prlctl command: %s"
,
err
)
err
:=
fmt
.
Errorf
(
"Error preparing prlctl command: %s"
,
err
)
state
.
Put
(
"error"
,
err
)
state
.
Put
(
"error"
,
err
)
...
...
builder/parallels/common/step_type_boot_command.go
View file @
76c2d2cb
...
@@ -10,6 +10,7 @@ import (
...
@@ -10,6 +10,7 @@ import (
"github.com/mitchellh/multistep"
"github.com/mitchellh/multistep"
"github.com/mitchellh/packer/packer"
"github.com/mitchellh/packer/packer"
"github.com/mitchellh/packer/template/interpolate"
)
)
const
KeyLeftShift
uint32
=
0xFFE1
const
KeyLeftShift
uint32
=
0xFFE1
...
@@ -35,7 +36,7 @@ type StepTypeBootCommand struct {
...
@@ -35,7 +36,7 @@ type StepTypeBootCommand struct {
BootCommand
[]
string
BootCommand
[]
string
HostInterfaces
[]
string
HostInterfaces
[]
string
VMName
string
VMName
string
Tpl
*
packer
.
ConfigTemplate
Ctx
interpolate
.
Context
}
}
func
(
s
*
StepTypeBootCommand
)
Run
(
state
multistep
.
StateBag
)
multistep
.
StepAction
{
func
(
s
*
StepTypeBootCommand
)
Run
(
state
multistep
.
StateBag
)
multistep
.
StepAction
{
...
@@ -61,7 +62,7 @@ func (s *StepTypeBootCommand) Run(state multistep.StateBag) multistep.StepAction
...
@@ -61,7 +62,7 @@ func (s *StepTypeBootCommand) Run(state multistep.StateBag) multistep.StepAction
ui
.
Say
(
fmt
.
Sprintf
(
"Host IP for the Parallels machine: %s"
,
hostIp
))
ui
.
Say
(
fmt
.
Sprintf
(
"Host IP for the Parallels machine: %s"
,
hostIp
))
tplData
:
=
&
bootCommandTemplateData
{
s
.
Ctx
.
Data
=
&
bootCommandTemplateData
{
hostIp
,
hostIp
,
httpPort
,
httpPort
,
s
.
VMName
,
s
.
VMName
,
...
@@ -69,7 +70,7 @@ func (s *StepTypeBootCommand) Run(state multistep.StateBag) multistep.StepAction
...
@@ -69,7 +70,7 @@ func (s *StepTypeBootCommand) Run(state multistep.StateBag) multistep.StepAction
ui
.
Say
(
"Typing the boot command..."
)
ui
.
Say
(
"Typing the boot command..."
)
for
_
,
command
:=
range
s
.
BootCommand
{
for
_
,
command
:=
range
s
.
BootCommand
{
command
,
err
:=
s
.
Tpl
.
Process
(
command
,
tplData
)
command
,
err
:=
interpolate
.
Render
(
command
,
&
s
.
Ctx
)
if
err
!=
nil
{
if
err
!=
nil
{
err
:=
fmt
.
Errorf
(
"Error preparing boot command: %s"
,
err
)
err
:=
fmt
.
Errorf
(
"Error preparing boot command: %s"
,
err
)
state
.
Put
(
"error"
,
err
)
state
.
Put
(
"error"
,
err
)
...
...
builder/parallels/common/step_upload_parallels_tools.go
View file @
76c2d2cb
...
@@ -2,10 +2,12 @@ package common
...
@@ -2,10 +2,12 @@ package common
import
(
import
(
"fmt"
"fmt"
"github.com/mitchellh/multistep"
"github.com/mitchellh/packer/packer"
"log"
"log"
"os"
"os"
"github.com/mitchellh/multistep"
"github.com/mitchellh/packer/packer"
"github.com/mitchellh/packer/template/interpolate"
)
)
// This step uploads the Parallels Tools ISO to the virtual machine.
// This step uploads the Parallels Tools ISO to the virtual machine.
...
@@ -25,7 +27,7 @@ type StepUploadParallelsTools struct {
...
@@ -25,7 +27,7 @@ type StepUploadParallelsTools struct {
ParallelsToolsFlavor
string
ParallelsToolsFlavor
string
ParallelsToolsGuestPath
string
ParallelsToolsGuestPath
string
ParallelsToolsMode
string
ParallelsToolsMode
string
Tpl
*
packer
.
ConfigTemplate
Ctx
interpolate
.
Context
}
}
func
(
s
*
StepUploadParallelsTools
)
Run
(
state
multistep
.
StateBag
)
multistep
.
StepAction
{
func
(
s
*
StepUploadParallelsTools
)
Run
(
state
multistep
.
StateBag
)
multistep
.
StepAction
{
...
@@ -48,11 +50,11 @@ func (s *StepUploadParallelsTools) Run(state multistep.StateBag) multistep.StepA
...
@@ -48,11 +50,11 @@ func (s *StepUploadParallelsTools) Run(state multistep.StateBag) multistep.StepA
}
}
defer
f
.
Close
()
defer
f
.
Close
()
tplData
:
=
&
toolsPathTemplate
{
s
.
Ctx
.
Data
=
&
toolsPathTemplate
{
Flavor
:
s
.
ParallelsToolsFlavor
,
Flavor
:
s
.
ParallelsToolsFlavor
,
}
}
s
.
ParallelsToolsGuestPath
,
err
=
s
.
Tpl
.
Process
(
s
.
ParallelsToolsGuestPath
,
tplData
)
s
.
ParallelsToolsGuestPath
,
err
=
interpolate
.
Render
(
s
.
ParallelsToolsGuestPath
,
&
s
.
Ctx
)
if
err
!=
nil
{
if
err
!=
nil
{
err
:=
fmt
.
Errorf
(
"Error preparing Parallels Tools path: %s"
,
err
)
err
:=
fmt
.
Errorf
(
"Error preparing Parallels Tools path: %s"
,
err
)
state
.
Put
(
"error"
,
err
)
state
.
Put
(
"error"
,
err
)
...
...
builder/parallels/common/tools_config.go
View file @
76c2d2cb
...
@@ -3,8 +3,8 @@ package common
...
@@ -3,8 +3,8 @@ package common
import
(
import
(
"errors"
"errors"
"fmt"
"fmt"
"github.com/mitchellh/packer/packer"
"
text/temp
late"
"
github.com/mitchellh/packer/template/interpo
late"
)
)
// These are the different valid mode values for "parallels_tools_mode" which
// These are the different valid mode values for "parallels_tools_mode" which
...
@@ -21,7 +21,7 @@ type ToolsConfig struct {
...
@@ -21,7 +21,7 @@ type ToolsConfig struct {
ParallelsToolsMode
string
`mapstructure:"parallels_tools_mode"`
ParallelsToolsMode
string
`mapstructure:"parallels_tools_mode"`
}
}
func
(
c
*
ToolsConfig
)
Prepare
(
t
*
packer
.
ConfigTemplate
)
[]
error
{
func
(
c
*
ToolsConfig
)
Prepare
(
ctx
*
interpolate
.
Context
)
[]
error
{
if
c
.
ParallelsToolsMode
==
""
{
if
c
.
ParallelsToolsMode
==
""
{
c
.
ParallelsToolsMode
=
ParallelsToolsModeUpload
c
.
ParallelsToolsMode
=
ParallelsToolsModeUpload
}
}
...
@@ -30,24 +30,6 @@ func (c *ToolsConfig) Prepare(t *packer.ConfigTemplate) []error {
...
@@ -30,24 +30,6 @@ func (c *ToolsConfig) Prepare(t *packer.ConfigTemplate) []error {
c
.
ParallelsToolsGuestPath
=
"prl-tools-{{.Flavor}}.iso"
c
.
ParallelsToolsGuestPath
=
"prl-tools-{{.Flavor}}.iso"
}
}
templates
:=
map
[
string
]
*
string
{
"parallels_tools_flavor"
:
&
c
.
ParallelsToolsFlavor
,
"parallels_tools_mode"
:
&
c
.
ParallelsToolsMode
,
}
var
err
error
errs
:=
make
([]
error
,
0
)
for
n
,
ptr
:=
range
templates
{
*
ptr
,
err
=
t
.
Process
(
*
ptr
,
nil
)
if
err
!=
nil
{
errs
=
append
(
errs
,
fmt
.
Errorf
(
"Error processing %s: %s"
,
n
,
err
))
}
}
if
_
,
err
:=
template
.
New
(
"path"
)
.
Parse
(
c
.
ParallelsToolsGuestPath
);
err
!=
nil
{
errs
=
append
(
errs
,
fmt
.
Errorf
(
"parallels_tools_guest_path invalid: %s"
,
err
))
}
validMode
:=
false
validMode
:=
false
validModes
:=
[]
string
{
validModes
:=
[]
string
{
ParallelsToolsModeDisable
,
ParallelsToolsModeDisable
,
...
@@ -62,6 +44,7 @@ func (c *ToolsConfig) Prepare(t *packer.ConfigTemplate) []error {
...
@@ -62,6 +44,7 @@ func (c *ToolsConfig) Prepare(t *packer.ConfigTemplate) []error {
}
}
}
}
var
errs
[]
error
if
!
validMode
{
if
!
validMode
{
errs
=
append
(
errs
,
errs
=
append
(
errs
,
fmt
.
Errorf
(
"parallels_tools_mode is invalid. Must be one of: %v"
,
fmt
.
Errorf
(
"parallels_tools_mode is invalid. Must be one of: %v"
,
...
...
builder/parallels/iso/builder.go
View file @
76c2d2cb
...
@@ -3,22 +3,25 @@ package iso
...
@@ -3,22 +3,25 @@ package iso
import
(
import
(
"errors"
"errors"
"fmt"
"fmt"
"log"
"strings"
"github.com/mitchellh/multistep"
"github.com/mitchellh/multistep"
parallelscommon
"github.com/mitchellh/packer/builder/parallels/common"
parallelscommon
"github.com/mitchellh/packer/builder/parallels/common"
"github.com/mitchellh/packer/common"
"github.com/mitchellh/packer/common"
"github.com/mitchellh/packer/helper/config"
"github.com/mitchellh/packer/packer"
"github.com/mitchellh/packer/packer"
"log"
"github.com/mitchellh/packer/template/interpolate"
"strings"
)
)
const
BuilderId
=
"rickard-von-essen.parallels"
const
BuilderId
=
"rickard-von-essen.parallels"
type
Builder
struct
{
type
Builder
struct
{
config
c
onfig
config
C
onfig
runner
multistep
.
Runner
runner
multistep
.
Runner
}
}
type
c
onfig
struct
{
type
C
onfig
struct
{
common
.
PackerConfig
`mapstructure:",squash"`
common
.
PackerConfig
`mapstructure:",squash"`
parallelscommon
.
FloppyConfig
`mapstructure:",squash"`
parallelscommon
.
FloppyConfig
`mapstructure:",squash"`
parallelscommon
.
OutputConfig
`mapstructure:",squash"`
parallelscommon
.
OutputConfig
`mapstructure:",squash"`
...
@@ -48,33 +51,35 @@ type config struct {
...
@@ -48,33 +51,35 @@ type config struct {
GuestOSDistribution
string
`mapstructure:"guest_os_distribution"`
GuestOSDistribution
string
`mapstructure:"guest_os_distribution"`
ParallelsToolsHostPath
string
`mapstructure:"parallels_tools_host_path"`
ParallelsToolsHostPath
string
`mapstructure:"parallels_tools_host_path"`
tpl
*
packer
.
ConfigTemplate
ctx
interpolate
.
Context
}
}
func
(
b
*
Builder
)
Prepare
(
raws
...
interface
{})
([]
string
,
error
)
{
func
(
b
*
Builder
)
Prepare
(
raws
...
interface
{})
([]
string
,
error
)
{
err
:=
config
.
Decode
(
&
b
.
config
,
&
config
.
DecodeOpts
{
md
,
err
:=
common
.
DecodeConfig
(
&
b
.
config
,
raws
...
)
Interpolate
:
true
,
if
err
!=
nil
{
InterpolateFilter
:
&
interpolate
.
RenderFilter
{
return
nil
,
err
Exclude
:
[]
string
{
}
"boot_command"
,
"prlctl"
,
b
.
config
.
tpl
,
err
=
packer
.
NewConfigTemplate
()
"parallel_tools_guest_path"
,
},
},
},
raws
...
)
if
err
!=
nil
{
if
err
!=
nil
{
return
nil
,
err
return
nil
,
err
}
}
b
.
config
.
tpl
.
UserVars
=
b
.
config
.
PackerUserVars
// Accumulate any errors and warnings
// Accumulate any errors and warnings
errs
:=
common
.
CheckUnusedConfig
(
md
)
var
errs
*
packer
.
MultiError
errs
=
packer
.
MultiErrorAppend
(
errs
,
b
.
config
.
FloppyConfig
.
Prepare
(
b
.
config
.
tpl
)
...
)
errs
=
packer
.
MultiErrorAppend
(
errs
,
b
.
config
.
FloppyConfig
.
Prepare
(
&
b
.
config
.
ctx
)
...
)
errs
=
packer
.
MultiErrorAppend
(
errs
=
packer
.
MultiErrorAppend
(
errs
,
b
.
config
.
OutputConfig
.
Prepare
(
b
.
config
.
tpl
,
&
b
.
config
.
PackerConfig
)
...
)
errs
,
b
.
config
.
OutputConfig
.
Prepare
(
&
b
.
config
.
ctx
,
&
b
.
config
.
PackerConfig
)
...
)
errs
=
packer
.
MultiErrorAppend
(
errs
,
b
.
config
.
RunConfig
.
Prepare
(
b
.
config
.
tpl
)
...
)
errs
=
packer
.
MultiErrorAppend
(
errs
,
b
.
config
.
RunConfig
.
Prepare
(
&
b
.
config
.
ctx
)
...
)
errs
=
packer
.
MultiErrorAppend
(
errs
,
b
.
config
.
PrlctlConfig
.
Prepare
(
b
.
config
.
tpl
)
...
)
errs
=
packer
.
MultiErrorAppend
(
errs
,
b
.
config
.
PrlctlConfig
.
Prepare
(
&
b
.
config
.
ctx
)
...
)
errs
=
packer
.
MultiErrorAppend
(
errs
,
b
.
config
.
PrlctlVersionConfig
.
Prepare
(
b
.
config
.
tpl
)
...
)
errs
=
packer
.
MultiErrorAppend
(
errs
,
b
.
config
.
PrlctlVersionConfig
.
Prepare
(
&
b
.
config
.
ctx
)
...
)
errs
=
packer
.
MultiErrorAppend
(
errs
,
b
.
config
.
ShutdownConfig
.
Prepare
(
b
.
config
.
tpl
)
...
)
errs
=
packer
.
MultiErrorAppend
(
errs
,
b
.
config
.
ShutdownConfig
.
Prepare
(
&
b
.
config
.
ctx
)
...
)
errs
=
packer
.
MultiErrorAppend
(
errs
,
b
.
config
.
SSHConfig
.
Prepare
(
b
.
config
.
tpl
)
...
)
errs
=
packer
.
MultiErrorAppend
(
errs
,
b
.
config
.
SSHConfig
.
Prepare
(
&
b
.
config
.
ctx
)
...
)
errs
=
packer
.
MultiErrorAppend
(
errs
,
b
.
config
.
ToolsConfig
.
Prepare
(
b
.
config
.
tpl
)
...
)
errs
=
packer
.
MultiErrorAppend
(
errs
,
b
.
config
.
ToolsConfig
.
Prepare
(
&
b
.
config
.
ctx
)
...
)
warnings
:=
make
([]
string
,
0
)
warnings
:=
make
([]
string
,
0
)
if
b
.
config
.
DiskSize
==
0
{
if
b
.
config
.
DiskSize
==
0
{
...
@@ -116,42 +121,6 @@ func (b *Builder) Prepare(raws ...interface{}) ([]string, error) {
...
@@ -116,42 +121,6 @@ func (b *Builder) Prepare(raws ...interface{}) ([]string, error) {
b
.
config
.
VMName
=
fmt
.
Sprintf
(
"packer-%s"
,
b
.
config
.
PackerBuildName
)
b
.
config
.
VMName
=
fmt
.
Sprintf
(
"packer-%s"
,
b
.
config
.
PackerBuildName
)
}
}
// Errors
templates
:=
map
[
string
]
*
string
{
"guest_os_type"
:
&
b
.
config
.
GuestOSType
,
"hard_drive_interface"
:
&
b
.
config
.
HardDriveInterface
,
"http_directory"
:
&
b
.
config
.
HTTPDir
,
"iso_checksum"
:
&
b
.
config
.
ISOChecksum
,
"iso_checksum_type"
:
&
b
.
config
.
ISOChecksumType
,
"iso_url"
:
&
b
.
config
.
RawSingleISOUrl
,
"vm_name"
:
&
b
.
config
.
VMName
,
}
for
n
,
ptr
:=
range
templates
{
var
err
error
*
ptr
,
err
=
b
.
config
.
tpl
.
Process
(
*
ptr
,
nil
)
if
err
!=
nil
{
errs
=
packer
.
MultiErrorAppend
(
errs
,
fmt
.
Errorf
(
"Error processing %s: %s"
,
n
,
err
))
}
}
for
i
,
url
:=
range
b
.
config
.
ISOUrls
{
var
err
error
b
.
config
.
ISOUrls
[
i
],
err
=
b
.
config
.
tpl
.
Process
(
url
,
nil
)
if
err
!=
nil
{
errs
=
packer
.
MultiErrorAppend
(
errs
,
fmt
.
Errorf
(
"Error processing iso_urls[%d]: %s"
,
i
,
err
))
}
}
for
i
,
command
:=
range
b
.
config
.
BootCommand
{
if
err
:=
b
.
config
.
tpl
.
Validate
(
command
);
err
!=
nil
{
errs
=
packer
.
MultiErrorAppend
(
errs
,
fmt
.
Errorf
(
"Error processing boot_command[%d]: %s"
,
i
,
err
))
}
}
if
b
.
config
.
HardDriveInterface
!=
"ide"
&&
b
.
config
.
HardDriveInterface
!=
"sata"
&&
b
.
config
.
HardDriveInterface
!=
"scsi"
{
if
b
.
config
.
HardDriveInterface
!=
"ide"
&&
b
.
config
.
HardDriveInterface
!=
"sata"
&&
b
.
config
.
HardDriveInterface
!=
"scsi"
{
errs
=
packer
.
MultiErrorAppend
(
errs
=
packer
.
MultiErrorAppend
(
errs
,
errors
.
New
(
"hard_drive_interface can only be ide, sata, or scsi"
))
errs
,
errors
.
New
(
"hard_drive_interface can only be ide, sata, or scsi"
))
...
@@ -264,7 +233,7 @@ func (b *Builder) Run(ui packer.Ui, hook packer.Hook, cache packer.Cache) (packe
...
@@ -264,7 +233,7 @@ func (b *Builder) Run(ui packer.Ui, hook packer.Hook, cache packer.Cache) (packe
new
(
parallelscommon
.
StepAttachFloppy
),
new
(
parallelscommon
.
StepAttachFloppy
),
&
parallelscommon
.
StepPrlctl
{
&
parallelscommon
.
StepPrlctl
{
Commands
:
b
.
config
.
Prlctl
,
Commands
:
b
.
config
.
Prlctl
,
Tpl
:
b
.
config
.
tpl
,
Ctx
:
b
.
config
.
ctx
,
},
},
&
parallelscommon
.
StepRun
{
&
parallelscommon
.
StepRun
{
BootWait
:
b
.
config
.
BootWait
,
BootWait
:
b
.
config
.
BootWait
,
...
@@ -274,7 +243,7 @@ func (b *Builder) Run(ui packer.Ui, hook packer.Hook, cache packer.Cache) (packe
...
@@ -274,7 +243,7 @@ func (b *Builder) Run(ui packer.Ui, hook packer.Hook, cache packer.Cache) (packe
BootCommand
:
b
.
config
.
BootCommand
,
BootCommand
:
b
.
config
.
BootCommand
,
HostInterfaces
:
b
.
config
.
HostInterfaces
,
HostInterfaces
:
b
.
config
.
HostInterfaces
,
VMName
:
b
.
config
.
VMName
,
VMName
:
b
.
config
.
VMName
,
Tpl
:
b
.
config
.
tpl
,
Ctx
:
b
.
config
.
ctx
,
},
},
&
common
.
StepConnectSSH
{
&
common
.
StepConnectSSH
{
SSHAddress
:
parallelscommon
.
SSHAddress
,
SSHAddress
:
parallelscommon
.
SSHAddress
,
...
@@ -288,7 +257,7 @@ func (b *Builder) Run(ui packer.Ui, hook packer.Hook, cache packer.Cache) (packe
...
@@ -288,7 +257,7 @@ func (b *Builder) Run(ui packer.Ui, hook packer.Hook, cache packer.Cache) (packe
ParallelsToolsFlavor
:
b
.
config
.
ParallelsToolsFlavor
,
ParallelsToolsFlavor
:
b
.
config
.
ParallelsToolsFlavor
,
ParallelsToolsGuestPath
:
b
.
config
.
ParallelsToolsGuestPath
,
ParallelsToolsGuestPath
:
b
.
config
.
ParallelsToolsGuestPath
,
ParallelsToolsMode
:
b
.
config
.
ParallelsToolsMode
,
ParallelsToolsMode
:
b
.
config
.
ParallelsToolsMode
,
Tpl
:
b
.
config
.
tpl
,
Ctx
:
b
.
config
.
ctx
,
},
},
new
(
common
.
StepProvision
),
new
(
common
.
StepProvision
),
&
parallelscommon
.
StepShutdown
{
&
parallelscommon
.
StepShutdown
{
...
...
builder/parallels/iso/step_create_disk.go
View file @
76c2d2cb
...
@@ -13,7 +13,7 @@ import (
...
@@ -13,7 +13,7 @@ import (
type
stepCreateDisk
struct
{}
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"
)
.
(
*
c
onfig
)
config
:=
state
.
Get
(
"config"
)
.
(
*
C
onfig
)
driver
:=
state
.
Get
(
"driver"
)
.
(
parallelscommon
.
Driver
)
driver
:=
state
.
Get
(
"driver"
)
.
(
parallelscommon
.
Driver
)
ui
:=
state
.
Get
(
"ui"
)
.
(
packer
.
Ui
)
ui
:=
state
.
Get
(
"ui"
)
.
(
packer
.
Ui
)
vmName
:=
state
.
Get
(
"vmName"
)
.
(
string
)
vmName
:=
state
.
Get
(
"vmName"
)
.
(
string
)
...
...
builder/parallels/iso/step_create_vm.go
View file @
76c2d2cb
...
@@ -18,7 +18,7 @@ type stepCreateVM struct {
...
@@ -18,7 +18,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"
)
.
(
*
c
onfig
)
config
:=
state
.
Get
(
"config"
)
.
(
*
C
onfig
)
driver
:=
state
.
Get
(
"driver"
)
.
(
parallelscommon
.
Driver
)
driver
:=
state
.
Get
(
"driver"
)
.
(
parallelscommon
.
Driver
)
ui
:=
state
.
Get
(
"ui"
)
.
(
packer
.
Ui
)
ui
:=
state
.
Get
(
"ui"
)
.
(
packer
.
Ui
)
name
:=
config
.
VMName
name
:=
config
.
VMName
...
...
builder/parallels/iso/step_http_server.go
View file @
76c2d2cb
...
@@ -25,7 +25,7 @@ type stepHTTPServer struct {
...
@@ -25,7 +25,7 @@ type stepHTTPServer struct {
}
}
func
(
s
*
stepHTTPServer
)
Run
(
state
multistep
.
StateBag
)
multistep
.
StepAction
{
func
(
s
*
stepHTTPServer
)
Run
(
state
multistep
.
StateBag
)
multistep
.
StepAction
{
config
:=
state
.
Get
(
"config"
)
.
(
*
c
onfig
)
config
:=
state
.
Get
(
"config"
)
.
(
*
C
onfig
)
ui
:=
state
.
Get
(
"ui"
)
.
(
packer
.
Ui
)
ui
:=
state
.
Get
(
"ui"
)
.
(
packer
.
Ui
)
var
httpPort
uint
=
0
var
httpPort
uint
=
0
...
...
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