Compare commits

...

2 Commits

Author SHA1 Message Date
aaa42182e3 Add bwexport for encrypted Bitwarden backups 2026-04-07 21:38:51 -04:00
6dd11b7ee9 Add a safe copy alias for cp 2026-04-02 21:49:46 -04:00
2 changed files with 49 additions and 0 deletions

View File

@@ -13,6 +13,7 @@ alias 'refreshalias'='source ~/.bash_aliases'
# File management
alias put='mv --update=none-fail --verbose'
alias copy='cp --update=none-fail --verbose'
alias mv='mv -i'
# SSH management

48
bitwarden/.local/bin/bwexport Executable file
View File

@@ -0,0 +1,48 @@
#!/usr/bin/env bash
set -o pipefail
msg() {
printf '[%s]: %s\n' "$1" "$2"
}
for cmd in bw gpg gzip; do
if ! command -v "$cmd" >/dev/null; then
msg 'ERROR' "'$cmd' not found"
exit 1
fi
done
read -srp "Vault password: " bw_pw
echo
if ! bw_session="$(printf '%s' "$bw_pw" | bw unlock --raw 2>/dev/null)"; then
msg 'ERROR' "Couldn't unlock vault"
exit 1
fi
unset bw_pw
read -srp "GPG passphrase: " gpg_pw
echo
read -srp "Confirm GPG passphrase: " gpg_pw2
echo
if [ "$gpg_pw" != "$gpg_pw2" ]; then
msg 'ERROR' "Passphrases don't match"
exit 1
fi
unset gpg_pw2
bw_date="$(TZ='America/New_York' date +%Y%m%dT%H%M)"
: "${BW_BACKUP:="./bw-export-$bw_date.json.gz.gpg"}"
if [ -e "$BW_BACKUP" ]; then
msg 'ERROR' "Existing file at $BW_BACKUP"
exit 1
fi
if ! bw export --format json --raw --session "$bw_session" | gzip |
gpg --symmetric --cipher-algo AES256 --pinentry-mode loopback \
--passphrase-fd 3 --batch -q \
-o "$BW_BACKUP" 3<<<"$gpg_pw"; then
msg 'ERROR' "Export failed"
unset gpg_pw
exit 1
fi
unset gpg_pw
bw lock --session "$bw_session" >/dev/null 2>&1
unset bw_session
msg 'INFO' "Exported to '$BW_BACKUP'"