diff options
Diffstat (limited to '')
-rw-r--r-- | src/e_events.go | 464 |
1 files changed, 7 insertions, 457 deletions
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) - } } } } |