mirror of
				https://github.com/optim-enterprises-bv/kubernetes.git
				synced 2025-11-04 04:08:16 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			301 lines
		
	
	
		
			9.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			301 lines
		
	
	
		
			9.2 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"
 | 
						|
	"net/url"
 | 
						|
	"strconv"
 | 
						|
)
 | 
						|
 | 
						|
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["storagePoolType"] = 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["storagePoolType"] = 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,omitempty"`
 | 
						|
	Type string `json:"type,omitempty"`
 | 
						|
}
 | 
						|
 | 
						|
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,omitempty"`
 | 
						|
	Capacityiops         int64             `json:"capacityiops,omitempty"`
 | 
						|
	Clusterid            string            `json:"clusterid,omitempty"`
 | 
						|
	Clustername          string            `json:"clustername,omitempty"`
 | 
						|
	Created              string            `json:"created,omitempty"`
 | 
						|
	Disksizeallocated    int64             `json:"disksizeallocated,omitempty"`
 | 
						|
	Disksizetotal        int64             `json:"disksizetotal,omitempty"`
 | 
						|
	Disksizeused         int64             `json:"disksizeused,omitempty"`
 | 
						|
	Hypervisor           string            `json:"hypervisor,omitempty"`
 | 
						|
	Id                   string            `json:"id,omitempty"`
 | 
						|
	Ipaddress            string            `json:"ipaddress,omitempty"`
 | 
						|
	Name                 string            `json:"name,omitempty"`
 | 
						|
	Overprovisionfactor  string            `json:"overprovisionfactor,omitempty"`
 | 
						|
	Path                 string            `json:"path,omitempty"`
 | 
						|
	Podid                string            `json:"podid,omitempty"`
 | 
						|
	Podname              string            `json:"podname,omitempty"`
 | 
						|
	Scope                string            `json:"scope,omitempty"`
 | 
						|
	State                string            `json:"state,omitempty"`
 | 
						|
	Storagecapabilities  map[string]string `json:"storagecapabilities,omitempty"`
 | 
						|
	Suitableformigration bool              `json:"suitableformigration,omitempty"`
 | 
						|
	Tags                 string            `json:"tags,omitempty"`
 | 
						|
	Type                 string            `json:"type,omitempty"`
 | 
						|
	Zoneid               string            `json:"zoneid,omitempty"`
 | 
						|
	Zonename             string            `json:"zonename,omitempty"`
 | 
						|
}
 | 
						|
 | 
						|
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,omitempty"`
 | 
						|
	Capacityiops         int64             `json:"capacityiops,omitempty"`
 | 
						|
	Clusterid            string            `json:"clusterid,omitempty"`
 | 
						|
	Clustername          string            `json:"clustername,omitempty"`
 | 
						|
	Created              string            `json:"created,omitempty"`
 | 
						|
	Disksizeallocated    int64             `json:"disksizeallocated,omitempty"`
 | 
						|
	Disksizetotal        int64             `json:"disksizetotal,omitempty"`
 | 
						|
	Disksizeused         int64             `json:"disksizeused,omitempty"`
 | 
						|
	Hypervisor           string            `json:"hypervisor,omitempty"`
 | 
						|
	Id                   string            `json:"id,omitempty"`
 | 
						|
	Ipaddress            string            `json:"ipaddress,omitempty"`
 | 
						|
	Name                 string            `json:"name,omitempty"`
 | 
						|
	Overprovisionfactor  string            `json:"overprovisionfactor,omitempty"`
 | 
						|
	Path                 string            `json:"path,omitempty"`
 | 
						|
	Podid                string            `json:"podid,omitempty"`
 | 
						|
	Podname              string            `json:"podname,omitempty"`
 | 
						|
	Scope                string            `json:"scope,omitempty"`
 | 
						|
	State                string            `json:"state,omitempty"`
 | 
						|
	Storagecapabilities  map[string]string `json:"storagecapabilities,omitempty"`
 | 
						|
	Suitableformigration bool              `json:"suitableformigration,omitempty"`
 | 
						|
	Tags                 string            `json:"tags,omitempty"`
 | 
						|
	Type                 string            `json:"type,omitempty"`
 | 
						|
	Zoneid               string            `json:"zoneid,omitempty"`
 | 
						|
	Zonename             string            `json:"zonename,omitempty"`
 | 
						|
}
 |