mirror of
				https://github.com/optim-enterprises-bv/vault.git
				synced 2025-10-30 18:17:55 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			119 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			119 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package api
 | |
| 
 | |
| import (
 | |
| 	"fmt"
 | |
| )
 | |
| 
 | |
| // Sys is used to perform system-related operations on Vault.
 | |
| type Sys struct {
 | |
| 	c *Client
 | |
| }
 | |
| 
 | |
| // Sys is used to return the client for sys-related API calls.
 | |
| func (c *Client) Sys() *Sys {
 | |
| 	return &Sys{c: c}
 | |
| }
 | |
| 
 | |
| func (c *Sys) SealStatus() (*SealStatusResponse, error) {
 | |
| 	r := c.c.NewRequest("GET", "/sys/seal-status")
 | |
| 	resp, err := c.c.RawRequest(r)
 | |
| 	if err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 	defer resp.Body.Close()
 | |
| 
 | |
| 	var result SealStatusResponse
 | |
| 	err = resp.DecodeJSON(&result)
 | |
| 	return &result, err
 | |
| }
 | |
| 
 | |
| func (c *Sys) Seal() error {
 | |
| 	r := c.c.NewRequest("PUT", "/sys/seal")
 | |
| 	resp, err := c.c.RawRequest(r)
 | |
| 	defer resp.Body.Close()
 | |
| 	return err
 | |
| }
 | |
| 
 | |
| func (c *Sys) Unseal(shard string) (*SealStatusResponse, error) {
 | |
| 	body := map[string]interface{}{"key": shard}
 | |
| 
 | |
| 	r := c.c.NewRequest("PUT", "/sys/unseal")
 | |
| 	if err := r.SetJSONBody(body); err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 
 | |
| 	resp, err := c.c.RawRequest(r)
 | |
| 	if err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 	defer resp.Body.Close()
 | |
| 
 | |
| 	var result SealStatusResponse
 | |
| 	err = resp.DecodeJSON(&result)
 | |
| 	return &result, err
 | |
| }
 | |
| 
 | |
| func (c *Sys) ListAuth() ([]*AuthResponse, error) {
 | |
| 	r := c.c.NewRequest("GET", "/sys/auth")
 | |
| 	resp, err := c.c.RawRequest(r)
 | |
| 	if err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 	defer resp.Body.Close()
 | |
| 
 | |
| 	var result []*AuthResponse
 | |
| 	err = resp.DecodeJSON(&result)
 | |
| 	return result, err
 | |
| }
 | |
| 
 | |
| func (c *Sys) EnableAuth(id string, opts *AuthRequest) error {
 | |
| 	body := make(map[string]string)
 | |
| 	for k, v := range opts.Config {
 | |
| 		body[k] = v
 | |
| 	}
 | |
| 	body["type"] = opts.Type
 | |
| 
 | |
| 	r := c.c.NewRequest("PUT", fmt.Sprintf("/sys/auth/%s", id))
 | |
| 	if err := r.SetJSONBody(body); err != nil {
 | |
| 		return err
 | |
| 	}
 | |
| 
 | |
| 	resp, err := c.c.RawRequest(r)
 | |
| 	if err != nil {
 | |
| 		return err
 | |
| 	}
 | |
| 	defer resp.Body.Close()
 | |
| 
 | |
| 	return nil
 | |
| }
 | |
| 
 | |
| func (c *Sys) DisableAuth(id string) error {
 | |
| 	r := c.c.NewRequest("DELETE", fmt.Sprintf("/sys/auth/%s", id))
 | |
| 	resp, err := c.c.RawRequest(r)
 | |
| 	defer resp.Body.Close()
 | |
| 	return err
 | |
| }
 | |
| 
 | |
| // Structures for the requests/resposne are all down here. They aren't
 | |
| // individually documentd because the map almost directly to the raw HTTP API
 | |
| // documentation. Please refer to that documentation for more details.
 | |
| 
 | |
| type AuthRequest struct {
 | |
| 	Type   string
 | |
| 	Config map[string]string
 | |
| }
 | |
| 
 | |
| type AuthResponse struct {
 | |
| 	ID   string
 | |
| 	Type string
 | |
| 	Help string
 | |
| 	Keys []string
 | |
| }
 | |
| 
 | |
| type SealStatusResponse struct {
 | |
| 	Sealed   bool
 | |
| 	T        int
 | |
| 	N        int
 | |
| 	Progress int
 | |
| }
 | 
