rscryutil - Man Page
Manage Encrypted Log Files
Synopsis
rscryutil [OPTIONS] [FILE] ...
Description
This tool performs various operations on encrypted log files. Most importantly, it provides the ability to decrypt them.
Options
- -d, --decrypt
Select decryption mode. This is the default mode.
- -W,--write-keyfile <file>
Utility function to write a key to a keyfile. The key can be obtained via any method.
- -l,--lib <library>
Select the crypto library to be used. Either "ossl" or "gcry". Defaults to "gcry" or whatever is currently available.
- -v, --verbose
Select verbose mode.
- -f, --force
Forces operations that otherwise would fail.
- -k,--keyfile <file>
Reads the key from <file>. File _must_ contain the key, only, no headers or other meta information. Keyfiles can be generated via the --write-keyfile option.
- -p,--key-program <path-to-program>
In this mode, the key is provided by a so-called "key program". This program is executed and must return the key to (as well as some meta information) via stdout. The core idea of key programs is that using this interface the user can implement as complex (and secure) method to obtain keys as desired, all without the need to make modifications to rsyslog.
- -K,--key <KEY>
TESTING AID, NOT FOR PRODUCTION USE. This uses the KEY specified on the command line. This is the actual key, and as such this mode is highly insecure. However, it can be useful for intial testing steps. This option may be removed in the future.
- -a,--algo <algo>
Sets the encryption algorightm (cipher) to be used. Refer to the list of supported algorithms below for the "gcry" library. The default algorithm for "gcry" is "AES128". For the "ossl" library, both the algorithm and mode are specified using this option, with "AES-128-CBC" as the default.
- -m,--mode <mode>
Sets the ciphermode to be used. See below for supported modes. The default is "CBC". In case of "ossl" library, this options is ignored.
- -r,--generate-random-key <bytes>
Generates a random key of length <bytes>. This option is meant to be used together with --write-keyfile (and it is hard to envision any other valid use for it).
Operation Modes
The operation mode specifies what exactly the tool does with the provided files. The default operation mode is "dump", but this may change in the future. Thus, it is recommended to always set the operations mode explicitely. If multiple operations mode are set on the command line, results are unpredictable.
decrypt
The provided log files are decrypted. Note that the .encinfo side files must exist and be accessible in order for decryption to to work.
write-keyfile
In this mode no log files are processed; thus it is an error to specify any on the command line. The specified keyfile is written. The key itself is obtained via the usual key commands. If --keyfile is used, that file is effectively copied.
For security reasons, existing key files are _not_ overwritten. To permit this, specify the --force option. When doing so, keep in mind that lost keys cannot be recovered and data encrypted with them may also be considered lost.
Keyfiles are always created with 0400 permission, that is read access for only the user. An exception is when an existing file is overwritten via the --force option, in which case the former permissions still apply.
Exit Codes
The command returns an exit code of 0 if everything went fine, and some other code in case of failures.
Supported Algorithms
In case of "ossl", see "ALGORITHM FETCHING" in crypto(7) for further information. In case of "gcry" we basically support what libgcrypt supports and that is:
3DES CAST5 BLOWFISH AES128 AES192 AES256 TWOFISH TWOFISH128 ARCFOUR DES SERPENT128 SERPENT192 SERPENT256 RFC2268_40 SEED CAMELLIA128 CAMELLIA192 CAMELLIA256
Supported Cipher Modes
In case of "gcry", we basically support what libgcrypt supports. This is:
ECB CFB CBC STREAM OFB CTR AESWRAP
Examples
rscryutil logfile
Decrypts "logfile" and sends data to stdout.
rscryutil -k keyfile -l ossl -a AES-256-CBC encryptedfile
Decrypts encryptedfile using ossl library with AES256 algorithm and CBC mode
rscryutil -k keyfile -l gcry -a AES256 -m CBC encryptedfile
Decrypts encryptedfile using gcry library with AES256 algorithm and CBC mode
rscryutil --generate-random-key 16 --keyfile /some/secured/path/keyfile
Generates random key and stores it in the specified keyfile.
Log Signatures
Encrypted log files can be used together with signing. To verify such a file, it must be decrypted first, and the verification tool rsgtutil(1) must be run on the decrypted file.
Security Considerations
Specifying keys directly on the command line (--key option) is very insecure and should not be done, except for testing purposes with test keys. Even then it is recommended to use keyfiles, which are also easy to handle during testing. Keep in mind that command history is usally be kept by bash and can also easily be monitored.
Local keyfiles are also a security risk. At a minimum, they should be used with very restrictive file permissions. For this reason, the rscryutil tool creates them with read permissions for the user, only, no matter what umask is set to.
When selecting cipher algorithms and modes, care needs to be taken. The defaults should be reasonable safe to use, but this tends to change over time. Keep up with the most current crypto recommendations.
See Also
rsgtutil(1), rsyslogd(8)
Copyright
This page is part of the rsyslog project, and is available under LGPLv2.
Author
Rainer Gerhards <rgerhards@adiscon.com>