api: auth methods
This commit is contained in:
parent
886812ecce
commit
a4fc46de2a
57
api/sys.go
57
api/sys.go
|
@ -1,5 +1,9 @@
|
|||
package api
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
)
|
||||
|
||||
// Sys is used to perform system-related operations on Vault.
|
||||
type Sys struct {
|
||||
c *Client
|
||||
|
@ -49,10 +53,63 @@ func (c *Sys) Unseal(shard string) (*SealStatusResponse, error) {
|
|||
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
|
||||
|
|
Loading…
Reference in a new issue