aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--src/i_events.go1
-rw-r--r--src/i_info.go220
2 files changed, 102 insertions, 119 deletions
diff --git a/src/i_events.go b/src/i_events.go
index 71b7386..47a439f 100644
--- a/src/i_events.go
+++ b/src/i_events.go
@@ -76,6 +76,7 @@ func i_list_follow_cursor(litems *ItemsList, ui *HardUI) {
litems.draw.prev != nil {
litems.draw = litems.draw.prev
}
+ // FIX: resize under select disappear
}
func i_set_unfold(data *HardData, item *ItemsNode) {
diff --git a/src/i_info.go b/src/i_info.go
index 60a38c0..4284032 100644
--- a/src/i_info.go
+++ b/src/i_info.go
@@ -125,35 +125,14 @@ func i_info_ssh(ui HardUI, host *HostNode, line int) int {
i_draw_text(ui.s,
(ui.dim[W] / 3) + 9, line, ui.dim[W] - 2, line,
ui.style[STYLE_DEF], host.Host)
- if line += 1; line > ui.dim[H] - 3 || host.Protocol == 2 {
- return line
- }
+ if line += 1; line > ui.dim[H] - 3 { return line }
i_draw_text(ui.s,
(ui.dim[W] / 3) + 3, line, ui.dim[W] - 2, line,
ui.style[STYLE_TITLE], "Port: ")
i_draw_text(ui.s,
(ui.dim[W] / 3) + 9, line, ui.dim[W] - 2, line,
ui.style[STYLE_DEF], strconv.Itoa(int(host.Port)))
- if line += 1; line > ui.dim[H] - 3 {
- return line
- }
- // RDP shit
- if host.Protocol == 1 {
- if len(host.Domain) > 0 {
- i_draw_text(ui.s,
- (ui.dim[W] / 3) + 3, line, ui.dim[W] - 2, line,
- ui.style[STYLE_TITLE], "Domain: ")
- i_draw_text(ui.s,
- (ui.dim[W] / 3) + 11, line, ui.dim[W] - 2, line,
- ui.style[STYLE_DEF], host.Domain)
- if line += 1; line > ui.dim[H] - 3 {
- return line
- }
- }
- }
- if line += 1; line > ui.dim[H] - 3 {
- return line
- }
+ if line += 2; line > ui.dim[H] - 3 { return line }
// user infos
i_draw_text(ui.s,
(ui.dim[W] / 3) + 3, line, ui.dim[W] - 2, line,
@@ -161,9 +140,7 @@ func i_info_ssh(ui HardUI, host *HostNode, line int) int {
i_draw_text(ui.s,
(ui.dim[W] / 3) + 9, line, ui.dim[W] - 2, line,
ui.style[STYLE_DEF], host.User)
- if line += 1; line > ui.dim[H] - 3 {
- return line
- }
+ if line += 1; line > ui.dim[H] - 3 { return line }
if len(host.Pass) > 0 {
i_draw_text(ui.s,
(ui.dim[W] / 3) + 3, line, ui.dim[W] - 2, line,
@@ -171,59 +148,45 @@ func i_info_ssh(ui HardUI, host *HostNode, line int) int {
i_draw_text(ui.s,
(ui.dim[W] / 3) + 9, line, ui.dim[W] - 2, line,
ui.style[STYLE_DEF], "***")
- if line += 1; line > ui.dim[H] - 3 {
- return line
- }
+ if line += 1; line > ui.dim[H] - 3 { return line }
}
- if host.Protocol == 0 && len(host.Priv) > 0 {
+ if len(host.Priv) > 0 {
i_draw_text(ui.s,
(ui.dim[W] / 3) + 3, line, ui.dim[W] - 2, line,
ui.style[STYLE_TITLE], "Privkey: ")
i_draw_text(ui.s,
(ui.dim[W] / 3) + 12, line, ui.dim[W] - 2, line,
ui.style[STYLE_DEF], host.Priv)
- if line += 1; line > ui.dim[H] - 3 {
- return line
- }
- }
- if line += 1; line > ui.dim[H] - 3 {
- return line
+ if line += 1; line > ui.dim[H] - 3 { return line }
}
+ if line += 1; line > ui.dim[H] - 3 { return line }
// jump
- if host.Protocol == 0 && len(host.Jump.Host) > 0 {
+ if len(host.Jump.Host) > 0 {
i_draw_text(ui.s,
(ui.dim[W] / 3) + 3, line, ui.dim[W] - 2, line,
ui.style[STYLE_TITLE], "Jump settings: ")
- if line += 1; line > ui.dim[H] - 3 {
- return line
- }
+ if line += 1; line > ui.dim[H] - 3 { return line }
i_draw_text(ui.s,
(ui.dim[W] / 3) + 4, line, ui.dim[W] - 2, line,
ui.style[STYLE_TITLE], "Host: ")
i_draw_text(ui.s,
(ui.dim[W] / 3) + 10, line, ui.dim[W] - 2, line,
ui.style[STYLE_DEF], host.Jump.Host)
- if line += 1; line > ui.dim[H] - 3 {
- return line
- }
+ if line += 1; line > ui.dim[H] - 3 { return line }
i_draw_text(ui.s,
(ui.dim[W] / 3) + 4, line, ui.dim[W] - 2, line,
ui.style[STYLE_TITLE], "Port: ")
i_draw_text(ui.s,
(ui.dim[W] / 3) + 10, line, ui.dim[W] - 2, line,
ui.style[STYLE_DEF], strconv.Itoa(int(host.Jump.Port)))
- if line += 1; line > ui.dim[H] - 3 {
- return line
- }
+ if line += 1; line > ui.dim[H] - 3 { return line }
i_draw_text(ui.s,
(ui.dim[W] / 3) + 4, line, ui.dim[W] - 2, line,
ui.style[STYLE_TITLE], "User: ")
i_draw_text(ui.s,
(ui.dim[W] / 3) + 10, line, ui.dim[W] - 2, line,
ui.style[STYLE_DEF], host.Jump.User)
- if line += 1; line > ui.dim[H] - 3 {
- return line
- }
+ if line += 1; line > ui.dim[H] - 3 { return line }
if len(host.Jump.Pass) > 0 {
i_draw_text(ui.s,
(ui.dim[W] / 3) + 4, line, ui.dim[W] - 2, line,
@@ -231,107 +194,126 @@ func i_info_ssh(ui HardUI, host *HostNode, line int) int {
i_draw_text(ui.s,
(ui.dim[W] / 3) + 10, line, ui.dim[W] - 2, line,
ui.style[STYLE_DEF], "***")
- if line += 1; line > ui.dim[H] - 3 {
- return line
- }
+ if line += 1; line > ui.dim[H] - 3 { return line }
}
- if host.Protocol == 0 && len(host.Jump.Priv) > 0 {
+ if len(host.Jump.Priv) > 0 {
i_draw_text(ui.s,
(ui.dim[W] / 3) + 4, line, ui.dim[W] - 2, line,
ui.style[STYLE_TITLE], "Privkey: ")
i_draw_text(ui.s,
(ui.dim[W] / 3) + 13, line, ui.dim[W] - 2, line,
ui.style[STYLE_DEF], host.Jump.Priv)
- if line += 1; line > ui.dim[H] - 3 {
- return line
- }
- }
- if line += 1; line > ui.dim[H] - 3 {
- return line
+ if line += 1; line > ui.dim[H] - 3 { return line }
}
+ if line += 1; line > ui.dim[H] - 3 { return line }
}
- // RDP shit
- if host.Protocol == 1 {
- qual := [3]string{"Low", "Medium", "High"}
+ return line
+}
+
+func i_info_rdp(ui HardUI, host *HostNode, line int) int {
+ // host, port
+ i_draw_text(ui.s,
+ (ui.dim[W] / 3) + 3, line, ui.dim[W] - 2, line,
+ ui.style[STYLE_TITLE], "Host: ")
+ i_draw_text(ui.s,
+ (ui.dim[W] / 3) + 9, line, ui.dim[W] - 2, line,
+ ui.style[STYLE_DEF], host.Host)
+ if line += 1; line > ui.dim[H] - 3 { return line }
+ i_draw_text(ui.s,
+ (ui.dim[W] / 3) + 3, line, ui.dim[W] - 2, line,
+ ui.style[STYLE_TITLE], "Port: ")
+ i_draw_text(ui.s,
+ (ui.dim[W] / 3) + 9, line, ui.dim[W] - 2, line,
+ ui.style[STYLE_DEF], strconv.Itoa(int(host.Port)))
+ if line += 1; line > ui.dim[H] - 3 { return line }
+ // rdp shit
+ if len(host.Domain) > 0 {
i_draw_text(ui.s,
(ui.dim[W] / 3) + 3, line, ui.dim[W] - 2, line,
- ui.style[STYLE_TITLE], "Screen size: ")
+ ui.style[STYLE_TITLE], "Domain: ")
i_draw_text(ui.s,
- (ui.dim[W] / 3) + 16, line, ui.dim[W] - 2, line,
- ui.style[STYLE_DEF],
- strconv.Itoa(int(host.Width)) + "x" +
- strconv.Itoa(int(host.Height)))
- if line += 1; line > ui.dim[H] - 3 {
- return line
- }
+ (ui.dim[W] / 3) + 11, line, ui.dim[W] - 2, line,
+ ui.style[STYLE_DEF], host.Domain)
+ }
+ if line += 2; line > ui.dim[H] - 3 { return line }
+ // user infos
+ i_draw_text(ui.s,
+ (ui.dim[W] / 3) + 3, line, ui.dim[W] - 2, line,
+ ui.style[STYLE_TITLE], "User: ")
+ i_draw_text(ui.s,
+ (ui.dim[W] / 3) + 9, line, ui.dim[W] - 2, line,
+ ui.style[STYLE_DEF], host.User)
+ if line += 1; line > ui.dim[H] - 3 { return line }
+ if len(host.Pass) > 0 {
i_draw_text(ui.s,
(ui.dim[W] / 3) + 3, line, ui.dim[W] - 2, line,
- ui.style[STYLE_TITLE], "Dynamic window: ")
+ ui.style[STYLE_TITLE], "Pass: ")
i_draw_text(ui.s,
- (ui.dim[W] / 3) + 19, line, ui.dim[W] - 2, line,
- ui.style[STYLE_DEF], strconv.FormatBool(host.Dynamic))
- if line += 1; line > ui.dim[H] - 3 {
- return line
- }
+ (ui.dim[W] / 3) + 9, line, ui.dim[W] - 2, line,
+ ui.style[STYLE_DEF], "***")
+ if line += 1; line > ui.dim[H] - 3 { return line }
+ }
+ if line += 1; line > ui.dim[H] - 3 { return line }
+ // rdp shit
+ qual := [3]string{"Low", "Medium", "High"}
+ i_draw_text(ui.s,
+ (ui.dim[W] / 3) + 3, line, ui.dim[W] - 2, line,
+ ui.style[STYLE_TITLE], "Screen size: ")
+ i_draw_text(ui.s,
+ (ui.dim[W] / 3) + 16, line, ui.dim[W] - 2, line,
+ ui.style[STYLE_DEF],
+ strconv.Itoa(int(host.Width)) + "x" +
+ strconv.Itoa(int(host.Height)))
+ if line += 1; line > ui.dim[H] - 3 { return line }
+ i_draw_text(ui.s,
+ (ui.dim[W] / 3) + 3, line, ui.dim[W] - 2, line,
+ ui.style[STYLE_TITLE], "Dynamic window: ")
+ i_draw_text(ui.s,
+ (ui.dim[W] / 3) + 19, line, ui.dim[W] - 2, line,
+ ui.style[STYLE_DEF], strconv.FormatBool(host.Dynamic))
+ if line += 1; line > ui.dim[H] - 3 { return line }
+ i_draw_text(ui.s,
+ (ui.dim[W] / 3) + 3, line, ui.dim[W] - 2, line,
+ ui.style[STYLE_TITLE], "Quality: ")
+ i_draw_text(ui.s,
+ (ui.dim[W] / 3) + 12, line, ui.dim[W] - 2, line,
+ ui.style[STYLE_DEF], qual[host.Quality])
+ if line += 2; line > ui.dim[H] - 3 { return line }
+ if host.Drive != nil {
i_draw_text(ui.s,
(ui.dim[W] / 3) + 3, line, ui.dim[W] - 2, line,
- ui.style[STYLE_TITLE], "Quality: ")
- i_draw_text(ui.s,
- (ui.dim[W] / 3) + 12, line, ui.dim[W] - 2, line,
- ui.style[STYLE_DEF], qual[host.Quality])
- if line += 2; line > ui.dim[H] - 3 {
- return line
- }
- if host.Drive != nil {
+ ui.style[STYLE_TITLE], "Drives: ")
+ if line += 1; line > ui.dim[H] - 3 { return line }
+ for share, path := range host.Drive {
i_draw_text(ui.s,
- (ui.dim[W] / 3) + 3, line, ui.dim[W] - 2, line,
- ui.style[STYLE_TITLE], "Drives: ")
- if line += 1; line > ui.dim[H] - 3 {
- return line
- }
- for share, path := range host.Drive {
- i_draw_text(ui.s,
- (ui.dim[W] / 3) + 4, line, ui.dim[W] - 2, line,
- ui.style[STYLE_TITLE], share + ":")
- i_draw_text(ui.s,
- (ui.dim[W] / 3) + 4 + len(share) + 2, line,
- ui.dim[W] - 2, line,
- ui.style[STYLE_DEF], path)
- if line += 1; line > ui.dim[H] - 3 {
- return line
- }
- }
- if line += 1; line > ui.dim[H] - 3 {
- return line
- }
+ (ui.dim[W] / 3) + 4, line, ui.dim[W] - 2, line,
+ ui.style[STYLE_TITLE], share + ":")
+ i_draw_text(ui.s,
+ (ui.dim[W] / 3) + 4 + len(share) + 2, line,
+ ui.dim[W] - 2, line,
+ ui.style[STYLE_DEF], path)
+ if line += 1; line > ui.dim[H] - 3 { return line }
}
+ if line += 1; line > ui.dim[H] - 3 { return line }
}
return line
}
-func i_info_rdp(ui HardUI, host *HostNode, line int) int {
+func i_info_cmd(ui HardUI, host *HostNode, line int) int {
i_draw_text(ui.s,
(ui.dim[W] / 3) + 3, line, ui.dim[W] - 2, line,
- ui.style[STYLE_TITLE], "Host: ")
+ ui.style[STYLE_TITLE], "Command: ")
i_draw_text(ui.s,
- (ui.dim[W] / 3) + 9, line, ui.dim[W] - 2, line,
+ (ui.dim[W] / 3) + 12, line, ui.dim[W] - 2, line,
ui.style[STYLE_DEF], host.Host)
- if line += 1; line > ui.dim[H] - 3 || host.Protocol == 2 {
- return line
- }
- return line
-}
-
-func i_info_cmd(ui HardUI, host *HostNode, line int) int {
+ if line += 2; line > ui.dim[H] - 3 { return line }
i_draw_text(ui.s,
(ui.dim[W] / 3) + 3, line, ui.dim[W] - 2, line,
- ui.style[STYLE_TITLE], "Command: ")
+ ui.style[STYLE_TITLE], "Silent: ")
i_draw_text(ui.s,
(ui.dim[W] / 3) + 12, line, ui.dim[W] - 2, line,
- ui.style[STYLE_DEF], host.Host)
- if line += 1; line > ui.dim[H] - 3 {
- return line
- }
+ ui.style[STYLE_DEF], host.Silent)
+ // TODO: here
return line
}