// // Copyright 2018, 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 AddBaremetalHostParams struct { p map[string]interface{} } func (p *AddBaremetalHostParams) toURLValues() url.Values { u := url.Values{} if p.p == nil { return u } if v, found := p.p["allocationstate"]; found { u.Set("allocationstate", v.(string)) } if v, found := p.p["clusterid"]; found { u.Set("clusterid", v.(string)) } if v, found := p.p["clustername"]; found { u.Set("clustername", v.(string)) } if v, found := p.p["hosttags"]; found { vv := strings.Join(v.([]string), ",") u.Set("hosttags", vv) } if v, found := p.p["hypervisor"]; found { u.Set("hypervisor", v.(string)) } if v, found := p.p["ipaddress"]; found { u.Set("ipaddress", v.(string)) } if v, found := p.p["password"]; found { u.Set("password", v.(string)) } if v, found := p.p["podid"]; found { u.Set("podid", v.(string)) } if v, found := p.p["url"]; found { u.Set("url", v.(string)) } if v, found := p.p["username"]; found { u.Set("username", v.(string)) } if v, found := p.p["zoneid"]; found { u.Set("zoneid", v.(string)) } return u } func (p *AddBaremetalHostParams) SetAllocationstate(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["allocationstate"] = v return } func (p *AddBaremetalHostParams) SetClusterid(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["clusterid"] = v return } func (p *AddBaremetalHostParams) SetClustername(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["clustername"] = v return } func (p *AddBaremetalHostParams) SetHosttags(v []string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["hosttags"] = v return } func (p *AddBaremetalHostParams) SetHypervisor(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["hypervisor"] = v return } func (p *AddBaremetalHostParams) SetIpaddress(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["ipaddress"] = v return } func (p *AddBaremetalHostParams) SetPassword(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["password"] = v return } func (p *AddBaremetalHostParams) SetPodid(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["podid"] = v return } func (p *AddBaremetalHostParams) SetUrl(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["url"] = v return } func (p *AddBaremetalHostParams) SetUsername(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["username"] = v return } func (p *AddBaremetalHostParams) 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 AddBaremetalHostParams instance, // as then you are sure you have configured all required params func (s *HostService) NewAddBaremetalHostParams(hypervisor string, password string, podid string, url string, username string, zoneid string) *AddBaremetalHostParams { p := &AddBaremetalHostParams{} p.p = make(map[string]interface{}) p.p["hypervisor"] = hypervisor p.p["password"] = password p.p["podid"] = podid p.p["url"] = url p.p["username"] = username p.p["zoneid"] = zoneid return p } // add a baremetal host func (s *HostService) AddBaremetalHost(p *AddBaremetalHostParams) (*AddBaremetalHostResponse, error) { resp, err := s.cs.newRequest("addBaremetalHost", p.toURLValues()) if err != nil { return nil, err } var r AddBaremetalHostResponse if err := json.Unmarshal(resp, &r); err != nil { return nil, err } return &r, nil } type AddBaremetalHostResponse struct { Annotation string `json:"annotation"` Averageload int64 `json:"averageload"` Capabilities string `json:"capabilities"` Clusterid string `json:"clusterid"` Clustername string `json:"clustername"` Clustertype string `json:"clustertype"` Cpuallocated string `json:"cpuallocated"` Cpunumber int `json:"cpunumber"` Cpusockets int `json:"cpusockets"` Cpuspeed int64 `json:"cpuspeed"` Cpuused string `json:"cpuused"` Cpuwithoverprovisioning string `json:"cpuwithoverprovisioning"` Created string `json:"created"` Details map[string]string `json:"details"` Disconnected string `json:"disconnected"` Disksizeallocated int64 `json:"disksizeallocated"` Disksizetotal int64 `json:"disksizetotal"` Events string `json:"events"` Gpugroup []AddBaremetalHostResponseGpugroup `json:"gpugroup"` Hahost bool `json:"hahost"` Hasenoughcapacity bool `json:"hasenoughcapacity"` Hostha string `json:"hostha"` Hosttags string `json:"hosttags"` Hypervisor string `json:"hypervisor"` Hypervisorversion string `json:"hypervisorversion"` Id string `json:"id"` Ipaddress string `json:"ipaddress"` Islocalstorageactive bool `json:"islocalstorageactive"` JobID string `json:"jobid"` Jobstatus int `json:"jobstatus"` Lastannotated string `json:"lastannotated"` Lastpinged string `json:"lastpinged"` Managementserverid int64 `json:"managementserverid"` Memoryallocated int64 `json:"memoryallocated"` Memorytotal int64 `json:"memorytotal"` Memoryused int64 `json:"memoryused"` Memorywithoverprovisioning string `json:"memorywithoverprovisioning"` Name string `json:"name"` Networkkbsread int64 `json:"networkkbsread"` Networkkbswrite int64 `json:"networkkbswrite"` Oscategoryid string `json:"oscategoryid"` Oscategoryname string `json:"oscategoryname"` Outofbandmanagement OutOfBandManagementResponse `json:"outofbandmanagement"` Podid string `json:"podid"` Podname string `json:"podname"` Removed string `json:"removed"` Resourcestate string `json:"resourcestate"` State string `json:"state"` Suitableformigration bool `json:"suitableformigration"` Type string `json:"type"` Username string `json:"username"` Version string `json:"version"` Zoneid string `json:"zoneid"` Zonename string `json:"zonename"` } type AddBaremetalHostResponseGpugroup struct { Gpugroupname string `json:"gpugroupname"` Vgpu []AddBaremetalHostResponseGpugroupVgpu `json:"vgpu"` } type AddBaremetalHostResponseGpugroupVgpu struct { Maxcapacity int64 `json:"maxcapacity"` Maxheads int64 `json:"maxheads"` Maxresolutionx int64 `json:"maxresolutionx"` Maxresolutiony int64 `json:"maxresolutiony"` Maxvgpuperpgpu int64 `json:"maxvgpuperpgpu"` Remainingcapacity int64 `json:"remainingcapacity"` Vgputype string `json:"vgputype"` Videoram int64 `json:"videoram"` } type AddGloboDnsHostParams struct { p map[string]interface{} } func (p *AddGloboDnsHostParams) toURLValues() url.Values { u := url.Values{} if p.p == nil { return u } if v, found := p.p["password"]; found { u.Set("password", v.(string)) } if v, found := p.p["physicalnetworkid"]; found { u.Set("physicalnetworkid", v.(string)) } if v, found := p.p["url"]; found { u.Set("url", v.(string)) } if v, found := p.p["username"]; found { u.Set("username", v.(string)) } return u } func (p *AddGloboDnsHostParams) SetPassword(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["password"] = v return } func (p *AddGloboDnsHostParams) SetPhysicalnetworkid(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["physicalnetworkid"] = v return } func (p *AddGloboDnsHostParams) SetUrl(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["url"] = v return } func (p *AddGloboDnsHostParams) SetUsername(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["username"] = v return } // You should always use this function to get a new AddGloboDnsHostParams instance, // as then you are sure you have configured all required params func (s *HostService) NewAddGloboDnsHostParams(password string, physicalnetworkid string, url string, username string) *AddGloboDnsHostParams { p := &AddGloboDnsHostParams{} p.p = make(map[string]interface{}) p.p["password"] = password p.p["physicalnetworkid"] = physicalnetworkid p.p["url"] = url p.p["username"] = username return p } // Adds the GloboDNS external host func (s *HostService) AddGloboDnsHost(p *AddGloboDnsHostParams) (*AddGloboDnsHostResponse, error) { resp, err := s.cs.newRequest("addGloboDnsHost", p.toURLValues()) if err != nil { return nil, err } var r AddGloboDnsHostResponse 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 } if err := json.Unmarshal(b, &r); err != nil { return nil, err } } return &r, nil } type AddGloboDnsHostResponse struct { Displaytext string `json:"displaytext"` JobID string `json:"jobid"` Jobstatus int `json:"jobstatus"` Success bool `json:"success"` } type AddHostParams struct { p map[string]interface{} } func (p *AddHostParams) toURLValues() url.Values { u := url.Values{} if p.p == nil { return u } if v, found := p.p["allocationstate"]; found { u.Set("allocationstate", v.(string)) } if v, found := p.p["clusterid"]; found { u.Set("clusterid", v.(string)) } if v, found := p.p["clustername"]; found { u.Set("clustername", v.(string)) } if v, found := p.p["hosttags"]; found { vv := strings.Join(v.([]string), ",") u.Set("hosttags", vv) } if v, found := p.p["hypervisor"]; found { u.Set("hypervisor", v.(string)) } if v, found := p.p["password"]; found { u.Set("password", v.(string)) } if v, found := p.p["podid"]; found { u.Set("podid", v.(string)) } if v, found := p.p["url"]; found { u.Set("url", v.(string)) } if v, found := p.p["username"]; found { u.Set("username", v.(string)) } if v, found := p.p["zoneid"]; found { u.Set("zoneid", v.(string)) } return u } func (p *AddHostParams) SetAllocationstate(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["allocationstate"] = v return } func (p *AddHostParams) SetClusterid(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["clusterid"] = v return } func (p *AddHostParams) SetClustername(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["clustername"] = v return } func (p *AddHostParams) SetHosttags(v []string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["hosttags"] = v return } func (p *AddHostParams) SetHypervisor(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["hypervisor"] = v return } func (p *AddHostParams) SetPassword(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["password"] = v return } func (p *AddHostParams) SetPodid(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["podid"] = v return } func (p *AddHostParams) SetUrl(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["url"] = v return } func (p *AddHostParams) SetUsername(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["username"] = v return } func (p *AddHostParams) 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 AddHostParams instance, // as then you are sure you have configured all required params func (s *HostService) NewAddHostParams(hypervisor string, password string, podid string, url string, username string, zoneid string) *AddHostParams { p := &AddHostParams{} p.p = make(map[string]interface{}) p.p["hypervisor"] = hypervisor p.p["password"] = password p.p["podid"] = podid p.p["url"] = url p.p["username"] = username p.p["zoneid"] = zoneid return p } // Adds a new host. func (s *HostService) AddHost(p *AddHostParams) (*AddHostResponse, error) { resp, err := s.cs.newRequest("addHost", p.toURLValues()) if err != nil { return nil, err } var r AddHostResponse if err := json.Unmarshal(resp, &r); err != nil { return nil, err } return &r, nil } type AddHostResponse struct { Annotation string `json:"annotation"` Averageload int64 `json:"averageload"` Capabilities string `json:"capabilities"` Clusterid string `json:"clusterid"` Clustername string `json:"clustername"` Clustertype string `json:"clustertype"` Cpuallocated string `json:"cpuallocated"` Cpunumber int `json:"cpunumber"` Cpusockets int `json:"cpusockets"` Cpuspeed int64 `json:"cpuspeed"` Cpuused string `json:"cpuused"` Cpuwithoverprovisioning string `json:"cpuwithoverprovisioning"` Created string `json:"created"` Details map[string]string `json:"details"` Disconnected string `json:"disconnected"` Disksizeallocated int64 `json:"disksizeallocated"` Disksizetotal int64 `json:"disksizetotal"` Events string `json:"events"` Gpugroup []AddHostResponseGpugroup `json:"gpugroup"` Hahost bool `json:"hahost"` Hasenoughcapacity bool `json:"hasenoughcapacity"` Hostha string `json:"hostha"` Hosttags string `json:"hosttags"` Hypervisor string `json:"hypervisor"` Hypervisorversion string `json:"hypervisorversion"` Id string `json:"id"` Ipaddress string `json:"ipaddress"` Islocalstorageactive bool `json:"islocalstorageactive"` JobID string `json:"jobid"` Jobstatus int `json:"jobstatus"` Lastannotated string `json:"lastannotated"` Lastpinged string `json:"lastpinged"` Managementserverid int64 `json:"managementserverid"` Memoryallocated int64 `json:"memoryallocated"` Memorytotal int64 `json:"memorytotal"` Memoryused int64 `json:"memoryused"` Memorywithoverprovisioning string `json:"memorywithoverprovisioning"` Name string `json:"name"` Networkkbsread int64 `json:"networkkbsread"` Networkkbswrite int64 `json:"networkkbswrite"` Oscategoryid string `json:"oscategoryid"` Oscategoryname string `json:"oscategoryname"` Outofbandmanagement OutOfBandManagementResponse `json:"outofbandmanagement"` Podid string `json:"podid"` Podname string `json:"podname"` Removed string `json:"removed"` Resourcestate string `json:"resourcestate"` State string `json:"state"` Suitableformigration bool `json:"suitableformigration"` Type string `json:"type"` Username string `json:"username"` Version string `json:"version"` Zoneid string `json:"zoneid"` Zonename string `json:"zonename"` } type AddHostResponseGpugroup struct { Gpugroupname string `json:"gpugroupname"` Vgpu []AddHostResponseGpugroupVgpu `json:"vgpu"` } type AddHostResponseGpugroupVgpu struct { Maxcapacity int64 `json:"maxcapacity"` Maxheads int64 `json:"maxheads"` Maxresolutionx int64 `json:"maxresolutionx"` Maxresolutiony int64 `json:"maxresolutiony"` Maxvgpuperpgpu int64 `json:"maxvgpuperpgpu"` Remainingcapacity int64 `json:"remainingcapacity"` Vgputype string `json:"vgputype"` Videoram int64 `json:"videoram"` } type AddSecondaryStorageParams struct { p map[string]interface{} } func (p *AddSecondaryStorageParams) toURLValues() url.Values { u := url.Values{} if p.p == nil { return u } if v, found := p.p["url"]; found { u.Set("url", v.(string)) } if v, found := p.p["zoneid"]; found { u.Set("zoneid", v.(string)) } return u } func (p *AddSecondaryStorageParams) SetUrl(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["url"] = v return } func (p *AddSecondaryStorageParams) 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 AddSecondaryStorageParams instance, // as then you are sure you have configured all required params func (s *HostService) NewAddSecondaryStorageParams(url string) *AddSecondaryStorageParams { p := &AddSecondaryStorageParams{} p.p = make(map[string]interface{}) p.p["url"] = url return p } // Adds secondary storage. func (s *HostService) AddSecondaryStorage(p *AddSecondaryStorageParams) (*AddSecondaryStorageResponse, error) { resp, err := s.cs.newRequest("addSecondaryStorage", p.toURLValues()) if err != nil { return nil, err } var r AddSecondaryStorageResponse if err := json.Unmarshal(resp, &r); err != nil { return nil, err } return &r, nil } type AddSecondaryStorageResponse struct { Id string `json:"id"` JobID string `json:"jobid"` Jobstatus int `json:"jobstatus"` Name string `json:"name"` Protocol string `json:"protocol"` Providername string `json:"providername"` Scope string `json:"scope"` Url string `json:"url"` Zoneid string `json:"zoneid"` Zonename string `json:"zonename"` } type CancelHostMaintenanceParams struct { p map[string]interface{} } func (p *CancelHostMaintenanceParams) 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 *CancelHostMaintenanceParams) 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 CancelHostMaintenanceParams instance, // as then you are sure you have configured all required params func (s *HostService) NewCancelHostMaintenanceParams(id string) *CancelHostMaintenanceParams { p := &CancelHostMaintenanceParams{} p.p = make(map[string]interface{}) p.p["id"] = id return p } // Cancels host maintenance. func (s *HostService) CancelHostMaintenance(p *CancelHostMaintenanceParams) (*CancelHostMaintenanceResponse, error) { resp, err := s.cs.newRequest("cancelHostMaintenance", p.toURLValues()) if err != nil { return nil, err } var r CancelHostMaintenanceResponse 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 CancelHostMaintenanceResponse struct { Annotation string `json:"annotation"` Averageload int64 `json:"averageload"` Capabilities string `json:"capabilities"` Clusterid string `json:"clusterid"` Clustername string `json:"clustername"` Clustertype string `json:"clustertype"` Cpuallocated string `json:"cpuallocated"` Cpunumber int `json:"cpunumber"` Cpusockets int `json:"cpusockets"` Cpuspeed int64 `json:"cpuspeed"` Cpuused string `json:"cpuused"` Cpuwithoverprovisioning string `json:"cpuwithoverprovisioning"` Created string `json:"created"` Details map[string]string `json:"details"` Disconnected string `json:"disconnected"` Disksizeallocated int64 `json:"disksizeallocated"` Disksizetotal int64 `json:"disksizetotal"` Events string `json:"events"` Gpugroup []CancelHostMaintenanceResponseGpugroup `json:"gpugroup"` Hahost bool `json:"hahost"` Hasenoughcapacity bool `json:"hasenoughcapacity"` Hostha string `json:"hostha"` Hosttags string `json:"hosttags"` Hypervisor string `json:"hypervisor"` Hypervisorversion string `json:"hypervisorversion"` Id string `json:"id"` Ipaddress string `json:"ipaddress"` Islocalstorageactive bool `json:"islocalstorageactive"` JobID string `json:"jobid"` Jobstatus int `json:"jobstatus"` Lastannotated string `json:"lastannotated"` Lastpinged string `json:"lastpinged"` Managementserverid int64 `json:"managementserverid"` Memoryallocated int64 `json:"memoryallocated"` Memorytotal int64 `json:"memorytotal"` Memoryused int64 `json:"memoryused"` Memorywithoverprovisioning string `json:"memorywithoverprovisioning"` Name string `json:"name"` Networkkbsread int64 `json:"networkkbsread"` Networkkbswrite int64 `json:"networkkbswrite"` Oscategoryid string `json:"oscategoryid"` Oscategoryname string `json:"oscategoryname"` Outofbandmanagement OutOfBandManagementResponse `json:"outofbandmanagement"` Podid string `json:"podid"` Podname string `json:"podname"` Removed string `json:"removed"` Resourcestate string `json:"resourcestate"` State string `json:"state"` Suitableformigration bool `json:"suitableformigration"` Type string `json:"type"` Username string `json:"username"` Version string `json:"version"` Zoneid string `json:"zoneid"` Zonename string `json:"zonename"` } type CancelHostMaintenanceResponseGpugroup struct { Gpugroupname string `json:"gpugroupname"` Vgpu []CancelHostMaintenanceResponseGpugroupVgpu `json:"vgpu"` } type CancelHostMaintenanceResponseGpugroupVgpu struct { Maxcapacity int64 `json:"maxcapacity"` Maxheads int64 `json:"maxheads"` Maxresolutionx int64 `json:"maxresolutionx"` Maxresolutiony int64 `json:"maxresolutiony"` Maxvgpuperpgpu int64 `json:"maxvgpuperpgpu"` Remainingcapacity int64 `json:"remainingcapacity"` Vgputype string `json:"vgputype"` Videoram int64 `json:"videoram"` } type DedicateHostParams struct { p map[string]interface{} } func (p *DedicateHostParams) toURLValues() url.Values { u := url.Values{} if p.p == nil { return u } if v, found := p.p["account"]; found { u.Set("account", v.(string)) } if v, found := p.p["domainid"]; found { u.Set("domainid", v.(string)) } if v, found := p.p["hostid"]; found { u.Set("hostid", v.(string)) } return u } func (p *DedicateHostParams) SetAccount(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["account"] = v return } func (p *DedicateHostParams) SetDomainid(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["domainid"] = v return } func (p *DedicateHostParams) SetHostid(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["hostid"] = v return } // You should always use this function to get a new DedicateHostParams instance, // as then you are sure you have configured all required params func (s *HostService) NewDedicateHostParams(domainid string, hostid string) *DedicateHostParams { p := &DedicateHostParams{} p.p = make(map[string]interface{}) p.p["domainid"] = domainid p.p["hostid"] = hostid return p } // Dedicates a host. func (s *HostService) DedicateHost(p *DedicateHostParams) (*DedicateHostResponse, error) { resp, err := s.cs.newRequest("dedicateHost", p.toURLValues()) if err != nil { return nil, err } var r DedicateHostResponse 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 DedicateHostResponse struct { Accountid string `json:"accountid"` Affinitygroupid string `json:"affinitygroupid"` Domainid string `json:"domainid"` Hostid string `json:"hostid"` Hostname string `json:"hostname"` Id string `json:"id"` JobID string `json:"jobid"` Jobstatus int `json:"jobstatus"` } type DeleteHostParams struct { p map[string]interface{} } func (p *DeleteHostParams) 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["forcedestroylocalstorage"]; found { vv := strconv.FormatBool(v.(bool)) u.Set("forcedestroylocalstorage", vv) } if v, found := p.p["id"]; found { u.Set("id", v.(string)) } return u } func (p *DeleteHostParams) SetForced(v bool) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["forced"] = v return } func (p *DeleteHostParams) SetForcedestroylocalstorage(v bool) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["forcedestroylocalstorage"] = v return } func (p *DeleteHostParams) 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 DeleteHostParams instance, // as then you are sure you have configured all required params func (s *HostService) NewDeleteHostParams(id string) *DeleteHostParams { p := &DeleteHostParams{} p.p = make(map[string]interface{}) p.p["id"] = id return p } // Deletes a host. func (s *HostService) DeleteHost(p *DeleteHostParams) (*DeleteHostResponse, error) { resp, err := s.cs.newRequest("deleteHost", p.toURLValues()) if err != nil { return nil, err } var r DeleteHostResponse if err := json.Unmarshal(resp, &r); err != nil { return nil, err } return &r, nil } type DeleteHostResponse struct { Displaytext string `json:"displaytext"` JobID string `json:"jobid"` Jobstatus int `json:"jobstatus"` Success bool `json:"success"` } func (r *DeleteHostResponse) UnmarshalJSON(b []byte) error { var m map[string]interface{} err := json.Unmarshal(b, &m) if err != nil { return err } if success, ok := m["success"].(string); ok { m["success"] = success == "true" b, err = json.Marshal(m) if err != nil { return err } } if ostypeid, ok := m["ostypeid"].(float64); ok { m["ostypeid"] = strconv.Itoa(int(ostypeid)) b, err = json.Marshal(m) if err != nil { return err } } type alias DeleteHostResponse return json.Unmarshal(b, (*alias)(r)) } type DisableOutOfBandManagementForHostParams struct { p map[string]interface{} } func (p *DisableOutOfBandManagementForHostParams) toURLValues() url.Values { u := url.Values{} if p.p == nil { return u } if v, found := p.p["hostid"]; found { u.Set("hostid", v.(string)) } return u } func (p *DisableOutOfBandManagementForHostParams) SetHostid(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["hostid"] = v return } // You should always use this function to get a new DisableOutOfBandManagementForHostParams instance, // as then you are sure you have configured all required params func (s *HostService) NewDisableOutOfBandManagementForHostParams(hostid string) *DisableOutOfBandManagementForHostParams { p := &DisableOutOfBandManagementForHostParams{} p.p = make(map[string]interface{}) p.p["hostid"] = hostid return p } // Disables out-of-band management for a host func (s *HostService) DisableOutOfBandManagementForHost(p *DisableOutOfBandManagementForHostParams) (*DisableOutOfBandManagementForHostResponse, error) { resp, err := s.cs.newRequest("disableOutOfBandManagementForHost", p.toURLValues()) if err != nil { return nil, err } var r DisableOutOfBandManagementForHostResponse 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 DisableOutOfBandManagementForHostResponse struct { Action string `json:"action"` Address string `json:"address"` Description string `json:"description"` Driver string `json:"driver"` Enabled bool `json:"enabled"` Hostid string `json:"hostid"` JobID string `json:"jobid"` Jobstatus int `json:"jobstatus"` Password string `json:"password"` Port string `json:"port"` Powerstate string `json:"powerstate"` Status bool `json:"status"` Username string `json:"username"` } type EnableOutOfBandManagementForHostParams struct { p map[string]interface{} } func (p *EnableOutOfBandManagementForHostParams) toURLValues() url.Values { u := url.Values{} if p.p == nil { return u } if v, found := p.p["hostid"]; found { u.Set("hostid", v.(string)) } return u } func (p *EnableOutOfBandManagementForHostParams) SetHostid(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["hostid"] = v return } // You should always use this function to get a new EnableOutOfBandManagementForHostParams instance, // as then you are sure you have configured all required params func (s *HostService) NewEnableOutOfBandManagementForHostParams(hostid string) *EnableOutOfBandManagementForHostParams { p := &EnableOutOfBandManagementForHostParams{} p.p = make(map[string]interface{}) p.p["hostid"] = hostid return p } // Enables out-of-band management for a host func (s *HostService) EnableOutOfBandManagementForHost(p *EnableOutOfBandManagementForHostParams) (*EnableOutOfBandManagementForHostResponse, error) { resp, err := s.cs.newRequest("enableOutOfBandManagementForHost", p.toURLValues()) if err != nil { return nil, err } var r EnableOutOfBandManagementForHostResponse 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 EnableOutOfBandManagementForHostResponse struct { Action string `json:"action"` Address string `json:"address"` Description string `json:"description"` Driver string `json:"driver"` Enabled bool `json:"enabled"` Hostid string `json:"hostid"` JobID string `json:"jobid"` Jobstatus int `json:"jobstatus"` Password string `json:"password"` Port string `json:"port"` Powerstate string `json:"powerstate"` Status bool `json:"status"` Username string `json:"username"` } type FindHostsForMigrationParams struct { p map[string]interface{} } func (p *FindHostsForMigrationParams) toURLValues() url.Values { u := url.Values{} if p.p == nil { return u } if v, found := p.p["keyword"]; found { u.Set("keyword", 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["virtualmachineid"]; found { u.Set("virtualmachineid", v.(string)) } return u } func (p *FindHostsForMigrationParams) SetKeyword(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["keyword"] = v return } func (p *FindHostsForMigrationParams) SetPage(v int) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["page"] = v return } func (p *FindHostsForMigrationParams) SetPagesize(v int) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["pagesize"] = v return } func (p *FindHostsForMigrationParams) 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 FindHostsForMigrationParams instance, // as then you are sure you have configured all required params func (s *HostService) NewFindHostsForMigrationParams(virtualmachineid string) *FindHostsForMigrationParams { p := &FindHostsForMigrationParams{} p.p = make(map[string]interface{}) p.p["virtualmachineid"] = virtualmachineid return p } // Find hosts suitable for migrating a virtual machine. func (s *HostService) FindHostsForMigration(p *FindHostsForMigrationParams) (*FindHostsForMigrationResponse, error) { resp, err := s.cs.newRequest("findHostsForMigration", p.toURLValues()) if err != nil { return nil, err } var r FindHostsForMigrationResponse if err := json.Unmarshal(resp, &r); err != nil { return nil, err } return &r, nil } type FindHostsForMigrationResponse struct { Averageload int64 `json:"averageload"` Capabilities string `json:"capabilities"` Clusterid string `json:"clusterid"` Clustername string `json:"clustername"` Clustertype string `json:"clustertype"` Cpuallocated string `json:"cpuallocated"` Cpunumber int `json:"cpunumber"` Cpuspeed int64 `json:"cpuspeed"` Cpuused string `json:"cpuused"` Cpuwithoverprovisioning string `json:"cpuwithoverprovisioning"` Created string `json:"created"` Disconnected string `json:"disconnected"` Disksizeallocated int64 `json:"disksizeallocated"` Disksizetotal int64 `json:"disksizetotal"` Events string `json:"events"` Hahost bool `json:"hahost"` Hasenoughcapacity bool `json:"hasenoughcapacity"` Hosttags string `json:"hosttags"` Hypervisor string `json:"hypervisor"` Hypervisorversion string `json:"hypervisorversion"` Id string `json:"id"` Ipaddress string `json:"ipaddress"` Islocalstorageactive bool `json:"islocalstorageactive"` JobID string `json:"jobid"` Jobstatus int `json:"jobstatus"` Lastpinged string `json:"lastpinged"` Managementserverid int64 `json:"managementserverid"` Memoryallocated string `json:"memoryallocated"` Memorytotal int64 `json:"memorytotal"` Memoryused int64 `json:"memoryused"` Memorywithoverprovisioning string `json:"memorywithoverprovisioning"` Name string `json:"name"` Networkkbsread int64 `json:"networkkbsread"` Networkkbswrite int64 `json:"networkkbswrite"` Oscategoryid string `json:"oscategoryid"` Oscategoryname string `json:"oscategoryname"` Podid string `json:"podid"` Podname string `json:"podname"` Removed string `json:"removed"` RequiresStorageMotion bool `json:"requiresStorageMotion"` Resourcestate string `json:"resourcestate"` State string `json:"state"` Suitableformigration bool `json:"suitableformigration"` Type string `json:"type"` Version string `json:"version"` Zoneid string `json:"zoneid"` Zonename string `json:"zonename"` } type ListDedicatedHostsParams struct { p map[string]interface{} } func (p *ListDedicatedHostsParams) toURLValues() url.Values { u := url.Values{} if p.p == nil { return u } if v, found := p.p["account"]; found { u.Set("account", v.(string)) } if v, found := p.p["affinitygroupid"]; found { u.Set("affinitygroupid", v.(string)) } if v, found := p.p["domainid"]; found { u.Set("domainid", v.(string)) } if v, found := p.p["hostid"]; found { u.Set("hostid", v.(string)) } if v, found := p.p["keyword"]; found { u.Set("keyword", 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) } return u } func (p *ListDedicatedHostsParams) SetAccount(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["account"] = v return } func (p *ListDedicatedHostsParams) SetAffinitygroupid(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["affinitygroupid"] = v return } func (p *ListDedicatedHostsParams) SetDomainid(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["domainid"] = v return } func (p *ListDedicatedHostsParams) SetHostid(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["hostid"] = v return } func (p *ListDedicatedHostsParams) SetKeyword(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["keyword"] = v return } func (p *ListDedicatedHostsParams) SetPage(v int) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["page"] = v return } func (p *ListDedicatedHostsParams) SetPagesize(v int) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["pagesize"] = v return } // You should always use this function to get a new ListDedicatedHostsParams instance, // as then you are sure you have configured all required params func (s *HostService) NewListDedicatedHostsParams() *ListDedicatedHostsParams { p := &ListDedicatedHostsParams{} p.p = make(map[string]interface{}) return p } // Lists dedicated hosts. func (s *HostService) ListDedicatedHosts(p *ListDedicatedHostsParams) (*ListDedicatedHostsResponse, error) { resp, err := s.cs.newRequest("listDedicatedHosts", p.toURLValues()) if err != nil { return nil, err } var r ListDedicatedHostsResponse if err := json.Unmarshal(resp, &r); err != nil { return nil, err } return &r, nil } type ListDedicatedHostsResponse struct { Count int `json:"count"` DedicatedHosts []*DedicatedHost `json:"dedicatedhost"` } type DedicatedHost struct { Accountid string `json:"accountid"` Affinitygroupid string `json:"affinitygroupid"` Domainid string `json:"domainid"` Hostid string `json:"hostid"` Hostname string `json:"hostname"` Id string `json:"id"` JobID string `json:"jobid"` Jobstatus int `json:"jobstatus"` } type ListHostTagsParams struct { p map[string]interface{} } func (p *ListHostTagsParams) toURLValues() url.Values { u := url.Values{} if p.p == nil { return u } if v, found := p.p["keyword"]; found { u.Set("keyword", 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) } return u } func (p *ListHostTagsParams) SetKeyword(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["keyword"] = v return } func (p *ListHostTagsParams) SetPage(v int) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["page"] = v return } func (p *ListHostTagsParams) SetPagesize(v int) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["pagesize"] = v return } // You should always use this function to get a new ListHostTagsParams instance, // as then you are sure you have configured all required params func (s *HostService) NewListHostTagsParams() *ListHostTagsParams { p := &ListHostTagsParams{} 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 *HostService) GetHostTagID(keyword string, opts ...OptionFunc) (string, int, error) { p := &ListHostTagsParams{} p.p = make(map[string]interface{}) p.p["keyword"] = keyword for _, fn := range append(s.cs.options, opts...) { if err := fn(s.cs, p); err != nil { return "", -1, err } } l, err := s.ListHostTags(p) if err != nil { return "", -1, err } if l.Count == 0 { return "", l.Count, fmt.Errorf("No match found for %s: %+v", keyword, l) } if l.Count == 1 { return l.HostTags[0].Id, l.Count, nil } if l.Count > 1 { for _, v := range l.HostTags { if v.Name == keyword { return v.Id, l.Count, nil } } } return "", l.Count, fmt.Errorf("Could not find an exact match for %s: %+v", keyword, l) } // Lists host tags func (s *HostService) ListHostTags(p *ListHostTagsParams) (*ListHostTagsResponse, error) { resp, err := s.cs.newRequest("listHostTags", p.toURLValues()) if err != nil { return nil, err } var r ListHostTagsResponse if err := json.Unmarshal(resp, &r); err != nil { return nil, err } return &r, nil } type ListHostTagsResponse struct { Count int `json:"count"` HostTags []*HostTag `json:"hosttag"` } type HostTag struct { Hostid int64 `json:"hostid"` Id string `json:"id"` JobID string `json:"jobid"` Jobstatus int `json:"jobstatus"` Name string `json:"name"` } type ListHostsParams struct { p map[string]interface{} } func (p *ListHostsParams) toURLValues() url.Values { u := url.Values{} if p.p == nil { return u } if v, found := p.p["clusterid"]; found { u.Set("clusterid", v.(string)) } if v, found := p.p["details"]; found { vv := strings.Join(v.([]string), ",") u.Set("details", vv) } if v, found := p.p["hahost"]; found { vv := strconv.FormatBool(v.(bool)) u.Set("hahost", vv) } if v, found := p.p["hypervisor"]; found { u.Set("hypervisor", 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["outofbandmanagementenabled"]; found { vv := strconv.FormatBool(v.(bool)) u.Set("outofbandmanagementenabled", vv) } if v, found := p.p["outofbandmanagementpowerstate"]; found { u.Set("outofbandmanagementpowerstate", 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["resourcestate"]; found { u.Set("resourcestate", v.(string)) } if v, found := p.p["state"]; found { u.Set("state", v.(string)) } if v, found := p.p["type"]; found { u.Set("type", v.(string)) } if v, found := p.p["virtualmachineid"]; found { u.Set("virtualmachineid", v.(string)) } if v, found := p.p["zoneid"]; found { u.Set("zoneid", v.(string)) } return u } func (p *ListHostsParams) SetClusterid(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["clusterid"] = v return } func (p *ListHostsParams) SetDetails(v []string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["details"] = v return } func (p *ListHostsParams) SetHahost(v bool) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["hahost"] = v return } func (p *ListHostsParams) SetHypervisor(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["hypervisor"] = v return } func (p *ListHostsParams) SetId(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["id"] = v return } func (p *ListHostsParams) SetKeyword(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["keyword"] = v return } func (p *ListHostsParams) SetName(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["name"] = v return } func (p *ListHostsParams) SetOutofbandmanagementenabled(v bool) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["outofbandmanagementenabled"] = v return } func (p *ListHostsParams) SetOutofbandmanagementpowerstate(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["outofbandmanagementpowerstate"] = v return } func (p *ListHostsParams) SetPage(v int) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["page"] = v return } func (p *ListHostsParams) SetPagesize(v int) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["pagesize"] = v return } func (p *ListHostsParams) SetPodid(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["podid"] = v return } func (p *ListHostsParams) SetResourcestate(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["resourcestate"] = v return } func (p *ListHostsParams) SetState(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["state"] = v return } func (p *ListHostsParams) SetType(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["type"] = v return } func (p *ListHostsParams) SetVirtualmachineid(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["virtualmachineid"] = v return } func (p *ListHostsParams) 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 ListHostsParams instance, // as then you are sure you have configured all required params func (s *HostService) NewListHostsParams() *ListHostsParams { p := &ListHostsParams{} 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 *HostService) GetHostID(name string, opts ...OptionFunc) (string, int, error) { p := &ListHostsParams{} p.p = make(map[string]interface{}) p.p["name"] = name for _, fn := range append(s.cs.options, opts...) { if err := fn(s.cs, p); err != nil { return "", -1, err } } l, err := s.ListHosts(p) if err != nil { return "", -1, err } if l.Count == 0 { return "", l.Count, fmt.Errorf("No match found for %s: %+v", name, l) } if l.Count == 1 { return l.Hosts[0].Id, l.Count, nil } if l.Count > 1 { for _, v := range l.Hosts { if v.Name == name { return v.Id, l.Count, nil } } } return "", l.Count, 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 *HostService) GetHostByName(name string, opts ...OptionFunc) (*Host, int, error) { id, count, err := s.GetHostID(name, opts...) if err != nil { return nil, count, err } r, count, err := s.GetHostByID(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 *HostService) GetHostByID(id string, opts ...OptionFunc) (*Host, int, error) { p := &ListHostsParams{} p.p = make(map[string]interface{}) p.p["id"] = id for _, fn := range append(s.cs.options, opts...) { if err := fn(s.cs, p); err != nil { return nil, -1, err } } l, err := s.ListHosts(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.Hosts[0], l.Count, nil } return nil, l.Count, fmt.Errorf("There is more then one result for Host UUID: %s!", id) } // Lists hosts. func (s *HostService) ListHosts(p *ListHostsParams) (*ListHostsResponse, error) { resp, err := s.cs.newRequest("listHosts", p.toURLValues()) if err != nil { return nil, err } var r ListHostsResponse if err := json.Unmarshal(resp, &r); err != nil { return nil, err } return &r, nil } type ListHostsResponse struct { Count int `json:"count"` Hosts []*Host `json:"host"` } type Host struct { Annotation string `json:"annotation"` Averageload int64 `json:"averageload"` Capabilities string `json:"capabilities"` Clusterid string `json:"clusterid"` Clustername string `json:"clustername"` Clustertype string `json:"clustertype"` Cpuallocated string `json:"cpuallocated"` Cpunumber int `json:"cpunumber"` Cpusockets int `json:"cpusockets"` Cpuspeed int64 `json:"cpuspeed"` Cpuused string `json:"cpuused"` Cpuwithoverprovisioning string `json:"cpuwithoverprovisioning"` Created string `json:"created"` Details map[string]string `json:"details"` Disconnected string `json:"disconnected"` Disksizeallocated int64 `json:"disksizeallocated"` Disksizetotal int64 `json:"disksizetotal"` Events string `json:"events"` Gpugroup []HostGpugroup `json:"gpugroup"` Hahost bool `json:"hahost"` Hasenoughcapacity bool `json:"hasenoughcapacity"` Hostha string `json:"hostha"` Hosttags string `json:"hosttags"` Hypervisor string `json:"hypervisor"` Hypervisorversion string `json:"hypervisorversion"` Id string `json:"id"` Ipaddress string `json:"ipaddress"` Islocalstorageactive bool `json:"islocalstorageactive"` JobID string `json:"jobid"` Jobstatus int `json:"jobstatus"` Lastannotated string `json:"lastannotated"` Lastpinged string `json:"lastpinged"` Managementserverid int64 `json:"managementserverid"` Memoryallocated int64 `json:"memoryallocated"` Memorytotal int64 `json:"memorytotal"` Memoryused int64 `json:"memoryused"` Memorywithoverprovisioning string `json:"memorywithoverprovisioning"` Name string `json:"name"` Networkkbsread int64 `json:"networkkbsread"` Networkkbswrite int64 `json:"networkkbswrite"` Oscategoryid string `json:"oscategoryid"` Oscategoryname string `json:"oscategoryname"` Outofbandmanagement OutOfBandManagementResponse `json:"outofbandmanagement"` Podid string `json:"podid"` Podname string `json:"podname"` Removed string `json:"removed"` Resourcestate string `json:"resourcestate"` State string `json:"state"` Suitableformigration bool `json:"suitableformigration"` Type string `json:"type"` Username string `json:"username"` Version string `json:"version"` Zoneid string `json:"zoneid"` Zonename string `json:"zonename"` } type HostGpugroup struct { Gpugroupname string `json:"gpugroupname"` Vgpu []HostGpugroupVgpu `json:"vgpu"` } type HostGpugroupVgpu struct { Maxcapacity int64 `json:"maxcapacity"` Maxheads int64 `json:"maxheads"` Maxresolutionx int64 `json:"maxresolutionx"` Maxresolutiony int64 `json:"maxresolutiony"` Maxvgpuperpgpu int64 `json:"maxvgpuperpgpu"` Remainingcapacity int64 `json:"remainingcapacity"` Vgputype string `json:"vgputype"` Videoram int64 `json:"videoram"` } type PrepareHostForMaintenanceParams struct { p map[string]interface{} } func (p *PrepareHostForMaintenanceParams) 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 *PrepareHostForMaintenanceParams) 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 PrepareHostForMaintenanceParams instance, // as then you are sure you have configured all required params func (s *HostService) NewPrepareHostForMaintenanceParams(id string) *PrepareHostForMaintenanceParams { p := &PrepareHostForMaintenanceParams{} p.p = make(map[string]interface{}) p.p["id"] = id return p } // Prepares a host for maintenance. func (s *HostService) PrepareHostForMaintenance(p *PrepareHostForMaintenanceParams) (*PrepareHostForMaintenanceResponse, error) { resp, err := s.cs.newRequest("prepareHostForMaintenance", p.toURLValues()) if err != nil { return nil, err } var r PrepareHostForMaintenanceResponse 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 PrepareHostForMaintenanceResponse struct { Annotation string `json:"annotation"` Averageload int64 `json:"averageload"` Capabilities string `json:"capabilities"` Clusterid string `json:"clusterid"` Clustername string `json:"clustername"` Clustertype string `json:"clustertype"` Cpuallocated string `json:"cpuallocated"` Cpunumber int `json:"cpunumber"` Cpusockets int `json:"cpusockets"` Cpuspeed int64 `json:"cpuspeed"` Cpuused string `json:"cpuused"` Cpuwithoverprovisioning string `json:"cpuwithoverprovisioning"` Created string `json:"created"` Details map[string]string `json:"details"` Disconnected string `json:"disconnected"` Disksizeallocated int64 `json:"disksizeallocated"` Disksizetotal int64 `json:"disksizetotal"` Events string `json:"events"` Gpugroup []PrepareHostForMaintenanceResponseGpugroup `json:"gpugroup"` Hahost bool `json:"hahost"` Hasenoughcapacity bool `json:"hasenoughcapacity"` Hostha string `json:"hostha"` Hosttags string `json:"hosttags"` Hypervisor string `json:"hypervisor"` Hypervisorversion string `json:"hypervisorversion"` Id string `json:"id"` Ipaddress string `json:"ipaddress"` Islocalstorageactive bool `json:"islocalstorageactive"` JobID string `json:"jobid"` Jobstatus int `json:"jobstatus"` Lastannotated string `json:"lastannotated"` Lastpinged string `json:"lastpinged"` Managementserverid int64 `json:"managementserverid"` Memoryallocated int64 `json:"memoryallocated"` Memorytotal int64 `json:"memorytotal"` Memoryused int64 `json:"memoryused"` Memorywithoverprovisioning string `json:"memorywithoverprovisioning"` Name string `json:"name"` Networkkbsread int64 `json:"networkkbsread"` Networkkbswrite int64 `json:"networkkbswrite"` Oscategoryid string `json:"oscategoryid"` Oscategoryname string `json:"oscategoryname"` Outofbandmanagement OutOfBandManagementResponse `json:"outofbandmanagement"` Podid string `json:"podid"` Podname string `json:"podname"` Removed string `json:"removed"` Resourcestate string `json:"resourcestate"` State string `json:"state"` Suitableformigration bool `json:"suitableformigration"` Type string `json:"type"` Username string `json:"username"` Version string `json:"version"` Zoneid string `json:"zoneid"` Zonename string `json:"zonename"` } type PrepareHostForMaintenanceResponseGpugroup struct { Gpugroupname string `json:"gpugroupname"` Vgpu []PrepareHostForMaintenanceResponseGpugroupVgpu `json:"vgpu"` } type PrepareHostForMaintenanceResponseGpugroupVgpu struct { Maxcapacity int64 `json:"maxcapacity"` Maxheads int64 `json:"maxheads"` Maxresolutionx int64 `json:"maxresolutionx"` Maxresolutiony int64 `json:"maxresolutiony"` Maxvgpuperpgpu int64 `json:"maxvgpuperpgpu"` Remainingcapacity int64 `json:"remainingcapacity"` Vgputype string `json:"vgputype"` Videoram int64 `json:"videoram"` } type ReconnectHostParams struct { p map[string]interface{} } func (p *ReconnectHostParams) 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 *ReconnectHostParams) 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 ReconnectHostParams instance, // as then you are sure you have configured all required params func (s *HostService) NewReconnectHostParams(id string) *ReconnectHostParams { p := &ReconnectHostParams{} p.p = make(map[string]interface{}) p.p["id"] = id return p } // Reconnects a host. func (s *HostService) ReconnectHost(p *ReconnectHostParams) (*ReconnectHostResponse, error) { resp, err := s.cs.newRequest("reconnectHost", p.toURLValues()) if err != nil { return nil, err } var r ReconnectHostResponse 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 ReconnectHostResponse struct { Annotation string `json:"annotation"` Averageload int64 `json:"averageload"` Capabilities string `json:"capabilities"` Clusterid string `json:"clusterid"` Clustername string `json:"clustername"` Clustertype string `json:"clustertype"` Cpuallocated string `json:"cpuallocated"` Cpunumber int `json:"cpunumber"` Cpusockets int `json:"cpusockets"` Cpuspeed int64 `json:"cpuspeed"` Cpuused string `json:"cpuused"` Cpuwithoverprovisioning string `json:"cpuwithoverprovisioning"` Created string `json:"created"` Details map[string]string `json:"details"` Disconnected string `json:"disconnected"` Disksizeallocated int64 `json:"disksizeallocated"` Disksizetotal int64 `json:"disksizetotal"` Events string `json:"events"` Gpugroup []ReconnectHostResponseGpugroup `json:"gpugroup"` Hahost bool `json:"hahost"` Hasenoughcapacity bool `json:"hasenoughcapacity"` Hostha string `json:"hostha"` Hosttags string `json:"hosttags"` Hypervisor string `json:"hypervisor"` Hypervisorversion string `json:"hypervisorversion"` Id string `json:"id"` Ipaddress string `json:"ipaddress"` Islocalstorageactive bool `json:"islocalstorageactive"` JobID string `json:"jobid"` Jobstatus int `json:"jobstatus"` Lastannotated string `json:"lastannotated"` Lastpinged string `json:"lastpinged"` Managementserverid int64 `json:"managementserverid"` Memoryallocated int64 `json:"memoryallocated"` Memorytotal int64 `json:"memorytotal"` Memoryused int64 `json:"memoryused"` Memorywithoverprovisioning string `json:"memorywithoverprovisioning"` Name string `json:"name"` Networkkbsread int64 `json:"networkkbsread"` Networkkbswrite int64 `json:"networkkbswrite"` Oscategoryid string `json:"oscategoryid"` Oscategoryname string `json:"oscategoryname"` Outofbandmanagement OutOfBandManagementResponse `json:"outofbandmanagement"` Podid string `json:"podid"` Podname string `json:"podname"` Removed string `json:"removed"` Resourcestate string `json:"resourcestate"` State string `json:"state"` Suitableformigration bool `json:"suitableformigration"` Type string `json:"type"` Username string `json:"username"` Version string `json:"version"` Zoneid string `json:"zoneid"` Zonename string `json:"zonename"` } type ReconnectHostResponseGpugroup struct { Gpugroupname string `json:"gpugroupname"` Vgpu []ReconnectHostResponseGpugroupVgpu `json:"vgpu"` } type ReconnectHostResponseGpugroupVgpu struct { Maxcapacity int64 `json:"maxcapacity"` Maxheads int64 `json:"maxheads"` Maxresolutionx int64 `json:"maxresolutionx"` Maxresolutiony int64 `json:"maxresolutiony"` Maxvgpuperpgpu int64 `json:"maxvgpuperpgpu"` Remainingcapacity int64 `json:"remainingcapacity"` Vgputype string `json:"vgputype"` Videoram int64 `json:"videoram"` } type ReleaseDedicatedHostParams struct { p map[string]interface{} } func (p *ReleaseDedicatedHostParams) toURLValues() url.Values { u := url.Values{} if p.p == nil { return u } if v, found := p.p["hostid"]; found { u.Set("hostid", v.(string)) } return u } func (p *ReleaseDedicatedHostParams) SetHostid(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["hostid"] = v return } // You should always use this function to get a new ReleaseDedicatedHostParams instance, // as then you are sure you have configured all required params func (s *HostService) NewReleaseDedicatedHostParams(hostid string) *ReleaseDedicatedHostParams { p := &ReleaseDedicatedHostParams{} p.p = make(map[string]interface{}) p.p["hostid"] = hostid return p } // Release the dedication for host func (s *HostService) ReleaseDedicatedHost(p *ReleaseDedicatedHostParams) (*ReleaseDedicatedHostResponse, error) { resp, err := s.cs.newRequest("releaseDedicatedHost", p.toURLValues()) if err != nil { return nil, err } var r ReleaseDedicatedHostResponse 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 } if err := json.Unmarshal(b, &r); err != nil { return nil, err } } return &r, nil } type ReleaseDedicatedHostResponse struct { Displaytext string `json:"displaytext"` JobID string `json:"jobid"` Jobstatus int `json:"jobstatus"` Success bool `json:"success"` } type ReleaseHostReservationParams struct { p map[string]interface{} } func (p *ReleaseHostReservationParams) 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 *ReleaseHostReservationParams) 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 ReleaseHostReservationParams instance, // as then you are sure you have configured all required params func (s *HostService) NewReleaseHostReservationParams(id string) *ReleaseHostReservationParams { p := &ReleaseHostReservationParams{} p.p = make(map[string]interface{}) p.p["id"] = id return p } // Releases host reservation. func (s *HostService) ReleaseHostReservation(p *ReleaseHostReservationParams) (*ReleaseHostReservationResponse, error) { resp, err := s.cs.newRequest("releaseHostReservation", p.toURLValues()) if err != nil { return nil, err } var r ReleaseHostReservationResponse 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 } if err := json.Unmarshal(b, &r); err != nil { return nil, err } } return &r, nil } type ReleaseHostReservationResponse struct { Displaytext string `json:"displaytext"` JobID string `json:"jobid"` Jobstatus int `json:"jobstatus"` Success bool `json:"success"` } type UpdateHostParams struct { p map[string]interface{} } func (p *UpdateHostParams) toURLValues() url.Values { u := url.Values{} if p.p == nil { return u } if v, found := p.p["allocationstate"]; found { u.Set("allocationstate", v.(string)) } if v, found := p.p["annotation"]; found { u.Set("annotation", v.(string)) } if v, found := p.p["hosttags"]; found { vv := strings.Join(v.([]string), ",") u.Set("hosttags", vv) } if v, found := p.p["id"]; found { u.Set("id", v.(string)) } if v, found := p.p["oscategoryid"]; found { u.Set("oscategoryid", v.(string)) } if v, found := p.p["url"]; found { u.Set("url", v.(string)) } return u } func (p *UpdateHostParams) SetAllocationstate(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["allocationstate"] = v return } func (p *UpdateHostParams) SetAnnotation(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["annotation"] = v return } func (p *UpdateHostParams) SetHosttags(v []string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["hosttags"] = v return } func (p *UpdateHostParams) SetId(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["id"] = v return } func (p *UpdateHostParams) SetOscategoryid(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["oscategoryid"] = v return } func (p *UpdateHostParams) SetUrl(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["url"] = v return } // You should always use this function to get a new UpdateHostParams instance, // as then you are sure you have configured all required params func (s *HostService) NewUpdateHostParams(id string) *UpdateHostParams { p := &UpdateHostParams{} p.p = make(map[string]interface{}) p.p["id"] = id return p } // Updates a host. func (s *HostService) UpdateHost(p *UpdateHostParams) (*UpdateHostResponse, error) { resp, err := s.cs.newRequest("updateHost", p.toURLValues()) if err != nil { return nil, err } var r UpdateHostResponse if err := json.Unmarshal(resp, &r); err != nil { return nil, err } return &r, nil } type UpdateHostResponse struct { Annotation string `json:"annotation"` Averageload int64 `json:"averageload"` Capabilities string `json:"capabilities"` Clusterid string `json:"clusterid"` Clustername string `json:"clustername"` Clustertype string `json:"clustertype"` Cpuallocated string `json:"cpuallocated"` Cpunumber int `json:"cpunumber"` Cpusockets int `json:"cpusockets"` Cpuspeed int64 `json:"cpuspeed"` Cpuused string `json:"cpuused"` Cpuwithoverprovisioning string `json:"cpuwithoverprovisioning"` Created string `json:"created"` Details map[string]string `json:"details"` Disconnected string `json:"disconnected"` Disksizeallocated int64 `json:"disksizeallocated"` Disksizetotal int64 `json:"disksizetotal"` Events string `json:"events"` Gpugroup []UpdateHostResponseGpugroup `json:"gpugroup"` Hahost bool `json:"hahost"` Hasenoughcapacity bool `json:"hasenoughcapacity"` Hostha string `json:"hostha"` Hosttags string `json:"hosttags"` Hypervisor string `json:"hypervisor"` Hypervisorversion string `json:"hypervisorversion"` Id string `json:"id"` Ipaddress string `json:"ipaddress"` Islocalstorageactive bool `json:"islocalstorageactive"` JobID string `json:"jobid"` Jobstatus int `json:"jobstatus"` Lastannotated string `json:"lastannotated"` Lastpinged string `json:"lastpinged"` Managementserverid int64 `json:"managementserverid"` Memoryallocated int64 `json:"memoryallocated"` Memorytotal int64 `json:"memorytotal"` Memoryused int64 `json:"memoryused"` Memorywithoverprovisioning string `json:"memorywithoverprovisioning"` Name string `json:"name"` Networkkbsread int64 `json:"networkkbsread"` Networkkbswrite int64 `json:"networkkbswrite"` Oscategoryid string `json:"oscategoryid"` Oscategoryname string `json:"oscategoryname"` Outofbandmanagement OutOfBandManagementResponse `json:"outofbandmanagement"` Podid string `json:"podid"` Podname string `json:"podname"` Removed string `json:"removed"` Resourcestate string `json:"resourcestate"` State string `json:"state"` Suitableformigration bool `json:"suitableformigration"` Type string `json:"type"` Username string `json:"username"` Version string `json:"version"` Zoneid string `json:"zoneid"` Zonename string `json:"zonename"` } type UpdateHostResponseGpugroup struct { Gpugroupname string `json:"gpugroupname"` Vgpu []UpdateHostResponseGpugroupVgpu `json:"vgpu"` } type UpdateHostResponseGpugroupVgpu struct { Maxcapacity int64 `json:"maxcapacity"` Maxheads int64 `json:"maxheads"` Maxresolutionx int64 `json:"maxresolutionx"` Maxresolutiony int64 `json:"maxresolutiony"` Maxvgpuperpgpu int64 `json:"maxvgpuperpgpu"` Remainingcapacity int64 `json:"remainingcapacity"` Vgputype string `json:"vgputype"` Videoram int64 `json:"videoram"` } type UpdateHostPasswordParams struct { p map[string]interface{} } func (p *UpdateHostPasswordParams) toURLValues() url.Values { u := url.Values{} if p.p == nil { return u } if v, found := p.p["clusterid"]; found { u.Set("clusterid", v.(string)) } if v, found := p.p["hostid"]; found { u.Set("hostid", v.(string)) } if v, found := p.p["password"]; found { u.Set("password", v.(string)) } if v, found := p.p["update_passwd_on_host"]; found { vv := strconv.FormatBool(v.(bool)) u.Set("update_passwd_on_host", vv) } if v, found := p.p["username"]; found { u.Set("username", v.(string)) } return u } func (p *UpdateHostPasswordParams) SetClusterid(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["clusterid"] = v return } func (p *UpdateHostPasswordParams) SetHostid(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["hostid"] = v return } func (p *UpdateHostPasswordParams) SetPassword(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["password"] = v return } func (p *UpdateHostPasswordParams) SetUpdate_passwd_on_host(v bool) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["update_passwd_on_host"] = v return } func (p *UpdateHostPasswordParams) SetUsername(v string) { if p.p == nil { p.p = make(map[string]interface{}) } p.p["username"] = v return } // You should always use this function to get a new UpdateHostPasswordParams instance, // as then you are sure you have configured all required params func (s *HostService) NewUpdateHostPasswordParams(password string, username string) *UpdateHostPasswordParams { p := &UpdateHostPasswordParams{} p.p = make(map[string]interface{}) p.p["password"] = password p.p["username"] = username return p } // Update password of a host/pool on management server. func (s *HostService) UpdateHostPassword(p *UpdateHostPasswordParams) (*UpdateHostPasswordResponse, error) { resp, err := s.cs.newRequest("updateHostPassword", p.toURLValues()) if err != nil { return nil, err } var r UpdateHostPasswordResponse if err := json.Unmarshal(resp, &r); err != nil { return nil, err } return &r, nil } type UpdateHostPasswordResponse struct { Displaytext string `json:"displaytext"` JobID string `json:"jobid"` Jobstatus int `json:"jobstatus"` Success bool `json:"success"` } func (r *UpdateHostPasswordResponse) UnmarshalJSON(b []byte) error { var m map[string]interface{} err := json.Unmarshal(b, &m) if err != nil { return err } if success, ok := m["success"].(string); ok { m["success"] = success == "true" b, err = json.Marshal(m) if err != nil { return err } } if ostypeid, ok := m["ostypeid"].(float64); ok { m["ostypeid"] = strconv.Itoa(int(ostypeid)) b, err = json.Marshal(m) if err != nil { return err } } type alias UpdateHostPasswordResponse return json.Unmarshal(b, (*alias)(r)) }