Universal Pluggable Logging Utility

6.3.2 · active · verified Sun Apr 19

The `log` package provides a universal and pluggable logging utility designed for JavaScript applications, currently stable at version 6.3.2. It focuses on being configurable, environment, and presentation agnostic, differentiating itself by not handling output directly but emitting events for external 'writers' (e.g., `log-node` for Node.js environments). Releases are made as needed, with several maintenance and minor feature updates occurring within the last few years. Key features include syslog-compatible log levels (debug, info, notice, warning, error), `debug`-style namespacing for granular control, and support for printf-like message formatting with various placeholders (e.g., `%s`, `%d`, `%j`, `%o`). This design allows developers to write application logs once and integrate different output mechanisms without changing core logging logic. It does not expose `critical`, `alert`, or `emergency` levels, expecting these to be handled as typical exceptions. A crucial differentiator is its modular approach, requiring an explicit 'writer' package to actually emit log messages, making it highly adaptable to various runtime environments and output formats.

Common errors

Warnings

Install

Imports

Quickstart

Demonstrates initializing the log system with `log-node`, creating default and namespaced loggers, logging at different levels, and dynamic enabling/disabling of log output.

import log from 'log';
import 'log-node'; // Initialize the Node.js writer for log output

// Default logger (writes at 'info' level by default)
log.info("Application started: %s", new Date().toISOString());

// Get a namespaced logger (similar to 'debug' library style)
const myLibLog = log.get('my-lib');
myLibLog.info("Initializing 'my-lib' module with config: %j", { debug: true, port: 3000 });

// Namespaces can be nested
const myLibFuncLog = myLibLog.get('func');
myLibFuncLog.debug("Executing critical function 'processData' for ID: %d", 12345);

// Log an 'error' level message
myLibFuncLog.error("Failed to process data due to an unexpected error. Details: %s", "Invalid input");

// Dynamically disable/enable logging for a specific level
const { restore } = myLibFuncLog.debug.disable();
myLibFuncLog.debug("This debug message should not be logged.");
restore(); // Restore previous visibility state
myLibFuncLog.debug("This debug message should now be logged.");

view raw JSON →