diff options
Diffstat (limited to 'src')
| -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)  					} | 
