Documentation ¶
Index ¶
- Constants
- func CommHost(host string) func(multistep.StateBag) (string, error)
- func NewArtifact(dir string, generatedData map[string]interface{}) (packersdk.Artifact, error)
- type BootScreenConfig
- type BootScreensConfig
- 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) IPAddress(mac string, vmName string) (string, error)
- func (d *DriverMock) Import(name, srcPath, dstPath string, reassignMAC bool) 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) PrlctlGet(...string) (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 FlatBootScreenConfig
- type HWConfig
- type HostIPFinder
- type IfconfigIPFinder
- type OCRWrapper
- 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) IPAddress(mac string, vmName string) (string, error)
- func (d *Parallels9Driver) Import(name, srcPath, dstDir string, reassignMAC bool) 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) PrlctlGet(args ...string) (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 SSHConfig
- type ScanCodes
- type StepAttachCD
- type StepAttachFloppy
- type StepAttachParallelsTools
- type StepCompactDisk
- type StepImport
- type StepOutputDir
- type StepPrepareParallelsTools
- type StepPrlctl
- type StepRun
- type StepScreenBasedBoot
- type StepShutdown
- type StepTypeBootCommand
- type StepUploadParallelsTools
- type StepUploadVersion
- type TesseractOCRWrapper
- type ToolsConfig
- type VisionOCRWrapper
- type WindowIDDetector
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"
BuilderId is the common builder ID to all of these artifacts.
const Prltype string = `` /* 1918-byte string literal not displayed */
Prltype is a Python 2 script that sends scancodes to a Parallels VM. It requires the prlsdkapi Python module, which is bundled with the Parallels Virtualization SDK.
Variables ¶
This section is empty.
Functions ¶
Types ¶
type BootScreenConfig ¶ added in v1.2.0
type BootScreenConfig struct { // BootConfig for this screen bootcommand.BootConfig `mapstructure:",squash"` // Screen name to identify ScreenName string `mapstructure:"screen_name"` // Strings present in the screen to identify this screen MatchingStrings []string `mapstructure:"matching_strings"` // Specifies if the current screen is the last screen // Screen based boot will stop after this screen IsLastScreen bool `mapstructure:"is_last_screen"` // If true, the screen will be deleted after first execution // Default value is false ExecuteOnlyOnce bool `mapstructure:"execute_only_once"` }
func (*BootScreenConfig) FlatBootCommand ¶ added in v1.2.0
func (c *BootScreenConfig) FlatBootCommand() string
func (*BootScreenConfig) FlatMapstructure ¶ added in v1.2.0
func (*BootScreenConfig) FlatMapstructure() interface{ HCL2Spec() map[string]hcldec.Spec }
FlatMapstructure returns a new FlatBootScreenConfig. FlatBootScreenConfig is an auto-generated flat version of BootScreenConfig. Where the contents a fields with a `mapstructure:,squash` tag are bubbled up.
func (*BootScreenConfig) Prepare ¶ added in v1.2.0
func (c *BootScreenConfig) Prepare(ctx *interpolate.Context) (errs []error)
type BootScreensConfig ¶ added in v1.2.0
type BootScreensConfig []BootScreenConfig
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 // PrlctlGet executes the given Prlctl command and returns the output PrlctlGet(...string) (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 configuration 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) (string, error) }
Driver is the interface that talks to Parallels and performs 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) IPAddress ¶
func (d *DriverMock) IPAddress(mac string, vmName 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) PrlctlGet ¶ added in v1.2.0
func (d *DriverMock) PrlctlGet(...string) (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 FlatBootScreenConfig ¶ added in v1.2.0
type FlatBootScreenConfig struct { BootGroupInterval *string `mapstructure:"boot_keygroup_interval" cty:"boot_keygroup_interval" hcl:"boot_keygroup_interval"` BootWait *string `mapstructure:"boot_wait" cty:"boot_wait" hcl:"boot_wait"` BootCommand []string `mapstructure:"boot_command" cty:"boot_command" hcl:"boot_command"` ScreenName *string `mapstructure:"screen_name" cty:"screen_name" hcl:"screen_name"` MatchingStrings []string `mapstructure:"matching_strings" cty:"matching_strings" hcl:"matching_strings"` IsLastScreen *bool `mapstructure:"is_last_screen" cty:"is_last_screen" hcl:"is_last_screen"` ExecuteOnlyOnce *bool `mapstructure:"execute_only_once" cty:"execute_only_once" hcl:"execute_only_once"` }
FlatBootScreenConfig is an auto-generated flat version of BootScreenConfig. Where the contents of a field with a `mapstructure:,squash` tag are bubbled up.
func (*FlatBootScreenConfig) HCL2Spec ¶ added in v1.2.0
func (*FlatBootScreenConfig) HCL2Spec() map[string]hcldec.Spec
HCL2Spec returns the hcl spec of a BootScreenConfig. This spec is used by HCL to read the fields of BootScreenConfig. The decoded values from this spec will then be applied to a FlatBootScreenConfig.
type HWConfig ¶
type HWConfig struct { // The number of cpus to use for building the VM. // Defaults to 1. CpuCount int `mapstructure:"cpus" required:"false"` // The amount of memory to use for building the VM in // megabytes. Defaults to 512 megabytes. MemorySize int `mapstructure:"memory" required:"false"` // Specifies whether to enable the sound device when // building the VM. Defaults to false. Sound bool `mapstructure:"sound" required:"false"` // Specifies whether to enable the USB bus when building // the VM. Defaults to false. USB bool `mapstructure:"usb" required:"false"` }
type HostIPFinder ¶
HostIPFinder allows to 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)
HostIP returns the host's IP address or an error if it could not be found from the `ifconfig` output.
type OCRWrapper ¶ added in v1.2.0
type OCRWrapper interface { // IdentifyCurrentScreen takes a screenshot of the current screen and returns the BootScreenConfig that matches the screen. IdentifyCurrentScreen(imagePath string) (bootScreenConfig BootScreenConfig, err error) // Removes the screen config with specified name if exist RemoveBootScreenConfigIfExist(screenName string) }
func NewOCRWrapper ¶ added in v1.2.0
func NewOCRWrapper(OCRLibrary string, ScreenConfigs map[string]BootScreenConfig) (OCRWrapper, error)
type OutputConfig ¶
type OutputConfig struct { // This is the path to the directory where the // resulting virtual machine will be created. This may be relative or absolute. // If relative, the path is relative to the working directory when packer // is executed. This directory must not exist or be empty prior to running // the builder. By default this is "output-BUILDNAME" where "BUILDNAME" is the // name of the build. OutputDir string `mapstructure:"output_directory" required:"false"` }
OutputConfig contains the configuration for builder's output.
func (*OutputConfig) Prepare ¶
func (c *OutputConfig) Prepare(ctx *interpolate.Context, pc *common.PackerConfig) []error
Prepare configures the output directory or returns an error if it already exists.
type Parallels10Driver ¶
type Parallels10Driver struct {
Parallels9Driver
}
Parallels10Driver are inherited from Parallels9Driver.
func (*Parallels10Driver) SetDefaultConfiguration ¶
func (d *Parallels10Driver) SetDefaultConfiguration(vmName string) error
SetDefaultConfiguration applies pre-defined default settings to the VM config.
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
SetDefaultConfiguration applies pre-defined default settings to the VM config.
func (*Parallels11Driver) Verify ¶
func (d *Parallels11Driver) Verify() error
Verify raises an error if the builder could not be used on that host machine.
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 }
Parallels9Driver is a base type for Parallels builders.
func (*Parallels9Driver) CompactDisk ¶
func (d *Parallels9Driver) CompactDisk(diskPath string) error
CompactDisk performs the compaction of the specified virtual disk image.
func (*Parallels9Driver) DeviceAddCDROM ¶
func (d *Parallels9Driver) DeviceAddCDROM(name string, image string) (string, error)
DeviceAddCDROM adds a virtual CDROM device and attaches the specified image.
func (*Parallels9Driver) DiskPath ¶
func (d *Parallels9Driver) DiskPath(name string) (string, error)
DiskPath returns a full path to the first virtual disk drive.
func (*Parallels9Driver) IPAddress ¶
func (d *Parallels9Driver) IPAddress(mac string, vmName string) (string, error)
IPAddress finds the IP address of a VM connected that uses DHCP by its MAC address If the MAC address is not found in the DHCP lease file, it will try to find ip using prlctl
func (*Parallels9Driver) Import ¶
func (d *Parallels9Driver) Import(name, srcPath, dstDir string, reassignMAC bool) error
Import creates a clone of the source VM and reassigns the MAC address if needed.
func (*Parallels9Driver) IsRunning ¶
func (d *Parallels9Driver) IsRunning(name string) (bool, error)
IsRunning determines whether the VM is running or not.
func (*Parallels9Driver) MAC ¶
func (d *Parallels9Driver) MAC(vmName string) (string, error)
MAC returns the MAC address of the VM's first network interface.
func (*Parallels9Driver) Prlctl ¶
func (d *Parallels9Driver) Prlctl(args ...string) error
Prlctl executes the specified "prlctl" command.
func (*Parallels9Driver) PrlctlGet ¶ added in v1.2.0
func (d *Parallels9Driver) PrlctlGet(args ...string) (string, error)
PrlctlGet executes the given "prlctl" command and returns the output
func (*Parallels9Driver) SendKeyScanCodes ¶
func (d *Parallels9Driver) SendKeyScanCodes(vmName string, codes ...string) error
SendKeyScanCodes sends the specified scancodes as key events to the VM. It is performed using "Prltype" script (refer to "prltype.go") if version is < 19.0.0. scancodes are sent by using prlctl CMD if version is >= 19.0.0
func (*Parallels9Driver) SetDefaultConfiguration ¶
func (d *Parallels9Driver) SetDefaultConfiguration(vmName string) error
SetDefaultConfiguration applies pre-defined default settings to the VM config.
func (*Parallels9Driver) Stop ¶
func (d *Parallels9Driver) Stop(name string) error
Stop forcibly stops the VM.
func (*Parallels9Driver) ToolsISOPath ¶
func (d *Parallels9Driver) ToolsISOPath(k string) (string, error)
ToolsISOPath returns a full path to the Parallels Tools ISO for the specified guest OS type. The following OS types are supported: "win", "lin", "mac", "other".
func (*Parallels9Driver) Verify ¶
func (d *Parallels9Driver) Verify() error
Verify raises an error if the builder could not be used on that host machine.
func (*Parallels9Driver) Version ¶
func (d *Parallels9Driver) Version() (string, error)
Version returns the version of Parallels Desktop installed on that host.
type PrlctlConfig ¶
type PrlctlConfig struct { // Custom prlctl commands to execute // in order to further customize the virtual machine being created. The value // of this is an array of commands to execute. The commands are executed in the // order defined in the template. For each command, the command is defined // itself as an array of strings, where each string represents a single // argument on the command-line to prlctl (but excluding prlctl itself). // Each arg is treated as a configuration // template, where the Name // variable is replaced with the VM name. More details on how to use prlctl // are below. Prlctl [][]string `mapstructure:"prlctl" required:"false"` }
PrlctlConfig contains the configuration for running "prlctl" commands before the VM start.
func (*PrlctlConfig) Prepare ¶
func (c *PrlctlConfig) Prepare(ctx *interpolate.Context) []error
Prepare sets the default value of "Prlctl" property.
type PrlctlPostConfig ¶
type PrlctlPostConfig struct { // Identical to prlctl, except // that it is run after the virtual machine is shutdown, and before the virtual // machine is exported. PrlctlPost [][]string `mapstructure:"prlctl_post" required:"false"` }
PrlctlPostConfig contains the configuration for running "prlctl" commands in the end of artifact build.
func (*PrlctlPostConfig) Prepare ¶
func (c *PrlctlPostConfig) Prepare(ctx *interpolate.Context) []error
Prepare sets the default value of "PrlctlPost" property.
type PrlctlVersionConfig ¶
type PrlctlVersionConfig struct { // The path within the virtual machine to // upload a file that contains the prlctl version that was used to create // the machine. This information can be useful for provisioning. By default // this is ".prlctl_version", which will generally upload it into the // home directory. PrlctlVersionFile string `mapstructure:"prlctl_version_file" required:"false"` }
PrlctlVersionConfig contains the configuration for `prlctl` version.
func (*PrlctlVersionConfig) Prepare ¶
func (c *PrlctlVersionConfig) Prepare(ctx *interpolate.Context) []error
Prepare sets the default value of "PrlctlVersionFile" property.
type SSHConfig ¶
type SSHConfig struct {
Comm communicator.Config `mapstructure:",squash"`
}
SSHConfig contains the configuration for SSH communicator.
type ScanCodes ¶ added in v1.1.1
type ScanCodes struct { Scancode int64 `json:"scancode"` Event string `json:"event"` Delay int `json:"delay"` }
Struct to format Scancodes in JSON
type StepAttachCD ¶ added in v1.2.2
type StepAttachCD struct {
// contains filtered or unexported fields
}
StepAttachCD is a step that attaches a cd to the virtual machine.
Uses:
driver Driver ui packersdk.Ui vmName string
Produces:
func (*StepAttachCD) Cleanup ¶ added in v1.2.2
func (s *StepAttachCD) Cleanup(state multistep.StateBag)
Cleanup removes the virtual FDD device attached to the VM.
func (*StepAttachCD) Run ¶ added in v1.2.2
func (s *StepAttachCD) Run(ctx context.Context, state multistep.StateBag) multistep.StepAction
Run adds a virtual CD to the VM and attaches the image. If the image is not specified, then this step will be skipped.
type StepAttachFloppy ¶
type StepAttachFloppy struct {
// contains filtered or unexported fields
}
StepAttachFloppy is a step that attaches a floppy to the virtual machine.
Uses:
driver Driver ui packersdk.Ui vmName string
Produces:
func (*StepAttachFloppy) Cleanup ¶
func (s *StepAttachFloppy) Cleanup(state multistep.StateBag)
Cleanup removes the virtual FDD device attached to the VM.
func (*StepAttachFloppy) Run ¶
func (s *StepAttachFloppy) Run(ctx context.Context, state multistep.StateBag) multistep.StepAction
Run adds a virtual FDD device to the VM and attaches the image. If the image is not specified, then this step will be skipped.
type StepAttachParallelsTools ¶
type StepAttachParallelsTools struct { ParallelsToolsMode string // contains filtered or unexported fields }
StepAttachParallelsTools is a step that attaches Parallels Tools ISO image as an inserted CD onto the virtual machine.
Uses:
driver Driver parallels_tools_path string ui packersdk.Ui vmName string
Produces:
func (*StepAttachParallelsTools) Cleanup ¶
func (s *StepAttachParallelsTools) Cleanup(state multistep.StateBag)
Cleanup removes the virtual CD-ROM device attached to the VM.
func (*StepAttachParallelsTools) Run ¶
func (s *StepAttachParallelsTools) Run(ctx context.Context, state multistep.StateBag) multistep.StepAction
Run adds a virtual CD-ROM device to the VM and attaches Parallels Tools ISO image. If ISO image is not specified, then this step will be skipped.
type StepCompactDisk ¶
type StepCompactDisk struct {
Skip bool
}
StepCompactDisk is a step that removes all empty blocks from expanding Parallels virtual disks and reduces the result disk size
Uses:
driver Driver vmName string ui packersdk.Ui
Produces:
<nothing>
func (*StepCompactDisk) Cleanup ¶
func (*StepCompactDisk) Cleanup(multistep.StateBag)
Cleanup does nothing.
func (*StepCompactDisk) Run ¶
func (s *StepCompactDisk) Run(ctx context.Context, state multistep.StateBag) multistep.StepAction
Run runs the compaction of the virtual disk attached to the VM.
type StepImport ¶ added in v1.1.1
type StepImport struct { Name string SourcePath string OutputDir string ReassignMAC bool // contains filtered or unexported fields }
This step imports an PVM VM into Parallels.
func (*StepImport) Cleanup ¶ added in v1.1.1
func (s *StepImport) Cleanup(state multistep.StateBag)
func (*StepImport) Run ¶ added in v1.1.1
func (s *StepImport) Run(ctx context.Context, 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)
Cleanup deletes the output directory.
func (*StepOutputDir) Run ¶
func (s *StepOutputDir) Run(ctx context.Context, state multistep.StateBag) multistep.StepAction
Run sets up the output directory.
type StepPrepareParallelsTools ¶
StepPrepareParallelsTools is a step that prepares parameters related to Parallels Tools.
Uses:
driver Driver
Produces:
parallels_tools_path string
func (*StepPrepareParallelsTools) Cleanup ¶
func (s *StepPrepareParallelsTools) Cleanup(multistep.StateBag)
Cleanup does nothing.
func (*StepPrepareParallelsTools) Run ¶
func (s *StepPrepareParallelsTools) Run(ctx context.Context, state multistep.StateBag) multistep.StepAction
Run sets the value of "parallels_tools_path".
type StepPrlctl ¶
type StepPrlctl struct { Commands [][]string Ctx interpolate.Context }
StepPrlctl is a step that executes additional `prlctl` commands as specified. by the template.
Uses:
driver Driver ui packersdk.Ui vmName string
Produces:
func (*StepPrlctl) Cleanup ¶
func (s *StepPrlctl) Cleanup(state multistep.StateBag)
Cleanup does nothing.
func (*StepPrlctl) Run ¶
func (s *StepPrlctl) Run(ctx context.Context, state multistep.StateBag) multistep.StepAction
Run executes `prlctl` commands.
type StepRun ¶
type StepRun struct {
// contains filtered or unexported fields
}
StepRun is a step that starts the virtual machine.
Uses:
driver Driver ui packersdk.Ui vmName string
Produces:
type StepScreenBasedBoot ¶ added in v1.2.0
type StepScreenBasedBoot struct { ScreenConfigs map[string]BootScreenConfig OCRLibrary string VmName string Ctx interpolate.Context }
This step creates the virtual disk that will be used as the hard drive for the virtual machine.
func (*StepScreenBasedBoot) Cleanup ¶ added in v1.2.0
func (s *StepScreenBasedBoot) Cleanup(state multistep.StateBag)
func (*StepScreenBasedBoot) Run ¶ added in v1.2.0
func (s *StepScreenBasedBoot) Run(ctx context.Context, state multistep.StateBag) multistep.StepAction
type StepShutdown ¶
StepShutdown is a step that shuts down the machine. It first attempts to do so gracefully, but ultimately forcefully shuts it down if that fails.
Uses:
communicator packersdk.Communicator driver Driver ui packersdk.Ui vmName string
Produces:
<nothing>
func (*StepShutdown) Cleanup ¶
func (s *StepShutdown) Cleanup(state multistep.StateBag)
Cleanup does nothing.
func (*StepShutdown) Run ¶
func (s *StepShutdown) Run(ctx context.Context, state multistep.StateBag) multistep.StepAction
Run shuts down the VM.
type StepTypeBootCommand ¶
type StepTypeBootCommand struct { BootCommand string BootWait time.Duration HostInterfaces []string VMName string Ctx interpolate.Context GroupInterval time.Duration }
StepTypeBootCommand is a step that "types" the boot command into the VM via the prltype script, built on the Parallels Virtualization SDK - Python API.
func (*StepTypeBootCommand) Cleanup ¶
func (*StepTypeBootCommand) Cleanup(multistep.StateBag)
Cleanup does nothing.
func (*StepTypeBootCommand) Run ¶
func (s *StepTypeBootCommand) Run(ctx context.Context, state multistep.StateBag) multistep.StepAction
Run types the boot command by sending key scancodes into the VM.
type StepUploadParallelsTools ¶
type StepUploadParallelsTools struct { ParallelsToolsFlavor string ParallelsToolsGuestPath string ParallelsToolsMode string Ctx interpolate.Context }
StepUploadParallelsTools is a step that uploads the Parallels Tools ISO to the VM.
Uses:
communicator packersdk.Communicator parallels_tools_path string ui packersdk.Ui
func (*StepUploadParallelsTools) Cleanup ¶
func (s *StepUploadParallelsTools) Cleanup(state multistep.StateBag)
Cleanup does nothing.
func (*StepUploadParallelsTools) Run ¶
func (s *StepUploadParallelsTools) Run(ctx context.Context, state multistep.StateBag) multistep.StepAction
Run uploads the Parallels Tools ISO to the VM.
type StepUploadVersion ¶
type StepUploadVersion struct {
Path string
}
StepUploadVersion is a step that uploads a file containing the version of Parallels Desktop, which can be useful for various provisioning reasons.
Uses:
communicator packersdk.Communicator driver Driver ui packersdk.Ui
func (*StepUploadVersion) Cleanup ¶
func (s *StepUploadVersion) Cleanup(state multistep.StateBag)
Cleanup does nothing.
func (*StepUploadVersion) Run ¶
func (s *StepUploadVersion) Run(ctx context.Context, state multistep.StateBag) multistep.StepAction
Run uploads a file containing the version of Parallels Desktop.
type TesseractOCRWrapper ¶ added in v1.2.0
type TesseractOCRWrapper struct {
ScreenConfigs map[string]BootScreenConfig
}
func NewTesseractOCRWrapper ¶ added in v1.2.0
func NewTesseractOCRWrapper(ScreenConfigs map[string]BootScreenConfig) *TesseractOCRWrapper
func (*TesseractOCRWrapper) IdentifyCurrentScreen ¶ added in v1.2.0
func (c *TesseractOCRWrapper) IdentifyCurrentScreen(imagePath string) (bootScreenConfig BootScreenConfig, err error)
func (*TesseractOCRWrapper) RemoveBootScreenConfigIfExist ¶ added in v1.2.1
func (c *TesseractOCRWrapper) RemoveBootScreenConfigIfExist(screenName string)
type ToolsConfig ¶
type ToolsConfig struct { // The flavor of the Parallels Tools ISO to // install into the VM. Valid values are "win", "lin", "mac", "os2" // and "other". This can be omitted only if parallels_tools_mode // is "disable". ParallelsToolsFlavor string `mapstructure:"parallels_tools_flavor" required:"true"` // The path in the virtual machine to // upload Parallels Tools. This only takes effect if parallels_tools_mode // is "upload". This is a configuration // template that has a single // valid variable: Flavor, which will be the value of // parallels_tools_flavor. By default this is `prl-tools-{{.Flavor}}.iso` // which should upload into the login directory of the user. ParallelsToolsGuestPath string `mapstructure:"parallels_tools_guest_path" required:"false"` // The method by which Parallels Tools are // made available to the guest for installation. Valid options are "upload", // "attach", or "disable". If the mode is "attach" the Parallels Tools ISO will // be attached as a CD device to the virtual machine. If the mode is "upload" // the Parallels Tools ISO will be uploaded to the path specified by // parallels_tools_guest_path. The default value is "upload". ParallelsToolsMode string `mapstructure:"parallels_tools_mode" required:"false"` }
ToolsConfig contains the builder configuration related to Parallels Tools.
func (*ToolsConfig) Prepare ¶
func (c *ToolsConfig) Prepare(ctx *interpolate.Context) []error
Prepare validates & sets up configuration options related to Parallels Tools.
type VisionOCRWrapper ¶ added in v1.2.0
type VisionOCRWrapper struct { ScreenConfigs map[string]BootScreenConfig OCRImpl *C.OCRImpl // contains filtered or unexported fields }
VisionOCRWrapper is a struct that acts as an Adapter to Apple's Vision Framework for Optical Character Recognition.
func NewVisionOCRWrapper ¶ added in v1.2.0
func NewVisionOCRWrapper(ScreenConfigs map[string]BootScreenConfig) *VisionOCRWrapper
func (*VisionOCRWrapper) IdentifyCurrentScreen ¶ added in v1.2.0
func (c *VisionOCRWrapper) IdentifyCurrentScreen(imagePath string) (bootScreenConfig BootScreenConfig, err error)
Extracts text from the image at the given path. Uses "Accurate" recognition level.
func (*VisionOCRWrapper) RemoveBootScreenConfigIfExist ¶ added in v1.2.1
func (c *VisionOCRWrapper) RemoveBootScreenConfigIfExist(screenName string)
type WindowIDDetector ¶ added in v1.2.0
type WindowIDDetector struct { }
VisionOCR is a struct that acts as an Adapter to Apple's Vision Framework for Optical Character Recognition.
func (*WindowIDDetector) DetectWindowId ¶ added in v1.2.0
func (c *WindowIDDetector) DetectWindowId(vmName string, state multistep.StateBag) (id int, err error)
DetectWindowId is a method that detects the window ID of a given VM.
Source Files ¶
- artifact.go
- boot_screen_config.go
- boot_screen_config.hcl2spec.go
- driver.go
- driver_10.go
- driver_11.go
- driver_9.go
- driver_mock.go
- host_ip.go
- host_ip_ifconfig.go
- hw_config.go
- ocr_wrapper.go
- output_config.go
- prlctl_config.go
- prlctl_post_config.go
- prlctl_version_config.go
- prltype.go
- ssh.go
- ssh_config.go
- step_attach_cd.go
- step_attach_floppy.go
- step_attach_parallels_tools.go
- step_compact_disk.go
- step_import.go
- step_output_dir.go
- step_prepare_parallels_tools.go
- step_prlctl.go
- step_run.go
- step_screen_based_boot.go
- step_shutdown.go
- step_type_boot_command.go
- step_upload_parallels_tools.go
- step_upload_version.go
- tesseract_ocr_wrapper.go
- tools_config.go
- vision_ocr_wrapper.go
- window_id_detector.go