mirror of
				https://github.com/k3s-io/kubernetes.git
				synced 2025-10-31 05:40:42 +00:00 
			
		
		
		
	This commits implements the Kubernetes volume plugin allowing pods to seamlessly access and use data stored on ScaleIO volumes.
		
			
				
	
	
		
			123 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			123 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package goscaleio
 | |
| 
 | |
| import (
 | |
| 	"bytes"
 | |
| 	"encoding/json"
 | |
| 	"errors"
 | |
| 	"fmt"
 | |
| 	"io/ioutil"
 | |
| 	"reflect"
 | |
| 
 | |
| 	types "github.com/codedellemc/goscaleio/types/v1"
 | |
| )
 | |
| 
 | |
| type Sds struct {
 | |
| 	Sds    *types.Sds
 | |
| 	client *Client
 | |
| }
 | |
| 
 | |
| func NewSds(client *Client) *Sds {
 | |
| 	return &Sds{
 | |
| 		Sds:    new(types.Sds),
 | |
| 		client: client,
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func NewSdsEx(client *Client, sds *types.Sds) *Sds {
 | |
| 	return &Sds{
 | |
| 		Sds:    sds,
 | |
| 		client: client,
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func (protectionDomain *ProtectionDomain) CreateSds(name string, ipList []string) (string, error) {
 | |
| 	endpoint := protectionDomain.client.SIOEndpoint
 | |
| 
 | |
| 	sdsParam := &types.SdsParam{}
 | |
| 	sdsParam.Name = name
 | |
| 	sdsParam.ProtectionDomainID = protectionDomain.ProtectionDomain.ID
 | |
| 
 | |
| 	if len(ipList) == 0 {
 | |
| 		return "", fmt.Errorf("Must provide at least 1 SDS IP")
 | |
| 	} else if len(ipList) == 1 {
 | |
| 		sdsIP := types.SdsIp{IP: ipList[0], Role: "all"}
 | |
| 		sdsIPList := &types.SdsIpList{sdsIP}
 | |
| 		sdsParam.IPList = append(sdsParam.IPList, sdsIPList)
 | |
| 	} else if len(ipList) >= 2 {
 | |
| 		sdsIP1 := types.SdsIp{IP: ipList[0], Role: "sdcOnly"}
 | |
| 		sdsIP2 := types.SdsIp{IP: ipList[1], Role: "sdsOnly"}
 | |
| 		sdsIPList1 := &types.SdsIpList{sdsIP1}
 | |
| 		sdsIPList2 := &types.SdsIpList{sdsIP2}
 | |
| 		sdsParam.IPList = append(sdsParam.IPList, sdsIPList1)
 | |
| 		sdsParam.IPList = append(sdsParam.IPList, sdsIPList2)
 | |
| 	}
 | |
| 
 | |
| 	jsonOutput, err := json.Marshal(&sdsParam)
 | |
| 	if err != nil {
 | |
| 		return "", fmt.Errorf("error marshaling: %s", err)
 | |
| 	}
 | |
| 	endpoint.Path = fmt.Sprintf("/api/types/Sds/instances")
 | |
| 
 | |
| 	req := protectionDomain.client.NewRequest(map[string]string{}, "POST", endpoint, bytes.NewBufferString(string(jsonOutput)))
 | |
| 	req.SetBasicAuth("", protectionDomain.client.Token)
 | |
| 	req.Header.Add("Accept", "application/json;version="+protectionDomain.client.configConnect.Version)
 | |
| 	req.Header.Add("Content-Type", "application/json;version="+protectionDomain.client.configConnect.Version)
 | |
| 
 | |
| 	resp, err := protectionDomain.client.retryCheckResp(&protectionDomain.client.Http, req)
 | |
| 	if err != nil {
 | |
| 		return "", err
 | |
| 	}
 | |
| 	defer resp.Body.Close()
 | |
| 
 | |
| 	bs, err := ioutil.ReadAll(resp.Body)
 | |
| 	if err != nil {
 | |
| 		return "", errors.New("error reading body")
 | |
| 	}
 | |
| 
 | |
| 	var sds types.SdsResp
 | |
| 	err = json.Unmarshal(bs, &sds)
 | |
| 	if err != nil {
 | |
| 		return "", err
 | |
| 	}
 | |
| 
 | |
| 	return sds.ID, nil
 | |
| }
 | |
| 
 | |
| func (protectionDomain *ProtectionDomain) GetSds() (sdss []types.Sds, err error) {
 | |
| 	endpoint := protectionDomain.client.SIOEndpoint
 | |
| 	endpoint.Path = fmt.Sprintf("/api/instances/ProtectionDomain::%v/relationships/Sds", protectionDomain.ProtectionDomain.ID)
 | |
| 
 | |
| 	req := protectionDomain.client.NewRequest(map[string]string{}, "GET", endpoint, nil)
 | |
| 	req.SetBasicAuth("", protectionDomain.client.Token)
 | |
| 	req.Header.Add("Accept", "application/json;version="+protectionDomain.client.configConnect.Version)
 | |
| 
 | |
| 	resp, err := protectionDomain.client.retryCheckResp(&protectionDomain.client.Http, req)
 | |
| 	if err != nil {
 | |
| 		return []types.Sds{}, fmt.Errorf("problem getting response: %v", err)
 | |
| 	}
 | |
| 	defer resp.Body.Close()
 | |
| 
 | |
| 	if err = protectionDomain.client.decodeBody(resp, &sdss); err != nil {
 | |
| 		return []types.Sds{}, fmt.Errorf("error decoding instances response: %s", err)
 | |
| 	}
 | |
| 
 | |
| 	return sdss, nil
 | |
| }
 | |
| 
 | |
| func (protectionDomain *ProtectionDomain) FindSds(field, value string) (sds *types.Sds, err error) {
 | |
| 	sdss, err := protectionDomain.GetSds()
 | |
| 	if err != nil {
 | |
| 		return &types.Sds{}, nil
 | |
| 	}
 | |
| 
 | |
| 	for _, sds := range sdss {
 | |
| 		valueOf := reflect.ValueOf(sds)
 | |
| 		switch {
 | |
| 		case reflect.Indirect(valueOf).FieldByName(field).String() == value:
 | |
| 			return &sds, nil
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	return &types.Sds{}, errors.New("Couldn't find SDS")
 | |
| }
 |