aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--c_exec.go18
-rw-r--r--c_hardflip.go1
-rw-r--r--c_lhosts.go12
-rw-r--r--c_parse.go14
-rw-r--r--i_ui.go140
5 files changed, 159 insertions, 26 deletions
diff --git a/c_exec.go b/c_exec.go
index fc42957..8193068 100644
--- a/c_exec.go
+++ b/c_exec.go
@@ -101,7 +101,8 @@ func c_format_ssh(host *HostNode) []string {
return cmd_fmt
}
-func c_format_rdp() {
+func c_format_rdp(host *HostNode) []string {
+ return []string{""}
}
func c_format_cmd(id uint64, lhost *HostList) {
@@ -114,21 +115,18 @@ func c_format_cmd(id uint64, lhost *HostList) {
}
if host.Type == 0 {
cmd_fmt = c_format_ssh(host)
+ } else if host.Type == 1 {
+ cmd_fmt = c_format_rdp(host)
+ } else if host.Type > 1 {
+ c_die("type not found", nil)
}
c_exec_cmd(cmd_fmt)
}
-func c_display_servers(lhost *HostList) {
- host := lhost.head
-
+func c_exec(id uint64, lhost *HostList) {
if lhost.head == nil {
fmt.Println("no hosts")
return
}
- for host != nil {
- fmt.Println(host.ID, host.Folder + host.Name)
- host = host.next
- }
- fmt.Println()
- c_format_cmd(4, lhost)
+ c_format_cmd(id, lhost)
}
diff --git a/c_hardflip.go b/c_hardflip.go
index 07e6112..93a179b 100644
--- a/c_hardflip.go
+++ b/c_hardflip.go
@@ -52,6 +52,5 @@ func main() {
data_dir = c_get_data_dir()
lhost := c_load_data_dir(data_dir)
- // c_display_servers(lhost)
i_ui(lhost)
}
diff --git a/c_lhosts.go b/c_lhosts.go
index 8e9a416..d98305c 100644
--- a/c_lhosts.go
+++ b/c_lhosts.go
@@ -110,6 +110,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 {
curr = curr.next
}
@@ -118,3 +119,14 @@ func (lhost *HostList) sel(id uint64) *HostNode {
}
return curr
}
+
+func (lhost *HostList) count() uint64 {
+ curr := lhost.head
+ var count uint64 = 0
+
+ for curr != nil {
+ curr = curr.next
+ count++
+ }
+ return count
+}
diff --git a/c_parse.go b/c_parse.go
index 358b2d3..43a270c 100644
--- a/c_parse.go
+++ b/c_parse.go
@@ -68,5 +68,19 @@ func c_read_yaml_file(file string) *HostNode {
if len(host.Host) == 0 {
return nil
}
+ if host.Type == 0 {
+ if host.Port == 0 {
+ host.Port = 22
+ }
+ if len(host.User) == 0 {
+ host.User = "root"
+ }
+ } else if host.Type == 1 {
+ if host.Port == 0 {
+ host.Port = 3389
+ }
+ } else if host.Type > 1 {
+ host_type = "Unknown"
+ }
return &host
}
diff --git a/i_ui.go b/i_ui.go
index 133f276..407f269 100644
--- a/i_ui.go
+++ b/i_ui.go
@@ -39,7 +39,7 @@
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
* hardflip: src/c_hardflip.go
- * Mon, 18 Dec 2023 17:59:45 +0100
+ * Mon, 18 Dec 2023 19:01:59 +0100
* Joe
*
* interfacing with the user
@@ -49,6 +49,7 @@ package main
import (
"os"
+ "strconv"
"github.com/gdamore/tcell/v2"
"golang.org/x/term"
)
@@ -71,9 +72,7 @@ func i_draw_text(s tcell.Screen,
}
}
-func i_draw_box(s tcell.Screen,
- x1, y1, x2, y2 int,
- title string, content string) {
+func i_draw_box(s tcell.Screen, x1, y1, x2, y2 int, title string) {
style := tcell.StyleDefault.Background(tcell.ColorReset).Foreground(tcell.ColorReset)
if y2 < y1 {
@@ -101,27 +100,118 @@ func i_draw_box(s tcell.Screen,
}
i_draw_text(s, x1 + 1, y1, x2 - 1, y2 - 1, style, title)
- i_draw_text(s, x1 + 1, y1 + 1, x2 - 1, y2 - 1, style, content)
}
func i_bottom_text(s tcell.Screen, term_w, term_h int, style tcell.Style) {
i_draw_text(s, 0, term_h - 1, term_w - 1, term_h, style, "(q) Quit")
}
-func i_hosts_panel(s tcell.Screen, term_w, term_h int, lhost *HostList) {
+func i_hosts_panel(s tcell.Screen,
+ term_w, term_h int,
+ def_style tcell.Style, lhost *HostList,
+ sel uint64, sel_max uint64) {
i_draw_box(s, 0, 0,
term_w / 3, term_h - 2,
- " hosts ", "")
+ " hosts ")
+ host := lhost.head
+ for host != nil {
+ style := def_style
+ if sel == host.ID {
+ style = tcell.StyleDefault.
+ Background(tcell.ColorWhite).
+ Foreground(tcell.ColorBlack)
+ }
+ spaces := ""
+ i := 0
+ for i < (term_w / 3) - len(host.Folder + host.Name) - 3 {
+ spaces += " "
+ i++
+ }
+ i_draw_text(s,
+ 1, int(host.ID) + 1, term_w / 3 - 1, int(host.ID) + 1,
+ style, " " + host.Folder + host.Name + spaces)
+ host = host.next
+ }
+ i_draw_text(s,
+ 1, term_h - 2, (term_w / 3) - 1, term_h - 1,
+ def_style, " " + strconv.Itoa(int(sel_max)) + " hosts ")
}
-func i_info_panel(s tcell.Screen, term_w, term_h int) {
+func i_info_panel(s tcell.Screen,
+ term_w, term_h int,
+ def_style tcell.Style, lhost *HostList, sel uint64) {
+ title_style := tcell.StyleDefault.
+ Background(tcell.ColorReset).
+ Foreground(tcell.ColorBlue).Dim(true).Bold(true)
+ host := lhost.sel(sel)
+ curr_line := 2
+ var host_type string
+ var pass string
+ var port int
+
i_draw_box(s, (term_w / 3) + 1, 0,
term_w - 1, term_h - 2,
- " infos ", "")
+ " infos ")
+ if host.Type == 0 {
+ host_type = "SSH"
+ } else if host.Type == 1 {
+ host_type = "RDP"
+ } else if host.Type > 1 {
+ host_type = "Unknown"
+ }
+ if len(host.Pass) > 0 {
+ pass = "***"
+ }
+
+ i_draw_text(s,
+ (term_w / 3) + 4, curr_line, term_w - 2, curr_line,
+ title_style, "Name: ")
+ i_draw_text(s,
+ (term_w / 3) + 10, curr_line, term_w - 2, curr_line,
+ def_style, host.Name)
+ curr_line += 1
+ i_draw_text(s,
+ (term_w / 3) + 4, curr_line, term_w - 2, curr_line,
+ title_style, "Type: ")
+ i_draw_text(s,
+ (term_w / 3) + 10, curr_line, term_w - 2, curr_line,
+ def_style, host_type)
+ curr_line += 2
+ i_draw_text(s,
+ (term_w / 3) + 4, curr_line, term_w - 2, curr_line,
+ title_style, "Host: ")
+ i_draw_text(s,
+ (term_w / 3) + 10, curr_line, term_w - 2, curr_line,
+ def_style, host.Host)
+ curr_line += 1
+ i_draw_text(s,
+ (term_w / 3) + 4, curr_line, term_w - 2, curr_line,
+ title_style, "Port: ")
+ i_draw_text(s,
+ (term_w / 3) + 10, curr_line, term_w - 2, curr_line,
+ def_style, strconv.Itoa(port))
+ curr_line += 2
+ i_draw_text(s,
+ (term_w / 3) + 4, curr_line, term_w - 2, curr_line,
+ title_style, "User: ")
+ i_draw_text(s,
+ (term_w / 3) + 10, curr_line, term_w - 2, curr_line,
+ def_style, host.User)
+ curr_line += 1
+ i_draw_text(s,
+ (term_w / 3) + 4, curr_line, term_w - 2, curr_line,
+ title_style, "Pass: ")
+ i_draw_text(s,
+ (term_w / 3) + 10, curr_line, term_w - 2, curr_line,
+ def_style, pass)
+ curr_line += 1
}
func i_ui(lhost *HostList) {
screen, err := tcell.NewScreen()
+ var sel uint64 = 0
+ sel_max := lhost.count()
+
if err != nil {
c_die("view", err)
}
@@ -134,22 +224,42 @@ func i_ui(lhost *HostList) {
screen.SetStyle(def_style)
quit := func() {
screen.Fini()
- os.Exit(0)
}
for {
term_w, term_h, _ := term.GetSize(0)
screen.Clear()
i_bottom_text(screen, term_w, term_h, def_style)
- i_hosts_panel(screen, term_w, term_h, lhost)
- i_info_panel(screen, term_w, term_h)
+ i_hosts_panel(screen, term_w, term_h, def_style, lhost, sel, sel_max)
+ i_info_panel(screen, term_w, term_h, def_style, lhost, sel)
screen.Show()
- ev := screen.PollEvent()
- switch ev := ev.(type) {
+ event := screen.PollEvent()
+ switch event := event.(type) {
case *tcell.EventResize:
screen.Sync()
case *tcell.EventKey:
- if ev.Key() == tcell.KeyEscape || ev.Key() == tcell.KeyCtrlC || ev.Rune() == 'q' || ev.Rune() == 'Q' {
+ if event.Key() == tcell.KeyEscape ||
+ event.Key() == tcell.KeyCtrlC ||
+ event.Rune() == 'q' ||
+ event.Rune() == 'Q' {
+ quit()
+ os.Exit(0)
+ }
+ if event.Rune() == 'j' ||
+ event.Key() == tcell.KeyDown {
+ if sel < sel_max - 1 {
+ sel += 1
+ }
+ }
+ if event.Rune() == 'k' ||
+ event.Key() == tcell.KeyUp {
+ if sel > 0 {
+ sel -= 1
+ }
+ }
+ if event.Key() == tcell.KeyEnter {
quit()
+ c_exec(sel, lhost)
+ os.Exit(0)
}
}
}