diff options
-rwxr-xr-x | gpgsecure.sh | 144 |
1 files changed, 123 insertions, 21 deletions
diff --git a/gpgsecure.sh b/gpgsecure.sh index bcb974d..261d046 100755 --- a/gpgsecure.sh +++ b/gpgsecure.sh @@ -35,23 +35,111 @@ shutdown() { exit } + writeback() { + trap shutdown SIGINT SIGTERM SIGKILL SIGQUIT SIGHUP + # Sync back to disk every 10 seconds while [ 0 ]; do - printf '%s Syncing back to encrypted storage\n' "$(date '+%F %T')" + #printf '%s Syncing back to encrypted storage\n' "$(date '+%F %T')" tar -C "${TMP}" -c . | gpg -e --recipient "${KEY}" > "${DIR}.tar.gpg" if [ $? -gt 0 ]; then printf 'WARNING: Something went wrong syncing back to encrypted storage\n' printf 'Your data is likely in danger.\n' printf 'If you see this message more than once, take a manual backup\n' fi - sleep 15 + sleep 20 & + wait $! done } + +open() { + local archive="${1}" + + # Convert DIR to absolute path to avoid cd issues + local dirname="$(cd $(dirname ${archive}) && pwd)" + local basename="$(basename ${archive})" + local dir="${dirname}/${basename}" + # Create a temp dir in memory to extract to for safety + export TMP=$(mktemp -d /tmp/dec-XXXXXXXXXXXXXX) + # Link! + ln -s "${TMP}" "${dir}" + + if [ ! -f "${dir}.tar.gpg" ]; then + # Tell the user if that encrypted archive does not exist. + printf 'Encrypted archive does not exist. Creating.\n' + else + # Extract the encrypted tarchive if it exists + gpg -d "${dir}.tar.gpg" | tar -C "${TMP}" -x + fi + + writeback & + echo $! > "${dirname}/.${basename}.pid" +} + + +status() { + local archive=${1} + + local dirname="$(dirname ${archive})" + local basename="$(basename ${archive})" + local pidfile="${dirname}/.${basename}.pid" + + # If no pidfile, assume closed + if [ ! -f "${pidfile}" ]; then + printf '%s is closed\n' "${archive}" + return 0 + fi + + local pid="$(cat ${pidfile})" + + ps "${pid}" 2>/dev/null 1>/dev/null + if [ $? -eq 0 ]; then + printf '%s is open\n' "${archive}" + elif [ $? -gt 0 ]; then + printf '%s is closed but a stale pidfile was found. Removing\n' "${archive}" + rm -f "${pidfile}" + else + printf '%s is closed\n' "${archive}" + fi +} + + +close() { + local archive=${1} + + local dirname="$(dirname ${archive})" + local basename="$(basename ${archive})" + local pidfile="${dirname}/.${basename}.pid" + local pid="$(cat ${pidfile})" + + ps "${pid}" 2>/dev/null 1>/dev/null + if [ $? -gt 0 ]; then + printf "Stale pidfile detected but share is not open. Removing\n" + rm -f "${pidfile}" + return 1 + else + # Send SIGTERM (15) to tell the process to exit cleanly + kill -15 "${pid}" + [ $? -eq 0 ] && rm "${pidfile}" && return 0 + + printf 'Error closing archive "%s"\n' "${archive}" + return 1 + fi +} + + main() { - DIR="${1}" - if [ -z "${DIR:-}" ]; then - printf 'Directory to decrypt required\n' + local action="${1}" + local archive="${2}" + + # Input validation + if [ -z "${action:-}" ]; then + printf 'Action (open, close, or status) required\n' + return 1 + fi + if [ -z "${archive:-}" ]; then + printf 'Archive to decrypt required\n' return 1 fi @@ -66,24 +154,38 @@ main() { return 1 fi - # Convert DIR to absolute path to avoid cd issues - DIR="$(cd $(dirname ${DIR}) && pwd)/$(basename ${DIR})" - # Create a temp dir in memory to extract to for safety - TMP=$(mktemp -d /tmp/dec-XXXXXXXXXXXXXX) - # Link! - ln -s "${TMP}" "${DIR}" - - if [ ! -f "${DIR}.tar.gpg" ]; then - # Tell the user if that encrypted archive does not exist. - printf 'Encrypted archive does not exist. Creating.\n' - else - # Extract the encrypted tarchive if it exists - gpg -d ${DIR}.tar.gpg | tar -C "${TMP}" -x + local dirname="$(dirname ${archive})" + local basename="$(basename ${archive})" + export DIR="${dirname}/${basename}" + + if [ "${action}" = 'open' ]; then + # Check if already open + if [ -f "${dirname}/.${basename}.pid" ]; then + printf 'ERROR: Archive "%s" is already open\n' "${archive}" + return 1 + else + printf 'Opening!\n' + open "${archive}" + return $? + fi + elif [ "${action}" = 'close' ]; then + # Check if already closed + if [ ! -f "${dirname}/.${basename}.pid" ]; then + printf 'ERROR: Archive "%s" is not open\n' "${archive}" + exit 1 + else + printf 'Closing!\n' + close "${archive}" + return $? + fi + elif [ "${action}" = 'status' ]; then + status "${archive}" + return $? fi - writeback - shutdown - return $? + # If we make it here, something went wrong. + printf 'ERROR: Unknown action "%s"\n' "${action}" + return 1 } main ${@} |