Overview
A newly released zato-enclog package lets one store Python logs in an encrypted form making it a great fit for environments that cannot keep clear text form of data such as PII (Personally Identifiable Information) in HIPAA-compliant applications.
The package comes with command-line tools to decrypt files, including a command that mimics tail -f functionality to watch decrypted logs as they grow.
Usage examples from Zato ..
fromloggingimportgetLoggerfromzato.server.serviceimportServiceenclog=getLogger('enclog')classMyService(Service):defhandle(self):enclog.info('This will be encrypted')
.. and pure Python:
importloggingfromzato.enclogimportEncryptedLogFormatter,genkeylevel=logging.INFOformat='%(levelname)s - %(message)s'key=genkey()formatter=EncryptedLogFormatter(key,format)handler=logging.StreamHandler()handler.setFormatter(formatter)logger=logging.getLogger('')logger.addHandler(handler)logger.setLevel(level)logger.info('This will be encrypted')
CLI screenshots
Key generation:
data:image/s3,"s3://crabby-images/0895e/0895e4eb1cb0147a4245cc477a16fe81155472f7" alt="Screenshot"
Demo:
data:image/s3,"s3://crabby-images/58370/58370b894ff4e265c812658b663c1707c037e893" alt="Screenshot"
Using tailf -f vs. enclog tailf. The former will show logs in encrypted form whereas the latter will display them decrypted.
data:image/s3,"s3://crabby-images/447bb/447bb76531b1073ea14ef934297963c14a833aa2" alt="Screenshot"
data:image/s3,"s3://crabby-images/c258c/c258caf0d47075f26e480e9c0c369f0da2c5c66c" alt="Screenshot"
Learn more
More information can be found at https://zato.io/docs/progguide/enclog/index.html