-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathadd.go
84 lines (75 loc) · 2.46 KB
/
add.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
package main
import (
"fmt"
"log"
"net"
"os"
"github.com/spf13/cobra"
)
var cmdAdd = &cobra.Command{
Use: "add [FLAGS]",
Example: "Without password encryption:\ngossh add -n my-server -a myserver.com -t 7121 -u root -p strong@pass\nWith password encryption:\ngossh add -n my-server -a myserver.com -t 7121 -u root -p strong@pass -k strong@key",
Short: "Adds a new server to the list",
Args: cobra.MinimumNArgs(0),
DisableFlagsInUseLine: true,
Run: func(cmd *cobra.Command, args []string) {
name, _ := cmd.Flags().GetString("name")
address, _ := cmd.Flags().GetString("address")
port, _ := cmd.Flags().GetString("port")
user, _ := cmd.Flags().GetString("user")
password, _ := cmd.Flags().GetString("password")
key, _ := cmd.Flags().GetString("key")
if name != "" && address != "" && user != "" && password != "" {
add(name, address, port, user, password, key)
} else {
fmt.Println("All flags except port and key are mandatory and must be provided.\nUse 'gossh add --help' for more information.")
os.Exit(0)
}
},
}
func resolveDNS(addr string) string {
fmt.Printf("Resolving IP address for %s...\n", addr)
ip, err := net.ResolveIPAddr("ip", addr)
if err != nil {
fmt.Printf("Failed to resolve IP address for %s\n", err)
os.Exit(1)
}
return ip.String()
}
func add(name, address, port, user, password, key string) {
// srv := new(sessionOpts)
// check if name is unique or not
if cfg.Section(name).HasKey("host") {
fmt.Println("server name must be unique")
os.Exit(0)
}
// create a section in config file
sec, _ := cfg.NewSection(name)
// parsing password
if key != "" {
p, err := encryptPass([]byte(key), password)
if err != nil {
log.Fatalln("Error while encrypting password:", err)
}
sec.NewKey("password", string(p))
sec.NewKey("encrypted", "1")
} else {
sec.NewKey("password", password)
sec.NewKey("encrypted", "0")
}
// save to servers.ini
sec.NewKey("host", address)
sec.NewKey("remote", resolveDNS(address))
sec.NewKey("port", port)
sec.NewKey("user", user)
err := cfg.SaveTo(cfgFileAddr)
if err != nil {
log.Fatalln("failed to add new server:", err)
}
fmt.Printf("Name: %s\nHost: %s\nPort: %s\nUser: %s\nSaved successfully.\n", name, address, port, user)
if key == "" {
fmt.Printf("You can may now connect using:\n $ gossh connect %s\n", name)
} else {
fmt.Printf("You can may now connect using:\n $ gossh connect %s -k [key]\n", name)
}
}