From 49aada16db9946daa5a945b7ff234ac32b4d4c91 Mon Sep 17 00:00:00 2001 From: Dmitry Voronin Date: Sun, 12 Jan 2025 22:27:53 +0300 Subject: [PATCH] Gpg: Add pipe support for encrypt/decrypt. --- home/program/bash/module/Gpg.sh | 33 +++++++++++++++++---------------- 1 file changed, 17 insertions(+), 16 deletions(-) diff --git a/home/program/bash/module/Gpg.sh b/home/program/bash/module/Gpg.sh index ff6fc6d..d7e5ab2 100644 --- a/home/program/bash/module/Gpg.sh +++ b/home/program/bash/module/Gpg.sh @@ -5,22 +5,21 @@ function scunlock() { echo verify | gpg --card-edit --no-tty --command-fd=0 } -# Encrypt files to myself. -# Usage: encrypt +# Encrypt files to myself from a file or stdin. +# Usage: encrypt [FILES] function encrypt() { local IFS=$'\n' local targets=(${@}) if [[ ${targets} == "" ]]; then - help encrypt - return 2 + gpg --encrypt --armor --recipient hi@voronind.com + else + process() { + pv "${target}" | gpg --encrypt --recipient hi@voronind.com --output "${target}.gpg" + } + + _iterate_targets process ${targets[@]} fi - - process() { - gpg --encrypt --armor --recipient hi@voronind.com --output "${target}.gpg" "${target}" - } - - _iterate_targets process ${targets[@]} } # Decrypt files to myself. @@ -29,13 +28,15 @@ function decrypt() { local IFS=$'\n' local targets=(${@}) - [[ ${targets} == "" ]] && targets=(*.gpg) + if [[ ${targets} == "" ]]; then + gpg --decrypt + else + process() { + pv "${target}" | gpg --decrypt --output "${target%.gpg}" + } - process() { - gpg --decrypt --output "${target%.gpg}" "${target}" - } - - _iterate_targets process ${targets[@]} + _iterate_targets process ${targets[@]} + fi } # Sign a file.