log-ew

winston logger wrapper with added inspection functions

Usage no npm install needed!

<script type="module">
  import logEw from 'https://cdn.skypack.dev/log-ew';
</script>

README

Winston logger wrapper with added inspection functions

Installation

$ npm install --save log-ew

Prerequisites

See winston README: https://github.com/winstonjs/winston

Usage

// require default logger (created with default options)
const log = require('log-ew');

// override default options
const log = require('log-ew')({ logger: console });

// making a logger available to other files
const log = require('log-ew');
log.consoleLogger = log({ logger: console });

Options

logger

Defaults to require('winston')

const log = require('log-ew');

// the log.loggers function comes from winston
log.loggers.add('logger1', {
    console: {
        colorize: true,
        label: 'logger 1',
    },
});
var logger1 = log({
    // logger.log must be a function(level, arguments…)
    logger: log.loggers.get('logger1'),
});

Logging

const log = require('log-ew');

// every property of winston is available by default
log.info('version', log.version);

// inspect arguments in more detail, this can be useful for errors
log.inspect.log(level, arguments…);
log.inspect.error(arguments…);
log.inspect.warn(arguments…);
log.inspect.info(arguments…);
log.inspect.verbose(arguments…);
log.inspect.debug(arguments…);
log.inspect.silly(arguments…);

// logging objects
log.inspect.fields({ firstName: 'John', lastName: 'Smith' }, ['firstName']); // info
log.inspect.fields({ firstName: 'John', lastName: 'Smith' }, ['firstName'], 'debug');
log.inspect.fields({ firstName: 'John', lastName: 'Smith' }, ['firstName'], { level: 'debug' });
log.inspect.hash('Hello', { firstName: 'John', lastName: 'Smith' }); // info
log.inspect.hash('Hello', { firstName: 'John', lastName: 'Smith' }, 'debug');

Running tests

$ npm install
$ npm test