--- layout: default title: Reference parent: Scripting ---
UTM Suite UTM virtual machines scripting suite.

makev : Create a new virtual machine.

make

new type : Specify 'virtual machine' here.

with properties record : You must specify the backend as well as a configuration with a name. If this is a QEMU virtual machine, you must specify the architecture in the configuration as well.

→ specifier : The new virtual machine (as a specifier).

applicationn [see also UTM USB Devices Suite] : An application's top level scripting object.

Elements

contains virtual machines.

Properties

auto terminate (boolean) : Auto terminate the application when all windows are closed?

backendenum : Backend type.

apple : Apple Virtualization.framework backend.

qemu : QEMU backend.

unavailable : The virtual machine is not currently available.

statusenum : Status type.

stopped : VM is not running.

starting : VM is starting up.

started : VM is running.

pausing : VM is going to pause.

paused : VM is paused.

resuming : VM is resuming from pause.

stopping : VM is stopping.

stop methodenum : Stop by method.

force : Force stop VM by sending stop request to the backend.

kill : Force kill VM by terminating the backend.

request : Send a power down request to the guest OS which may be ignored.

serial interfaceenum : Serial port interface.

ptty : Pseudo TTY port.

tcp : TCP port.

unavailable : Serial interface is currently unavailable or is in use by the GUI.

startv : Start a virtual machine or resume a suspended virtual machine.

start virtual machine : Virtual machine to start.

[saving boolean] : When false, do not save the VM changes to disk. Default value is true.

suspendv : Suspend a running virtual machine to memory.

suspend virtual machine : Virtual machine to suspend.

[saving boolean] : Save VM state to disk after suspend. Default value is false.

stopv : Shuts down a running virtual machine.

stop virtual machine : Virtual machine to stop.

[by force/‌kill/‌request] : Method to stop the VM.

deletev : Delete a virtual machine. All data will be deleted, there is no confirmation!

delete virtual machine : The virtual machine to delete.

duplicatev : Copy an virtual machine and all its data.

duplicate virtual machine : The virtual machine to copy.

[with properties record] : Only the configuration can be changed.

importv : Import a new virtual machine from a file.

import

new type : Specify 'virtual machine' here.

from file : The virtual machine file (.utm) to import.

→ specifier : The new virtual machine (as a specifier).

exportv : Export a virtual machine to a specified location.

export virtual machine : The virtual machine to export.

to file : Location to export the VM to.

virtual machinen [see also UTM Guest Suite, UTM Configuration Suite, UTM USB Devices Suite] : A virtual machine registered in UTM.

Elements

contains serial ports; contained by application.

Properties

id (text, r/o) : The unique identifier of the VM.

name (text, r/o) : The name of the VM.

backend (apple/‌qemu/‌unavailable, r/o) : Emulation/virtualization engine used.

status (stopped/‌starting/‌started/‌pausing/‌paused/‌resuming/‌stopping, r/o) : Current running status.

responds to

start, suspend, stop, delete.

serial portn : A serial port in the guest that can be connected to from the host.

Elements

contained by virtual machines.

Properties

id (integer, r/o) : The unique identifier of the tag.

interface (ptty/‌tcp/‌unavailable, r/o) : The type of serial interface on the host.

address (text, r/o) : Host address of the serial port (determined by the interface type).

port (integer, r/o) : Port number of the serial port (not used in some interface types).

UTM Guest Suite UTM virtual machine guest scripting suite. In order to use these commands, QEMU guest agent must be running.

virtual machinen [see also UTM Suite, UTM Configuration Suite, UTM USB Devices Suite] : Guest agent access.

Elements

contains guest files, guest processes.

responds to

open file, execute, query ip.

open modeenum : File open mode.

reading : Open the file as read only. The file must exist.

writing : Open the file for writing. If the file does not exist, it will be created. If the file exists, it will be overwritten.

appending : Open the file for writing at the end. Offsets are ignored for writes. If the file does not exist, it will be created.

open filev : Open a file on the guest. You must close the file when you are done to prevent leaking guest resources.

