list keys and refactor
This commit is contained in:
parent
4e1ad1b285
commit
8157baf782
4 changed files with 154 additions and 82 deletions
90
main.go
90
main.go
|
|
@ -4,16 +4,13 @@ import (
|
|||
"flag"
|
||||
"fmt"
|
||||
"os"
|
||||
"os/exec"
|
||||
"os/signal"
|
||||
"strings"
|
||||
"syscall"
|
||||
)
|
||||
|
||||
func main() {
|
||||
flag.Usage = func() {
|
||||
fmt.Fprintf(os.Stderr, "Usage: %s [gosh-flags] [user@host] [ssh-flags]\n", os.Args[0])
|
||||
fmt.Fprintf(os.Stderr, "\nManagement Commands:\n")
|
||||
fmt.Fprintf(os.Stderr, " %s [flags] list-keys\n", os.Args[0])
|
||||
fmt.Fprintf(os.Stderr, " %s [flags] add-key <user_pattern> <host_pattern> <path_to_key>\n", os.Args[0])
|
||||
fmt.Fprintf(os.Stderr, "\nFlags:\n")
|
||||
flag.PrintDefaults()
|
||||
|
|
@ -32,98 +29,29 @@ func main() {
|
|||
|
||||
cmd := args[0]
|
||||
|
||||
if cmd == "add-key" {
|
||||
switch cmd {
|
||||
case "add-key":
|
||||
if argc != 4 {
|
||||
fmt.Println("Error: Incorrect arguments for add-key.")
|
||||
fmt.Println("Try: gosh [--db path] add-key <user_pattern> <host_pattern> <path_to_key>")
|
||||
os.Exit(1)
|
||||
}
|
||||
|
||||
db, err := initDB(*dbPath)
|
||||
err := handleAddKey(*dbPath, args[1], args[2], args[3])
|
||||
if err != nil {
|
||||
fmt.Println("Error:", err)
|
||||
os.Exit(1)
|
||||
}
|
||||
defer db.Close()
|
||||
os.Exit(0)
|
||||
|
||||
userPattern := args[1]
|
||||
hostPattern := args[2]
|
||||
keyPath := args[3]
|
||||
err = addKey(db, userPattern, hostPattern, keyPath)
|
||||
case "list-keys":
|
||||
err := handleListKey(*dbPath)
|
||||
if err != nil {
|
||||
fmt.Println("Error:", err)
|
||||
os.Exit(1)
|
||||
}
|
||||
return
|
||||
os.Exit(0)
|
||||
}
|
||||
|
||||
user, host := parseDestination(args)
|
||||
env := os.Environ()
|
||||
|
||||
if host != "" {
|
||||
db, err := initDB(*dbPath)
|
||||
if err != nil {
|
||||
fmt.Println("Error:", err)
|
||||
os.Exit(1)
|
||||
}
|
||||
|
||||
pemData, err := findKey(db, user, host)
|
||||
if err != nil {
|
||||
fmt.Println("Error:", err)
|
||||
os.Exit(1)
|
||||
}
|
||||
|
||||
db.Close()
|
||||
|
||||
targetName := host
|
||||
if user != "" {
|
||||
targetName = user + "@" + host
|
||||
}
|
||||
|
||||
socketPath, cleanup, err := startEphemeralAgent(pemData, targetName)
|
||||
if err != nil {
|
||||
fmt.Println("Error:", err)
|
||||
os.Exit(1)
|
||||
}
|
||||
defer cleanup()
|
||||
|
||||
newEnv := []string{"SSH_AUTH_SOCK=" + socketPath}
|
||||
for _, e := range env {
|
||||
if !strings.HasPrefix(e, "SSH_AUTH_SOCK=") {
|
||||
newEnv = append(newEnv, e)
|
||||
}
|
||||
}
|
||||
env = newEnv
|
||||
}
|
||||
|
||||
sshPath, err := exec.LookPath("ssh")
|
||||
if err != nil {
|
||||
fmt.Println("Error:", err)
|
||||
os.Exit(1)
|
||||
}
|
||||
|
||||
sshCmd := exec.Command(sshPath, args...)
|
||||
sshCmd.Env = env
|
||||
sshCmd.Stdin = os.Stdin
|
||||
sshCmd.Stdout = os.Stdout
|
||||
sshCmd.Stderr = os.Stderr
|
||||
|
||||
c := make(chan os.Signal, 1)
|
||||
signal.Notify(c, os.Interrupt, syscall.SIGTERM)
|
||||
go func() {
|
||||
for sig := range c {
|
||||
if sshCmd.Process != nil {
|
||||
sshCmd.Process.Signal(sig)
|
||||
}
|
||||
}
|
||||
}()
|
||||
|
||||
err = sshCmd.Run()
|
||||
if err != nil {
|
||||
fmt.Println("Error:", err)
|
||||
if exitErr, ok := err.(*exec.ExitError); ok {
|
||||
os.Exit(exitErr.ExitCode())
|
||||
}
|
||||
os.Exit(1)
|
||||
}
|
||||
startSSH(*dbPath, args)
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue