Documentation ¶
Index ¶
- Constants
- func CommHost(state multistep.StateBag) (string, error)
- func NewArtifact(dir string) (packer.Artifact, error)
- func SSHConfigFunc(config SSHConfig) func(multistep.StateBag) (*ssh.ClientConfig, error)
- type Driver
- type DriverMock
- func (d *DriverMock) CompactDisk(path string) error
- func (d *DriverMock) DeviceAddCdRom(name string, image string) (string, error)
- func (d *DriverMock) DiskPath(name string) (string, error)
- func (d *DriverMock) Import(name, srcPath, dstPath string, reassignMac bool) error
- func (d *DriverMock) IpAddress(mac string) (string, error)
- func (d *DriverMock) IsRunning(name string) (bool, error)
- func (d *DriverMock) Mac(name string) (string, error)
- func (d *DriverMock) Prlctl(args ...string) error
- func (d *DriverMock) SendKeyScanCodes(name string, scancodes ...string) error
- func (d *DriverMock) SetDefaultConfiguration(name string) error
- func (d *DriverMock) Stop(name string) error
- func (d *DriverMock) ToolsIsoPath(flavor string) (string, error)
- func (d *DriverMock) Verify() error
- func (d *DriverMock) Version() (string, error)
- type FloppyConfig
- type HostIPFinder
- type IfconfigIPFinder
- type OutputConfig
- type Parallels10Driver
- type Parallels11Driver
- type Parallels9Driver
- func (d *Parallels9Driver) CompactDisk(diskPath string) error
- func (d *Parallels9Driver) DeviceAddCdRom(name string, image string) (string, error)
- func (d *Parallels9Driver) DiskPath(name string) (string, error)
- func (d *Parallels9Driver) Import(name, srcPath, dstDir string, reassignMac bool) error
- func (d *Parallels9Driver) IpAddress(mac string) (string, error)
- func (d *Parallels9Driver) IsRunning(name string) (bool, error)
- func (d *Parallels9Driver) Mac(vmName string) (string, error)
- func (d *Parallels9Driver) Prlctl(args ...string) error
- func (d *Parallels9Driver) SendKeyScanCodes(vmName string, codes ...string) error
- func (d *Parallels9Driver) SetDefaultConfiguration(vmName string) error
- func (d *Parallels9Driver) Stop(name string) error
- func (d *Parallels9Driver) ToolsIsoPath(k string) (string, error)
- func (d *Parallels9Driver) Verify() error
- func (d *Parallels9Driver) Version() (string, error)
- type PrlctlConfig
- type PrlctlPostConfig
- type PrlctlVersionConfig
- type RunConfig
- type SSHConfig
- type ShutdownConfig
- type StepAttachFloppy
- type StepAttachParallelsTools
- type StepCompactDisk
- type StepOutputDir
- type StepPrepareParallelsTools
- type StepPrlctl
- type StepRun
- type StepShutdown
- type StepTypeBootCommand
- type StepUploadParallelsTools
- type StepUploadVersion
- type ToolsConfig
Constants ¶
const ( ParallelsToolsModeDisable string = "disable" ParallelsToolsModeAttach = "attach" ParallelsToolsModeUpload = "upload" )
These are the different valid mode values for "parallels_tools_mode" which determine how guest additions are delivered to the guest.
const BuilderId = "packer.parallels"
This is the common builder ID to all of these artifacts.
const KeyLeftShift uint32 = 0xFFE1
const Prltype string = `` /* 1593-byte string literal not displayed */
Variables ¶
This section is empty.
Functions ¶
func NewArtifact ¶
NewArtifact returns a Parallels artifact containing the files in the given directory.
func SSHConfigFunc ¶
Types ¶
type Driver ¶
type Driver interface { // Compact a virtual disk image. CompactDisk(string) error // Adds new CD/DVD drive to the VM and returns name of this device DeviceAddCdRom(string, string) (string, error) // Get path to the first virtual disk image DiskPath(string) (string, error) // Import a VM Import(string, string, string, bool) error // Checks if the VM with the given name is running. IsRunning(string) (bool, error) // Stop stops a running machine, forcefully. Stop(string) error // Prlctl executes the given Prlctl command Prlctl(...string) error // Get the path to the Parallels Tools ISO for the given flavor. ToolsIsoPath(string) (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 Parallels that is installed. Version() (string, error) // Send scancodes to the vm using the prltype python script. SendKeyScanCodes(string, ...string) error // Apply default сonfiguration settings to the virtual machine SetDefaultConfiguration(string) error // Finds the MAC address of the NIC nic0 Mac(string) (string, error) // Finds the IP address of a VM connected that uses DHCP by its MAC address IpAddress(string) (string, error) }
A driver is able to talk to Parallels 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 Parallels builder for Packer, and to abstract differences in versions out of the builder steps, so sometimes the methods are extremely specific.
type DriverMock ¶
type DriverMock struct { sync.Mutex CompactDiskCalled bool CompactDiskPath string CompactDiskErr error DeviceAddCdRomCalled bool DeviceAddCdRomName string DeviceAddCdRomImage string DeviceAddCdRomResult string DeviceAddCdRomErr error DiskPathCalled bool DiskPathName string DiskPathResult string DiskPathErr error ImportCalled bool ImportName string ImportSrcPath string ImportDstPath string ImportErr error IsRunningName string IsRunningReturn bool IsRunningErr error StopName string StopErr error PrlctlCalls [][]string PrlctlErrs []error VerifyCalled bool VerifyErr error VersionCalled bool VersionResult string VersionErr error SendKeyScanCodesCalls [][]string SendKeyScanCodesErrs []error SetDefaultConfigurationCalled bool SetDefaultConfigurationError error ToolsIsoPathCalled bool ToolsIsoPathFlavor string ToolsIsoPathResult string ToolsIsoPathErr error MacName string MacReturn string MacError error IpAddressMac string IpAddressReturn string IpAddressError error }
func (*DriverMock) CompactDisk ¶
func (d *DriverMock) CompactDisk(path string) error
func (*DriverMock) DeviceAddCdRom ¶
func (d *DriverMock) DeviceAddCdRom(name string, image string) (string, error)
func (*DriverMock) Import ¶
func (d *DriverMock) Import(name, srcPath, dstPath string, reassignMac bool) error
func (*DriverMock) Prlctl ¶
func (d *DriverMock) Prlctl(args ...string) error
func (*DriverMock) SendKeyScanCodes ¶
func (d *DriverMock) SendKeyScanCodes(name string, scancodes ...string) error
func (*DriverMock) SetDefaultConfiguration ¶
func (d *DriverMock) SetDefaultConfiguration(name string) error
func (*DriverMock) Stop ¶
func (d *DriverMock) Stop(name string) error
func (*DriverMock) ToolsIsoPath ¶
func (d *DriverMock) ToolsIsoPath(flavor string) (string, error)
func (*DriverMock) Verify ¶
func (d *DriverMock) Verify() error
func (*DriverMock) Version ¶
func (d *DriverMock) Version() (string, error)
type FloppyConfig ¶
type FloppyConfig struct {
FloppyFiles []string `mapstructure:"floppy_files"`
}
FloppyConfig is configuration related to created floppy disks and attaching them to a Parallels virtual machine.
func (*FloppyConfig) Prepare ¶
func (c *FloppyConfig) Prepare(ctx *interpolate.Context) []error
type HostIPFinder ¶
Interface to help find the host IP that is available from within the Parallels virtual machines.
type IfconfigIPFinder ¶
type IfconfigIPFinder struct {
Devices []string
}
IfconfigIPFinder finds the host IP based on the output of `ifconfig`.
func (*IfconfigIPFinder) HostIP ¶
func (f *IfconfigIPFinder) HostIP() (string, error)
type OutputConfig ¶
type OutputConfig struct {
OutputDir string `mapstructure:"output_directory"`
}
func (*OutputConfig) Prepare ¶
func (c *OutputConfig) Prepare(ctx *interpolate.Context, pc *common.PackerConfig) []error
type Parallels10Driver ¶
type Parallels10Driver struct {
Parallels9Driver
}
Parallels10Driver are inherited from Parallels9Driver. Used for Parallels v 10 & 11
func (*Parallels10Driver) SetDefaultConfiguration ¶
func (d *Parallels10Driver) SetDefaultConfiguration(vmName string) error
type Parallels11Driver ¶
type Parallels11Driver struct {
Parallels9Driver
}
Parallels11Driver are inherited from Parallels9Driver. Used for Parallels Desktop 11, requires Pro or Business Edition
func (*Parallels11Driver) SetDefaultConfiguration ¶
func (d *Parallels11Driver) SetDefaultConfiguration(vmName string) error
func (*Parallels11Driver) Verify ¶
func (d *Parallels11Driver) Verify() error
type Parallels9Driver ¶
type Parallels9Driver struct { // This is the path to the "prlctl" application. PrlctlPath string // This is the path to the "prlsrvctl" application. PrlsrvctlPath string // contains filtered or unexported fields }
func (*Parallels9Driver) CompactDisk ¶
func (d *Parallels9Driver) CompactDisk(diskPath string) error
func (*Parallels9Driver) DeviceAddCdRom ¶
func (d *Parallels9Driver) DeviceAddCdRom(name string, image string) (string, error)
func (*Parallels9Driver) DiskPath ¶
func (d *Parallels9Driver) DiskPath(name string) (string, error)
func (*Parallels9Driver) Import ¶
func (d *Parallels9Driver) Import(name, srcPath, dstDir string, reassignMac bool) error
func (*Parallels9Driver) IpAddress ¶
func (d *Parallels9Driver) IpAddress(mac string) (string, error)
Finds the IP address of a VM connected that uses DHCP by its MAC address
Parses the file /Library/Preferences/Parallels/parallels_dhcp_leases file contain a list of DHCP leases given by Parallels Desktop Example line: 10.211.55.181="1418921112,1800,001c42f593fb,ff42f593fb000100011c25b9ff001c42f593fb" IP Address ="Lease expiry, Lease time, MAC, MAC or DUID"
func (*Parallels9Driver) IsRunning ¶
func (d *Parallels9Driver) IsRunning(name string) (bool, error)
func (*Parallels9Driver) Prlctl ¶
func (d *Parallels9Driver) Prlctl(args ...string) error
func (*Parallels9Driver) SendKeyScanCodes ¶
func (d *Parallels9Driver) SendKeyScanCodes(vmName string, codes ...string) error
func (*Parallels9Driver) SetDefaultConfiguration ¶
func (d *Parallels9Driver) SetDefaultConfiguration(vmName string) error
func (*Parallels9Driver) Stop ¶
func (d *Parallels9Driver) Stop(name string) error
func (*Parallels9Driver) ToolsIsoPath ¶
func (d *Parallels9Driver) ToolsIsoPath(k string) (string, error)
func (*Parallels9Driver) Verify ¶
func (d *Parallels9Driver) Verify() error
func (*Parallels9Driver) Version ¶
func (d *Parallels9Driver) Version() (string, error)
type PrlctlConfig ¶
type PrlctlConfig struct {
Prlctl [][]string `mapstructure:"prlctl"`
}
func (*PrlctlConfig) Prepare ¶
func (c *PrlctlConfig) Prepare(ctx *interpolate.Context) []error
type PrlctlPostConfig ¶
type PrlctlPostConfig struct {
PrlctlPost [][]string `mapstructure:"prlctl_post"`
}
func (*PrlctlPostConfig) Prepare ¶
func (c *PrlctlPostConfig) Prepare(ctx *interpolate.Context) []error
type PrlctlVersionConfig ¶
type PrlctlVersionConfig struct {
PrlctlVersionFile string `mapstructure:"prlctl_version_file"`
}
func (*PrlctlVersionConfig) Prepare ¶
func (c *PrlctlVersionConfig) Prepare(ctx *interpolate.Context) []error
type SSHConfig ¶
type SSHConfig struct { Comm communicator.Config `mapstructure:",squash"` // These are deprecated, but we keep them around for BC // TODO(@mitchellh): remove SSHKeyPath string `mapstructure:"ssh_key_path"` SSHWaitTimeout time.Duration `mapstructure:"ssh_wait_timeout"` }
type ShutdownConfig ¶
type ShutdownConfig struct { ShutdownCommand string `mapstructure:"shutdown_command"` RawShutdownTimeout string `mapstructure:"shutdown_timeout"` ShutdownTimeout time.Duration `` }
func (*ShutdownConfig) Prepare ¶
func (c *ShutdownConfig) Prepare(ctx *interpolate.Context) []error
type StepAttachFloppy ¶
type StepAttachFloppy struct {
// contains filtered or unexported fields
}
This step attaches a floppy to the virtual machine.
Uses:
driver Driver ui packer.Ui vmName string
Produces:
func (*StepAttachFloppy) Cleanup ¶
func (s *StepAttachFloppy) Cleanup(state multistep.StateBag)
func (*StepAttachFloppy) Run ¶
func (s *StepAttachFloppy) Run(state multistep.StateBag) multistep.StepAction
type StepAttachParallelsTools ¶
type StepAttachParallelsTools struct { ParallelsToolsMode string // contains filtered or unexported fields }
This step attaches the Parallels Tools as an inserted CD onto the virtual machine.
Uses:
driver Driver parallels_tools_path string ui packer.Ui vmName string
Produces:
func (*StepAttachParallelsTools) Cleanup ¶
func (s *StepAttachParallelsTools) Cleanup(state multistep.StateBag)
func (*StepAttachParallelsTools) Run ¶
func (s *StepAttachParallelsTools) Run(state multistep.StateBag) multistep.StepAction
type StepCompactDisk ¶
type StepCompactDisk struct {
Skip bool
}
This step removes all empty blocks from expanding Parallels virtual disks and reduces the result disk size
Uses:
driver Driver vmName string ui packer.Ui
Produces:
<nothing>
func (*StepCompactDisk) Cleanup ¶
func (*StepCompactDisk) Cleanup(multistep.StateBag)
func (*StepCompactDisk) Run ¶
func (s *StepCompactDisk) Run(state multistep.StateBag) multistep.StepAction
type StepOutputDir ¶
StepOutputDir sets up the output directory by creating it if it does not exist, deleting it if it does exist and we're forcing, and cleaning it up when we're done with it.
func (*StepOutputDir) Cleanup ¶
func (s *StepOutputDir) Cleanup(state multistep.StateBag)
func (*StepOutputDir) Run ¶
func (s *StepOutputDir) Run(state multistep.StateBag) multistep.StepAction
type StepPrepareParallelsTools ¶
This step prepares parameters related to Parallels Tools.
Uses:
driver Driver
Produces:
parallels_tools_path string
func (*StepPrepareParallelsTools) Cleanup ¶
func (s *StepPrepareParallelsTools) Cleanup(multistep.StateBag)
func (*StepPrepareParallelsTools) Run ¶
func (s *StepPrepareParallelsTools) Run(state multistep.StateBag) multistep.StepAction
type StepPrlctl ¶
type StepPrlctl struct { Commands [][]string Ctx interpolate.Context }
This step executes additional prlctl commands as specified by the template.
Uses:
driver Driver ui packer.Ui vmName string
Produces:
func (*StepPrlctl) Cleanup ¶
func (s *StepPrlctl) Cleanup(state multistep.StateBag)
func (*StepPrlctl) Run ¶
func (s *StepPrlctl) Run(state multistep.StateBag) multistep.StepAction
type StepRun ¶
This step starts the virtual machine.
Uses:
driver Driver ui packer.Ui vmName string
Produces:
type StepShutdown ¶
This step shuts down the machine. It first attempts to do so gracefully, but ultimately forcefully shuts it down if that fails.
Uses:
communicator packer.Communicator driver Driver ui packer.Ui vmName string
Produces:
<nothing>
func (*StepShutdown) Cleanup ¶
func (s *StepShutdown) Cleanup(state multistep.StateBag)
func (*StepShutdown) Run ¶
func (s *StepShutdown) Run(state multistep.StateBag) multistep.StepAction
type StepTypeBootCommand ¶
type StepTypeBootCommand struct { BootCommand []string HostInterfaces []string VMName string Ctx interpolate.Context }
This step "types" the boot command into the VM via the prltype script, built on the Parallels Virtualization SDK - Python API.
Uses:
driver Driver http_port int ui packer.Ui vmName string
Produces:
<nothing>
func (*StepTypeBootCommand) Cleanup ¶
func (*StepTypeBootCommand) Cleanup(multistep.StateBag)
func (*StepTypeBootCommand) Run ¶
func (s *StepTypeBootCommand) Run(state multistep.StateBag) multistep.StepAction
type StepUploadParallelsTools ¶
type StepUploadParallelsTools struct { ParallelsToolsFlavor string ParallelsToolsGuestPath string ParallelsToolsMode string Ctx interpolate.Context }
This step uploads the guest additions ISO to the VM.
func (*StepUploadParallelsTools) Cleanup ¶
func (s *StepUploadParallelsTools) Cleanup(state multistep.StateBag)
func (*StepUploadParallelsTools) Run ¶
func (s *StepUploadParallelsTools) Run(state multistep.StateBag) multistep.StepAction
type StepUploadVersion ¶
type StepUploadVersion struct {
Path string
}
This step uploads a file containing the Parallels version, which can be useful for various provisioning reasons.
func (*StepUploadVersion) Cleanup ¶
func (s *StepUploadVersion) Cleanup(state multistep.StateBag)
func (*StepUploadVersion) Run ¶
func (s *StepUploadVersion) Run(state multistep.StateBag) multistep.StepAction
type ToolsConfig ¶
type ToolsConfig struct { ParallelsToolsFlavor string `mapstructure:"parallels_tools_flavor"` ParallelsToolsGuestPath string `mapstructure:"parallels_tools_guest_path"` ParallelsToolsMode string `mapstructure:"parallels_tools_mode"` }
func (*ToolsConfig) Prepare ¶
func (c *ToolsConfig) Prepare(ctx *interpolate.Context) []error
Source Files ¶
- artifact.go
- driver.go
- driver_10.go
- driver_11.go
- driver_9.go
- driver_mock.go
- floppy_config.go
- host_ip.go
- host_ip_ifconfig.go
- output_config.go
- prlctl_config.go
- prlctl_post_config.go
- prlctl_version_config.go
- prltype.go
- run_config.go
- shutdown_config.go
- ssh.go
- ssh_config.go
- step_attach_floppy.go
- step_attach_parallels_tools.go
- step_compact_disk.go
- step_output_dir.go
- step_prepare_parallels_tools.go
- step_prlctl.go
- step_run.go
- step_shutdown.go
- step_type_boot_command.go
- step_upload_parallels_tools.go
- step_upload_version.go
- tools_config.go