open-vault/api/sys_seal.go

62 lines
1.4 KiB
Go
Raw Normal View History

2015-03-11 19:03:28 +00:00
package api
func (c *Sys) SealStatus() (*SealStatusResponse, error) {
2015-03-13 17:32:22 +00:00
r := c.c.NewRequest("GET", "/v1/sys/seal-status")
return sealStatusRequest(c, r)
2015-03-11 19:03:28 +00:00
}
func (c *Sys) Seal() error {
2015-03-13 17:32:22 +00:00
r := c.c.NewRequest("PUT", "/v1/sys/seal")
2015-03-11 19:03:28 +00:00
resp, err := c.c.RawRequest(r)
if err == nil {
defer resp.Body.Close()
}
2015-03-11 19:03:28 +00:00
return err
}
func (c *Sys) ResetUnsealProcess() (*SealStatusResponse, error) {
body := map[string]interface{}{"reset": true}
r := c.c.NewRequest("PUT", "/v1/sys/unseal")
if err := r.SetJSONBody(body); err != nil {
return nil, err
}
return sealStatusRequest(c, r)
}
2015-03-11 19:03:28 +00:00
func (c *Sys) Unseal(shard string) (*SealStatusResponse, error) {
body := map[string]interface{}{"key": shard}
2015-03-13 17:32:22 +00:00
r := c.c.NewRequest("PUT", "/v1/sys/unseal")
2015-03-11 19:03:28 +00:00
if err := r.SetJSONBody(body); err != nil {
return nil, err
}
return sealStatusRequest(c, r)
}
func sealStatusRequest(c *Sys, r *Request) (*SealStatusResponse, error) {
2015-03-11 19:03:28 +00:00
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
}
type SealStatusResponse struct {
Type string `json:"type"`
Sealed bool `json:"sealed"`
T int `json:"t"`
N int `json:"n"`
Progress int `json:"progress"`
Nonce string `json:"nonce"`
Version string `json:"version"`
ClusterName string `json:"cluster_name,omitempty"`
ClusterID string `json:"cluster_id,omitempty"`
2015-03-11 19:03:28 +00:00
}