easylog v0.1.1
easylog
A wrapper around winston to simplify configuration and log beautifully.
Table of Contents
- Motivation
- Installation
- Usage
- Configuration * Log the Logging
- API node_env easylog_level root_dir_files cwd logdir root_label override_winston injected_deps injected_deps.winston package_json * config_file_candidates
Motivation
Winston is an excellent logging library that consists of easy to understand and easy to hack components. Getting started is relatively painless and there's a plethora of transports for various endpoints like files, console, databases, cloud services...
What winston lacks is the possiblity to configure the components without a lot
of code. I found myself copy and pasting a wrapper class that sets up nice
console formatting, sane log file locations, timer/profiling etc. I wanted a
library that would make these customizations easy and whose behavior could be
driven by one or more configuration files rather than code. easylog is that
library.
Installation
npm install --save easylogUsage
The module generates a default logging container and exports a constructor for child loggers.
The best way to use it is to pass it the current module. This way the logger will know for which file it logs events:
/* myFile.js */
var log = require('easylog')(module)
log.info("Life, Universe &c?", {'answer', 42});
Configuration
easylog can be configured by a JSON object that conforms to a JSON schema file.
By default, the configuration will be searched, in order of preference:
- A file easylog-development.jsonoreasylog-production.json, depending on your$NODE_ENV
- A file easylog.json
- An easylogentry in thepackage.json
The full schema is comprehensive but you can specify only fragments of the configuraiton in the mentioned locations, the default config will be computed on the fly, see ./doc/default-config.json for a static copy of the default configuration file.
Log Patterns
easylog expects the log messages described as
log-pattern macros. Please refer to the
documentation of pre-defined
macros there.
The default pattern for the log entry is:
'[%levelColor(%pad{-5}(%LEVEL))] ' +
'%levelColor(%date)' +
' |%label| ' +
'%message' +
'%meta'The default pattern for the label is:
%pkg{name}' +
'%@{sep}(:)' +
'%@{name}(%path{%name})' +
'%?(%config{child})(' +
  '%@{sep}(#)' +
  '%@{child}(%config{child})' +
')'Log the Logging
It can be tedious to debug why logging isn't working the way it's supposed to.
You'd find yourself falling back to console.log et al to log the problems
that prevent logging. To prevent you from this particular type of yak-shaving,
easylog by default logs its own startup and every reload of configuration
with level DEBUG.
API
node_env
The environemnt, i.e. development or production. This overrides the
NODE_ENV environment variable and defaults to development.
easylog_level
The log level of easylog itself. For debugging purposes, this is set to debug
by defualt. See Log the Logging.
root_dir_files
cwd
logdir
root_label
The label of the root logger, by default ROOT.
override_winston
If set, easylog will override the logger singleton that is returned when you
require('winston'). This has the advantage that it will also enable your
logging configuration for other logger that use winston. If set to true (the
default) then winston.log will be overridden with easylog's root logger's
log method.