common

package
v1.2.2 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Oct 18, 2024 License: MPL-2.0 Imports: 32 Imported by: 0

Documentation

Index

Constants

View Source
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.

View Source
const BuilderId = "packer.parallels"

BuilderId is the common builder ID to all of these artifacts.

View Source
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

func CommHost

func CommHost(host string) func(multistep.StateBag) (string, error)

CommHost returns the VM's IP address which should be used to access it by SSH.

func NewArtifact

func NewArtifact(dir string, generatedData map[string]interface{}) (packersdk.Artifact, error)

NewArtifact returns a Parallels artifact containing the files in the given directory.

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.

func NewDriver

func NewDriver() (Driver, error)

NewDriver returns a new driver implementation for this version of Parallels Desktop, or an error if the driver couldn't be initialized.

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) DiskPath

func (d *DriverMock) DiskPath(name 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) IsRunning

func (d *DriverMock) IsRunning(name string) (bool, error)

func (*DriverMock) MAC

func (d *DriverMock) MAC(name string) (string, 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"`
}

func (*HWConfig) Prepare

func (c *HWConfig) Prepare(ctx *interpolate.Context) []error

type HostIPFinder

type HostIPFinder interface {
	HostIP() (string, error)
}

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.

func (*SSHConfig) Prepare

func (c *SSHConfig) Prepare(ctx *interpolate.Context) []error

Prepare sets the default values for SSH communicator properties.

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

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

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

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

Cleanup does nothing.

func (*StepCompactDisk) Run

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

type StepOutputDir

type StepOutputDir struct {
	Force bool
	Path  string
	// contains filtered or unexported fields
}

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

Run sets up the output directory.

type StepPrepareParallelsTools

type StepPrepareParallelsTools struct {
	ParallelsToolsFlavor string
	ParallelsToolsMode   string
}

StepPrepareParallelsTools is a step that prepares parameters related to Parallels Tools.

Uses:

driver Driver

Produces:

parallels_tools_path string

func (*StepPrepareParallelsTools) Cleanup

Cleanup does nothing.

func (*StepPrepareParallelsTools) Run

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

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:

func (*StepRun) Cleanup

func (s *StepRun) Cleanup(state multistep.StateBag)

Cleanup stops the VM.

func (*StepRun) Run

Run starts the VM.

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

type StepShutdown

type StepShutdown struct {
	Command string
	Timeout time.Duration
}

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

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

Cleanup does nothing.

func (*StepTypeBootCommand) Run

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

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

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.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL