From f052e7fdf3082c59fedd5d94a036de8f56f54bef Mon Sep 17 00:00:00 2001 From: Seth Vargo Date: Wed, 16 Aug 2017 18:44:28 -0400 Subject: [PATCH] Add SignKey endpoint for SSH API client --- api/ssh.go | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) diff --git a/api/ssh.go b/api/ssh.go index 7c3e56bb4a..a17b0eb230 100644 --- a/api/ssh.go +++ b/api/ssh.go @@ -36,3 +36,20 @@ func (c *SSH) Credential(role string, data map[string]interface{}) (*Secret, err return ParseSecret(resp.Body) } + +// SignKey signs the given public key and returns a signed public key to pass +// along with the SSH request. +func (c *SSH) SignKey(role string, data map[string]interface{}) (*Secret, error) { + r := c.c.NewRequest("PUT", fmt.Sprintf("/v1/%s/sign/%s", c.MountPoint, role)) + if err := r.SetJSONBody(data); err != nil { + return nil, err + } + + resp, err := c.c.RawRequest(r) + if err != nil { + return nil, err + } + defer resp.Body.Close() + + return ParseSecret(resp.Body) +}