Logger
What?
Log json in an easily consumable and readable format.
Why?
You want visibility across both applications and their dependencies easily configured using environment variables, with messsage filtering/addressability based on both logger name and level in order avoid having to do this. Based on parts of bunyan and debug.
Example
// LOGGER="foo:bar*|error,ping:pong|info,-ping:pong:pork" node example.js
import Logger from '@hello10/logger';
let logger = new Logger({name: 'foo', something: 'wow'});
// this will be ignored because name fails to match and level too low
logger.info('hi');
// this will be ignored because name fails to match
logger.error('wow');
// Create a new child logger
logger = logger.child('bar');
// This will be shown
logger.error('oh no');
// Create another logger
let logger2 = new Logger({name: 'ping:pong', funk: 'derp'});
// This will be ignored because level is too low
logger2.debug('derp');
// This will be shown
logger2.error(new Error('dorf'));
logger2 = logger2.child('pork');
// This will be ignored because of the explicit exclude
logger2.fatal('bork');
Output
oh no { name: 'foo:bar',
something: 'wow',
message: 'oh no',
time: '2020-07-03T00:51:22.975Z' }
dorf { name: 'ping:pong',
funk: 'derp',
message: 'dorf',
error:
'{"stack":"Error: dorf ...<STACKTRACE HERE>","message":"dorf"}',
time: '2020-07-03T00:51:22.985Z' }
Todo
- Add configured payload serializers (i.e.
error
,request
,response
) - Allow configurability for fixed keys i.e .
time
,error
andmessage
so people can usets
,err
,msg
etc. - Allow for not logging the message as prefix