diff options
Diffstat (limited to '')
-rw-r--r-- | src/i_events.go | 25 | ||||
-rw-r--r-- | src/i_insert.go | 29 | ||||
-rw-r--r-- | src/i_ui.go | 6 |
3 files changed, 49 insertions, 11 deletions
diff --git a/src/i_events.go b/src/i_events.go index 48c3471..3e1b810 100644 --- a/src/i_events.go +++ b/src/i_events.go @@ -159,7 +159,7 @@ func i_fold_dir(data *HardData, item *ItemsNode) { return } // this is not the end - end = next_dir.prev + end = next_dir.prev end.next = nil item.next = next_dir next_dir.prev = item @@ -285,7 +285,7 @@ func i_readline(event *tcell.EventKey, data *HardData) { event.Key() == tcell.KeyBackspace2) { data.ui.buff = data.ui.buff[:len(data.ui.buff) - 1] } else if event.Key() == tcell.KeyCtrlU { - data.ui.buff = "" + data.ui.buff = "" } else if event.Rune() >= 32 && event.Rune() <= 126 { data.ui.buff += string(event.Rune()) } @@ -322,7 +322,7 @@ func i_set_protocol_defaults(data *HardData, in *HostNode) { case 0: in.Port = 22 in.Jump.Port = 22 - data.ui.insert_sel_max = 7 + data.ui.insert_sel_max = 10 case 1: in.Port = 3389 in.Quality = 2 @@ -577,6 +577,11 @@ func i_events(data *HardData) { case 4: break case 5: ui.buff = data.insert.Priv case 6: ui.buff = data.insert.Jump.Host + case 7: ui.buff = strconv.Itoa(int( + data.insert.Jump.Port)) + case 8: ui.buff = data.insert.Jump.User + case 9: break + case 10: ui.buff = data.insert.Jump.Priv } } } else { @@ -605,11 +610,11 @@ func i_events(data *HardData) { ui.s.HideCursor() i_set_protocol_defaults(data, data.insert) } - case 1, 2, 3, 4, 5, 6, 7: + case 1, 2, 3, 4, 5, 6, 7, 8, 9, 10: if event.Key() == tcell.KeyEnter { switch data.ui.insert_sel { case 1: data.insert.Host = ui.buff - case 2: + case 2: tmp, _ := strconv.Atoi(ui.buff) data.insert.Port = uint16(tmp) case 3: data.insert.User = ui.buff @@ -622,6 +627,12 @@ func i_events(data *HardData) { case 7: tmp, _ := strconv.Atoi(ui.buff) data.insert.Jump.Port = uint16(tmp) + case 8: data.insert.Jump.User = ui.buff + case 9: + pass, _ := c_encrypt_str(ui.buff, + data.opts.GPG) + data.insert.Jump.Pass = pass + case 10: data.insert.Jump.Priv = ui.buff } data.ui.insert_sel_ok = false ui.buff = "" @@ -639,7 +650,7 @@ func i_events(data *HardData) { ui.s.HideCursor() ui.buff = "" ui.mode = NORMAL_MODE - data.insert = nil + data.insert = nil } else if event.Key() == tcell.KeyEnter { i_mkdir(data, ui) ui.s.HideCursor() @@ -648,6 +659,6 @@ func i_events(data *HardData) { } else { i_readline(event, data) } - } + } } } diff --git a/src/i_insert.go b/src/i_insert.go index a0f629f..23c2bc6 100644 --- a/src/i_insert.go +++ b/src/i_insert.go @@ -71,7 +71,7 @@ func i_draw_text_box(ui HardUI, line int, dim Quad, label, content string, if l <= dim.L { l = dim.L + 1 } i_draw_text(ui.s, l, line, ui.dim[W] / 2, line, ui.style[DEF_STYLE], label) - if id == 4 && len(content) > 0 { + if (id == 4 || id == 9) && len(content) > 0 { content = "***" } if red == true { @@ -150,6 +150,7 @@ func i_draw_insert_ssh(ui HardUI, line int, win Quad, in *HostNode) { i_draw_text(ui.s, ui.dim[W] / 2, win.T + line, win.R - 1, win.T + line, ui.style[ERR_STYLE], text) } + red = false if line += 2; win.T + line >= win.B { return } text = "---- Jump settings ----" i_draw_text(ui.s, ui.dim[W] / 2 - len(text) / 2, win.T + line, win.R - 1, @@ -160,5 +161,31 @@ func i_draw_insert_ssh(ui HardUI, line int, win Quad, in *HostNode) { if line += 1; win.T + line >= win.B { return } i_draw_text_box(ui, win.T + line, win, "Port", strconv.Itoa(int(in.Jump.Port)), 7, ui.insert_sel, false) + if line += 2; win.T + line >= win.B { return } + i_draw_text_box(ui, win.T + line, win, "User", + in.Jump.User, 8, ui.insert_sel, false) + if line += 1; win.T + line >= win.B { return } + i_draw_text_box(ui, win.T + line, win, "Pass", + in.Jump.Pass, 9, ui.insert_sel, false) + if line += 1; win.T + line >= win.B { return } + if len(in.Jump.Priv) > 0 { + file := in.Jump.Priv + if file[0] == '~' { + home, _ := os.UserHomeDir() + file = home + file[1:] + } + if stat, err := os.Stat(file); + err != nil || stat.IsDir() == true { + red = true + } + } + i_draw_text_box(ui, win.T + line, win, "SSH private key", + in.Jump.Priv, 10, ui.insert_sel, red) + if red == true { + if line += 1; win.T + line >= win.B { return } + text := "file does not exist" + i_draw_text(ui.s, ui.dim[W] / 2, win.T + line, + win.R - 1, win.T + line, ui.style[ERR_STYLE], text) + } // TODO: here } diff --git a/src/i_ui.go b/src/i_ui.go index 97ca3d5..89c89ac 100644 --- a/src/i_ui.go +++ b/src/i_ui.go @@ -665,11 +665,11 @@ func i_ui(data_dir string) { i_prompt_generic(data.ui, "Host/IP: ", false, "") case 2, 7: i_prompt_generic(data.ui, "Port: ", false, "") - case 3: + case 3, 8: i_prompt_generic(data.ui, "User: ", false, "") - case 4: + case 4, 9: i_prompt_generic(data.ui, "Pass: ", true, "") - case 5: + case 5, 10: i_prompt_generic(data.ui, "Private key: ", false, home_dir) } |