terraform/vendor/github.com/xanzy/go-cloudstack/cloudstack/SystemVMService.go

1047 lines
31 KiB
Go

//
// Copyright 2016, Sander van Harmelen
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
//
package cloudstack
import (
"encoding/json"
"fmt"
"net/url"
"strconv"
"strings"
)
type StartSystemVmParams struct {
p map[string]interface{}
}
func (p *StartSystemVmParams) toURLValues() url.Values {
u := url.Values{}
if p.p == nil {
return u
}
if v, found := p.p["id"]; found {
u.Set("id", v.(string))
}
return u
}
func (p *StartSystemVmParams) SetId(v string) {
if p.p == nil {
p.p = make(map[string]interface{})
}
p.p["id"] = v
return
}
// You should always use this function to get a new StartSystemVmParams instance,
// as then you are sure you have configured all required params
func (s *SystemVMService) NewStartSystemVmParams(id string) *StartSystemVmParams {
p := &StartSystemVmParams{}
p.p = make(map[string]interface{})
p.p["id"] = id
return p
}
// Starts a system virtual machine.
func (s *SystemVMService) StartSystemVm(p *StartSystemVmParams) (*StartSystemVmResponse, error) {
resp, err := s.cs.newRequest("startSystemVm", p.toURLValues())
if err != nil {
return nil, err
}
var r StartSystemVmResponse
if err := json.Unmarshal(resp, &r); err != nil {
return nil, err
}
// If we have a async client, we need to wait for the async result
if s.cs.async {
b, err := s.cs.GetAsyncJobResult(r.JobID, s.cs.timeout)
if err != nil {
if err == AsyncTimeoutErr {
return &r, err
}
return nil, err
}
b, err = getRawValue(b)
if err != nil {
return nil, err
}
if err := json.Unmarshal(b, &r); err != nil {
return nil, err
}
}
return &r, nil
}
type StartSystemVmResponse struct {
JobID string `json:"jobid,omitempty"`
Activeviewersessions int `json:"activeviewersessions,omitempty"`
Created string `json:"created,omitempty"`
Dns1 string `json:"dns1,omitempty"`
Dns2 string `json:"dns2,omitempty"`
Gateway string `json:"gateway,omitempty"`
Hostid string `json:"hostid,omitempty"`
Hostname string `json:"hostname,omitempty"`
Hypervisor string `json:"hypervisor,omitempty"`
Id string `json:"id,omitempty"`
Jobid string `json:"jobid,omitempty"`
Jobstatus int `json:"jobstatus,omitempty"`
Linklocalip string `json:"linklocalip,omitempty"`
Linklocalmacaddress string `json:"linklocalmacaddress,omitempty"`
Linklocalnetmask string `json:"linklocalnetmask,omitempty"`
Name string `json:"name,omitempty"`
Networkdomain string `json:"networkdomain,omitempty"`
Podid string `json:"podid,omitempty"`
Privateip string `json:"privateip,omitempty"`
Privatemacaddress string `json:"privatemacaddress,omitempty"`
Privatenetmask string `json:"privatenetmask,omitempty"`
Publicip string `json:"publicip,omitempty"`
Publicmacaddress string `json:"publicmacaddress,omitempty"`
Publicnetmask string `json:"publicnetmask,omitempty"`
State string `json:"state,omitempty"`
Systemvmtype string `json:"systemvmtype,omitempty"`
Templateid string `json:"templateid,omitempty"`
Zoneid string `json:"zoneid,omitempty"`
Zonename string `json:"zonename,omitempty"`
}
type RebootSystemVmParams struct {
p map[string]interface{}
}
func (p *RebootSystemVmParams) toURLValues() url.Values {
u := url.Values{}
if p.p == nil {
return u
}
if v, found := p.p["id"]; found {
u.Set("id", v.(string))
}
return u
}
func (p *RebootSystemVmParams) SetId(v string) {
if p.p == nil {
p.p = make(map[string]interface{})
}
p.p["id"] = v
return
}
// You should always use this function to get a new RebootSystemVmParams instance,
// as then you are sure you have configured all required params
func (s *SystemVMService) NewRebootSystemVmParams(id string) *RebootSystemVmParams {
p := &RebootSystemVmParams{}
p.p = make(map[string]interface{})
p.p["id"] = id
return p
}
// Reboots a system VM.
func (s *SystemVMService) RebootSystemVm(p *RebootSystemVmParams) (*RebootSystemVmResponse, error) {
resp, err := s.cs.newRequest("rebootSystemVm", p.toURLValues())
if err != nil {
return nil, err
}
var r RebootSystemVmResponse
if err := json.Unmarshal(resp, &r); err != nil {
return nil, err
}
// If we have a async client, we need to wait for the async result
if s.cs.async {
b, err := s.cs.GetAsyncJobResult(r.JobID, s.cs.timeout)
if err != nil {
if err == AsyncTimeoutErr {
return &r, err
}
return nil, err
}
b, err = getRawValue(b)
if err != nil {
return nil, err
}
if err := json.Unmarshal(b, &r); err != nil {
return nil, err
}
}
return &r, nil
}
type RebootSystemVmResponse struct {
JobID string `json:"jobid,omitempty"`
Activeviewersessions int `json:"activeviewersessions,omitempty"`
Created string `json:"created,omitempty"`
Dns1 string `json:"dns1,omitempty"`
Dns2 string `json:"dns2,omitempty"`
Gateway string `json:"gateway,omitempty"`
Hostid string `json:"hostid,omitempty"`
Hostname string `json:"hostname,omitempty"`
Hypervisor string `json:"hypervisor,omitempty"`
Id string `json:"id,omitempty"`
Jobid string `json:"jobid,omitempty"`
Jobstatus int `json:"jobstatus,omitempty"`
Linklocalip string `json:"linklocalip,omitempty"`
Linklocalmacaddress string `json:"linklocalmacaddress,omitempty"`
Linklocalnetmask string `json:"linklocalnetmask,omitempty"`
Name string `json:"name,omitempty"`
Networkdomain string `json:"networkdomain,omitempty"`
Podid string `json:"podid,omitempty"`
Privateip string `json:"privateip,omitempty"`
Privatemacaddress string `json:"privatemacaddress,omitempty"`
Privatenetmask string `json:"privatenetmask,omitempty"`
Publicip string `json:"publicip,omitempty"`
Publicmacaddress string `json:"publicmacaddress,omitempty"`
Publicnetmask string `json:"publicnetmask,omitempty"`
State string `json:"state,omitempty"`
Systemvmtype string `json:"systemvmtype,omitempty"`
Templateid string `json:"templateid,omitempty"`
Zoneid string `json:"zoneid,omitempty"`
Zonename string `json:"zonename,omitempty"`
}
type StopSystemVmParams struct {
p map[string]interface{}
}
func (p *StopSystemVmParams) toURLValues() url.Values {
u := url.Values{}
if p.p == nil {
return u
}
if v, found := p.p["forced"]; found {
vv := strconv.FormatBool(v.(bool))
u.Set("forced", vv)
}
if v, found := p.p["id"]; found {
u.Set("id", v.(string))
}
return u
}
func (p *StopSystemVmParams) SetForced(v bool) {
if p.p == nil {
p.p = make(map[string]interface{})
}
p.p["forced"] = v
return
}
func (p *StopSystemVmParams) SetId(v string) {
if p.p == nil {
p.p = make(map[string]interface{})
}
p.p["id"] = v
return
}
// You should always use this function to get a new StopSystemVmParams instance,
// as then you are sure you have configured all required params
func (s *SystemVMService) NewStopSystemVmParams(id string) *StopSystemVmParams {
p := &StopSystemVmParams{}
p.p = make(map[string]interface{})
p.p["id"] = id
return p
}
// Stops a system VM.
func (s *SystemVMService) StopSystemVm(p *StopSystemVmParams) (*StopSystemVmResponse, error) {
resp, err := s.cs.newRequest("stopSystemVm", p.toURLValues())
if err != nil {
return nil, err
}
var r StopSystemVmResponse
if err := json.Unmarshal(resp, &r); err != nil {
return nil, err
}
// If we have a async client, we need to wait for the async result
if s.cs.async {
b, err := s.cs.GetAsyncJobResult(r.JobID, s.cs.timeout)
if err != nil {
if err == AsyncTimeoutErr {
return &r, err
}
return nil, err
}
b, err = getRawValue(b)
if err != nil {
return nil, err
}
if err := json.Unmarshal(b, &r); err != nil {
return nil, err
}
}
return &r, nil
}
type StopSystemVmResponse struct {
JobID string `json:"jobid,omitempty"`
Activeviewersessions int `json:"activeviewersessions,omitempty"`
Created string `json:"created,omitempty"`
Dns1 string `json:"dns1,omitempty"`
Dns2 string `json:"dns2,omitempty"`
Gateway string `json:"gateway,omitempty"`
Hostid string `json:"hostid,omitempty"`
Hostname string `json:"hostname,omitempty"`
Hypervisor string `json:"hypervisor,omitempty"`
Id string `json:"id,omitempty"`
Jobid string `json:"jobid,omitempty"`
Jobstatus int `json:"jobstatus,omitempty"`
Linklocalip string `json:"linklocalip,omitempty"`
Linklocalmacaddress string `json:"linklocalmacaddress,omitempty"`
Linklocalnetmask string `json:"linklocalnetmask,omitempty"`
Name string `json:"name,omitempty"`
Networkdomain string `json:"networkdomain,omitempty"`
Podid string `json:"podid,omitempty"`
Privateip string `json:"privateip,omitempty"`
Privatemacaddress string `json:"privatemacaddress,omitempty"`
Privatenetmask string `json:"privatenetmask,omitempty"`
Publicip string `json:"publicip,omitempty"`
Publicmacaddress string `json:"publicmacaddress,omitempty"`
Publicnetmask string `json:"publicnetmask,omitempty"`
State string `json:"state,omitempty"`
Systemvmtype string `json:"systemvmtype,omitempty"`
Templateid string `json:"templateid,omitempty"`
Zoneid string `json:"zoneid,omitempty"`
Zonename string `json:"zonename,omitempty"`
}
type DestroySystemVmParams struct {
p map[string]interface{}
}
func (p *DestroySystemVmParams) toURLValues() url.Values {
u := url.Values{}
if p.p == nil {
return u
}
if v, found := p.p["id"]; found {
u.Set("id", v.(string))
}
return u
}
func (p *DestroySystemVmParams) SetId(v string) {
if p.p == nil {
p.p = make(map[string]interface{})
}
p.p["id"] = v
return
}
// You should always use this function to get a new DestroySystemVmParams instance,
// as then you are sure you have configured all required params
func (s *SystemVMService) NewDestroySystemVmParams(id string) *DestroySystemVmParams {
p := &DestroySystemVmParams{}
p.p = make(map[string]interface{})
p.p["id"] = id
return p
}
// Destroyes a system virtual machine.
func (s *SystemVMService) DestroySystemVm(p *DestroySystemVmParams) (*DestroySystemVmResponse, error) {
resp, err := s.cs.newRequest("destroySystemVm", p.toURLValues())
if err != nil {
return nil, err
}
var r DestroySystemVmResponse
if err := json.Unmarshal(resp, &r); err != nil {
return nil, err
}
// If we have a async client, we need to wait for the async result
if s.cs.async {
b, err := s.cs.GetAsyncJobResult(r.JobID, s.cs.timeout)
if err != nil {
if err == AsyncTimeoutErr {
return &r, err
}
return nil, err
}
b, err = getRawValue(b)
if err != nil {
return nil, err
}
if err := json.Unmarshal(b, &r); err != nil {
return nil, err
}
}
return &r, nil
}
type DestroySystemVmResponse struct {
JobID string `json:"jobid,omitempty"`
Activeviewersessions int `json:"activeviewersessions,omitempty"`
Created string `json:"created,omitempty"`
Dns1 string `json:"dns1,omitempty"`
Dns2 string `json:"dns2,omitempty"`
Gateway string `json:"gateway,omitempty"`
Hostid string `json:"hostid,omitempty"`
Hostname string `json:"hostname,omitempty"`
Hypervisor string `json:"hypervisor,omitempty"`
Id string `json:"id,omitempty"`
Jobid string `json:"jobid,omitempty"`
Jobstatus int `json:"jobstatus,omitempty"`
Linklocalip string `json:"linklocalip,omitempty"`
Linklocalmacaddress string `json:"linklocalmacaddress,omitempty"`
Linklocalnetmask string `json:"linklocalnetmask,omitempty"`
Name string `json:"name,omitempty"`
Networkdomain string `json:"networkdomain,omitempty"`
Podid string `json:"podid,omitempty"`
Privateip string `json:"privateip,omitempty"`
Privatemacaddress string `json:"privatemacaddress,omitempty"`
Privatenetmask string `json:"privatenetmask,omitempty"`
Publicip string `json:"publicip,omitempty"`
Publicmacaddress string `json:"publicmacaddress,omitempty"`
Publicnetmask string `json:"publicnetmask,omitempty"`
State string `json:"state,omitempty"`
Systemvmtype string `json:"systemvmtype,omitempty"`
Templateid string `json:"templateid,omitempty"`
Zoneid string `json:"zoneid,omitempty"`
Zonename string `json:"zonename,omitempty"`
}
type ListSystemVmsParams struct {
p map[string]interface{}
}
func (p *ListSystemVmsParams) toURLValues() url.Values {
u := url.Values{}
if p.p == nil {
return u
}
if v, found := p.p["hostid"]; found {
u.Set("hostid", v.(string))
}
if v, found := p.p["id"]; found {
u.Set("id", v.(string))
}
if v, found := p.p["keyword"]; found {
u.Set("keyword", v.(string))
}
if v, found := p.p["name"]; found {
u.Set("name", v.(string))
}
if v, found := p.p["page"]; found {
vv := strconv.Itoa(v.(int))
u.Set("page", vv)
}
if v, found := p.p["pagesize"]; found {
vv := strconv.Itoa(v.(int))
u.Set("pagesize", vv)
}
if v, found := p.p["podid"]; found {
u.Set("podid", v.(string))
}
if v, found := p.p["state"]; found {
u.Set("state", v.(string))
}
if v, found := p.p["storageid"]; found {
u.Set("storageid", v.(string))
}
if v, found := p.p["systemvmtype"]; found {
u.Set("systemvmtype", v.(string))
}
if v, found := p.p["zoneid"]; found {
u.Set("zoneid", v.(string))
}
return u
}
func (p *ListSystemVmsParams) SetHostid(v string) {
if p.p == nil {
p.p = make(map[string]interface{})
}
p.p["hostid"] = v
return
}
func (p *ListSystemVmsParams) SetId(v string) {
if p.p == nil {
p.p = make(map[string]interface{})
}
p.p["id"] = v
return
}
func (p *ListSystemVmsParams) SetKeyword(v string) {
if p.p == nil {
p.p = make(map[string]interface{})
}
p.p["keyword"] = v
return
}
func (p *ListSystemVmsParams) SetName(v string) {
if p.p == nil {
p.p = make(map[string]interface{})
}
p.p["name"] = v
return
}
func (p *ListSystemVmsParams) SetPage(v int) {
if p.p == nil {
p.p = make(map[string]interface{})
}
p.p["page"] = v
return
}
func (p *ListSystemVmsParams) SetPagesize(v int) {
if p.p == nil {
p.p = make(map[string]interface{})
}
p.p["pagesize"] = v
return
}
func (p *ListSystemVmsParams) SetPodid(v string) {
if p.p == nil {
p.p = make(map[string]interface{})
}
p.p["podid"] = v
return
}
func (p *ListSystemVmsParams) SetState(v string) {
if p.p == nil {
p.p = make(map[string]interface{})
}
p.p["state"] = v
return
}
func (p *ListSystemVmsParams) SetStorageid(v string) {
if p.p == nil {
p.p = make(map[string]interface{})
}
p.p["storageid"] = v
return
}
func (p *ListSystemVmsParams) SetSystemvmtype(v string) {
if p.p == nil {
p.p = make(map[string]interface{})
}
p.p["systemvmtype"] = v
return
}
func (p *ListSystemVmsParams) SetZoneid(v string) {
if p.p == nil {
p.p = make(map[string]interface{})
}
p.p["zoneid"] = v
return
}
// You should always use this function to get a new ListSystemVmsParams instance,
// as then you are sure you have configured all required params
func (s *SystemVMService) NewListSystemVmsParams() *ListSystemVmsParams {
p := &ListSystemVmsParams{}
p.p = make(map[string]interface{})
return p
}
// This is a courtesy helper function, which in some cases may not work as expected!
func (s *SystemVMService) GetSystemVmID(name string, opts ...OptionFunc) (string, error) {
p := &ListSystemVmsParams{}
p.p = make(map[string]interface{})
p.p["name"] = name
for _, fn := range opts {
if err := fn(s.cs, p); err != nil {
return "", err
}
}
l, err := s.ListSystemVms(p)
if err != nil {
return "", err
}
if l.Count == 0 {
return "", fmt.Errorf("No match found for %s: %+v", name, l)
}
if l.Count == 1 {
return l.SystemVms[0].Id, nil
}
if l.Count > 1 {
for _, v := range l.SystemVms {
if v.Name == name {
return v.Id, nil
}
}
}
return "", fmt.Errorf("Could not find an exact match for %s: %+v", name, l)
}
// This is a courtesy helper function, which in some cases may not work as expected!
func (s *SystemVMService) GetSystemVmByName(name string, opts ...OptionFunc) (*SystemVm, int, error) {
id, err := s.GetSystemVmID(name, opts...)
if err != nil {
return nil, -1, err
}
r, count, err := s.GetSystemVmByID(id, opts...)
if err != nil {
return nil, count, err
}
return r, count, nil
}
// This is a courtesy helper function, which in some cases may not work as expected!
func (s *SystemVMService) GetSystemVmByID(id string, opts ...OptionFunc) (*SystemVm, int, error) {
p := &ListSystemVmsParams{}
p.p = make(map[string]interface{})
p.p["id"] = id
for _, fn := range opts {
if err := fn(s.cs, p); err != nil {
return nil, -1, err
}
}
l, err := s.ListSystemVms(p)
if err != nil {
if strings.Contains(err.Error(), fmt.Sprintf(
"Invalid parameter id value=%s due to incorrect long value format, "+
"or entity does not exist", id)) {
return nil, 0, fmt.Errorf("No match found for %s: %+v", id, l)
}
return nil, -1, err
}
if l.Count == 0 {
return nil, l.Count, fmt.Errorf("No match found for %s: %+v", id, l)
}
if l.Count == 1 {
return l.SystemVms[0], l.Count, nil
}
return nil, l.Count, fmt.Errorf("There is more then one result for SystemVm UUID: %s!", id)
}
// List system virtual machines.
func (s *SystemVMService) ListSystemVms(p *ListSystemVmsParams) (*ListSystemVmsResponse, error) {
resp, err := s.cs.newRequest("listSystemVms", p.toURLValues())
if err != nil {
return nil, err
}
var r ListSystemVmsResponse
if err := json.Unmarshal(resp, &r); err != nil {
return nil, err
}
return &r, nil
}
type ListSystemVmsResponse struct {
Count int `json:"count"`
SystemVms []*SystemVm `json:"systemvm"`
}
type SystemVm struct {
Activeviewersessions int `json:"activeviewersessions,omitempty"`
Created string `json:"created,omitempty"`
Dns1 string `json:"dns1,omitempty"`
Dns2 string `json:"dns2,omitempty"`
Gateway string `json:"gateway,omitempty"`
Hostid string `json:"hostid,omitempty"`
Hostname string `json:"hostname,omitempty"`
Hypervisor string `json:"hypervisor,omitempty"`
Id string `json:"id,omitempty"`
Jobid string `json:"jobid,omitempty"`
Jobstatus int `json:"jobstatus,omitempty"`
Linklocalip string `json:"linklocalip,omitempty"`
Linklocalmacaddress string `json:"linklocalmacaddress,omitempty"`
Linklocalnetmask string `json:"linklocalnetmask,omitempty"`
Name string `json:"name,omitempty"`
Networkdomain string `json:"networkdomain,omitempty"`
Podid string `json:"podid,omitempty"`
Privateip string `json:"privateip,omitempty"`
Privatemacaddress string `json:"privatemacaddress,omitempty"`
Privatenetmask string `json:"privatenetmask,omitempty"`
Publicip string `json:"publicip,omitempty"`
Publicmacaddress string `json:"publicmacaddress,omitempty"`
Publicnetmask string `json:"publicnetmask,omitempty"`
State string `json:"state,omitempty"`
Systemvmtype string `json:"systemvmtype,omitempty"`
Templateid string `json:"templateid,omitempty"`
Zoneid string `json:"zoneid,omitempty"`
Zonename string `json:"zonename,omitempty"`
}
type MigrateSystemVmParams struct {
p map[string]interface{}
}
func (p *MigrateSystemVmParams) toURLValues() url.Values {
u := url.Values{}
if p.p == nil {
return u
}
if v, found := p.p["hostid"]; found {
u.Set("hostid", v.(string))
}
if v, found := p.p["virtualmachineid"]; found {
u.Set("virtualmachineid", v.(string))
}
return u
}
func (p *MigrateSystemVmParams) SetHostid(v string) {
if p.p == nil {
p.p = make(map[string]interface{})
}
p.p["hostid"] = v
return
}
func (p *MigrateSystemVmParams) SetVirtualmachineid(v string) {
if p.p == nil {
p.p = make(map[string]interface{})
}
p.p["virtualmachineid"] = v
return
}
// You should always use this function to get a new MigrateSystemVmParams instance,
// as then you are sure you have configured all required params
func (s *SystemVMService) NewMigrateSystemVmParams(hostid string, virtualmachineid string) *MigrateSystemVmParams {
p := &MigrateSystemVmParams{}
p.p = make(map[string]interface{})
p.p["hostid"] = hostid
p.p["virtualmachineid"] = virtualmachineid
return p
}
// Attempts Migration of a system virtual machine to the host specified.
func (s *SystemVMService) MigrateSystemVm(p *MigrateSystemVmParams) (*MigrateSystemVmResponse, error) {
resp, err := s.cs.newRequest("migrateSystemVm", p.toURLValues())
if err != nil {
return nil, err
}
var r MigrateSystemVmResponse
if err := json.Unmarshal(resp, &r); err != nil {
return nil, err
}
// If we have a async client, we need to wait for the async result
if s.cs.async {
b, err := s.cs.GetAsyncJobResult(r.JobID, s.cs.timeout)
if err != nil {
if err == AsyncTimeoutErr {
return &r, err
}
return nil, err
}
b, err = getRawValue(b)
if err != nil {
return nil, err
}
if err := json.Unmarshal(b, &r); err != nil {
return nil, err
}
}
return &r, nil
}
type MigrateSystemVmResponse struct {
JobID string `json:"jobid,omitempty"`
Activeviewersessions int `json:"activeviewersessions,omitempty"`
Created string `json:"created,omitempty"`
Dns1 string `json:"dns1,omitempty"`
Dns2 string `json:"dns2,omitempty"`
Gateway string `json:"gateway,omitempty"`
Hostid string `json:"hostid,omitempty"`
Hostname string `json:"hostname,omitempty"`
Hypervisor string `json:"hypervisor,omitempty"`
Id string `json:"id,omitempty"`
Jobid string `json:"jobid,omitempty"`
Jobstatus int `json:"jobstatus,omitempty"`
Linklocalip string `json:"linklocalip,omitempty"`
Linklocalmacaddress string `json:"linklocalmacaddress,omitempty"`
Linklocalnetmask string `json:"linklocalnetmask,omitempty"`
Name string `json:"name,omitempty"`
Networkdomain string `json:"networkdomain,omitempty"`
Podid string `json:"podid,omitempty"`
Privateip string `json:"privateip,omitempty"`
Privatemacaddress string `json:"privatemacaddress,omitempty"`
Privatenetmask string `json:"privatenetmask,omitempty"`
Publicip string `json:"publicip,omitempty"`
Publicmacaddress string `json:"publicmacaddress,omitempty"`
Publicnetmask string `json:"publicnetmask,omitempty"`
State string `json:"state,omitempty"`
Systemvmtype string `json:"systemvmtype,omitempty"`
Templateid string `json:"templateid,omitempty"`
Zoneid string `json:"zoneid,omitempty"`
Zonename string `json:"zonename,omitempty"`
}
type ChangeServiceForSystemVmParams struct {
p map[string]interface{}
}
func (p *ChangeServiceForSystemVmParams) toURLValues() url.Values {
u := url.Values{}
if p.p == nil {
return u
}
if v, found := p.p["details"]; found {
i := 0
for k, vv := range v.(map[string]string) {
u.Set(fmt.Sprintf("details[%d].key", i), k)
u.Set(fmt.Sprintf("details[%d].value", i), vv)
i++
}
}
if v, found := p.p["id"]; found {
u.Set("id", v.(string))
}
if v, found := p.p["serviceofferingid"]; found {
u.Set("serviceofferingid", v.(string))
}
return u
}
func (p *ChangeServiceForSystemVmParams) SetDetails(v map[string]string) {
if p.p == nil {
p.p = make(map[string]interface{})
}
p.p["details"] = v
return
}
func (p *ChangeServiceForSystemVmParams) SetId(v string) {
if p.p == nil {
p.p = make(map[string]interface{})
}
p.p["id"] = v
return
}
func (p *ChangeServiceForSystemVmParams) SetServiceofferingid(v string) {
if p.p == nil {
p.p = make(map[string]interface{})
}
p.p["serviceofferingid"] = v
return
}
// You should always use this function to get a new ChangeServiceForSystemVmParams instance,
// as then you are sure you have configured all required params
func (s *SystemVMService) NewChangeServiceForSystemVmParams(id string, serviceofferingid string) *ChangeServiceForSystemVmParams {
p := &ChangeServiceForSystemVmParams{}
p.p = make(map[string]interface{})
p.p["id"] = id
p.p["serviceofferingid"] = serviceofferingid
return p
}
// Changes the service offering for a system vm (console proxy or secondary storage). The system vm must be in a "Stopped" state for this command to take effect.
func (s *SystemVMService) ChangeServiceForSystemVm(p *ChangeServiceForSystemVmParams) (*ChangeServiceForSystemVmResponse, error) {
resp, err := s.cs.newRequest("changeServiceForSystemVm", p.toURLValues())
if err != nil {
return nil, err
}
var r ChangeServiceForSystemVmResponse
if err := json.Unmarshal(resp, &r); err != nil {
return nil, err
}
return &r, nil
}
type ChangeServiceForSystemVmResponse struct {
Activeviewersessions int `json:"activeviewersessions,omitempty"`
Created string `json:"created,omitempty"`
Dns1 string `json:"dns1,omitempty"`
Dns2 string `json:"dns2,omitempty"`
Gateway string `json:"gateway,omitempty"`
Hostid string `json:"hostid,omitempty"`
Hostname string `json:"hostname,omitempty"`
Hypervisor string `json:"hypervisor,omitempty"`
Id string `json:"id,omitempty"`
Jobid string `json:"jobid,omitempty"`
Jobstatus int `json:"jobstatus,omitempty"`
Linklocalip string `json:"linklocalip,omitempty"`
Linklocalmacaddress string `json:"linklocalmacaddress,omitempty"`
Linklocalnetmask string `json:"linklocalnetmask,omitempty"`
Name string `json:"name,omitempty"`
Networkdomain string `json:"networkdomain,omitempty"`
Podid string `json:"podid,omitempty"`
Privateip string `json:"privateip,omitempty"`
Privatemacaddress string `json:"privatemacaddress,omitempty"`
Privatenetmask string `json:"privatenetmask,omitempty"`
Publicip string `json:"publicip,omitempty"`
Publicmacaddress string `json:"publicmacaddress,omitempty"`
Publicnetmask string `json:"publicnetmask,omitempty"`
State string `json:"state,omitempty"`
Systemvmtype string `json:"systemvmtype,omitempty"`
Templateid string `json:"templateid,omitempty"`
Zoneid string `json:"zoneid,omitempty"`
Zonename string `json:"zonename,omitempty"`
}
type ScaleSystemVmParams struct {
p map[string]interface{}
}
func (p *ScaleSystemVmParams) toURLValues() url.Values {
u := url.Values{}
if p.p == nil {
return u
}
if v, found := p.p["details"]; found {
i := 0
for k, vv := range v.(map[string]string) {
u.Set(fmt.Sprintf("details[%d].key", i), k)
u.Set(fmt.Sprintf("details[%d].value", i), vv)
i++
}
}
if v, found := p.p["id"]; found {
u.Set("id", v.(string))
}
if v, found := p.p["serviceofferingid"]; found {
u.Set("serviceofferingid", v.(string))
}
return u
}
func (p *ScaleSystemVmParams) SetDetails(v map[string]string) {
if p.p == nil {
p.p = make(map[string]interface{})
}
p.p["details"] = v
return
}
func (p *ScaleSystemVmParams) SetId(v string) {
if p.p == nil {
p.p = make(map[string]interface{})
}
p.p["id"] = v
return
}
func (p *ScaleSystemVmParams) SetServiceofferingid(v string) {
if p.p == nil {
p.p = make(map[string]interface{})
}
p.p["serviceofferingid"] = v
return
}
// You should always use this function to get a new ScaleSystemVmParams instance,
// as then you are sure you have configured all required params
func (s *SystemVMService) NewScaleSystemVmParams(id string, serviceofferingid string) *ScaleSystemVmParams {
p := &ScaleSystemVmParams{}
p.p = make(map[string]interface{})
p.p["id"] = id
p.p["serviceofferingid"] = serviceofferingid
return p
}
// Scale the service offering for a system vm (console proxy or secondary storage). The system vm must be in a "Stopped" state for this command to take effect.
func (s *SystemVMService) ScaleSystemVm(p *ScaleSystemVmParams) (*ScaleSystemVmResponse, error) {
resp, err := s.cs.newRequest("scaleSystemVm", p.toURLValues())
if err != nil {
return nil, err
}
var r ScaleSystemVmResponse
if err := json.Unmarshal(resp, &r); err != nil {
return nil, err
}
// If we have a async client, we need to wait for the async result
if s.cs.async {
b, err := s.cs.GetAsyncJobResult(r.JobID, s.cs.timeout)
if err != nil {
if err == AsyncTimeoutErr {
return &r, err
}
return nil, err
}
b, err = getRawValue(b)
if err != nil {
return nil, err
}
if err := json.Unmarshal(b, &r); err != nil {
return nil, err
}
}
return &r, nil
}
type ScaleSystemVmResponse struct {
JobID string `json:"jobid,omitempty"`
Activeviewersessions int `json:"activeviewersessions,omitempty"`
Created string `json:"created,omitempty"`
Dns1 string `json:"dns1,omitempty"`
Dns2 string `json:"dns2,omitempty"`
Gateway string `json:"gateway,omitempty"`
Hostid string `json:"hostid,omitempty"`
Hostname string `json:"hostname,omitempty"`
Hypervisor string `json:"hypervisor,omitempty"`
Id string `json:"id,omitempty"`
Jobid string `json:"jobid,omitempty"`
Jobstatus int `json:"jobstatus,omitempty"`
Linklocalip string `json:"linklocalip,omitempty"`
Linklocalmacaddress string `json:"linklocalmacaddress,omitempty"`
Linklocalnetmask string `json:"linklocalnetmask,omitempty"`
Name string `json:"name,omitempty"`
Networkdomain string `json:"networkdomain,omitempty"`
Podid string `json:"podid,omitempty"`
Privateip string `json:"privateip,omitempty"`
Privatemacaddress string `json:"privatemacaddress,omitempty"`
Privatenetmask string `json:"privatenetmask,omitempty"`
Publicip string `json:"publicip,omitempty"`
Publicmacaddress string `json:"publicmacaddress,omitempty"`
Publicnetmask string `json:"publicnetmask,omitempty"`
State string `json:"state,omitempty"`
Systemvmtype string `json:"systemvmtype,omitempty"`
Templateid string `json:"templateid,omitempty"`
Zoneid string `json:"zoneid,omitempty"`
Zonename string `json:"zonename,omitempty"`
}