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

app-log

v0.1.3

Published

Application json logger, part of app-helpers project

Downloads

5

Readme

app-log

Part of app helpers project.

Log all the stuff in json for slick analyzing and processing.

Installation

npm install app-log

Usage

var log = require('app-log');

function createUser() {
	var user = { email: '[email protected]', name: 'john' };
	log.info('New user created with email', user.email, user);
}

createUser();

// Concat all scalar values (strings, numbers) with spaces,
// and aggregate all objects to `data` property

// {
//   "functionName": "createUser",
//   "filePath": "/Users/boo1ean/src/app-log/stuff.js",
//   "lineNumber": 6,
//   "level": "info",
//   "time": "2014-11-29T14:01:23.253Z",
//   "message": "New user created with email [email protected]",
//   "data": {
//     "email": "[email protected]",
//     "name": "john"
//   }
// }

Available log levels

var log = require('app-log');

/**
 * Detailed debug information.
 */
log.debug('Transaction completed', transaction),

/**
 * Interesting events.
 *
 * Example: User logs in, SQL logs.
 */
log.info('User registered', user);

/**
 * Normal but significant events.
 */
log.notice('Whatever..');

/**
 * Exceptional occurrences that are not errors.
 *
 * Example: Use of deprecated APIs, poor use of an API, undesirable things
 * that are not necessarily wrong.
 */
log.warning('User permissions denied', context);

/**
 * Runtime errors that do not require immediate action but should typically
 * be logged and monitored.
 */
log.error('Unavailable product type requested');

/**
 * Critical conditions.
 *
 * Example: Application component unavailable, unexpected exception.
 */
alert.critical('NO!!');

/**
 * Action must be taken immediately.
 *
 * Example: Entire website down, database unavailable, etc. This should
 * trigger the SMS alerts and wake you up.
 */
log.alert('FIRE!!!');


/**
 * System is unusable.
 */
log.emergency('we all dead');

Events

You can attach event handlers on log levels to do something critically useful:

log.on('error', function notifyEveryone (message) {
	mailer.sendErrorToEveryone(message);
});

Pretty printing json

By default log json object is pretty-printed. To disable pretty-printing and get single-line json objects:

log.disablePrettyPrint();

// To enable back

log.enablePrettyPrint();

Automatic catching and logging of uncaught exceptions

log.catchUncaughtExceptions();

throw new Error('hey-hop!');

// {
//   "functionName": null,
//   "filePath": "/Users/boo1ean/src/app-log/index.js",
//   "lineNumber": 130,
//   "level": "alert",
//   "time": "2014-11-29T13:26:16.336Z",
//   "message": "Uncaught exception",
//   "data": {
//     "message": "Error: hey-hop!",
//     "stacktrace": [
//       "at Object.<anonymous> (/Users/boo1ean/src/app-log/stuff.js:15:7)",
//       "at Module._compile (module.js:456:26)",
//       "at Object.Module._extensions..js (module.js:474:10)",
//       "at Module.load (module.js:356:32)",
//       "at Function.Module._load (module.js:312:12)",
//       "at Function.Module.runMain (module.js:497:10)",
//       "at startup (node.js:119:16)",
//       "at node.js:901:3"
//     ]
//   }
// }

Work with logs

After you have bunch of log json messages you can search through it using astonishing json cli util.

Here is some usefule examples:

# Find all warning-level messages
cat api.out.log | json -g | json -c 'this.level === "warning"'

# Get number of error-level log messages
cat api.out.log | json -g | json -c 'this.level === "error"' | json length

License

MIT