aboutsummaryrefslogtreecommitdiffstats
path: root/bin
diff options
context:
space:
mode:
authorDavid Runge <david.runge@frqrec.com>2014-04-13 16:53:28 +0200
committerDavid Runge <david.runge@frqrec.com>2014-04-13 16:53:28 +0200
commit899fa24894f4ec29e0b4cbea3dba154231e7aa0a (patch)
tree61d2a6f0e49fb5c2f3ac84d9c3f959da52a074c8 /bin
parent6d53debdbc1fed72c2f91694538fc33526933392 (diff)
downloaddotfiles-899fa24894f4ec29e0b4cbea3dba154231e7aa0a.tar.gz
dotfiles-899fa24894f4ec29e0b4cbea3dba154231e7aa0a.tar.bz2
dotfiles-899fa24894f4ec29e0b4cbea3dba154231e7aa0a.tar.xz
dotfiles-899fa24894f4ec29e0b4cbea3dba154231e7aa0a.zip
Adding function for gpg crypted file editing.
Diffstat (limited to 'bin')
-rwxr-xr-xbin/secret41
1 files changed, 41 insertions, 0 deletions
diff --git a/bin/secret b/bin/secret
new file mode 100755
index 0000000..27391ff
--- /dev/null
+++ b/bin/secret
@@ -0,0 +1,41 @@
+#!/bin/bash
+#
+# Open and write to a gpg encrypted file
+# Will create the file for you if it's not there yet
+#
+# secret <path/to/file>
+
+writeback () {
+ gpg --yes -eq -r "$gpgkey" -o $1 $tmpfile
+ echo "Encrypted file using gpg public key: $gpgkey"
+ chmod 600 $1
+ echo "Finished working on file: $1."
+ rm $tmpfile
+ echo "Removed temp file $tmpfile"
+}
+
+filetotmp () {
+ gpg --yes -o $tmpfile -d $1
+}
+
+tmpfile=$(mktemp)
+gpgkey="David Runge <david.runge@frqrec.com>"
+
+# if file is available, use it, else create it
+if [[ -f "$1" ]];then
+ filetotmp $1
+ echo "File $1 now in $tmpfile ."
+fi
+
+echo "Opening file in $EDITOR"
+# edit decrypted file in /tmp
+$EDITOR $tmpfile
+if [[ $? -gt 0 ]];then
+ echo "Something went wrong with $EDITOR ."
+ echo "Aborting."
+ rm $tmpfile
+ echo "Deleted $tmpfile ."
+else
+ # write back the file
+ writeback $1
+fi