logcabin

Provides flexible logging for Node.JS applications inspired by Zend Framework's Zend_Log package.

Usage no npm install needed!

<script type="module">
  import logcabin from 'https://cdn.skypack.dev/logcabin';
</script>

README

Log Cabin

Provides flexible logging for Node.JS applications inspired by Zend Framework's Zend_Log package.

Install

npm install logcabin

Usage

In an Express-based application you might create something like lib/log.js


var 
  logcabin = require('logcabin'),
  Log = new logcabin.Log(),
  logglyOptions = {
    token: 'my-very-long-token',
    subdomain: 'mysubdomain',
    tags: [], 
    auth: {
      username: "myusername",
      password: "myP@ssw0rd"
    },
    json:true
  }
;

switch (process.env.NODE_ENV) {
  
  // on my local machine just console everything
  case 'local': 
    Log.addWriter('console', new logcabin.writers.Console()); 
    break;

  // on development and production log to loggly
  case 'development':
  case 'production':
    logglyOptions.tags.push(process.env.NODE_ENV);
    var loggly = new logcabin.writers.Loggly(logglyOptions, ['warn', 'error', 'notfound', 'unauthorized']);
    Log.addWriter('loggly', loggly);
}

module.exports = Log;

Then in your application you could do something like this:


// be sure to point to the right path to where you saved log.js
var log = require('lib/log');

// Using a Mongoose model
MyModel.find({ name: 'john', age: { $gte: 18 }}, function (err, docs) {
  if (err !== undefined) {
    log.error(err);
  }
});