nix/home/program/bash/module/Gpg.sh

93 lines
1.7 KiB
Bash
Raw Permalink Normal View History

2024-12-18 10:54:24 +03:00
# Check smartcard pin.
function scunlock() {
pkill keyboxd &>/dev/null
# pkill gpg-agent &> /dev/null
echo verify | gpg --card-edit --no-tty --command-fd=0
}
# Encrypt files to myself from a file or stdin.
# Usage: encrypt [FILES]
2024-12-18 10:54:24 +03:00
function encrypt() {
local IFS=$'\n'
local targets=(${@})
if [[ ${targets} == "" ]]; then
gpg --encrypt --armor --recipient hi@voronind.com
else
process() {
pv "${target}" | gpg --encrypt --recipient hi@voronind.com --output "${target}.gpg"
}
2024-12-18 10:54:24 +03:00
_iterate_targets process ${targets[@]}
fi
2024-12-18 10:54:24 +03:00
}
# Decrypt files to myself.
# Usage: decrypt [FILES]
function decrypt() {
local IFS=$'\n'
local targets=(${@})
if [[ ${targets} == "" ]]; then
gpg --decrypt
else
process() {
pv "${target}" | gpg --decrypt --output "${target%.gpg}"
}
2024-12-18 10:54:24 +03:00
_iterate_targets process ${targets[@]}
fi
2024-12-18 10:54:24 +03:00
}
# Sign a file.
# Usage: sign <FILES>
function sign() {
local IFS=$'\n'
local targets=(${@})
if [[ ${targets} == "" ]]; then
help sign
return 2
fi
process() {
gpg --detach-sig --armor --output "${target}.sig" "${target}"
}
_iterate_targets process ${targets[@]}
}
# Verify a signature. All .sig files by default.
# Usage: verify [FILES]
function verify() {
local IFS=$'\n'
local targets=(${@})
[[ ${targets} == "" ]] && targets=(*.sig)
process() {
gpg --verify "${target}"
}
_iterate_targets process ${targets[@]}
}
# Find user keys using keyservers.
# Usage: gpg_find <EMAIL>
function gpg_find() {
local email="${1}"
if [[ ${email} == "" ]]; then
help gpg_find
return 2
fi
gpg --locate-keys "${email}" ||
gpg --locate-keys --auto-key-locate hkps://keys.openpgp.org "${email}"
}
# Update keys.
function gpg_refresh() {
gpg --refresh-keys
}