GnuPG is what I've chosen to used for this process and because you've stated that decryption steps where to opaque (I agree in this usage instance) I've also worked on that side of the problem too. Check the projects' Travis-CI build logs for what features currently work as designed and the travis.yml file for following along with the logs' output. Basically you'll need three scripts from this project; the keygen script, decryption helper script, and named pipe listener script. The keygen script & decryption helper script should be used on the device that will preform decryption and the named pipe listener script should be on the device preforming encryption.
The encrypting named pipe listener script accepts strings, file paths, or directory paths once setup and outputs encrypted results in a predictable fashion.
Below are example commands that could be placed into your nightly backup script for encryption and for directories compression+encryption
echo "some messages text" > /path/to/named.pipe
## Message text is ASCII armor encrypted and appended to specified file when script was stated
echo "${HOME}/Documents" > /path/to/named.pipe
## Directories are compressed with tar and encrypted with output to time stamped file in bulk output directory
echo "${HOME}/.bash_history" > /path/to/named.pipe
For decryption you'll want to check out how the build scripts .travis-ci/script_decrypt.sh
& .travis-ci/test_search_script_decrypt.sh
for how the appended strings of encrypted data are recovered and how bulk files/directories are restored.
Of course with stuff this experimental it's best to not use primary key pares (kinda why the keygen script was written) and it should not be used on important data until you're confident in how to restore it to readable form.
tar xz
in the second set of commands betar -xz
instead? – Kenny Evitt May 29 '16 at 20:58-
– Florian Diesch May 30 '16 at 00:23z
option does add much – feklee Feb 10 '19 at 15:01--batch --passphrase my_secret
instead – Stefan Haberl Feb 07 '20 at 12:32--compress-algo none
on gpg to disable double compression. If you remove thez
option, then strictly speaking it is not tgz.gpg? – zypA13510 Sep 14 '20 at 09:04