package egoscale import ( "bytes" "compress/gzip" "context" "encoding/base64" "fmt" "io/ioutil" "net" "net/url" ) // VirtualMachineState holds the state of the instance // // https://github.com/apache/cloudstack/blob/master/api/src/main/java/com/cloud/vm/VirtualMachine.java type VirtualMachineState string const ( // VirtualMachineStarting VM is being started. At this state, you should find host id filled which means it's being started on that host VirtualMachineStarting VirtualMachineState = "Starting" // VirtualMachineRunning VM is running. host id has the host that it is running on VirtualMachineRunning VirtualMachineState = "Running" // VirtualMachineStopping VM is being stopped. host id has the host that it is being stopped on VirtualMachineStopping VirtualMachineState = "Stopping" // VirtualMachineStopped VM is stopped. host id should be null VirtualMachineStopped VirtualMachineState = "Stopped" // VirtualMachineDestroyed VM is marked for destroy VirtualMachineDestroyed VirtualMachineState = "Destroyed" // VirtualMachineExpunging "VM is being expunged VirtualMachineExpunging VirtualMachineState = "Expunging" // VirtualMachineMigrating VM is being live migrated. host id holds destination host, last host id holds source host VirtualMachineMigrating VirtualMachineState = "Migrating" // VirtualMachineMoving VM is being migrated offline (volume is being moved). VirtualMachineMoving VirtualMachineState = "Moving" // VirtualMachineError VM is in error VirtualMachineError VirtualMachineState = "Error" // VirtualMachineUnknown VM state is unknown VirtualMachineUnknown VirtualMachineState = "Unknown" // VirtualMachineShutdowned VM is shutdowned from inside VirtualMachineShutdowned VirtualMachineState = "Shutdowned" ) // VirtualMachine represents a virtual machine // // See: http://docs.cloudstack.apache.org/projects/cloudstack-administration/en/stable/virtual_machines.html type VirtualMachine struct { Account string `json:"account,omitempty" doc:"the account associated with the virtual machine"` AccountID *UUID `json:"accountid,omitempty" doc:"the account ID associated with the virtual machine"` AffinityGroup []AffinityGroup `json:"affinitygroup,omitempty" doc:"list of affinity groups associated with the virtual machine"` ClusterID *UUID `json:"clusterid,omitempty" doc:"the ID of the vm's cluster"` ClusterName string `json:"clustername,omitempty" doc:"the name of the vm's cluster"` CPUNumber int `json:"cpunumber,omitempty" doc:"the number of cpu this virtual machine is running with"` CPUSpeed int `json:"cpuspeed,omitempty" doc:"the speed of each cpu"` CPUUsed string `json:"cpuused,omitempty" doc:"the amount of the vm's CPU currently used"` Created string `json:"created,omitempty" doc:"the date when this virtual machine was created"` Details map[string]string `json:"details,omitempty" doc:"Vm details in key/value pairs."` DiskIoRead int64 `json:"diskioread,omitempty" doc:"the read (io) of disk on the vm"` DiskIoWrite int64 `json:"diskiowrite,omitempty" doc:"the write (io) of disk on the vm"` DiskKbsRead int64 `json:"diskkbsread,omitempty" doc:"the read (bytes) of disk on the vm"` DiskKbsWrite int64 `json:"diskkbswrite,omitempty" doc:"the write (bytes) of disk on the vm"` DiskOfferingID *UUID `json:"diskofferingid,omitempty" doc:"the ID of the disk offering of the virtual machine"` DiskOfferingName string `json:"diskofferingname,omitempty" doc:"the name of the disk offering of the virtual machine"` DisplayName string `json:"displayname,omitempty" doc:"user generated name. The name of the virtual machine is returned if no displayname exists."` ForVirtualNetwork bool `json:"forvirtualnetwork,omitempty" doc:"the virtual network for the service offering"` Group string `json:"group,omitempty" doc:"the group name of the virtual machine"` GroupID *UUID `json:"groupid,omitempty" doc:"the group ID of the virtual machine"` HAEnable bool `json:"haenable,omitempty" doc:"true if high-availability is enabled, false otherwise"` HostName string `json:"hostname,omitempty" doc:"the name of the host for the virtual machine"` ID *UUID `json:"id,omitempty" doc:"the ID of the virtual machine"` InstanceName string `json:"instancename,omitempty" doc:"instance name of the user vm; this parameter is returned to the ROOT admin only"` IsoDisplayText string `json:"isodisplaytext,omitempty" doc:"an alternate display text of the ISO attached to the virtual machine"` IsoID *UUID `json:"isoid,omitempty" doc:"the ID of the ISO attached to the virtual machine"` IsoName string `json:"isoname,omitempty" doc:"the name of the ISO attached to the virtual machine"` KeyPair string `json:"keypair,omitempty" doc:"ssh key-pair"` Memory int `json:"memory,omitempty" doc:"the memory allocated for the virtual machine"` Name string `json:"name,omitempty" doc:"the name of the virtual machine"` NetworkKbsRead int64 `json:"networkkbsread,omitempty" doc:"the incoming network traffic on the vm"` NetworkKbsWrite int64 `json:"networkkbswrite,omitempty" doc:"the outgoing network traffic on the host"` Nic []Nic `json:"nic,omitempty" doc:"the list of nics associated with vm"` OSCategoryID *UUID `json:"oscategoryid,omitempty" doc:"Os category ID of the virtual machine"` OSCategoryName string `json:"oscategoryname,omitempty" doc:"Os category name of the virtual machine"` OSTypeID *UUID `json:"ostypeid,omitempty" doc:"OS type id of the vm"` Password string `json:"password,omitempty" doc:"the password (if exists) of the virtual machine"` PasswordEnabled bool `json:"passwordenabled,omitempty" doc:"true if the password rest feature is enabled, false otherwise"` PCIDevices []PCIDevice `json:"pcidevices,omitempty" doc:"list of PCI devices"` PodID *UUID `json:"podid,omitempty" doc:"the ID of the vm's pod"` PodName string `json:"podname,omitempty" doc:"the name of the vm's pod"` PublicIP string `json:"publicip,omitempty" doc:"public IP address id associated with vm via Static nat rule"` PublicIPID *UUID `json:"publicipid,omitempty" doc:"public IP address id associated with vm via Static nat rule"` RootDeviceID int64 `json:"rootdeviceid,omitempty" doc:"device ID of the root volume"` RootDeviceType string `json:"rootdevicetype,omitempty" doc:"device type of the root volume"` SecurityGroup []SecurityGroup `json:"securitygroup,omitempty" doc:"list of security groups associated with the virtual machine"` ServiceOfferingID *UUID `json:"serviceofferingid,omitempty" doc:"the ID of the service offering of the virtual machine"` ServiceOfferingName string `json:"serviceofferingname,omitempty" doc:"the name of the service offering of the virtual machine"` ServiceState string `json:"servicestate,omitempty" doc:"State of the Service from LB rule"` State string `json:"state,omitempty" doc:"the state of the virtual machine"` Tags []ResourceTag `json:"tags,omitempty" doc:"the list of resource tags associated with vm"` TemplateDisplayText string `json:"templatedisplaytext,omitempty" doc:"an alternate display text of the template for the virtual machine"` TemplateID *UUID `json:"templateid,omitempty" doc:"the ID of the template for the virtual machine. A -1 is returned if the virtual machine was created from an ISO file."` TemplateName string `json:"templatename,omitempty" doc:"the name of the template for the virtual machine"` ZoneID *UUID `json:"zoneid,omitempty" doc:"the ID of the availablility zone for the virtual machine"` ZoneName string `json:"zonename,omitempty" doc:"the name of the availability zone for the virtual machine"` } // ResourceType returns the type of the resource func (VirtualMachine) ResourceType() string { return "UserVM" } // Delete destroys the VM func (vm VirtualMachine) Delete(ctx context.Context, client *Client) error { _, err := client.RequestWithContext(ctx, &DestroyVirtualMachine{ ID: vm.ID, }) return err } // ListRequest builds the ListVirtualMachines request func (vm VirtualMachine) ListRequest() (ListCommand, error) { // XXX: AffinityGroupID, SecurityGroupID req := &ListVirtualMachines{ GroupID: vm.GroupID, ID: vm.ID, Name: vm.Name, State: vm.State, TemplateID: vm.TemplateID, ZoneID: vm.ZoneID, } nic := vm.DefaultNic() if nic != nil { req.IPAddress = nic.IPAddress } for i := range vm.Tags { req.Tags = append(req.Tags, vm.Tags[i]) } return req, nil } // DefaultNic returns the default nic func (vm VirtualMachine) DefaultNic() *Nic { for i, nic := range vm.Nic { if nic.IsDefault { return &vm.Nic[i] } } return nil } // IP returns the default nic IP address func (vm VirtualMachine) IP() *net.IP { nic := vm.DefaultNic() if nic != nil { ip := nic.IPAddress return &ip } return nil } // NicsByType returns the corresponding interfaces base on the given type func (vm VirtualMachine) NicsByType(nicType string) []Nic { nics := make([]Nic, 0) for _, nic := range vm.Nic { if nic.Type == nicType { // XXX The API forgets to specify it n := nic n.VirtualMachineID = vm.ID nics = append(nics, n) } } return nics } // NicByNetworkID returns the corresponding interface based on the given NetworkID // // A VM cannot be connected twice to a same network. func (vm VirtualMachine) NicByNetworkID(networkID UUID) *Nic { for _, nic := range vm.Nic { if nic.NetworkID.Equal(networkID) { n := nic n.VirtualMachineID = vm.ID return &n } } return nil } // NicByID returns the corresponding interface base on its ID func (vm VirtualMachine) NicByID(nicID UUID) *Nic { for _, nic := range vm.Nic { if nic.ID.Equal(nicID) { n := nic n.VirtualMachineID = vm.ID return &n } } return nil } // IPToNetwork represents a mapping between ip and networks type IPToNetwork struct { IP net.IP `json:"ip,omitempty"` Ipv6 net.IP `json:"ipv6,omitempty"` NetworkID *UUID `json:"networkid,omitempty"` } // PCIDevice represents a PCI card present in the host type PCIDevice struct { PCIVendorName string `json:"pcivendorname,omitempty" doc:"Device vendor name of pci card"` DeviceID string `json:"deviceid,omitempty" doc:"Device model ID of pci card"` RemainingCapacity int `json:"remainingcapacity,omitempty" doc:"Remaining capacity in terms of no. of more VMs that can be deployped with this vGPU type"` MaxCapacity int `json:"maxcapacity,omitempty" doc:"Maximum vgpu can be created with this vgpu type on the given pci group"` PCIVendorID string `json:"pcivendorid,omitempty" doc:"Device vendor ID of pci card"` PCIDeviceName string `json:"pcidevicename,omitempty" doc:"Device model name of pci card"` } // Password represents an encrypted password // // TODO: method to decrypt it, https://cwiki.apache.org/confluence/pages/viewpage.action?pageId=34014652 type Password struct { EncryptedPassword string `json:"encryptedpassword"` } // VirtualMachineUserData represents the base64 encoded user-data type VirtualMachineUserData struct { UserData string `json:"userdata" doc:"Base 64 encoded VM user data"` VirtualMachineID *UUID `json:"virtualmachineid" doc:"the ID of the virtual machine"` } // Decode decodes as a readable string the content of the user-data (base64 ยท gzip) func (userdata VirtualMachineUserData) Decode() (string, error) { data, err := base64.StdEncoding.DecodeString(userdata.UserData) if err != nil { return "", err } // 0x1f8b is the magic number for gzip if len(data) < 2 || data[0] != 0x1f || data[1] != 0x8b { return string(data), nil } gr, err := gzip.NewReader(bytes.NewBuffer(data)) if err != nil { return "", err } defer gr.Close() // nolint: errcheck str, err := ioutil.ReadAll(gr) if err != nil { return "", err } return string(str), nil } // DeployVirtualMachine (Async) represents the machine creation // // Regarding the UserData field, the client is responsible to base64 (and probably gzip) it. Doing it within this library would make the integration with other tools, e.g. Terraform harder. type DeployVirtualMachine struct { AffinityGroupIDs []UUID `json:"affinitygroupids,omitempty" doc:"comma separated list of affinity groups id that are going to be applied to the virtual machine. Mutually exclusive with affinitygroupnames parameter"` AffinityGroupNames []string `json:"affinitygroupnames,omitempty" doc:"comma separated list of affinity groups names that are going to be applied to the virtual machine.Mutually exclusive with affinitygroupids parameter"` Details map[string]string `json:"details,omitempty" doc:"used to specify the custom parameters."` DiskOfferingID *UUID `json:"diskofferingid,omitempty" doc:"the ID of the disk offering for the virtual machine. If the template is of ISO format, the diskofferingid is for the root disk volume. Otherwise this parameter is used to indicate the offering for the data disk volume. If the templateid parameter passed is from a Template object, the diskofferingid refers to a DATA Disk Volume created. If the templateid parameter passed is from an ISO object, the diskofferingid refers to a ROOT Disk Volume created."` DisplayName string `json:"displayname,omitempty" doc:"an optional user generated name for the virtual machine"` Group string `json:"group,omitempty" doc:"an optional group for the virtual machine"` IP4 *bool `json:"ip4,omitempty" doc:"True to set an IPv4 to the default interface"` IP6 *bool `json:"ip6,omitempty" doc:"True to set an IPv6 to the default interface"` IP6Address net.IP `json:"ip6address,omitempty" doc:"the ipv6 address for default vm's network"` IPAddress net.IP `json:"ipaddress,omitempty" doc:"the ip address for default vm's network"` Keyboard string `json:"keyboard,omitempty" doc:"an optional keyboard device type for the virtual machine. valid value can be one of de,de-ch,es,fi,fr,fr-be,fr-ch,is,it,jp,nl-be,no,pt,uk,us"` KeyPair string `json:"keypair,omitempty" doc:"name of the ssh key pair used to login to the virtual machine"` Name string `json:"name,omitempty" doc:"host name for the virtual machine"` NetworkIDs []UUID `json:"networkids,omitempty" doc:"list of network ids used by virtual machine. Can't be specified with ipToNetworkList parameter"` RootDiskSize int64 `json:"rootdisksize,omitempty" doc:"Optional field to resize root disk on deploy. Value is in GB. Only applies to template-based deployments. Analogous to details[0].rootdisksize, which takes precedence over this parameter if both are provided"` SecurityGroupIDs []UUID `json:"securitygroupids,omitempty" doc:"comma separated list of security groups id that going to be applied to the virtual machine. Should be passed only when vm is created from a zone with Basic Network support. Mutually exclusive with securitygroupnames parameter"` SecurityGroupNames []string `json:"securitygroupnames,omitempty" doc:"comma separated list of security groups names that going to be applied to the virtual machine. Should be passed only when vm is created from a zone with Basic Network support. Mutually exclusive with securitygroupids parameter"` ServiceOfferingID *UUID `json:"serviceofferingid" doc:"the ID of the service offering for the virtual machine"` Size int64 `json:"size,omitempty" doc:"the arbitrary size for the DATADISK volume. Mutually exclusive with diskofferingid"` StartVM *bool `json:"startvm,omitempty" doc:"true if start vm after creating. Default value is true"` TemplateID *UUID `json:"templateid" doc:"the ID of the template for the virtual machine"` UserData string `json:"userdata,omitempty" doc:"an optional binary data that can be sent to the virtual machine upon a successful deployment. This binary data must be base64 encoded before adding it to the request. Using HTTP GET (via querystring), you can send up to 2KB of data after base64 encoding. Using HTTP POST(via POST body), you can send up to 32K of data after base64 encoding."` ZoneID *UUID `json:"zoneid" doc:"availability zone for the virtual machine"` _ bool `name:"deployVirtualMachine" description:"Creates and automatically starts a virtual machine based on a service offering, disk offering, and template."` } func (req DeployVirtualMachine) onBeforeSend(_ url.Values) error { // Either AffinityGroupIDs or AffinityGroupNames must be set if len(req.AffinityGroupIDs) > 0 && len(req.AffinityGroupNames) > 0 { return fmt.Errorf("either AffinityGroupIDs or AffinityGroupNames must be set") } // Either SecurityGroupIDs or SecurityGroupNames must be set if len(req.SecurityGroupIDs) > 0 && len(req.SecurityGroupNames) > 0 { return fmt.Errorf("either SecurityGroupIDs or SecurityGroupNames must be set") } return nil } // Response returns the struct to unmarshal func (DeployVirtualMachine) Response() interface{} { return new(AsyncJobResult) } // AsyncResponse returns the struct to unmarshal the async job func (DeployVirtualMachine) AsyncResponse() interface{} { return new(VirtualMachine) } // StartVirtualMachine (Async) represents the creation of the virtual machine type StartVirtualMachine struct { ID *UUID `json:"id" doc:"The ID of the virtual machine"` _ bool `name:"startVirtualMachine" description:"Starts a virtual machine."` } // Response returns the struct to unmarshal func (StartVirtualMachine) Response() interface{} { return new(AsyncJobResult) } // AsyncResponse returns the struct to unmarshal the async job func (StartVirtualMachine) AsyncResponse() interface{} { return new(VirtualMachine) } // StopVirtualMachine (Async) represents the stopping of the virtual machine type StopVirtualMachine struct { ID *UUID `json:"id" doc:"The ID of the virtual machine"` Forced *bool `json:"forced,omitempty" doc:"Force stop the VM (vm is marked as Stopped even when command fails to be send to the backend). The caller knows the VM is stopped."` _ bool `name:"stopVirtualMachine" description:"Stops a virtual machine."` } // Response returns the struct to unmarshal func (StopVirtualMachine) Response() interface{} { return new(AsyncJobResult) } // AsyncResponse returns the struct to unmarshal the async job func (StopVirtualMachine) AsyncResponse() interface{} { return new(VirtualMachine) } // RebootVirtualMachine (Async) represents the rebooting of the virtual machine type RebootVirtualMachine struct { ID *UUID `json:"id" doc:"The ID of the virtual machine"` _ bool `name:"rebootVirtualMachine" description:"Reboots a virtual machine."` } // Response returns the struct to unmarshal func (RebootVirtualMachine) Response() interface{} { return new(AsyncJobResult) } // AsyncResponse returns the struct to unmarshal the async job func (RebootVirtualMachine) AsyncResponse() interface{} { return new(VirtualMachine) } // RestoreVirtualMachine (Async) represents the restoration of the virtual machine type RestoreVirtualMachine struct { VirtualMachineID *UUID `json:"virtualmachineid" doc:"Virtual Machine ID"` TemplateID *UUID `json:"templateid,omitempty" doc:"an optional template Id to restore vm from the new template. This can be an ISO id in case of restore vm deployed using ISO"` RootDiskSize int64 `json:"rootdisksize,omitempty" doc:"Optional field to resize root disk on restore. Value is in GB. Only applies to template-based deployments."` _ bool `name:"restoreVirtualMachine" description:"Restore a VM to original template/ISO or new template/ISO"` } // Response returns the struct to unmarshal func (RestoreVirtualMachine) Response() interface{} { return new(AsyncJobResult) } // AsyncResponse returns the struct to unmarshal the async job func (RestoreVirtualMachine) AsyncResponse() interface{} { return new(VirtualMachine) } // RecoverVirtualMachine represents the restoration of the virtual machine type RecoverVirtualMachine struct { ID *UUID `json:"id" doc:"The ID of the virtual machine"` _ bool `name:"recoverVirtualMachine" description:"Recovers a virtual machine."` } // Response returns the struct to unmarshal func (RecoverVirtualMachine) Response() interface{} { return new(VirtualMachine) } // DestroyVirtualMachine (Async) represents the destruction of the virtual machine type DestroyVirtualMachine struct { ID *UUID `json:"id" doc:"The ID of the virtual machine"` _ bool `name:"destroyVirtualMachine" description:"Destroys a virtual machine."` } // Response returns the struct to unmarshal func (DestroyVirtualMachine) Response() interface{} { return new(AsyncJobResult) } // AsyncResponse returns the struct to unmarshal the async job func (DestroyVirtualMachine) AsyncResponse() interface{} { return new(VirtualMachine) } // UpdateVirtualMachine represents the update of the virtual machine type UpdateVirtualMachine struct { ID *UUID `json:"id" doc:"The ID of the virtual machine"` Details map[string]string `json:"details,omitempty" doc:"Details in key/value pairs."` DisplayName string `json:"displayname,omitempty" doc:"user generated name"` Group string `json:"group,omitempty" doc:"group of the virtual machine"` Name string `json:"name,omitempty" doc:"new host name of the vm. The VM has to be stopped/started for this update to take affect"` SecurityGroupIDs []UUID `json:"securitygroupids,omitempty" doc:"list of security group ids to be applied on the virtual machine."` UserData string `json:"userdata,omitempty" doc:"an optional binary data that can be sent to the virtual machine upon a successful deployment. This binary data must be base64 encoded before adding it to the request. Using HTTP GET (via querystring), you can send up to 2KB of data after base64 encoding. Using HTTP POST(via POST body), you can send up to 32K of data after base64 encoding."` _ bool `name:"updateVirtualMachine" description:"Updates properties of a virtual machine. The VM has to be stopped and restarted for the new properties to take effect. UpdateVirtualMachine does not first check whether the VM is stopped. Therefore, stop the VM manually before issuing this call."` } // Response returns the struct to unmarshal func (UpdateVirtualMachine) Response() interface{} { return new(VirtualMachine) } // ExpungeVirtualMachine represents the annihilation of a VM type ExpungeVirtualMachine struct { ID *UUID `json:"id" doc:"The ID of the virtual machine"` _ bool `name:"expungeVirtualMachine" description:"Expunge a virtual machine. Once expunged, it cannot be recoverd."` } // Response returns the struct to unmarshal func (ExpungeVirtualMachine) Response() interface{} { return new(AsyncJobResult) } // AsyncResponse returns the struct to unmarshal the async job func (ExpungeVirtualMachine) AsyncResponse() interface{} { return new(BooleanResponse) } // ScaleVirtualMachine (Async) scales the virtual machine to a new service offering. // // ChangeServiceForVirtualMachine does the same thing but returns the // new Virtual Machine which is more consistent with the rest of the API. type ScaleVirtualMachine struct { ID *UUID `json:"id" doc:"The ID of the virtual machine"` ServiceOfferingID *UUID `json:"serviceofferingid" doc:"the ID of the service offering for the virtual machine"` Details map[string]string `json:"details,omitempty" doc:"name value pairs of custom parameters for cpu,memory and cpunumber. example details[i].name=value"` _ bool `name:"scaleVirtualMachine" description:"Scales the virtual machine to a new service offering."` } // Response returns the struct to unmarshal func (ScaleVirtualMachine) Response() interface{} { return new(AsyncJobResult) } // AsyncResponse returns the struct to unmarshal the async job func (ScaleVirtualMachine) AsyncResponse() interface{} { return new(BooleanResponse) } // ChangeServiceForVirtualMachine changes the service offering for a virtual machine. The virtual machine must be in a "Stopped" state for this command to take effect. type ChangeServiceForVirtualMachine struct { ID *UUID `json:"id" doc:"The ID of the virtual machine"` ServiceOfferingID *UUID `json:"serviceofferingid" doc:"the service offering ID to apply to the virtual machine"` Details map[string]string `json:"details,omitempty" doc:"name value pairs of custom parameters for cpu, memory and cpunumber. example details[i].name=value"` _ bool `name:"changeServiceForVirtualMachine" description:"Changes the service offering for a virtual machine. The virtual machine must be in a \"Stopped\" state for this command to take effect."` } // Response returns the struct to unmarshal func (ChangeServiceForVirtualMachine) Response() interface{} { return new(VirtualMachine) } // ResetPasswordForVirtualMachine resets the password for virtual machine. The virtual machine must be in a "Stopped" state... type ResetPasswordForVirtualMachine struct { ID *UUID `json:"id" doc:"The ID of the virtual machine"` _ bool `name:"resetPasswordForVirtualMachine" description:"Resets the password for virtual machine. The virtual machine must be in a \"Stopped\" state and the template must already support this feature for this command to take effect."` } // Response returns the struct to unmarshal func (ResetPasswordForVirtualMachine) Response() interface{} { return new(AsyncJobResult) } // AsyncResponse returns the struct to unmarshal the async job func (ResetPasswordForVirtualMachine) AsyncResponse() interface{} { return new(VirtualMachine) } // GetVMPassword asks for an encrypted password type GetVMPassword struct { ID *UUID `json:"id" doc:"The ID of the virtual machine"` _ bool `name:"getVMPassword" description:"Returns an encrypted password for the VM"` } // Response returns the struct to unmarshal func (GetVMPassword) Response() interface{} { return new(Password) } //go:generate go run generate/main.go -interface=Listable ListVirtualMachines // ListVirtualMachines represents a search for a VM type ListVirtualMachines struct { AffinityGroupID *UUID `json:"affinitygroupid,omitempty" doc:"list vms by affinity group"` Details []string `json:"details,omitempty" doc:"comma separated list of host details requested, value can be a list of [all, group, nics, stats, secgrp, tmpl, servoff, diskoff, iso, volume, min, affgrp]. If no parameter is passed in, the details will be defaulted to all"` ForVirtualNetwork *bool `json:"forvirtualnetwork,omitempty" doc:"list by network type; true if need to list vms using Virtual Network, false otherwise"` GroupID *UUID `json:"groupid,omitempty" doc:"the group ID"` ID *UUID `json:"id,omitempty" doc:"the ID of the virtual machine"` IDs []UUID `json:"ids,omitempty" doc:"the IDs of the virtual machines, mutually exclusive with id"` IPAddress net.IP `json:"ipaddress,omitempty" doc:"an IP address to filter the result"` IsoID *UUID `json:"isoid,omitempty" doc:"list vms by iso"` Keyword string `json:"keyword,omitempty" doc:"List by keyword"` Name string `json:"name,omitempty" doc:"name of the virtual machine"` NetworkID *UUID `json:"networkid,omitempty" doc:"list by network id"` Page int `json:"page,omitempty"` PageSize int `json:"pagesize,omitempty"` ServiceOfferindID *UUID `json:"serviceofferingid,omitempty" doc:"list by the service offering"` State string `json:"state,omitempty" doc:"state of the virtual machine"` Tags []ResourceTag `json:"tags,omitempty" doc:"List resources by tags (key/value pairs)"` TemplateID *UUID `json:"templateid,omitempty" doc:"list vms by template"` ZoneID *UUID `json:"zoneid,omitempty" doc:"the availability zone ID"` _ bool `name:"listVirtualMachines" description:"List the virtual machines owned by the account."` } // ListVirtualMachinesResponse represents a list of virtual machines type ListVirtualMachinesResponse struct { Count int `json:"count"` VirtualMachine []VirtualMachine `json:"virtualmachine"` } // AddNicToVirtualMachine (Async) adds a NIC to a VM type AddNicToVirtualMachine struct { NetworkID *UUID `json:"networkid" doc:"Network ID"` VirtualMachineID *UUID `json:"virtualmachineid" doc:"Virtual Machine ID"` IPAddress net.IP `json:"ipaddress,omitempty" doc:"Static IP address lease for the corresponding NIC and network which should be in the range defined in the network"` _ bool `name:"addNicToVirtualMachine" description:"Adds VM to specified network by creating a NIC"` } // Response returns the struct to unmarshal func (AddNicToVirtualMachine) Response() interface{} { return new(AsyncJobResult) } // AsyncResponse returns the struct to unmarshal the async job func (AddNicToVirtualMachine) AsyncResponse() interface{} { return new(VirtualMachine) } // RemoveNicFromVirtualMachine (Async) removes a NIC from a VM type RemoveNicFromVirtualMachine struct { NicID *UUID `json:"nicid" doc:"NIC ID"` VirtualMachineID *UUID `json:"virtualmachineid" doc:"Virtual Machine ID"` _ bool `name:"removeNicFromVirtualMachine" description:"Removes VM from specified network by deleting a NIC"` } // Response returns the struct to unmarshal func (RemoveNicFromVirtualMachine) Response() interface{} { return new(AsyncJobResult) } // AsyncResponse returns the struct to unmarshal the async job func (RemoveNicFromVirtualMachine) AsyncResponse() interface{} { return new(VirtualMachine) } // UpdateDefaultNicForVirtualMachine (Async) adds a NIC to a VM type UpdateDefaultNicForVirtualMachine struct { NicID *UUID `json:"nicid" doc:"NIC ID"` VirtualMachineID *UUID `json:"virtualmachineid" doc:"Virtual Machine ID"` _ bool `name:"updateDefaultNicForVirtualMachine" description:"Changes the default NIC on a VM"` } // Response returns the struct to unmarshal func (UpdateDefaultNicForVirtualMachine) Response() interface{} { return new(AsyncJobResult) } // AsyncResponse returns the struct to unmarshal the async job func (UpdateDefaultNicForVirtualMachine) AsyncResponse() interface{} { return new(VirtualMachine) } // GetVirtualMachineUserData returns the user-data of the given VM type GetVirtualMachineUserData struct { VirtualMachineID *UUID `json:"virtualmachineid" doc:"The ID of the virtual machine"` _ bool `name:"getVirtualMachineUserData" description:"Returns user data associated with the VM"` } // Response returns the struct to unmarshal func (GetVirtualMachineUserData) Response() interface{} { return new(VirtualMachineUserData) } // UpdateVMNicIP updates the default IP address of a VM Nic type UpdateVMNicIP struct { _ bool `name:"updateVmNicIp" description:"Update the default Ip of a VM Nic"` IPAddress net.IP `json:"ipaddress,omitempty" doc:"Static IP address lease for the corresponding NIC and network which should be in the range defined in the network. If absent, the call removes the lease associated with the nic."` NicID *UUID `json:"nicid" doc:"the ID of the nic."` } // Response returns the struct to unmarshal func (UpdateVMNicIP) Response() interface{} { return new(AsyncJobResult) } // AsyncResponse returns the struct to unmarshal the async job func (UpdateVMNicIP) AsyncResponse() interface{} { return new(VirtualMachine) }