paragonie / monolog-quill
Monolog handler for writing to a Chronicle instance
Installs: 7 143
Dependents: 1
Suggesters: 0
Security: 0
Stars: 3
Watchers: 1
Forks: 1
Open Issues: 0
pkg:composer/paragonie/monolog-quill
Requires
- php: ^7.1|^8
- monolog/monolog: ^1
- paragonie/quill: ^0.6|^1
Requires (Dev)
- vimeo/psalm: ^3|^4
This package is auto-updated.
Last update: 2025-10-08 20:59:48 UTC
README
Requires PHP 7.1 or newer.
Want to use Monolog to write security events to a Chronicle?
This library uses Quill to transcribe log messages to a Chronicle instance. This can be a public or private Chronicle.
Installation
composer require paragonie/monolog-quill
Usage
<?php use Monolog\Logger; use ParagonIE\MonologQuill\QuillHandler; use ParagonIE\Quill\Quill; use ParagonIE\ConstantTime\Base64UrlSafe; use ParagonIE\Sapient\CryptographyKeys\{ SigningSecretKey, SigningPublicKey }; // Create a Quill for writing data to the Chronicle instance $quill = (new Quill()) ->setChronicleURL('https://chronicle-public-test.paragonie.com/chronicle') ->setServerPublicKey( new SigningPublicKey( Base64UrlSafe::decode('3BK4hOYTWJbLV5QdqS-DFKEYOMKd-G5M9BvfbqG1ICI=') ) ) ->setClientID('**Your Client ID provided by the Chronicle here**') ->setClientSecretKey( new SigningSecretKey('/* Loaded from the filesystem or something. */') ); // Push the Handler to Monolog $log = new Logger('security'); $handler = (new QuillHandler($quill, Logger::ALERT)); $log->pushHandler($handler); // Now security events will be logged in your Chronicle $log->alert( 'User bob logged in at ' . ((new DateTime())->format(\DateTime::ATOM)) );
Encrypted Message Logging
Simply pass an instance of SealingPublicKey or SharedEncryptionKey to the
handler, via the setEncryptionKey() method, to encrypt log messages.
$handler->setEncryptionKey( new SealingPublicKey('/* Loaded from the filesystem or something. */') );
Encrypted Message Logging - Complete Example
<?php use Monolog\Logger; use ParagonIE\MonologQuill\QuillHandler; use ParagonIE\Quill\Quill; use ParagonIE\ConstantTime\Base64UrlSafe; use ParagonIE\Sapient\CryptographyKeys\{ SealingPublicKey, SigningSecretKey, SigningPublicKey }; // Create a Quill for writing data to the Chronicle instance $quill = (new Quill()) ->setChronicleURL('https://chronicle-public-test.paragonie.com/chronicle') ->setServerPublicKey( new SigningPublicKey( Base64UrlSafe::decode('3BK4hOYTWJbLV5QdqS-DFKEYOMKd-G5M9BvfbqG1ICI=') ) ) ->setClientID('**Your Client ID provided by the Chronicle here**') ->setClientSecretKey( new SigningSecretKey('/* Loaded from the filesystem or something. */') ); // Push the Handler to Monolog $log = new Logger('security'); $handler = (new QuillHandler($quill, Logger::ALERT)); // Set this to an instance of SealingPublicKey or SharedEncryptionKey: $handler->setEncryptionKey( new SealingPublicKey('/* Loaded from the filesystem or something. */') ); $log->pushHandler($handler); // Now security events will be logged in your Chronicle $log->alert( 'User bob logged in at ' . ((new DateTime())->format(\DateTime::ATOM)) );