aboutsummaryrefslogtreecommitdiffstats
path: root/password_cmd.go
diff options
context:
space:
mode:
authorTeddy Wing2017-06-03 21:39:38 +0200
committerTeddy Wing2017-06-03 21:39:38 +0200
commit8c0f7e4c10643f3519c5900497dcf2ef326b178d (patch)
tree58b43be49d3e470d68543ced658c22c9ea07bf9b /password_cmd.go
parent3062c5a1923c0021f6e29e9ab3fe2e7184c7be35 (diff)
parentf5b1fb3d0ef37ed44b8f7302343dcd5cd16bd725 (diff)
downloadtimetasker-8c0f7e4c10643f3519c5900497dcf2ef326b178d.tar.bz2
Merge branch 'password-cmd' into timetasker-daily
Diffstat (limited to 'password_cmd.go')
-rw-r--r--password_cmd.go22
1 files changed, 22 insertions, 0 deletions
diff --git a/password_cmd.go b/password_cmd.go
new file mode 100644
index 0000000..821c8f6
--- /dev/null
+++ b/password_cmd.go
@@ -0,0 +1,22 @@
+package main
+
+import (
+ "os"
+ "os/exec"
+)
+
+// Execute the given string as a shell command and return the resulting output
+func passwordCmd(password_cmd string) (password string, err error) {
+ shell := os.Getenv("SHELL")
+
+ // `Command` requires us to pass shell arguments as parameters to the
+ // function, but we don't know what the arguments are because
+ // `password_cmd` is an arbitrary command. To get around this, we pass the
+ // password command to the current shell to execute.
+ output, err := exec.Command(shell, "-c", password_cmd).Output()
+ if err != nil {
+ return "", err
+ }
+
+ return string(output), nil
+}