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.
		
			
				
	
	
		
			132 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			132 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package goscaleio
 | |
| 
 | |
| import (
 | |
| 	"bytes"
 | |
| 	"encoding/json"
 | |
| 	"errors"
 | |
| 	"fmt"
 | |
| 	"io/ioutil"
 | |
| 
 | |
| 	types "github.com/codedellemc/goscaleio/types/v1"
 | |
| )
 | |
| 
 | |
| type ProtectionDomain struct {
 | |
| 	ProtectionDomain *types.ProtectionDomain
 | |
| 	client           *Client
 | |
| }
 | |
| 
 | |
| func NewProtectionDomain(client *Client) *ProtectionDomain {
 | |
| 	return &ProtectionDomain{
 | |
| 		ProtectionDomain: new(types.ProtectionDomain),
 | |
| 		client:           client,
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func NewProtectionDomainEx(client *Client, pd *types.ProtectionDomain) *ProtectionDomain {
 | |
| 	return &ProtectionDomain{
 | |
| 		ProtectionDomain: pd,
 | |
| 		client:           client,
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func (system *System) CreateProtectionDomain(name string) (string, error) {
 | |
| 	endpoint := system.client.SIOEndpoint
 | |
| 
 | |
| 	protectionDomainParam := &types.ProtectionDomainParam{}
 | |
| 	protectionDomainParam.Name = name
 | |
| 
 | |
| 	jsonOutput, err := json.Marshal(&protectionDomainParam)
 | |
| 	if err != nil {
 | |
| 		return "", fmt.Errorf("error marshaling: %s", err)
 | |
| 	}
 | |
| 	endpoint.Path = fmt.Sprintf("/api/types/ProtectionDomain/instances")
 | |
| 
 | |
| 	req := system.client.NewRequest(map[string]string{}, "POST", endpoint, bytes.NewBufferString(string(jsonOutput)))
 | |
| 	req.SetBasicAuth("", system.client.Token)
 | |
| 	req.Header.Add("Accept", "application/json;version="+system.client.configConnect.Version)
 | |
| 	req.Header.Add("Content-Type", "application/json;version="+system.client.configConnect.Version)
 | |
| 
 | |
| 	resp, err := system.client.retryCheckResp(&system.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 pd types.ProtectionDomainResp
 | |
| 	err = json.Unmarshal(bs, &pd)
 | |
| 	if err != nil {
 | |
| 		return "", err
 | |
| 	}
 | |
| 
 | |
| 	return pd.ID, nil
 | |
| }
 | |
| 
 | |
| func (system *System) GetProtectionDomain(protectiondomainhref string) (protectionDomains []*types.ProtectionDomain, err error) {
 | |
| 
 | |
| 	endpoint := system.client.SIOEndpoint
 | |
| 
 | |
| 	if protectiondomainhref == "" {
 | |
| 		link, err := GetLink(system.System.Links, "/api/System/relationship/ProtectionDomain")
 | |
| 		if err != nil {
 | |
| 			return []*types.ProtectionDomain{}, errors.New("Error: problem finding link")
 | |
| 		}
 | |
| 
 | |
| 		endpoint.Path = link.HREF
 | |
| 	} else {
 | |
| 		endpoint.Path = protectiondomainhref
 | |
| 	}
 | |
| 
 | |
| 	req := system.client.NewRequest(map[string]string{}, "GET", endpoint, nil)
 | |
| 	req.SetBasicAuth("", system.client.Token)
 | |
| 	req.Header.Add("Accept", "application/json;version="+system.client.configConnect.Version)
 | |
| 
 | |
| 	resp, err := system.client.retryCheckResp(&system.client.Http, req)
 | |
| 	if err != nil {
 | |
| 		return []*types.ProtectionDomain{}, fmt.Errorf("problem getting response: %v", err)
 | |
| 	}
 | |
| 	defer resp.Body.Close()
 | |
| 
 | |
| 	if protectiondomainhref == "" {
 | |
| 		if err = system.client.decodeBody(resp, &protectionDomains); err != nil {
 | |
| 			return []*types.ProtectionDomain{}, fmt.Errorf("error decoding instances response: %s", err)
 | |
| 		}
 | |
| 	} else {
 | |
| 		protectionDomain := &types.ProtectionDomain{}
 | |
| 		if err = system.client.decodeBody(resp, &protectionDomain); err != nil {
 | |
| 			return []*types.ProtectionDomain{}, fmt.Errorf("error decoding instances response: %s", err)
 | |
| 		}
 | |
| 		protectionDomains = append(protectionDomains, protectionDomain)
 | |
| 
 | |
| 	}
 | |
| 	//
 | |
| 	// bs, err := ioutil.ReadAll(resp.Body)
 | |
| 	// if err != nil {
 | |
| 	// 	return []types.ProtectionDomain{}, errors.New("error reading body")
 | |
| 	// }
 | |
| 	//
 | |
| 	// fmt.Println(string(bs))
 | |
| 	// log.Fatalf("here")
 | |
| 	// return []types.ProtectionDomain{}, nil
 | |
| 	return protectionDomains, nil
 | |
| }
 | |
| 
 | |
| func (system *System) FindProtectionDomain(id, name, href string) (protectionDomain *types.ProtectionDomain, err error) {
 | |
| 	protectionDomains, err := system.GetProtectionDomain(href)
 | |
| 	if err != nil {
 | |
| 		return &types.ProtectionDomain{}, fmt.Errorf("Error getting protection domains %s", err)
 | |
| 	}
 | |
| 
 | |
| 	for _, protectionDomain = range protectionDomains {
 | |
| 		if protectionDomain.ID == id || protectionDomain.Name == name || href != "" {
 | |
| 			return protectionDomain, nil
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	return &types.ProtectionDomain{}, errors.New("Couldn't find protection domain")
 | |
| }
 |