| // |
| // 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" |
| "net/url" |
| "strconv" |
| ) |
| |
| type CancelStorageMaintenanceParams struct { |
| p map[string]interface{} |
| } |
| |
| func (p *CancelStorageMaintenanceParams) 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 *CancelStorageMaintenanceParams) 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 CancelStorageMaintenanceParams instance, |
| // as then you are sure you have configured all required params |
| func (s *StoragePoolService) NewCancelStorageMaintenanceParams(id string) *CancelStorageMaintenanceParams { |
| p := &CancelStorageMaintenanceParams{} |
| p.p = make(map[string]interface{}) |
| p.p["id"] = id |
| return p |
| } |
| |
| // Cancels maintenance for primary storage |
| func (s *StoragePoolService) CancelStorageMaintenance(p *CancelStorageMaintenanceParams) (*CancelStorageMaintenanceResponse, error) { |
| resp, err := s.cs.newRequest("cancelStorageMaintenance", p.toURLValues()) |
| if err != nil { |
| return nil, err |
| } |
| |
| var r CancelStorageMaintenanceResponse |
| 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 CancelStorageMaintenanceResponse struct { |
| JobID string `json:"jobid"` |
| Allocatediops int64 `json:"allocatediops"` |
| Capacityiops int64 `json:"capacityiops"` |
| Clusterid string `json:"clusterid"` |
| Clustername string `json:"clustername"` |
| Created string `json:"created"` |
| Disksizeallocated int64 `json:"disksizeallocated"` |
| Disksizetotal int64 `json:"disksizetotal"` |
| Disksizeused int64 `json:"disksizeused"` |
| Hypervisor string `json:"hypervisor"` |
| Id string `json:"id"` |
| Ipaddress string `json:"ipaddress"` |
| Name string `json:"name"` |
| Overprovisionfactor string `json:"overprovisionfactor"` |
| Path string `json:"path"` |
| Podid string `json:"podid"` |
| Podname string `json:"podname"` |
| Provider string `json:"provider"` |
| Scope string `json:"scope"` |
| State string `json:"state"` |
| Storagecapabilities map[string]string `json:"storagecapabilities"` |
| Suitableformigration bool `json:"suitableformigration"` |
| Tags string `json:"tags"` |
| Type string `json:"type"` |
| Zoneid string `json:"zoneid"` |
| Zonename string `json:"zonename"` |
| } |
| |
| type EnableStorageMaintenanceParams struct { |
| p map[string]interface{} |
| } |
| |
| func (p *EnableStorageMaintenanceParams) 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 *EnableStorageMaintenanceParams) 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 EnableStorageMaintenanceParams instance, |
| // as then you are sure you have configured all required params |
| func (s *StoragePoolService) NewEnableStorageMaintenanceParams(id string) *EnableStorageMaintenanceParams { |
| p := &EnableStorageMaintenanceParams{} |
| p.p = make(map[string]interface{}) |
| p.p["id"] = id |
| return p |
| } |
| |
| // Puts storage pool into maintenance state |
| func (s *StoragePoolService) EnableStorageMaintenance(p *EnableStorageMaintenanceParams) (*EnableStorageMaintenanceResponse, error) { |
| resp, err := s.cs.newRequest("enableStorageMaintenance", p.toURLValues()) |
| if err != nil { |
| return nil, err |
| } |
| |
| var r EnableStorageMaintenanceResponse |
| 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 EnableStorageMaintenanceResponse struct { |
| JobID string `json:"jobid"` |
| Allocatediops int64 `json:"allocatediops"` |
| Capacityiops int64 `json:"capacityiops"` |
| Clusterid string `json:"clusterid"` |
| Clustername string `json:"clustername"` |
| Created string `json:"created"` |
| Disksizeallocated int64 `json:"disksizeallocated"` |
| Disksizetotal int64 `json:"disksizetotal"` |
| Disksizeused int64 `json:"disksizeused"` |
| Hypervisor string `json:"hypervisor"` |
| Id string `json:"id"` |
| Ipaddress string `json:"ipaddress"` |
| Name string `json:"name"` |
| Overprovisionfactor string `json:"overprovisionfactor"` |
| Path string `json:"path"` |
| Podid string `json:"podid"` |
| Podname string `json:"podname"` |
| Provider string `json:"provider"` |
| Scope string `json:"scope"` |
| State string `json:"state"` |
| Storagecapabilities map[string]string `json:"storagecapabilities"` |
| Suitableformigration bool `json:"suitableformigration"` |
| Tags string `json:"tags"` |
| Type string `json:"type"` |
| Zoneid string `json:"zoneid"` |
| Zonename string `json:"zonename"` |
| } |
| |
| type ListStorageProvidersParams struct { |
| p map[string]interface{} |
| } |
| |
| func (p *ListStorageProvidersParams) 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["type"]; found { |
| u.Set("type", v.(string)) |
| } |
| return u |
| } |
| |
| func (p *ListStorageProvidersParams) SetKeyword(v string) { |
| if p.p == nil { |
| p.p = make(map[string]interface{}) |
| } |
| p.p["keyword"] = v |
| return |
| } |
| |
| func (p *ListStorageProvidersParams) SetPage(v int) { |
| if p.p == nil { |
| p.p = make(map[string]interface{}) |
| } |
| p.p["page"] = v |
| return |
| } |
| |
| func (p *ListStorageProvidersParams) SetPagesize(v int) { |
| if p.p == nil { |
| p.p = make(map[string]interface{}) |
| } |
| p.p["pagesize"] = v |
| return |
| } |
| |
| func (p *ListStorageProvidersParams) SetType(v string) { |
| if p.p == nil { |
| p.p = make(map[string]interface{}) |
| } |
| p.p["type"] = v |
| return |
| } |
| |
| // You should always use this function to get a new ListStorageProvidersParams instance, |
| // as then you are sure you have configured all required params |
| func (s *StoragePoolService) NewListStorageProvidersParams(storagePoolType string) *ListStorageProvidersParams { |
| p := &ListStorageProvidersParams{} |
| p.p = make(map[string]interface{}) |
| p.p["type"] = storagePoolType |
| return p |
| } |
| |
| // Lists storage providers. |
| func (s *StoragePoolService) ListStorageProviders(p *ListStorageProvidersParams) (*ListStorageProvidersResponse, error) { |
| resp, err := s.cs.newRequest("listStorageProviders", p.toURLValues()) |
| if err != nil { |
| return nil, err |
| } |
| |
| var r ListStorageProvidersResponse |
| if err := json.Unmarshal(resp, &r); err != nil { |
| return nil, err |
| } |
| |
| return &r, nil |
| } |
| |
| type ListStorageProvidersResponse struct { |
| Count int `json:"count"` |
| StorageProviders []*StorageProvider `json:"storageprovider"` |
| } |
| |
| type StorageProvider struct { |
| Name string `json:"name"` |
| Type string `json:"type"` |
| } |