npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

log4js2

v2.0.0-alpha1

Published

[![Build Status](https://travis-ci.org/anigenero/log4js2.svg?branch=master)](https://travis-ci.org/anigenero/log4js2) [![codecov](https://codecov.io/gh/anigenero/log4js2/branch/master/graph/badge.svg)](https://codecov.io/gh/anigenero/log4js2)

Downloads

47

Readme

Build Status codecov

log4js2

log4js2 is a fast and lightweight logging library that enables logging flexibility within JavaScript/TypeScript applications, similar to Apache's Log4j2 library. This library is designed to mirror Log4j2 functionality to the best ability that a JavaScript framework can. It can also serve as a drop-in replacement for log4js, since the namespace and functions are mostly similar.

Installing & Building

If you're building from source, simply run

> npm install
> npm run build

Or, you can install log4js2 from npm.

npm install log4js2 --save

Setup

Import log4js from the module:

import * as log4js from 'log4js2';

Usage

Logging works out-of-the-box, with no configuration, however, note that only error messages will display without specific configuration

const logger = log4js.getLogger('myLogger');
logger.error('This is a log');

Default layout will follow the pattern layout of %d [%p] %c - %m

03-24-2016 12:00:18,670 [ERROR] myLogger - This is a log

Configuration

Configure log4js using the configure() method. This must be the first thing you do. Otherwise, the first log you commit will not allow updates from this function

import {configure, LogLevel} from 'log4js2';

configure({
    
    layout : '%d [%p] %c %M:%line:%column - %m %ex',
    appenders : [{
        appender: 'Console'
    }],
    loggers : [{
        tag: 'App',
        logLevel : LogLevel.INFO
    }]
});

Virtual Console

ConsoleAppender utilizes a virtual console that "hijacks" console and inputs it into the log4js2 stream. Make sure log4js2 is loaded at the top of the page to ensure all logs are caught.

console.log('console log');

// outputs: 08-30-2018 12:38:00 [INFO] main - console log

Configuration Options

appenders

Type: Array.<AppenderConfiguration> Default: [{ appender: 'Console' }]

Sets the appenders for the given log configuration. Packaged with log4js2 is the console appender . You can develop your own appenders to add more functionality.

loggers

Type: Array.<LoggerConfiguration> Default: [{ logLevel : log4js.LogLevel.ERROR }]

Specifies the loggers for log4js2. The tag property specifies what logger the appender pertains to (see below), and the logLevel specifies the logging level (use log4js.LogLevel). You can also set a logger-specific layout using the patternLayout property.

configure({
    // ...
    loggers : [ {
	    logLevel : LogLevel.INFO
    }, {
		tag : 'debugLogger',
		logLevel : LogLevel.DEBUG
	}]
});

const logger = getLogger('myLogger');
const debugLogger = getLogger('debugLogger');

logger.debug('This message will not show');
debugLogger.debug('This message will show');

layout

Type: String Default: "%d [%p] %c - %m"

Sets the pattern layout for the logs. Keep in mind that some of the layout tags are relatively more expensive, and should only really be used in a development environment - such as %method and %line. Refer to the wiki for more information.

configure({
    patternLayout : '%d{MM-dd-yyyy HH:mm:ss} [%p] %c.%M:%line - %message',
    // ...
});

const logger = getLogger('myLogger');
logger.warn('This is a log {}', 'with parameters');
03-24-2016 16:04:41 [WARN] myLogger.anonymous:15 - This is a log with parameters
Note: Showing Method Names

In order to make the %method tag word, you must call from named function, like so:

function callerFunction() {
    log.info('This is within a name function');
}
03-24-2016 16:17:50,360 [INFO] myLogger.callerFunction:3 - This is within a name function

Otherwise, non-named functions will simply display an 'anonymous' placeholder:

let callerFunction = function () {
    log.info('This is an anonymous function');
};
03-24-2016 16:19:42,373 [INFO] myLogger.anonymous:3 - This is an anonymous function

Custom Appenders

You can output logs to a specific location or methodology using a custom appender. The @Appender decorator will handle registering the appender with log4js2.

@Appender({
    name: 'CustomAppender'
})
class MyAppender extends LogAppender {
    
    static get name() {
        return 'myappender';
    }
    
    append(logEvent: LogEvent) {
        
        const message: string = this.format(logEvent);
        // ... handle formatted result
        
    }
    
}

log4js

configure(configuration)

configuration Configuration

Sets the configuration. If no configuration is set before the first log, then the default configuration will be used. See configuration for options.

getLogger(logger)

logger? String [optional]

Gets a logger instance. If the logger is not set, the logger name will be pulled from the containing named instance it was created in (anonymous if unnamed).

setLogLevel(logLevel, logger)

logLevel LogLevel|Number, logger? String

Sets the log level for a specific logger, or all loggers (if logger is not set).