open file virtual machine : Virtual machine of the guest.

at text : The guest path of the file to open.

[for reading/‌writing/‌appending] : Open mode.

[updating boolean] : If true, will open for both reading and writing. The file existance requirement and creation is still governed by the open mode. Default is false.

guest file : Guest file to operate on.

executev : Execute a command or script on the guest.

execute virtual machine : Virtual machine of the guest.

at text : Either the full path of the executable to run or an executable found in the guest's PATH environment.

[with arguments list of text] : List of arguments to pass to the executable.

[with environment list of text] : List of environment variables to pass to the executable. Each entry should be in the format NAME=VALUE.

[using input text] : Data to feed into the process's standard input. If using base64 encoding, this should be a valid base64 string.

[base64 encoding boolean] : Input data is base64 encoded. The data will be decoded before being passed to the executable. Default is false.

[output capturing boolean] : If true, the standard output and error will be captured and accessible in the returned object. You need to call update on the object to get the data. Default is false.

guest process : Guest process that can be used to fetch the return value and outputs (if captured).

query ipv : Query the guest for all IP addresses on its network interfaces (excluding loopback).

query ip virtual machine : Virtual machine of the guest.

→ list of text : List of IP addresses on all network interfaces (excluding loopback). Both IPv4 and IPv6 addresses can be returned. IPv4 addresses will show up before IPv6 addresses if any are available.

guest filen : A file that resides on the guest.

Elements

contained by virtual machines.

Properties

id (integer, r/o) : The handle for the file.

responds to

read, pull, write, push, close.

whenceenum : Where to offset from.

start position : The start of the file (only positive offsets).

current position : The current pointer (both positive and negative offsets).

end position : The end of the file (only negative offsets for reads, both for writes).

readv : Reads text data from a guest file.

read guest file : Guest file to read.

[at offset integer] : Specify the offset to start reading from. Default value is zero.

[from start position/‌current position/‌end position] : Specify where the offset is from. Default value is from the current file pointer.

[for length integer] : Amount of bytes to read. The limit is 48 MB. Default is to read until the end.

[base64 encoding boolean] : If true, then the result will be base64 encoded. This is recommended if you are reading a binary file. Default is false.

[closing boolean] : If true, the file will be closed after reading and must be opened again to perform more operations. If false, you can perform multiple reads on the same open file. The default is true.

→ text : Data read from the guest file.

pullv : Pulls a file from the guest to the host.

pull guest file : Guest file to pull.

to file : The host file in which to save the guest file.

[closing boolean] : If true, the file will be closed after reading and must be opened again to perform more operations. If false, you can perform multiple reads on the same open file. The default is true.

writev : Writes text data to a guest file.

write guest file : Guest file to write.

with data text : Data to write to the guest file. If base64 encoding is specified, this should be a valid base64 string which will be decoded before writing.

[at offset integer] : Specify the offset to start writing to. Default value is zero.

[from start position/‌current position/‌end position] : Specify where the offset is from. Default value is from the current file pointer.

[base64 encoding boolean] : If true, then the input data is base64 encoded. This is recommended if you are writing a binary file. Default is false.

[closing boolean] : If true, the file will be closed after writing and must be opened again to perform more operations. If false, you can perform multiple reads on the same open file. The default is true.

pushv : Pushes a file from the host to the guest and closes it.

push guest file : Guest file to push.

from file : The host file in which to send to the guest.

[closing boolean] : If true, the file will be closed after writing and must be opened again to perform more operations. If false, you can perform multiple reads on the same open file. The default is true.

closev : Closes the file and prevent further operations.

close guest file : Guest file to close.

guest processn, pl guest processes : A process on the guest.

Elements

contained by virtual machines.

Properties

id (integer, r/o) : The PID of the process.

responds to

get result.

execute resultn : Process results after execution.

Properties

exited (boolean, r/o) : If true, the process has terminated.

exit code (integer, r/o) : Exit code if it was normally terminated.

signal code (integer, r/o) : Signal number (Linux) or unhandled exception code (Windows) if the process was abnormally terminated.

output text (text, r/o) : If capture is enabled, the stdout of the process as text.

error text (text, r/o) : If capture is enabled, the stderr of the process as text.

output data (text, r/o) : If capture is enabled, the stdout of the process as base64 encoded data.

error data (text, r/o) : If capture is enabled, the stderr of the process as base64 encoded data.

get resultv : Fetch execution result from the guest.

get result guest process : Guest process to fetch result from.

execute result : Result from the guest.

UTM Configuration Suite UTM virtual machine configuration suite. Use this to create and configurate virtual machines.

virtual machinen [see also UTM Suite, UTM Guest Suite, UTM USB Devices Suite] : Virtual machine configuration.

Properties

configuration (qemu configuration or apple configuration, r/o) : The configuration of the virtual machine.

responds to

update configuration.

update configurationv : Update the configuration of the virtual machine. The VM must be in the stopped state.

update configuration virtual machine : Virtual machine to configure.

with qemu configuration or apple configuration : The configuration to update the virtual machine. You cannot change the backend with this!

qemu configurationn : QEMU virtual machine configuration.

Properties

name (text) : Virtual machine name.

notes (text) : User-specified notes.

architecture (text) : QEMU system architecture.

machine (text) : QEMU target machine (if empty, the default will be used).

memory (integer) : RAM size (in mebibytes).

cpu cores (integer) : Number of CPU cores (0 is the default for this host).

hypervisor (boolean) : Use the hypervisor (if supported)?

uefi (boolean) : Use UEFI boot?

directory share mode (none/‌WebDAV/‌VirtFS) : Mode for directory sharing.

drives (list of qemu drive configuration) : List of drive configuration.

network interfaces (list of qemu network configuration) : List of network configuration.

serial ports (list of qemu serial configuration) : List of serial configuration.

qemu additional arguments (list of qemu argument) : List of qemu arguments.

qemu directory share modeenum : Method for sharing directory in QEMU.

none : Do not enable directory sharing.

WebDAV : Use SPICE WebDav (SPICE guest tools required).

VirtFS : Use VirtFS mount tagged 'share' (VirtFS guest drivers required).

qemu drive configurationn : QEMU virtual existing drive configuration.

Properties

id (text, r/o) : The unique identifier for this drive (if empty, a new drive will be created).

removable (boolean, r/o) : Is this drive removable (cannot be changed after creation)?

interface (none/‌IDE/‌SCSI/‌SD/‌MTD/‌Floppy/‌PFlash/‌VirtIO/‌NVMe/‌USB) : The hardware interface this drive is attached to (if empty, the default will be used).

host size (integer, r/o) : The size of this drive as seen by the host (in MiB).

guest size (integer) : The size of this drive as seen by the guest (in MiB).

raw (boolean) : Is this disk image raw format (only for newly created drives)?

source (file) : An existing file to use as the source image.

qemu network configurationn : QEMU virtual network configuration.

Properties

index (integer) : The position of the configuration to update. It can be empty to create a new device. Index is invalid after updating the configuration and must be reset to the current position.

hardware (text) : Name of the emulated network card (if empty, the default will be used).

mode (emulated/‌shared/‌host/‌bridged) : This determines how the network device is attached to the host.

address (text) : MAC address (formatted as XX:XX:XX:XX:XX:XX, if empty a random address will be genertaed)

host interface (text) : Only used in bridged mode. Specify the interface name to bridge to.

port forwards (list of qemu port forward) : Only used in emulated mode. Allows port forwarding from guest to host.

qemu network modeenum : Mode for networking device.

emulated : Emulate a VLAN.

shared : NAT based sharing with the host.

host : NAT based sharing with no WAN routing.

bridged : Bridged to a host interface.

qemu port forwardn : QEMU port forward configuration.

Properties

protocol (TCP/‌UDP) : Protocol of the port that will be forwarded.

host address (text) : The host interface IP address to forward to (if empty, it will forward to any interface).

