diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/c_defs.go | 10 | ||||
-rw-r--r-- | src/c_hardflip.go | 1 | ||||
-rw-r--r-- | src/c_lhosts.go | 6 | ||||
-rw-r--r-- | src/i_events.go | 87 | ||||
-rw-r--r-- | src/i_insert.go | 223 | ||||
-rw-r--r-- | src/i_ui.go | 61 |
6 files changed, 250 insertions, 138 deletions
diff --git a/src/c_defs.go b/src/c_defs.go index a1da14f..b621382 100644 --- a/src/c_defs.go +++ b/src/c_defs.go @@ -139,7 +139,17 @@ const ( INS_CMD_SILENT INS_CMD_NOTE INS_CMD_OK + INS_OS_HOST + INS_OS_USER + INS_OS_PASS + INS_OS_USERDOMAINID + INS_OS_PROJECTID + INS_OS_REGION + INS_OS_ENDTYPE + INS_OS_INTERFACE + INS_OS_IDAPI // TODO: here + INS_OS_OK ) var ( diff --git a/src/c_hardflip.go b/src/c_hardflip.go index 7b88913..cf3f2de 100644 --- a/src/c_hardflip.go +++ b/src/c_hardflip.go @@ -59,6 +59,7 @@ type HardData struct { opts HardOpts folds map[*DirsNode]*ItemsList data_dir string + home_dir string load_err []error insert_err []error keys [][2]string diff --git a/src/c_lhosts.go b/src/c_lhosts.go index cb2279a..3510ee1 100644 --- a/src/c_lhosts.go +++ b/src/c_lhosts.go @@ -55,13 +55,13 @@ package main type StackSettings struct { UserDomainID string `yaml:"user_domain_id,omitempty"` ProjectID string `yaml:"project_id,omitempty"` + RegionName string `yaml:"region_name,omitempty"` + EndpointType string `yaml:"endpoint_type,omitempty"` + Interface string `yaml:"interface,omitempty"` IdentityAPI string `yaml:"identity_api_version,omitempty"` ImageAPI string `yaml:"image_api_version,omitempty"` NetworkAPI string `yaml:"network_api_version,omitempty"` VolumeAPI string `yaml:"volume_api_version,omitempty"` - RegionName string `yaml:"region_name,omitempty"` - EndpointType string `yaml:"endpoint_type,omitempty"` - Interface string `yaml:"interface,omitempty"` } type JumpSettings struct { diff --git a/src/i_events.go b/src/i_events.go index dc6d44f..b3fa6d5 100644 --- a/src/i_events.go +++ b/src/i_events.go @@ -351,7 +351,7 @@ func i_set_protocol_defaults(data *HardData, in *HostNode) { in.Stack.VolumeAPI = "3.42" in.Stack.EndpointType = "publicURL" in.Stack.Interface = "public" - data.ui.insert_sel_max = 2 + data.ui.insert_sel_max = INS_OS_OK } } @@ -585,6 +585,13 @@ func i_events(data *HardData) { } else if data.insert.Protocol == PROTOCOL_CMD && data.ui.insert_sel == INS_PROTOCOL { data.ui.insert_sel = INS_CMD_CMD + } else if data.insert.Protocol == PROTOCOL_OS && + data.ui.insert_sel == INS_PROTOCOL { + data.ui.insert_sel = INS_OS_HOST + } else if data.insert.Protocol == PROTOCOL_SSH && + data.ui.insert_sel == INS_SSH_JUMP_HOST && + len(data.insert.Jump.Host) == 0 { + data.ui.insert_sel = INS_SSH_NOTE } else if data.ui.insert_sel < data.ui.insert_sel_max { data.ui.insert_sel += 1 } @@ -596,6 +603,13 @@ func i_events(data *HardData) { } else if data.insert.Protocol == PROTOCOL_CMD && data.ui.insert_sel == INS_CMD_CMD { data.ui.insert_sel = INS_PROTOCOL + } else if data.insert.Protocol == PROTOCOL_OS && + data.ui.insert_sel == INS_OS_HOST { + data.ui.insert_sel = INS_PROTOCOL + } else if data.insert.Protocol == PROTOCOL_SSH && + data.ui.insert_sel == INS_SSH_NOTE && + len(data.insert.Jump.Host) == 0 { + data.ui.insert_sel = INS_SSH_JUMP_HOST } else if data.ui.insert_sel > INS_PROTOCOL { data.ui.insert_sel -= 1 } @@ -613,8 +627,18 @@ func i_events(data *HardData) { event.Key() == tcell.KeyEnter { data.ui.insert_sel_ok = true switch data.ui.insert_sel { + case INS_SSH_OK, + INS_RDP_OK + len(data.insert.Drive), + INS_CMD_OK: + data.ui.insert_sel_ok = false + i_insert_check_ok(data, data.insert) + if data.insert_err != nil { + break + } + i_insert_host(data, data.insert) case INS_SSH_HOST, - INS_RDP_HOST: + INS_RDP_HOST, + INS_OS_HOST: ui.buff = data.insert.Host case INS_SSH_PORT, INS_RDP_PORT: @@ -622,10 +646,12 @@ func i_events(data *HardData) { ui.buff = strconv.Itoa(int(data.insert.Port)) } case INS_SSH_USER, - INS_RDP_USER: + INS_RDP_USER, + INS_OS_USER: ui.buff = data.insert.User case INS_SSH_PASS, - INS_RDP_PASS: + INS_RDP_PASS, + INS_OS_PASS: break case INS_SSH_PRIV: ui.buff = data.insert.Priv case INS_SSH_JUMP_HOST: ui.buff = data.insert.Jump.Host @@ -660,19 +686,22 @@ func i_events(data *HardData) { data.insert.Silent = true } break + case INS_OS_USERDOMAINID: + ui.buff = data.insert.Stack.UserDomainID + case INS_OS_PROJECTID: + ui.buff = data.insert.Stack.ProjectID + case INS_OS_REGION: + ui.buff = data.insert.Stack.RegionName + case INS_OS_ENDTYPE: + ui.buff = data.insert.Stack.EndpointType + case INS_OS_INTERFACE: + ui.buff = data.insert.Stack.Interface + case INS_OS_IDAPI: + ui.buff = data.insert.Stack.IdentityAPI case INS_SSH_NOTE, INS_RDP_NOTE + len(data.insert.Drive), INS_CMD_NOTE: ui.buff = data.insert.Note - case INS_SSH_OK, - INS_RDP_OK + len(data.insert.Drive), - INS_CMD_OK: - data.ui.insert_sel_ok = false - i_insert_check_ok(data, data.insert) - if data.insert_err != nil { - break - } - i_insert_host(data, data.insert) } } } else { @@ -808,21 +837,33 @@ func i_events(data *HardData) { INS_RDP_NOTE + len(data.insert.Drive), INS_CMD_CMD, INS_CMD_SHELL, - INS_CMD_NOTE: + INS_CMD_NOTE, + INS_OS_HOST, + INS_OS_USER, + INS_OS_PASS, + INS_OS_USERDOMAINID, + INS_OS_PROJECTID, + INS_OS_REGION, + INS_OS_ENDTYPE, + INS_OS_INTERFACE, + INS_OS_IDAPI: if event.Key() == tcell.KeyEnter { switch data.ui.insert_sel { case INS_SSH_HOST, - INS_RDP_HOST: + INS_RDP_HOST, + INS_OS_HOST: data.insert.Host = ui.buff case INS_SSH_PORT, INS_RDP_PORT: tmp, _ := strconv.Atoi(ui.buff) data.insert.Port = uint16(tmp) case INS_SSH_USER, - INS_RDP_USER: + INS_RDP_USER, + INS_OS_USER: data.insert.User = ui.buff case INS_SSH_PASS, - INS_RDP_PASS: + INS_RDP_PASS, + INS_OS_PASS: data.insert.Pass, _ = c_encrypt_str(ui.buff, data.opts.GPG) case INS_SSH_PRIV: data.insert.Priv = ui.buff @@ -851,6 +892,18 @@ func i_events(data *HardData) { data.insert.Host = ui.buff case INS_CMD_SHELL: data.insert.Shell[0] = ui.buff + case INS_OS_USERDOMAINID: + data.insert.Stack.UserDomainID = ui.buff + case INS_OS_PROJECTID: + data.insert.Stack.ProjectID = ui.buff + case INS_OS_REGION: + data.insert.Stack.RegionName = ui.buff + case INS_OS_ENDTYPE: + data.insert.Stack.EndpointType = ui.buff + case INS_OS_INTERFACE: + data.insert.Stack.Interface = ui.buff + case INS_OS_IDAPI: + data.insert.Stack.IdentityAPI = ui.buff case INS_SSH_NOTE, INS_RDP_NOTE + len(data.insert.Drive), INS_CMD_NOTE: diff --git a/src/i_insert.go b/src/i_insert.go index 354bc71..0565c4c 100644 --- a/src/i_insert.go +++ b/src/i_insert.go @@ -43,7 +43,7 @@ * POSSIBILITY OF SUCH DAMAGE. * * hardflip: src/i_insert.go - * Tue Apr 16 17:11:12 2024 + * Wed Apr 17 14:00:27 2024 * Joe * * insert a new host @@ -86,7 +86,7 @@ func i_insert_format_filename(name, path string) string { return str } -func i_insert_abs_files(insert *HostNode) { +func i_insert_abs_files(insert *HostNode, home_dir string) { files := []*string{ &insert.Priv, &insert.Jump.Priv, @@ -96,10 +96,6 @@ func i_insert_abs_files(insert *HostNode) { for _, v := range files { if len(*v) > 0 { if (*v)[0] == '~' { - home_dir, err := os.UserHomeDir() - if err != nil { - return - } *v = home_dir + (*v)[1:] } *v, _ = filepath.Abs(*v) @@ -108,10 +104,6 @@ func i_insert_abs_files(insert *HostNode) { for k, v := range insert.Drive { if len(v) > 0 { if (v)[0] == '~' { - home_dir, err := os.UserHomeDir() - if err != nil { - return - } v = home_dir + (v)[1:] } v, _ = filepath.Abs(v) @@ -135,7 +127,7 @@ func i_insert_default_users(insert *HostNode) { } func i_insert_host(data *HardData, insert *HostNode) { - i_insert_abs_files(insert) + i_insert_abs_files(insert, data.home_dir) i_insert_default_users(insert) if len(insert.Drive) == 0 { insert.Drive = nil @@ -222,11 +214,7 @@ func i_insert_check_ok(data *HardData, in *HostNode) { for _, v := range file { if len(v) > 0 { if v[0] == '~' { - home_dir, err := os.UserHomeDir() - if err != nil { - return - } - v = home_dir + v[1:] + v = data.home_dir + v[1:] } if stat, err := os.Stat(v); err != nil { @@ -240,11 +228,7 @@ func i_insert_check_ok(data *HardData, in *HostNode) { } for _, v := range in.Drive { if v[0] == '~' { - home_dir, err := os.UserHomeDir() - if err != nil { - return - } - v = home_dir + v[1:] + v = data.home_dir + v[1:] } if stat, err := os.Stat(v); err != nil { @@ -291,7 +275,8 @@ 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 == INS_SSH_PASS || id == INS_SSH_JUMP_PASS || id == INS_RDP_PASS) && + if (id == INS_SSH_PASS || id == INS_SSH_JUMP_PASS || + id == INS_RDP_PASS || id == INS_OS_PASS) && len(content) > 0 { content = "***" } @@ -330,8 +315,86 @@ func i_draw_ok_butt(ui HardUI, line int, id, selected int) { (ui.dim[W] / 2) + (butt_size / 2), line, style, buff) } -func i_draw_insert_panel(ui HardUI, in *HostNode) { - type draw_insert_func func(ui HardUI, line int, win Quad, in *HostNode) int +func i_draw_insert_inputs(ui HardUI, in *HostNode, home_dir string) { + if ui.insert_sel_ok == false { + return + } + switch ui.insert_sel { + case INS_PROTOCOL: + i_prompt_list(ui, "Connection type", "Type:", + PROTOCOL_STR[:]) + case INS_SSH_HOST, + INS_SSH_JUMP_HOST, + INS_RDP_HOST: + i_prompt_generic(ui, "Host/IP: ", false, "") + case INS_SSH_PORT, + INS_SSH_JUMP_PORT, + INS_RDP_PORT: + i_prompt_generic(ui, "Port: ", false, "") + case INS_SSH_USER, + INS_SSH_JUMP_USER, + INS_RDP_USER, + INS_OS_USER: + i_prompt_generic(ui, "User: ", false, "") + case INS_SSH_PASS, + INS_SSH_JUMP_PASS, + INS_RDP_PASS, + INS_OS_PASS: + i_prompt_generic(ui, "Pass: ", true, "") + case INS_SSH_PRIV, + INS_SSH_JUMP_PRIV: + i_prompt_generic(ui, "Private key: ", + false, home_dir) + case INS_SSH_NOTE, + INS_RDP_NOTE + len(in.Drive), + INS_CMD_NOTE: + i_prompt_generic(ui, "Note: ", false, "") + case INS_RDP_DOMAIN: + i_prompt_generic(ui, "Domain: ", false, "") + case INS_RDP_FILE: + i_prompt_generic(ui, "RDP file: ", false, home_dir) + case INS_RDP_SCREENSIZE: + i_prompt_list(ui, "Window size", "Size:", + RDP_SCREENSIZE[:]) + case INS_RDP_QUALITY: + i_prompt_list(ui, "Quality", "Quality:", + RDP_QUALITY[:]) + case INS_RDP_DRIVE + len(in.Drive): + if len(ui.drives_buff) == 0 { + i_prompt_generic(ui, "Name: ", false, "") + } else { + i_prompt_dir(ui, "Local directory: ", home_dir) + } + case INS_CMD_CMD: + i_prompt_generic(ui, "Command: ", false, "") + case INS_CMD_SHELL: + i_prompt_generic(ui, "Shell: ", false, home_dir) + case INS_OS_HOST: + i_prompt_generic(ui, "Endpoint: ", false, "") + case INS_OS_USERDOMAINID: + i_prompt_generic(ui, "UserDomainID: ", false, "") + case INS_OS_PROJECTID: + i_prompt_generic(ui, "ProjectID: ", false, "") + case INS_OS_REGION: + i_prompt_generic(ui, "Region name: ", false, "") + case INS_OS_ENDTYPE: + i_prompt_generic(ui, "Endpoint type: ", false, "") + case INS_OS_INTERFACE: + i_prompt_generic(ui, "Interface: ", false, "") + case INS_OS_IDAPI: + i_prompt_generic(ui, "Identity API version: ", false, "") + } + if len(in.Drive) > 0 && + ui.insert_sel >= INS_RDP_DRIVE && + ui.insert_sel < INS_RDP_DRIVE + + len(in.Drive) { + i_draw_remove_share(ui) + } +} + +func i_draw_insert_panel(ui HardUI, in *HostNode, home_dir string) { + type draw_insert_func func(ui HardUI, line int, win Quad, + in *HostNode, home string) int if len(in.Name) == 0 { return @@ -357,14 +420,16 @@ func i_draw_insert_panel(ui HardUI, in *HostNode) { i_draw_insert_cmd, i_draw_insert_os, } - end_line = fp[in.Protocol](ui, line, win, in) + end_line = fp[in.Protocol](ui, line, win, in, home_dir) if win.T + end_line >= win.B { ui.s.SetContent(ui.dim[W] / 2, win.B, '▼', nil, ui.style[BOX_STYLE]) // TODO: scroll or something } + i_draw_insert_inputs(ui, in, home_dir) } -func i_draw_insert_ssh(ui HardUI, line int, win Quad, in *HostNode) int { +func i_draw_insert_ssh(ui HardUI, line int, win Quad, + in *HostNode, home string) int { red := false if win.T + line >= win.B { return line } text := "---- Host settings ----" @@ -385,7 +450,6 @@ func i_draw_insert_ssh(ui HardUI, line int, win Quad, in *HostNode) int { if line += 1; win.T + line >= win.B { return line } if file := in.Priv; len(file) > 0 { if file[0] == '~' { - home, _ := os.UserHomeDir() file = home + file[1:] } if stat, err := os.Stat(file); @@ -409,36 +473,37 @@ func i_draw_insert_ssh(ui HardUI, line int, win Quad, in *HostNode) int { if line += 2; win.T + line >= win.B { return line } i_draw_text_box(ui, win.T + line, win, "Host/IP", in.Jump.Host, INS_SSH_JUMP_HOST, false) - if line += 1; win.T + line >= win.B { return line } - i_draw_text_box(ui, win.T + line, win, "Port", - strconv.Itoa(int(in.Jump.Port)), - INS_SSH_JUMP_PORT, false) - if line += 2; win.T + line >= win.B { return line } - i_draw_text_box(ui, win.T + line, win, "User", in.Jump.User, - INS_SSH_JUMP_USER, false) - if line += 1; win.T + line >= win.B { return line } - i_draw_text_box(ui, win.T + line, win, "Pass", in.Jump.Pass, - INS_SSH_JUMP_PASS, false) - if line += 1; win.T + line >= win.B { return line} - if len(in.Jump.Priv) > 0 { - file := in.Jump.Priv - if file[0] == '~' { - home, _ := os.UserHomeDir() - file = home + file[1:] + if len(in.Jump.Host) > 0 { + if line += 1; win.T + line >= win.B { return line } + i_draw_text_box(ui, win.T + line, win, "Port", + strconv.Itoa(int(in.Jump.Port)), + INS_SSH_JUMP_PORT, false) + if line += 2; win.T + line >= win.B { return line } + i_draw_text_box(ui, win.T + line, win, "User", in.Jump.User, + INS_SSH_JUMP_USER, false) + if line += 1; win.T + line >= win.B { return line } + i_draw_text_box(ui, win.T + line, win, "Pass", in.Jump.Pass, + INS_SSH_JUMP_PASS, false) + if line += 1; win.T + line >= win.B { return line} + if len(in.Jump.Priv) > 0 { + file := in.Jump.Priv + if file[0] == '~' { + file = home + file[1:] + } + if stat, err := os.Stat(file); + err != nil || stat.IsDir() == true { + red = true + } } - 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, + INS_SSH_JUMP_PRIV, red) + if red == true { + if line += 1; win.T + line >= win.B { return line } + 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) } } - i_draw_text_box(ui, win.T + line, win, "SSH private key", in.Jump.Priv, - INS_SSH_JUMP_PRIV, red) - if red == true { - if line += 1; win.T + line >= win.B { return line } - 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) - } if line += 2; win.T + line >= win.B { return line } text = "---- Note ----" i_draw_text(ui.s, ui.dim[W] / 2 - len(text) / 2, win.T + line, win.R - 1, @@ -451,7 +516,8 @@ func i_draw_insert_ssh(ui HardUI, line int, win Quad, in *HostNode) int { return line } -func i_draw_insert_rdp(ui HardUI, line int, win Quad, in *HostNode) int { +func i_draw_insert_rdp(ui HardUI, line int, win Quad, + in *HostNode, home string) int { red := false if win.T + line >= win.B { return line } text := "---- Host settings ----" @@ -479,7 +545,6 @@ func i_draw_insert_rdp(ui HardUI, line int, win Quad, in *HostNode) int { if line += 2; win.T + line >= win.B { return line } if file := in.RDPFile; len(file) > 0 { if file[0] == '~' { - home, _ := os.UserHomeDir() file = home + file[1:] } if stat, err := os.Stat(file); @@ -520,7 +585,6 @@ func i_draw_insert_rdp(ui HardUI, line int, win Quad, in *HostNode) int { red = false if dir := in.Drive[v]; len(dir) > 0 { if dir[0] == '~' { - home, _ := os.UserHomeDir() dir = home + dir[1:] } if stat, err := os.Stat(dir); @@ -553,7 +617,8 @@ func i_draw_insert_rdp(ui HardUI, line int, win Quad, in *HostNode) int { return line } -func i_draw_insert_cmd(ui HardUI, line int, win Quad, in *HostNode) int { +func i_draw_insert_cmd(ui HardUI, line int, win Quad, + in *HostNode, home string) int { red := false if win.T + line >= win.B { return line } text := "---- Settings ----" @@ -565,7 +630,6 @@ func i_draw_insert_cmd(ui HardUI, line int, win Quad, in *HostNode) int { if line += 1; win.T + line >= win.B { return line } if shell := in.Shell[0]; len(shell) > 0 { if shell[0] == '~' { - home, _ := os.UserHomeDir() shell = home + shell[1:] } if stat, err := os.Stat(shell); @@ -597,6 +661,45 @@ func i_draw_insert_cmd(ui HardUI, line int, win Quad, in *HostNode) int { return line } -func i_draw_insert_os(ui HardUI, line int, win Quad, in *HostNode) int { +func i_draw_insert_os(ui HardUI, line int, win Quad, + in *HostNode, home string) int { + if win.T + line >= win.B { return line } + text := "---- Host settings ----" + i_draw_text(ui.s, ui.dim[W] / 2 - len(text) / 2, win.T + line, win.R - 1, + win.T + line, ui.style[DEF_STYLE], text) + if line += 2; win.T + line >= win.B { return line } + i_draw_text_box(ui, win.T + line, win, "Endpoint", in.Host, + INS_OS_HOST, false) + if line += 2; win.T + line >= win.B { return line } + i_draw_text_box(ui, win.T + line, win, "User", in.User, + INS_OS_USER, false) + if line += 1; win.T + line >= win.B { return line } + i_draw_text_box(ui, win.T + line, win, "Pass", in.Pass, + INS_OS_PASS, false) + if line += 2; win.T + line >= win.B { return line } + i_draw_text_box(ui, win.T + line, win, "User domain ID", + in.Stack.UserDomainID, + INS_OS_USERDOMAINID, false) + if line += 1; win.T + line >= win.B { return line } + i_draw_text_box(ui, win.T + line, win, "Project ID", in.Stack.ProjectID, + INS_OS_PROJECTID, false) + if line += 1; win.T + line >= win.B { return line } + i_draw_text_box(ui, win.T + line, win, "Region name", in.Stack.RegionName, + INS_OS_REGION, false) + if line += 2; win.T + line >= win.B { return line } + i_draw_text_box(ui, win.T + line, win, "Endpoint type", + in.Stack.EndpointType, + INS_OS_ENDTYPE, false) + if line += 1; win.T + line >= win.B { return line } + i_draw_text_box(ui, win.T + line, win, "Interface", in.Stack.Interface, + INS_OS_INTERFACE, false) + if line += 2; win.T + line >= win.B { return line } + text = "---- API settings ----" + i_draw_text(ui.s, ui.dim[W] / 2 - len(text) / 2, win.T + line, win.R - 1, + win.T + line, ui.style[DEF_STYLE], text) + if line += 2; win.T + line >= win.B { return line } + i_draw_text_box(ui, win.T + line, win, "Identity API version", + in.Stack.IdentityAPI, + INS_OS_IDAPI, false) return line } diff --git a/src/i_ui.go b/src/i_ui.go index e5800bf..2565f32 100644 --- a/src/i_ui.go +++ b/src/i_ui.go @@ -673,6 +673,7 @@ func i_ui(data_dir string) { opts, make(map[*DirsNode]*ItemsList), data_dir, + home_dir, load_err, nil, [][2]string{}, @@ -711,64 +712,8 @@ func i_ui(data_dir string) { if data.insert == nil { i_prompt_insert(data.ui, data.litems.curr) } else { - i_draw_insert_panel(data.ui, data.insert) - if data.ui.insert_sel_ok == true { - switch data.ui.insert_sel { - case INS_PROTOCOL: - i_prompt_list(data.ui, "Connection type", "Type:", - PROTOCOL_STR[:]) - case INS_SSH_HOST, - INS_SSH_JUMP_HOST, - INS_RDP_HOST: - i_prompt_generic(data.ui, "Host/IP: ", false, "") - case INS_SSH_PORT, - INS_SSH_JUMP_PORT, - INS_RDP_PORT: - i_prompt_generic(data.ui, "Port: ", false, "") - case INS_SSH_USER, - INS_SSH_JUMP_USER, - INS_RDP_USER: - i_prompt_generic(data.ui, "User: ", false, "") - case INS_SSH_PASS, - INS_SSH_JUMP_PASS, - INS_RDP_PASS: - i_prompt_generic(data.ui, "Pass: ", true, "") - case INS_SSH_PRIV, - INS_SSH_JUMP_PRIV: - i_prompt_generic(data.ui, "Private key: ", - false, home_dir) - case INS_SSH_NOTE, - INS_RDP_NOTE + len(data.insert.Drive), - INS_CMD_NOTE: - i_prompt_generic(data.ui, "Note: ", false, "") - case INS_RDP_DOMAIN: - i_prompt_generic(data.ui, "Domain: ", false, "") - case INS_RDP_FILE: - i_prompt_generic(data.ui, "RDP file: ", false, home_dir) - case INS_RDP_SCREENSIZE: - i_prompt_list(data.ui, "Window size", "Size:", - RDP_SCREENSIZE[:]) - case INS_RDP_QUALITY: - i_prompt_list(data.ui, "Quality", "Quality:", - RDP_QUALITY[:]) - case INS_RDP_DRIVE + len(data.insert.Drive): - if len(data.ui.drives_buff) == 0 { - i_prompt_generic(data.ui, "Name: ", false, "") - } else { - i_prompt_dir(data.ui, "Local directory: ", home_dir) - } - case INS_CMD_CMD: - i_prompt_generic(data.ui, "Command: ", false, "") - case INS_CMD_SHELL: - i_prompt_generic(data.ui, "Shell: ", false, home_dir) - } - if len(data.insert.Drive) > 0 && - data.ui.insert_sel >= INS_RDP_DRIVE && - data.ui.insert_sel < INS_RDP_DRIVE + - len(data.insert.Drive) { - i_draw_remove_share(data.ui) - } - } else if data.insert_err != nil { + i_draw_insert_panel(data.ui, data.insert, data.home_dir) + if data.insert_err != nil { i_draw_insert_err_msg(data.ui, data.insert_err) } } |