Palin is a beautiful Bristol formatter for development logging.
Install with npm install palin --save
Please remember to star ⭐️ this repo!
const log = require('bristol');
const palin = require('palin');
log.addTarget('console').withFormatter(palin);
log.info("We're up and running!");
One of Palin's main features is the ability to log whatever you throw at it. For example, you may want to log two Errors and other associated data.
const err1 = new Error('Error 1');
const err2 = new Error('Error 2');
log.error('oh, snap!', err1, err2, [ 'thing', 123 ])
Produces:
23:00:46:035 ERROR oh, snap! (test/integration.js:16)
→ { '0': 'thing', '1': 123 }
→ Error: Error 1
→ at Object.<anonymous> (/Users/Mark/projects/palin/test/integration.js:14:12)
→ at Module._compile (module.js:425:26)
→ at Object.Module._extensions..js (module.js:432:10)
→ at Module.load (module.js:356:32)
→ at Function.Module._load (module.js:313:12)
→ at Function.Module.runMain (module.js:457:10)
→ at startup (node.js:138:18)
→ at node.js:974:3
→ Error: Error 2
→ at Object.<anonymous> (/Users/Mark/projects/palin/test/integration.js:15:12)
→ at Module._compile (module.js:425:26)
→ at Object.Module._extensions..js (module.js:432:10)
→ at Module.load (module.js:356:32)
→ at Function.Module._load (module.js:313:12)
→ at Function.Module.runMain (module.js:457:10)
→ at startup (node.js:138:18)
→ at node.js:974:3
As per the Bristol logger API, you may specify options for formatters.
log
.addTarget('console')
.withFormatter(palin, {
// formatter options go here
});
Palin logs the file path where log messages originate from. Usually these paths are needlessly long. The rootFolderName
option allows you to specify a string prefix of where to shorten the path.
log
.addTarget('console')
.withFormatter(palin, {
rootFolderName: 'MyProject'
});
// produces log messages like:
// 08:54:25:892 LOG hello (controller/hello.js:9)
// instead of:
// 08:54:25:892 LOG hello (/Users/Mark/projects/MyProject/controller/hello.js:9)
Palin logs timestamps in the "HH:mm:ss:SSS" format by default. You may want your timestamps to be different. This can be controlled with the timestamp
option.
You can disable timestamps:
log
.addTarget('console')
.withFormatter(palin, {
timestamp: false
});
You can also provide your own timestamp function (shown with Moment.js):
var moment = require('moment'); // using moment.js
log
.addTarget('console')
.withFormatter(palin, {
timestamp: function(date) {
return moment(date).format(); // produces moment's default format
}
});
Any information that is attached to a log message is indented and included on the next line. The indentation format can be controlled with the indent
option.
log
.addTarget('console')
.withFormatter(palin, {
indent: '\n ⇒ '
});
Palin formats objects using the built-in require('util').inspect()
. Use the objectDepth
option to increase depth of each object printed.
log
.addTarget('console')
.withFormatter(palin, {
objectDepth: 5 // instead of inspect's default level ( usually 2 )
});
Hide the source line/file of messages. Useful for logging purely informational messages.
log
.addTarget('console')
.withFormatter(palin, {
souce: false
});
Palin supports the concept of a "scope", which is a way of labeling groups of log messages. To use this, simply add an object with the key scope
to the list of arguments. The color of the scope variable will be maintained for the lifetime of the the Bristol logger.
log.info('hello world', { scope: 'welcome' });
// produces:
// 08:54:25:892 INFO controller welcome (controller/hello.js:9)