goldwarden-vaultwarden-bitw.../cmd/ssh.go

91 lines
2.2 KiB
Go
Raw Normal View History

2023-07-17 03:23:26 +02:00
package cmd
import (
"fmt"
"github.com/atotto/clipboard"
2023-09-20 03:05:44 +02:00
"github.com/quexten/goldwarden/ipc/messages"
2023-07-17 03:23:26 +02:00
"github.com/spf13/cobra"
)
var sshCmd = &cobra.Command{
Use: "ssh",
Short: "Commands for managing SSH keys",
Long: `Commands for managing SSH keys.`,
Run: func(cmd *cobra.Command, args []string) {
cmd.Help()
},
}
// runCmd represents the run command
var sshAddCmd = &cobra.Command{
Use: "add",
Short: "Runs a command with environment variables from your vault",
Long: `Runs a command with environment variables from your vault.
The variables are stored as a secure note. Consult the documentation for more information.`,
Run: func(cmd *cobra.Command, args []string) {
2023-08-21 18:37:34 +02:00
loginIfRequired()
2023-07-17 03:23:26 +02:00
name, _ := cmd.Flags().GetString("name")
2023-07-18 22:07:40 +02:00
copyToClipboard, _ := cmd.Flags().GetBool("clipboard")
2023-07-17 03:23:26 +02:00
2023-09-20 03:05:44 +02:00
result, err := commandClient.SendToAgent(messages.CreateSSHKeyRequest{
2023-07-17 03:23:26 +02:00
Name: name,
})
if err != nil {
2023-09-11 22:45:01 +02:00
handleSendToAgentError(err)
2023-07-17 03:23:26 +02:00
return
}
switch result.(type) {
2023-09-20 03:05:44 +02:00
case messages.CreateSSHKeyResponse:
response := result.(messages.CreateSSHKeyResponse)
2023-07-17 03:23:26 +02:00
fmt.Println(response.Digest)
2023-07-18 22:07:40 +02:00
if copyToClipboard {
clipboard.WriteAll(string(response.Digest))
}
break
2023-09-20 03:05:44 +02:00
case messages.ActionResponse:
println("Error: " + result.(messages.ActionResponse).Message)
2023-07-17 03:23:26 +02:00
return
}
},
}
var listSSHCmd = &cobra.Command{
Use: "list",
Short: "Lists all SSH keys in your vault",
Long: `Lists all SSH keys in your vault.`,
Run: func(cmd *cobra.Command, args []string) {
2023-08-21 18:37:34 +02:00
loginIfRequired()
2023-09-20 03:05:44 +02:00
result, err := commandClient.SendToAgent(messages.GetSSHKeysRequest{})
2023-07-17 03:23:26 +02:00
if err != nil {
2023-09-11 22:45:01 +02:00
handleSendToAgentError(err)
2023-07-17 03:23:26 +02:00
return
}
switch result.(type) {
2023-09-20 03:05:44 +02:00
case messages.GetSSHKeysResponse:
response := result.(messages.GetSSHKeysResponse)
2023-07-17 03:23:26 +02:00
for _, key := range response.Keys {
fmt.Println(key)
}
break
2023-09-20 03:05:44 +02:00
case messages.ActionResponse:
println("Error: " + result.(messages.ActionResponse).Message)
2023-07-17 03:23:26 +02:00
return
}
},
}
func init() {
rootCmd.AddCommand(sshCmd)
sshCmd.AddCommand(sshAddCmd)
sshAddCmd.PersistentFlags().String("name", "", "")
sshAddCmd.MarkFlagRequired("name")
2023-07-18 22:07:40 +02:00
sshAddCmd.PersistentFlags().Bool("clipboard", false, "Copy the public key to the clipboard")
2023-07-17 03:23:26 +02:00
sshCmd.AddCommand(listSSHCmd)
}