host port (integer) : Port number on the host.

guest address (text) : The IP address on the guest subnet to forward from (if empty, any guest IP will be accepted).

guest port (integer) : Port number on the guest.

qemu serial configurationn : QEMU virtual serial configuration.

Properties

index (integer) : The position of the configuration to update. It can be empty to create a new device. Index is invalid after updating the configuration and must be reset to the current position.

hardware (text) : Name of the emulated serial device (if empty, the default will be used).

interface (ptty/‌tcp/‌unavailable) : The type of serial interface on the host.

port (integer) : The port number to listen on when the interface is a TCP server.

qemu argumentn : QEMU argument configuration.

Properties

argument string (text) : The QEMU argument as a string.

apple configurationn : Apple virtual machine configuration.

Properties

name (text) : Virtual machine name.

notes (text) : User-specified notes.

memory (integer) : RAM size (in mebibytes).

cpu cores (integer) : Number of CPU cores (0 is the default for this host).

directory shares (list of apple directory share configuration) : List of directory share configuration.

drives (list of apple drive configuration) : List of drive configuration.

network interfaces (list of apple network configuration) : List of network configuration.

serial ports (list of apple serial configuration) : List of serial configuration.

apple directory share configurationn : Apple directory share configuration.

Properties

index (integer) : The position of the configuration to update. It can be empty to create a new device. Index is invalid after updating the configuration and must be reset to the current position.

read only (boolean, r/o) : Is this directory read-only?

apple drive configurationn : Apple virtual existing drive configuration.

Properties

id (text, r/o) : The unique identifier for this drive (if empty, a new drive will be created).

removable (boolean, r/o) : Is this drive removable (cannot be changed after creation)?

host size (integer, r/o) : The size of this drive as seen by the host (in MiB).

guest size (integer) : The size of this drive as seen by the guest (in MiB).

source (file) : An existing file to use as the source image.

apple network configurationn : Apple virtual network configuration.

Properties

index (integer) : The position of the configuration to update. It can be empty to create a new device. Index is invalid after updating the configuration and must be reset to the current position.

mode (shared/‌bridged) : This determines how the network device is attached to the host.

address (text) : MAC address (formatted as XX:XX:XX:XX:XX:XX, if empty a random address will be genertaed)

host interface (text) : Only used in bridged mode. Specify the interface name to bridge to.

apple network modeenum : Mode for networking device.

shared : NAT based sharing with the host.

bridged : Bridged to a host interface.

apple serial configurationn : Apple virtual serial configuration.

Properties

index (integer) : The position of the configuration to update. It can be empty to create a new device. Index is invalid after updating the configuration and must be reset to the current position.

interface (ptty/‌tcp/‌unavailable) : The type of serial interface on the host (only PTTY is supported).

UTM USB Devices Suite UTM virtual machine USB devices suite. Use this to connect USB devices from the host to the guest.

applicationn [see also UTM Suite] : An application's top level scripting object.

Elements

contains usb devices.

usb devicen : A host USB device that is shared with the guest.

Elements

contained by application, virtual machines.

Properties

id (integer, r/o) : A unique identifier corrosponding to the USB bus and port number.

name (text, r/o) : The name of the USB device.

manufacturer name (text, r/o) : The product name described by the iManufacturer descriptor.

product name (text, r/o) : The product name described by the iProduct descriptor.

vendor id (integer, r/o) : The vendor ID described by the idVendor descriptor.

product id (integer, r/o) : The product ID described by the idProduct descriptor.

responds to

connect, disconnect.

virtual machinen [see also UTM Suite, UTM Guest Suite, UTM Configuration Suite] : Virtual machine USB devices.

Elements

contains usb devices.

connectv : Connect a USB device to a running VM and remove it from the host.

connect usb device : The USB device to connect to the VM.

to virtual machine : The virtual machine to connect. The virtual machine must be running. Not all backends support USB sharing.

disconnectv : Disconnect a USB device from the guest and re-assign it to the host.

disconnect usb device : The USB device to disconnect.