aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJoe <rbo@gmx.us>2024-04-24 20:20:20 +0200
committerJoe <rbo@gmx.us>2024-04-24 20:20:20 +0200
commit6df427e26a4e4890ad9994940bb38cd96e5970e8 (patch)
tree2c5caadc228e706402c489ccd2561c34e690792f
parentjump (diff)
downloadhardflip-6df427e26a4e4890ad9994940bb38cd96e5970e8.tar.gz
hardflip-6df427e26a4e4890ad9994940bb38cd96e5970e8.tar.bz2
hardflip-6df427e26a4e4890ad9994940bb38cd96e5970e8.tar.xz
hardflip-6df427e26a4e4890ad9994940bb38cd96e5970e8.tar.zst
hardflip-6df427e26a4e4890ad9994940bb38cd96e5970e8.zip
refactor
-rw-r--r--src/c_defs.go1
-rw-r--r--src/c_exec.go2
-rw-r--r--src/e_events.go464
-rw-r--r--src/e_keys.go484
-rw-r--r--src/i_ui.go13
5 files changed, 495 insertions, 469 deletions
diff --git a/src/c_defs.go b/src/c_defs.go
index 579df64..577f1ec 100644
--- a/src/c_defs.go
+++ b/src/c_defs.go
@@ -78,6 +78,7 @@ const (
WELCOME_MODE
MKDIR_MODE
INSERT_MODE
+ MODE_MAX = INSERT_MODE
)
const (
diff --git a/src/c_exec.go b/src/c_exec.go
index d36951b..371e28c 100644
--- a/src/c_exec.go
+++ b/src/c_exec.go
@@ -53,7 +53,6 @@ package main
import (
"bytes"
- // "fmt"
"math/rand/v2"
"os"
"os/exec"
@@ -230,7 +229,6 @@ func c_format_cmd(host *HostNode, opts HardOpts,
}
func c_redirect_ssh(host *HostNode, local_port uint16) error {
- // TODO: here
rdr_fmt := []string{}
rdr_fmt = append(rdr_fmt, "ssh", "-f")
rdr_fmt = append(rdr_fmt, "-L",
diff --git a/src/e_events.go b/src/e_events.go
index b089a03..8c7011e 100644
--- a/src/e_events.go
+++ b/src/e_events.go
@@ -53,8 +53,6 @@ package main
import (
"os"
- "strconv"
- "strings"
"github.com/gdamore/tcell/v2"
"golang.org/x/term"
@@ -280,7 +278,7 @@ func e_delete_host(data *HardData) error {
return nil
}
-func e_readline(event *tcell.EventKey, buffer *string) {
+func e_readline(event tcell.EventKey, buffer *string) {
if len(*buffer) > 0 &&
(event.Key() == tcell.KeyBackspace ||
event.Key() == tcell.KeyBackspace2) {
@@ -356,7 +354,7 @@ func e_set_protocol_defaults(data *HardData, in *HostNode) {
}
// screen events such as keypresses
-func e_events(data *HardData) {
+func e_events(data *HardData, fp [MODE_MAX + 1]key_event_mode_func) {
ui := &data.ui
event := ui.s.PollEvent()
switch event := event.(type) {
@@ -365,460 +363,12 @@ func e_events(data *HardData) {
e_list_follow_cursor(data.litems, ui)
ui.s.Sync()
case *tcell.EventKey:
- switch ui.mode {
- case NORMAL_MODE:
- e_normal_events(data, *event)
+ if ui.mode > MODE_MAX {
+ return
+ } else if brk := fp[ui.mode](data, *event); brk == true {
+ return
+ } else if ui.mode == NORMAL_MODE {
e_list_follow_cursor(data.litems, ui)
- case DELETE_MODE:
- e_delete_events(data, *event)
- case ERROR_MODE:
- e_error_events(data, *event)
- case WELCOME_MODE:
- // TODO: here
- if event.Key() == tcell.KeyEscape ||
- event.Key() == tcell.KeyCtrlC {
- ui.s.Fini()
- os.Exit(0)
- }
- if len(data.opts.GPG) == 0 {
- if event.Rune() < '1' || event.Rune() > '9' {
- break
- } else {
- data.opts.GPG = data.keys[event.Rune() - 48 - 1][0]
- ui.s.HideCursor()
- }
- } else {
- if event.Rune() == 'y' {
- ui.mode = NORMAL_MODE
- c_write_options(data.opts.file, data.opts, &data.load_err)
- } else if event.Rune() == 'n' {
- data.opts.GPG = ""
- }
- }
- case INSERT_MODE:
- if data.insert == nil {
- if event.Key() == tcell.KeyEscape ||
- event.Key() == tcell.KeyCtrlC {
- ui.s.HideCursor()
- data.ui.mode = NORMAL_MODE
- data.ui.insert_sel = 0
- data.insert = nil
- ui.buff = ""
- } else if event.Key() == tcell.KeyEnter {
- if ui.buff == "" {
- ui.s.HideCursor()
- data.ui.mode = NORMAL_MODE
- data.ui.insert_sel = 0
- data.ui.insert_sel_ok = false
- data.insert = nil
- ui.buff = ""
- break
- }
- ui.s.HideCursor()
- data.insert = &HostNode{}
- e_set_protocol_defaults(data, data.insert)
- data.insert.Name = ui.buff
- ui.buff = ""
- if data.litems.curr != nil {
- data.insert.parent = data.litems.curr.path_node()
- } else {
- data.insert.parent = data.ldirs.head
- }
- } else {
- e_readline(event, &data.ui.buff)
- }
- } else if data.insert != nil {
- if data.insert_err != nil {
- if event.Rune() != 0 ||
- event.Key() == tcell.KeyEscape ||
- event.Key() == tcell.KeyEnter {
- data.insert_err = nil
- }
- } else if data.ui.insert_sel_ok == false {
- if event.Key() == tcell.KeyEscape ||
- event.Key() == tcell.KeyCtrlC ||
- event.Rune() == 'q' {
- ui.s.HideCursor()
- data.ui.mode = NORMAL_MODE
- data.ui.insert_sel = 0
- data.insert = nil
- ui.buff = ""
- } else if event.Rune() == 'j' ||
- event.Key() == tcell.KeyDown ||
- event.Key() == tcell.KeyTab {
- if data.insert.Protocol == PROTOCOL_RDP &&
- data.ui.insert_sel == INS_PROTOCOL {
- data.ui.insert_sel = INS_RDP_HOST
- } 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
- }
- } else if event.Rune() == 'k' ||
- event.Key() == tcell.KeyUp {
- if data.insert.Protocol == PROTOCOL_RDP &&
- data.ui.insert_sel == INS_RDP_HOST {
- data.ui.insert_sel = INS_PROTOCOL
- } 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
- }
- } else if event.Rune() == 'g' ||
- event.Rune() == 'h' ||
- event.Key() == tcell.KeyLeft {
- data.ui.insert_sel = INS_PROTOCOL
- } else if event.Rune() == 'G' ||
- event.Rune() == 'l' ||
- event.Key() == tcell.KeyRight {
- data.ui.insert_sel = data.ui.insert_sel_max
- } else if event.Rune() == 'i' ||
- event.Rune() == 'a' ||
- event.Rune() == ' ' ||
- 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,
- INS_OS_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_OS_HOST:
- ui.buff = data.insert.Host
- case INS_SSH_PORT,
- INS_RDP_PORT:
- if data.insert.Port > 0 {
- ui.buff = strconv.Itoa(int(data.insert.Port))
- }
- case INS_SSH_USER,
- INS_RDP_USER,
- INS_OS_USER:
- ui.buff = data.insert.User
- case INS_SSH_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
- case INS_SSH_JUMP_PORT:
- if data.insert.Jump.Port > 0 {
- ui.buff = strconv.Itoa(int(
- data.insert.Jump.Port))
- }
- case INS_SSH_JUMP_USER: ui.buff = data.insert.Jump.User
- 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_RDP_SCREENSIZE: break
- case INS_RDP_DYNAMIC:
- data.ui.insert_sel_ok = false
- if data.insert.Dynamic == true {
- data.insert.Dynamic = false
- } else {
- data.insert.Dynamic = true
- }
- break
- case INS_RDP_QUALITY: break
- case INS_RDP_DRIVE + len(data.insert.Drive): break
- case INS_CMD_CMD: ui.buff = data.insert.Host
- case INS_CMD_SHELL: ui.buff = data.insert.Shell[0]
- case INS_CMD_SILENT:
- data.ui.insert_sel_ok = false
- if data.insert.Silent == true {
- data.insert.Silent = false
- } else {
- 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_OS_IMGAPI:
- ui.buff = data.insert.Stack.ImageAPI
- case INS_OS_NETAPI:
- ui.buff = data.insert.Stack.NetworkAPI
- case INS_OS_VOLAPI:
- ui.buff = data.insert.Stack.VolumeAPI
- case INS_SSH_NOTE,
- INS_RDP_NOTE + len(data.insert.Drive),
- INS_CMD_NOTE,
- INS_OS_NOTE:
- ui.buff = data.insert.Note
- }
- }
- } else {
- if event.Key() == tcell.KeyEscape ||
- event.Key() == tcell.KeyCtrlC {
- data.ui.insert_sel_ok = false
- ui.buff = ""
- ui.drives_buff = ""
- ui.s.HideCursor()
- }
- if len(data.insert.Drive) > 0 &&
- (data.ui.insert_sel >= INS_RDP_DRIVE &&
- data.ui.insert_sel < INS_RDP_DRIVE +
- len(data.insert.Drive)) {
- if event.Rune() == 'y' ||
- event.Rune() == 'Y' ||
- event.Key() == tcell.KeyEnter {
- delete(data.insert.Drive,
- data.insert.drive_keys[
- data.ui.insert_sel - INS_RDP_DRIVE])
- if len(data.insert.Drive) == 0 {
- data.insert.Drive = nil
- }
- e_set_drive_keys(data)
- }
- data.ui.insert_sel_ok = false
- break
- }
- switch data.ui.insert_sel {
- case INS_PROTOCOL:
- if event.Rune() < '1' || event.Rune() > '4' {
- data.ui.insert_sel_ok = false
- ui.buff = ""
- ui.s.HideCursor()
- break
- } else {
- name := data.insert.Name
- parent := data.insert.parent
- data.insert = nil
- data.insert = &HostNode{}
- data.insert.Name = name
- data.insert.parent = parent
- data.insert.Protocol = int8(event.Rune() - 48 - 1)
- data.ui.insert_sel_ok = false
- ui.s.HideCursor()
- e_set_protocol_defaults(data, data.insert)
- }
- case INS_RDP_SCREENSIZE:
- if event.Rune() < '1' || event.Rune() > '7' {
- data.ui.insert_sel_ok = false
- ui.buff = ""
- ui.s.HideCursor()
- break
- } else {
- s := strings.Split(
- RDP_SCREENSIZE[uint8(event.Rune() - 48 - 1)],
- "x")
- if len(s) != 2 {
- return
- }
- tmp, _ := strconv.Atoi(s[W])
- data.insert.Width = uint16(tmp)
- tmp, _ = strconv.Atoi(s[H])
- data.insert.Height = uint16(tmp)
- data.ui.insert_sel_ok = false
- ui.s.HideCursor()
- }
- case INS_RDP_QUALITY:
- if event.Rune() < '1' || event.Rune() > '3' {
- data.ui.insert_sel_ok = false
- ui.buff = ""
- ui.s.HideCursor()
- break
- } else {
- data.insert.Quality = uint8(event.Rune() - 48 - 1)
- data.ui.insert_sel_ok = false
- ui.s.HideCursor()
- }
- case INS_RDP_DRIVE + len(data.insert.Drive):
- if len(data.ui.drives_buff) == 0 {
- if event.Key() == tcell.KeyEnter {
- if len(ui.buff) == 0 {
- data.ui.insert_sel_ok = false
- data.ui.drives_buff = ""
- ui.buff = ""
- ui.s.HideCursor()
- break
- }
- data.ui.drives_buff = ui.buff
- ui.buff = ""
- } else {
- e_readline(event, &data.ui.buff)
- }
- } else {
- if event.Key() == tcell.KeyEnter {
- if len(ui.buff) == 0 {
- data.ui.insert_sel_ok = false
- data.ui.drives_buff = ""
- ui.buff = ""
- ui.s.HideCursor()
- break
- }
- if len(data.insert.Drive) == 0 {
- data.insert.Drive = make(map[string]string)
- }
- data.insert.Drive[ui.drives_buff] = ui.buff
- e_set_drive_keys(data)
- data.ui.insert_sel_ok = false
- ui.drives_buff = ""
- ui.buff = ""
- ui.s.HideCursor()
- } else {
- e_readline(event, &data.ui.buff)
- }
- }
- case INS_SSH_HOST,
- INS_SSH_PORT,
- INS_SSH_USER,
- INS_SSH_PASS,
- INS_SSH_PRIV,
- INS_SSH_JUMP_HOST,
- INS_SSH_JUMP_PORT,
- INS_SSH_JUMP_USER,
- INS_SSH_JUMP_PASS,
- INS_SSH_JUMP_PRIV,
- INS_SSH_NOTE,
- INS_RDP_HOST,
- INS_RDP_PORT,
- INS_RDP_DOMAIN,
- INS_RDP_USER,
- INS_RDP_PASS,
- INS_RDP_FILE,
- INS_RDP_NOTE + len(data.insert.Drive),
- INS_CMD_CMD,
- INS_CMD_SHELL,
- 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,
- INS_OS_IMGAPI,
- INS_OS_NETAPI,
- INS_OS_VOLAPI,
- INS_OS_NOTE:
- if event.Key() == tcell.KeyEnter {
- switch data.ui.insert_sel {
- case INS_SSH_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_OS_USER:
- data.insert.User = ui.buff
- case INS_SSH_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
- case INS_SSH_JUMP_HOST:
- data.insert.Jump.Host = ui.buff
- if len(ui.buff) > 0 {
- data.insert.Jump.Port = 22
- } else {
- data.insert.Jump.Port = 0
- }
- case INS_SSH_JUMP_PORT:
- tmp, _ := strconv.Atoi(ui.buff)
- data.insert.Jump.Port = uint16(tmp)
- case INS_SSH_JUMP_USER:
- data.insert.Jump.User = ui.buff
- case INS_SSH_JUMP_PASS:
- data.insert.Jump.Pass, _ =
- c_encrypt_str(ui.buff, data.opts.GPG)
- case INS_SSH_JUMP_PRIV:
- data.insert.Jump.Priv = ui.buff
- case INS_RDP_DOMAIN:
- data.insert.Domain = ui.buff
- case INS_RDP_FILE:
- data.insert.RDPFile = ui.buff
- case INS_CMD_CMD:
- 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_OS_IMGAPI:
- data.insert.Stack.ImageAPI = ui.buff
- case INS_OS_NETAPI:
- data.insert.Stack.NetworkAPI = ui.buff
- case INS_OS_VOLAPI:
- data.insert.Stack.VolumeAPI = ui.buff
- case INS_SSH_NOTE,
- INS_RDP_NOTE + len(data.insert.Drive),
- INS_CMD_NOTE,
- INS_OS_NOTE:
- data.insert.Note = ui.buff
- }
- data.ui.insert_sel_ok = false
- ui.buff = ""
- ui.s.HideCursor()
- } else {
- e_readline(event, &data.ui.buff)
- }
- }
- }
- }
- case MKDIR_MODE:
- if event.Key() == tcell.KeyEscape ||
- event.Key() == tcell.KeyCtrlC {
- ui.s.HideCursor()
- ui.mode = NORMAL_MODE
- ui.buff = ""
- data.insert = nil
- } else if event.Key() == tcell.KeyEnter {
- e_mkdir(data, ui)
- ui.s.HideCursor()
- ui.mode = NORMAL_MODE
- ui.buff = ""
- } else {
- e_readline(event, &data.ui.buff)
- }
}
}
}
diff --git a/src/e_keys.go b/src/e_keys.go
index 831a80f..4f45d85 100644
--- a/src/e_keys.go
+++ b/src/e_keys.go
@@ -53,11 +53,13 @@ package main
import (
"os"
+ "strconv"
+ "strings"
"github.com/gdamore/tcell/v2"
)
-func e_normal_events(data *HardData, event tcell.EventKey) {
+func e_normal_events(data *HardData, event tcell.EventKey) bool {
if event.Key() == tcell.KeyCtrlC ||
event.Rune() == 'q' {
data.ui.s.Fini()
@@ -117,7 +119,7 @@ func e_normal_events(data *HardData, event tcell.EventKey) {
e_fold_dir(data, curr)
data.litems.curr = curr
data.litems.draw = data.litems.curr
- return
+ return true
} else {
if data.folds[curr.Dirs.Parent] == nil {
parent := curr.Dirs.Parent
@@ -129,7 +131,7 @@ func e_normal_events(data *HardData, event tcell.EventKey) {
e_fold_dir(data, curr_new)
data.litems.curr = curr_new
data.litems.draw = data.litems.curr
- return
+ return true
} else {
if data.folds[curr_new.Dirs] ==
nil {
@@ -139,7 +141,7 @@ func e_normal_events(data *HardData, event tcell.EventKey) {
}
}
}
- return
+ return true
}
}
}
@@ -147,7 +149,7 @@ func e_normal_events(data *HardData, event tcell.EventKey) {
event.Key() == tcell.KeyRight ||
event.Key() == tcell.KeyEnter {
if data.litems.curr == nil {
- return
+ return true
} else if data.litems.curr.is_dir() == false {
c_exec(data.litems.curr.Host, data.opts, &data.ui)
} else if data.litems.curr.Dirs != nil &&
@@ -159,7 +161,7 @@ func e_normal_events(data *HardData, event tcell.EventKey) {
} else if event.Rune() == ' ' {
if data.litems.curr == nil ||
data.litems.curr.is_dir() == false {
- return
+ return true
}
if data.litems.curr.Dirs != nil &&
data.folds[data.litems.curr.Dirs] == nil {
@@ -180,13 +182,14 @@ func e_normal_events(data *HardData, event tcell.EventKey) {
} else if event.Rune() == 'y' {
if data.litems.curr == nil ||
data.litems.curr.is_dir() == true {
- return
+ return true
}
data.yank = data.litems.curr
}
+ return false
}
-func e_delete_events(data *HardData, event tcell.EventKey) {
+func e_delete_events(data *HardData, event tcell.EventKey) bool {
if event.Key() == tcell.KeyEscape ||
event.Key() == tcell.KeyCtrlC ||
event.Rune() == 'n' {
@@ -195,15 +198,478 @@ func e_delete_events(data *HardData, event tcell.EventKey) {
event.Rune() == 'y' {
if err := e_delete_host(data); err == nil {
data.ui.mode = NORMAL_MODE
+ return true
}
}
+ return false
}
-func e_error_events(data *HardData, event tcell.EventKey) {
+func e_load_events(data *HardData, event tcell.EventKey) bool {
+ return true
+}
+
+func e_error_events(data *HardData, event tcell.EventKey) bool {
if event.Rune() != 0 ||
event.Key() == tcell.KeyEscape ||
event.Key() == tcell.KeyEnter {
data.ui.mode = NORMAL_MODE
data.load_err = nil
}
+ return false
+}
+
+func e_welcome_events(data *HardData, event tcell.EventKey) bool {
+ if event.Key() == tcell.KeyEscape ||
+ event.Key() == tcell.KeyCtrlC {
+ data.ui.s.Fini()
+ os.Exit(0)
+ }
+ if len(data.opts.GPG) == 0 {
+ if event.Rune() < '1' || event.Rune() > '9' {
+ return true
+ } else {
+ data.opts.GPG = data.keys[event.Rune() - 48 - 1][0]
+ data.ui.s.HideCursor()
+ }
+ } else {
+ if event.Rune() == 'y' {
+ data.ui.mode = NORMAL_MODE
+ c_write_options(data.opts.file, data.opts, &data.load_err)
+ } else if event.Rune() == 'n' {
+ data.opts.GPG = ""
+ }
+ }
+ return false
+}
+
+func e_insert_events(data *HardData, event tcell.EventKey) bool {
+ ui := &data.ui
+
+ if data.insert == nil {
+ if event.Key() == tcell.KeyEscape ||
+ event.Key() == tcell.KeyCtrlC {
+ ui.s.HideCursor()
+ data.ui.mode = NORMAL_MODE
+ data.ui.insert_sel = 0
+ data.insert = nil
+ ui.buff = ""
+ } else if event.Key() == tcell.KeyEnter {
+ if ui.buff == "" {
+ ui.s.HideCursor()
+ data.ui.mode = NORMAL_MODE
+ data.ui.insert_sel = 0
+ data.ui.insert_sel_ok = false
+ data.insert = nil
+ ui.buff = ""
+ return true
+ }
+ ui.s.HideCursor()
+ data.insert = &HostNode{}
+ e_set_protocol_defaults(data, data.insert)
+ data.insert.Name = ui.buff
+ ui.buff = ""
+ if data.litems.curr != nil {
+ data.insert.parent = data.litems.curr.path_node()
+ } else {
+ data.insert.parent = data.ldirs.head
+ }
+ } else {
+ e_readline(event, &data.ui.buff)
+ }
+ } else if data.insert != nil {
+ if data.insert_err != nil {
+ if event.Rune() != 0 ||
+ event.Key() == tcell.KeyEscape ||
+ event.Key() == tcell.KeyEnter {
+ data.insert_err = nil
+ }
+ } else if data.ui.insert_sel_ok == false {
+ if event.Key() == tcell.KeyEscape ||
+ event.Key() == tcell.KeyCtrlC ||
+ event.Rune() == 'q' {
+ ui.s.HideCursor()
+ data.ui.mode = NORMAL_MODE
+ data.ui.insert_sel = 0
+ data.insert = nil
+ ui.buff = ""
+ } else if event.Rune() == 'j' ||
+ event.Key() == tcell.KeyDown ||
+ event.Key() == tcell.KeyTab {
+ if data.insert.Protocol == PROTOCOL_RDP &&
+ data.ui.insert_sel == INS_PROTOCOL {
+ data.ui.insert_sel = INS_RDP_HOST
+ } 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
+ }
+ } else if event.Rune() == 'k' ||
+ event.Key() == tcell.KeyUp {
+ if data.insert.Protocol == PROTOCOL_RDP &&
+ data.ui.insert_sel == INS_RDP_HOST {
+ data.ui.insert_sel = INS_PROTOCOL
+ } 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
+ }
+ } else if event.Rune() == 'g' ||
+ event.Rune() == 'h' ||
+ event.Key() == tcell.KeyLeft {
+ data.ui.insert_sel = INS_PROTOCOL
+ } else if event.Rune() == 'G' ||
+ event.Rune() == 'l' ||
+ event.Key() == tcell.KeyRight {
+ data.ui.insert_sel = data.ui.insert_sel_max
+ } else if event.Rune() == 'i' ||
+ event.Rune() == 'a' ||
+ event.Rune() == ' ' ||
+ 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,
+ INS_OS_OK:
+ data.ui.insert_sel_ok = false
+ i_insert_check_ok(data, data.insert)
+ if data.insert_err != nil {
+ return true
+ }
+ i_insert_host(data, data.insert)
+ case INS_SSH_HOST,
+ INS_RDP_HOST,
+ INS_OS_HOST:
+ ui.buff = data.insert.Host
+ case INS_SSH_PORT,
+ INS_RDP_PORT:
+ if data.insert.Port > 0 {
+ ui.buff = strconv.Itoa(int(data.insert.Port))
+ }
+ case INS_SSH_USER,
+ INS_RDP_USER,
+ INS_OS_USER:
+ ui.buff = data.insert.User
+ case INS_SSH_PASS,
+ INS_RDP_PASS,
+ INS_OS_PASS:
+ return true
+ case INS_SSH_PRIV: ui.buff = data.insert.Priv
+ case INS_SSH_JUMP_HOST: ui.buff = data.insert.Jump.Host
+ case INS_SSH_JUMP_PORT:
+ if data.insert.Jump.Port > 0 {
+ ui.buff = strconv.Itoa(int(
+ data.insert.Jump.Port))
+ }
+ case INS_SSH_JUMP_USER: ui.buff = data.insert.Jump.User
+ case INS_SSH_JUMP_PASS: return true
+ 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_RDP_SCREENSIZE: return true
+ case INS_RDP_DYNAMIC:
+ data.ui.insert_sel_ok = false
+ if data.insert.Dynamic == true {
+ data.insert.Dynamic = false
+ } else {
+ data.insert.Dynamic = true
+ }
+ return true
+ case INS_RDP_QUALITY: return true
+ case INS_RDP_DRIVE + len(data.insert.Drive): return true
+ case INS_CMD_CMD: ui.buff = data.insert.Host
+ case INS_CMD_SHELL: ui.buff = data.insert.Shell[0]
+ case INS_CMD_SILENT:
+ data.ui.insert_sel_ok = false
+ if data.insert.Silent == true {
+ data.insert.Silent = false
+ } else {
+ data.insert.Silent = true
+ }
+ return true
+ 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_OS_IMGAPI:
+ ui.buff = data.insert.Stack.ImageAPI
+ case INS_OS_NETAPI:
+ ui.buff = data.insert.Stack.NetworkAPI
+ case INS_OS_VOLAPI:
+ ui.buff = data.insert.Stack.VolumeAPI
+ case INS_SSH_NOTE,
+ INS_RDP_NOTE + len(data.insert.Drive),
+ INS_CMD_NOTE,
+ INS_OS_NOTE:
+ ui.buff = data.insert.Note
+ }
+ }
+ } else {
+ if event.Key() == tcell.KeyEscape ||
+ event.Key() == tcell.KeyCtrlC {
+ data.ui.insert_sel_ok = false
+ ui.buff = ""
+ ui.drives_buff = ""
+ ui.s.HideCursor()
+ }
+ if len(data.insert.Drive) > 0 &&
+ (data.ui.insert_sel >= INS_RDP_DRIVE &&
+ data.ui.insert_sel < INS_RDP_DRIVE +
+ len(data.insert.Drive)) {
+ if event.Rune() == 'y' ||
+ event.Rune() == 'Y' ||
+ event.Key() == tcell.KeyEnter {
+ delete(data.insert.Drive,
+ data.insert.drive_keys[
+ data.ui.insert_sel - INS_RDP_DRIVE])
+ if len(data.insert.Drive) == 0 {
+ data.insert.Drive = nil
+ }
+ e_set_drive_keys(data)
+ }
+ data.ui.insert_sel_ok = false
+ return true
+ }
+ switch data.ui.insert_sel {
+ case INS_PROTOCOL:
+ if event.Rune() < '1' || event.Rune() > '4' {
+ data.ui.insert_sel_ok = false
+ ui.buff = ""
+ ui.s.HideCursor()
+ return true
+ } else {
+ name := data.insert.Name
+ parent := data.insert.parent
+ data.insert = nil
+ data.insert = &HostNode{}
+ data.insert.Name = name
+ data.insert.parent = parent
+ data.insert.Protocol = int8(event.Rune() - 48 - 1)
+ data.ui.insert_sel_ok = false
+ ui.s.HideCursor()
+ e_set_protocol_defaults(data, data.insert)
+ }
+ case INS_RDP_SCREENSIZE:
+ if event.Rune() < '1' || event.Rune() > '7' {
+ data.ui.insert_sel_ok = false
+ ui.buff = ""
+ ui.s.HideCursor()
+ return true
+ } else {
+ s := strings.Split(
+ RDP_SCREENSIZE[uint8(event.Rune() - 48 - 1)],
+ "x")
+ if len(s) != 2 {
+ return true
+ }
+ tmp, _ := strconv.Atoi(s[W])
+ data.insert.Width = uint16(tmp)
+ tmp, _ = strconv.Atoi(s[H])
+ data.insert.Height = uint16(tmp)
+ data.ui.insert_sel_ok = false
+ ui.s.HideCursor()
+ }
+ case INS_RDP_QUALITY:
+ if event.Rune() < '1' || event.Rune() > '3' {
+ data.ui.insert_sel_ok = false
+ ui.buff = ""
+ ui.s.HideCursor()
+ return true
+ } else {
+ data.insert.Quality = uint8(event.Rune() - 48 - 1)
+ data.ui.insert_sel_ok = false
+ ui.s.HideCursor()
+ }
+ case INS_RDP_DRIVE + len(data.insert.Drive):
+ if len(data.ui.drives_buff) == 0 {
+ if event.Key() == tcell.KeyEnter {
+ if len(ui.buff) == 0 {
+ data.ui.insert_sel_ok = false
+ data.ui.drives_buff = ""
+ ui.buff = ""
+ ui.s.HideCursor()
+ return true
+ }
+ data.ui.drives_buff = ui.buff
+ ui.buff = ""
+ } else {
+ e_readline(event, &data.ui.buff)
+ }
+ } else {
+ if event.Key() == tcell.KeyEnter {
+ if len(ui.buff) == 0 {
+ data.ui.insert_sel_ok = false
+ data.ui.drives_buff = ""
+ ui.buff = ""
+ ui.s.HideCursor()
+ return true
+ }
+ if len(data.insert.Drive) == 0 {
+ data.insert.Drive = make(map[string]string)
+ }
+ data.insert.Drive[ui.drives_buff] = ui.buff
+ e_set_drive_keys(data)
+ data.ui.insert_sel_ok = false
+ ui.drives_buff = ""
+ ui.buff = ""
+ ui.s.HideCursor()
+ } else {
+ e_readline(event, &data.ui.buff)
+ }
+ }
+ case INS_SSH_HOST,
+ INS_SSH_PORT,
+ INS_SSH_USER,
+ INS_SSH_PASS,
+ INS_SSH_PRIV,
+ INS_SSH_JUMP_HOST,
+ INS_SSH_JUMP_PORT,
+ INS_SSH_JUMP_USER,
+ INS_SSH_JUMP_PASS,
+ INS_SSH_JUMP_PRIV,
+ INS_SSH_NOTE,
+ INS_RDP_HOST,
+ INS_RDP_PORT,
+ INS_RDP_DOMAIN,
+ INS_RDP_USER,
+ INS_RDP_PASS,
+ INS_RDP_FILE,
+ INS_RDP_NOTE + len(data.insert.Drive),
+ INS_CMD_CMD,
+ INS_CMD_SHELL,
+ 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,
+ INS_OS_IMGAPI,
+ INS_OS_NETAPI,
+ INS_OS_VOLAPI,
+ INS_OS_NOTE:
+ if event.Key() == tcell.KeyEnter {
+ switch data.ui.insert_sel {
+ case INS_SSH_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_OS_USER:
+ data.insert.User = ui.buff
+ case INS_SSH_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
+ case INS_SSH_JUMP_HOST:
+ data.insert.Jump.Host = ui.buff
+ if len(ui.buff) > 0 {
+ data.insert.Jump.Port = 22
+ } else {
+ data.insert.Jump.Port = 0
+ }
+ case INS_SSH_JUMP_PORT:
+ tmp, _ := strconv.Atoi(ui.buff)
+ data.insert.Jump.Port = uint16(tmp)
+ case INS_SSH_JUMP_USER:
+ data.insert.Jump.User = ui.buff
+ case INS_SSH_JUMP_PASS:
+ data.insert.Jump.Pass, _ =
+ c_encrypt_str(ui.buff, data.opts.GPG)
+ case INS_SSH_JUMP_PRIV:
+ data.insert.Jump.Priv = ui.buff
+ case INS_RDP_DOMAIN:
+ data.insert.Domain = ui.buff
+ case INS_RDP_FILE:
+ data.insert.RDPFile = ui.buff
+ case INS_CMD_CMD:
+ 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_OS_IMGAPI:
+ data.insert.Stack.ImageAPI = ui.buff
+ case INS_OS_NETAPI:
+ data.insert.Stack.NetworkAPI = ui.buff
+ case INS_OS_VOLAPI:
+ data.insert.Stack.VolumeAPI = ui.buff
+ case INS_SSH_NOTE,
+ INS_RDP_NOTE + len(data.insert.Drive),
+ INS_CMD_NOTE,
+ INS_OS_NOTE:
+ data.insert.Note = ui.buff
+ }
+ data.ui.insert_sel_ok = false
+ ui.buff = ""
+ ui.s.HideCursor()
+ } else {
+ e_readline(event, &data.ui.buff)
+ }
+ }
+ }
+ }
+ return false
+}
+
+func e_mkdir_events(data *HardData, event tcell.EventKey) bool {
+ if event.Key() == tcell.KeyEscape ||
+ event.Key() == tcell.KeyCtrlC {
+ data.ui.s.HideCursor()
+ data.ui.mode = NORMAL_MODE
+ data.ui.buff = ""
+ data.insert = nil
+ } else if event.Key() == tcell.KeyEnter {
+ e_mkdir(data, &data.ui)
+ data.ui.s.HideCursor()
+ data.ui.mode = NORMAL_MODE
+ data.ui.buff = ""
+ } else {
+ e_readline(event, &data.ui.buff)
+ }
+ return false
}
diff --git a/src/i_ui.go b/src/i_ui.go
index b19921b..8dc9721 100644
--- a/src/i_ui.go
+++ b/src/i_ui.go
@@ -649,6 +649,8 @@ func i_init_styles(ui *HardUI) {
Foreground(tcell.ColorYellow).Dim(true).Bold(true)
}
+type key_event_mode_func func(*HardData, tcell.EventKey) bool
+
func i_ui(data_dir string) {
home_dir, _ := os.UserHomeDir()
ui := HardUI{}
@@ -691,6 +693,15 @@ func i_ui(data_dir string) {
data.ui.mode = WELCOME_MODE
data.keys = c_get_secret_gpg_keyring()
}
+ fp := [MODE_MAX + 1]key_event_mode_func{
+ NORMAL_MODE: e_normal_events,
+ DELETE_MODE: e_delete_events,
+ LOAD_MODE: e_load_events,
+ ERROR_MODE: e_error_events,
+ WELCOME_MODE: e_welcome_events,
+ MKDIR_MODE: e_mkdir_events,
+ INSERT_MODE: e_insert_events,
+ }
for {
data.ui.s.Clear()
i_draw_bottom_text(data.ui, data.opts, data.insert, data.insert_err)
@@ -727,6 +738,6 @@ func i_ui(data_dir string) {
}
}
data.ui.s.Show()
- e_events(&data)
+ e_events(&data, fp)
}
}