aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--c_exec.go34
-rw-r--r--c_lhosts.go1
2 files changed, 25 insertions, 10 deletions
diff --git a/c_exec.go b/c_exec.go
index eab792a..0759526 100644
--- a/c_exec.go
+++ b/c_exec.go
@@ -54,8 +54,31 @@ import (
"strconv"
)
+func exec_cmd(cmd_fmt []string) {
+ cmd := exec.Command(cmd_fmt[0], cmd_fmt[1:]...)
+
+ cmd.Stdin = os.Stdin
+ cmd.Stdout = os.Stdout
+ cmd.Stderr = os.Stderr
+ cmd.Run()
+}
+
+func format_cmd(id uint64, lhost *HostList) {
+ curr := lhost.head
+ var cmd_fmt []string
+
+ curr = lhost.sel(id)
+ if curr == nil {
+ c_die("host id not found", nil)
+ }
+ cmd_fmt = []string{"ssh", "-i", curr.Priv, "-p", strconv.Itoa(int(curr.Port)), curr.User + "@" + curr.Host}
+ fmt.Println(cmd_fmt)
+ exec_cmd(cmd_fmt)
+}
+
func display_servers(lhost *HostList) {
curr := lhost.head
+
if lhost.head == nil {
fmt.Println("no hosts")
return
@@ -65,14 +88,5 @@ func display_servers(lhost *HostList) {
curr = curr.next
}
fmt.Println()
- curr = lhost.sel(3)
- if curr == nil {
- c_die("host id not found", nil)
- }
- fmt.Println ("ssh", "-i", curr.Priv, "-p", strconv.Itoa(int(curr.Port)), curr.User + "@" + curr.Host)
- cmd := exec.Command("ssh", "-i", curr.Priv, "-p", strconv.Itoa(int(curr.Port)), curr.User + "@" + curr.Host)
- cmd.Stdin = os.Stdin
- cmd.Stdout = os.Stdout
- cmd.Stderr = os.Stderr
- cmd.Run()
+ format_cmd(3, lhost)
}
diff --git a/c_lhosts.go b/c_lhosts.go
index db932f9..d197607 100644
--- a/c_lhosts.go
+++ b/c_lhosts.go
@@ -103,6 +103,7 @@ func (lhost *HostList) del(id uint64) {
}
}
+// return the list node with the according id
func (lhost *HostList) sel(id uint64) *HostNode {
curr := lhost.head
for curr.next != nil && curr.ID != id {