aboutsummaryrefslogtreecommitdiffstats
path: root/src/i_insert.go
diff options
context:
space:
mode:
Diffstat (limited to 'src/i_insert.go')
-rw-r--r--src/i_insert.go223
1 files changed, 163 insertions, 60 deletions
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
}