Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

cli-logger

Package Overview
Dependencies
Maintainers
1
Versions
47
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

cli-logger

Logger implementation for command line interfaces

  • 0.4.0
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
3.4K
increased by10.58%
Maintainers
1
Weekly downloads
 
Created
Source

Logger

Logger implementation for command line interfaces.

Install

npm install cli-logger

Test

npm test

Features

  • Seamless integration with ttycolor
  • JSON output compatible with bunyan
  • Bitwise log level support
  • 100% code coverage

Examples

Example programs are in the bin directory and there are many usage examples in the test suite.

Usage

Unless streams have been configured all log messages are written to process.stdout.

Normal

Normal mode uses log levels that correspond to the bunyan log levels and behaviour (log messages are written if they are greater than or equal to the configured log level):

var log = require('cli-logger');
var conf = {level: log.WARN};
logger = log(conf);
logger.warn('mock %s message', 'warn');
// this will not be logged as the log level is warn
logger.info('mock %s message', 'info');

Bitwise

Using bitwise log levels allows fine-grained control of how log messages are routed, to enable bitwise mode pass true as the second argument when creating the logger:

var log = require('cli-logger');
var conf = {level: log.BW_INFO|log.BW_FATAL};
logger = log(conf, true);
logger.info('mock %s message', 'info');

If you just want to disable one or two log levels it is more convenient to use the XOR operator:

var log = require('cli-logger');
var conf = {level: log.BW_ALL^log.BW_TRACE};
logger = log(conf, true);
logger.info('mock %s message', 'info');

Note that in normal mode you may use string log levels, such as 'trace', but in bitwise mode you may only use integer log levels.

Configuration

  • name: The name of the logger, default is basename(process.argv[1]).
  • json: Print log records as newline delimited JSON, default is false.
  • level: A default log level to use when a stream does not explicitly specify a log level, default is INFO.
  • src: A boolean that indicates that file name, line number and function name (when available) should be included in the log record, default is false.
  • stack: A boolean used in conjunction with src to also include an array of the stack trace caller information, default is false.
  • console: A boolean indicating that console methods should be used when writing log records, this enables the ttycolor integration, default is false.
  • serializers: Map of log record property names to serialization functions, default is null.
  • writers: Map of log level string names to console functions, default is null. Use this to customize the functions used when console is true, see writers.
  • streams: An array or object that configures the streams that log records are written to, by default if this property is not present a single stream is configured for process.stdout.

If you specify any unknown properties in the configuration then these are considered persistent fields and are added to every log record. This is a convenient way to add labels for sub-components to log records.

Streams

Configuring output streams is typically done using an array, but as a convenience an object may be specified to configure a single output stream:

var log = require('cli-logger');
var conf = {streams: {stream: process.stderr, level: log.WARN}}
var logger = log(conf);
// ...

File

You may configure a file stream by using the path stream property. For example, to log the INFO level and above to stdout and ERROR and above to a file:

var log = require('cli-logger');
var conf = {streams: [
  {
    stream: process.stdout,
    level: log.INFO
  },
  {
    path: 'log/errors.log',
    level: log.ERROR
  }
]};
var logger = log(conf);
// ...

When creating file streams the default flags used is a you may specify the flags property to change this behaviour:

var log = require('cli-logger');
var conf = {streams: [
  {
    path: 'log/errors.log',
    flags: 'ax',
    level: log.ERROR
  }
]};
var logger = log(conf);
// ...

The encoding and mode options supported by fs.createWriteStream are also respected if present.

License

Everything is MIT. Read the license if you feel inclined.

Keywords

FAQs

Package last updated on 17 Feb 2014

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc