diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/c_hardflip.go | 2 | ||||
-rw-r--r-- | src/c_init.go | 12 | ||||
-rw-r--r-- | src/c_parse.go | 3 | ||||
-rw-r--r-- | src/c_utils.go | 18 |
4 files changed, 31 insertions, 4 deletions
diff --git a/src/c_hardflip.go b/src/c_hardflip.go index fc6ca69..02433ce 100644 --- a/src/c_hardflip.go +++ b/src/c_hardflip.go @@ -64,6 +64,6 @@ type HardData struct { func main() { data_dir := c_get_data_dir(nil) - opts := HardOpts{true, true, "plain", false, ""} + opts := HardOpts{true, true, "plainq", false, ""} i_ui(data_dir, opts) } diff --git a/src/c_init.go b/src/c_init.go index 8981099..85eb9c8 100644 --- a/src/c_init.go +++ b/src/c_init.go @@ -52,6 +52,8 @@ package main import ( + "errors" + "fmt" "os" "path/filepath" ) @@ -96,6 +98,16 @@ func c_recurse_data_dir(dir, root string, opts HardOpts, } else if host_node != nil { host_node.Filename = filename host_node.Parent = &dir_node + if len(opts.GPG) == 0 { + host_node.Pass = "" + } else if opts.GPG != "plain" && len(host_node.Pass) > 0 { + host_node.Pass, err = c_decrypt_str(host_node.Pass) + if err != nil { + str := fmt.Sprintf("%s%s: password decryption: %v\n", + dir, filename, err) + *load_err = append(*load_err, errors.New(str)) + } + } dir_node.lhost.add_back(host_node) } i_draw_load_ui(ui) diff --git a/src/c_parse.go b/src/c_parse.go index 3a58558..2a7b881 100644 --- a/src/c_parse.go +++ b/src/c_parse.go @@ -69,9 +69,6 @@ func c_read_yaml_file(file string, if err := yaml.Unmarshal(yaml_file, &host); err != nil { return nil, err } - if len(opts.GPG) == 0 { - host.Pass = "" - } if len(host.Name) == 0 { return nil, nil } diff --git a/src/c_utils.go b/src/c_utils.go index df49a4f..01c8665 100644 --- a/src/c_utils.go +++ b/src/c_utils.go @@ -54,6 +54,8 @@ package main import ( "fmt" "os" + "os/exec" + "strings" ) // this function will go get the data folder and try to create it if it does @@ -117,3 +119,19 @@ func c_error_mode(msg string, err error, ui *HardUI) { ui.err[ERROR_MSG] = msg ui.err[ERROR_ERR] = err_str } + +// c_encrypt_str encrypts a string with the given gpgkey +func c_encrypt_str(str string, gpg string) (string, error) { + cmd := exec.Command("gpg", "-r", gpg, "-a", "-e") + cmd.Stdin = strings.NewReader(str) + out, err := cmd.Output() + return string(out), err +} + +// c_decrypt_str will try to decrypt the given str +func c_decrypt_str(str string) (string, error) { + cmd := exec.Command("gpg", "-q", "-d") + cmd.Stdin = strings.NewReader(str) + out, err := cmd.Output() + return string(out), err +} |