aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/i_events.go6
-rw-r--r--src/i_insert.go74
2 files changed, 54 insertions, 26 deletions
diff --git a/src/i_events.go b/src/i_events.go
index ca1e017..de92428 100644
--- a/src/i_events.go
+++ b/src/i_events.go
@@ -620,6 +620,7 @@ func i_events(data *HardData) {
case INS_SSH_JUMP_PASS: break
case INS_SSH_JUMP_PRIV: ui.buff = data.insert.Jump.Priv
case INS_RDP_DOMAIN: ui.buff = data.insert.Domain
+ case INS_RDP_FILE: ui.buff = data.insert.RDPFile
case INS_SSH_OK,
INS_RDP_OK:
data.ui.insert_sel_ok = false
@@ -670,7 +671,8 @@ func i_events(data *HardData) {
INS_RDP_PORT,
INS_RDP_DOMAIN,
INS_RDP_USER,
- INS_RDP_PASS:
+ INS_RDP_PASS,
+ INS_RDP_FILE:
if event.Key() == tcell.KeyEnter {
switch data.ui.insert_sel {
case INS_SSH_HOST,
@@ -707,6 +709,8 @@ func i_events(data *HardData) {
data.insert.Jump.Priv = ui.buff
case INS_RDP_DOMAIN:
data.insert.Domain = ui.buff
+ case INS_RDP_FILE:
+ data.insert.RDPFile = ui.buff
}
data.ui.insert_sel_ok = false
ui.buff = ""
diff --git a/src/i_insert.go b/src/i_insert.go
index 3d30dd7..2634014 100644
--- a/src/i_insert.go
+++ b/src/i_insert.go
@@ -137,36 +137,44 @@ func i_insert_host(data *HardData, insert *HostNode) {
data.insert = nil
}
-func i_insert_check_ok(data *HardData, insert *HostNode) {
- if len(insert.Name) == 0 {
+func i_insert_check_ok(data *HardData, in *HostNode) {
+ if len(in.Name) == 0 {
data.insert_err = append(data.insert_err, errors.New("no name"))
}
- if len(insert.Host) == 0 {
+ if len(in.Host) == 0 {
+ // TODO: here rdpfile
data.insert_err = append(data.insert_err, errors.New("no host"))
}
- if insert.Port == 0 {
+ if in.Port == 0 {
data.insert_err = append(data.insert_err, errors.New("port can't be 0"))
}
- if len(insert.Jump.Host) > 0 && insert.Jump.Port == 0 {
+ if len(in.Jump.Host) > 0 && in.Jump.Port == 0 {
data.insert_err = append(data.insert_err,
errors.New("jump port can't be 0"))
}
- if insert.Protocol == PROTOCOL_SSH && len(insert.Priv) != 0 {
- file := insert.Priv
- if file[0] == '~' {
- home_dir, err := os.UserHomeDir()
- if err != nil {
- return
+ var file [2]string
+ switch in.Protocol {
+ case PROTOCOL_SSH: file[0], file[1] = in.Priv, in.Jump.Priv
+ case PROTOCOL_RDP: file[0] = in.RDPFile
+ default: return
+ }
+ 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:]
+ }
+ if stat, err := os.Stat(v);
+ err != nil {
+ data.insert_err = append(data.insert_err, errors.New(v +
+ ": file does not exist"))
+ } else if stat.IsDir() == true {
+ data.insert_err = append(data.insert_err, errors.New(v +
+ ": file is a directory"))
}
- file = home_dir + file[1:]
- }
- if stat, err := os.Stat(file);
- err != nil {
- data.insert_err = append(data.insert_err, errors.New(file +
- ": file does not exist"))
- } else if stat.IsDir() == true {
- data.insert_err = append(data.insert_err, errors.New(file +
- ": file is a directory"))
}
}
}
@@ -266,7 +274,7 @@ func i_draw_insert_cmd(ui HardUI, line int, win Quad, in *HostNode) int {
}
func i_draw_insert_rdp(ui HardUI, line int, win Quad, in *HostNode) int {
- // red := false
+ red := false
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,
@@ -291,8 +299,25 @@ func i_draw_insert_rdp(ui HardUI, line int, win Quad, in *HostNode) int {
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, "Pass", in.RDPFile,
- INS_RDP_FILE, ui.insert_sel, false)
+ if file := in.RDPFile; len(file) > 0 {
+ 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, "RDP file", in.RDPFile,
+ INS_RDP_FILE, ui.insert_sel, 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)
+ }
+ red = false
if line += 2; win.T + line >= win.B { return line }
i_draw_ok_butt(ui, win.T + line, INS_RDP_OK, ui.insert_sel)
return line
@@ -317,8 +342,7 @@ func i_draw_insert_ssh(ui HardUI, line int, win Quad, in *HostNode) int {
i_draw_text_box(ui, win.T + line, win, "Pass", in.Pass,
INS_SSH_PASS, ui.insert_sel, false)
if line += 1; win.T + line >= win.B { return line }
- if len(in.Priv) > 0 {
- file := in.Priv
+ if file := in.Priv; len(file) > 0 {
if file[0] == '~' {
home, _ := os.UserHomeDir()
file = home + file[1:]