/ilog

light-weight, smart and pure log module

Primary LanguageJavaScriptMIT LicenseMIT

ilog

light-weight, smart and pure log module.

NPM version Build Status Downloads

Installation

npm install ilog

API

const ilog = require('ilog')

or

import { ilog } from 'ilog'

ilog([arguments]) [no level]

ilog.log([arguments]) [no level]

Format one or more arguments to string and write it to ilog._stdout.

Example:

ilog('hello', {a: 1, b: 2}, [1, 2, 3])
// Output: hello { a: 1, b: 2 } [ 1, 2, 3 ]

Source Code:

function ilog () {
  if (arguments.length) {
    ilog._stdout.write(ilog._assembleLog(util.format.apply(null, arguments)))
  }
}

ilog.emerg(error) [level 0]

ilog.alert(error) [level 1]

ilog.crit(error) [level 2]

ilog.error(error) [level 3]

ilog.warning(error) [level 4]

Format the error object to error string and write it to ilog._stderr.

Example:

ilog.error()
// Nothing

ilog.error(null)
// Nothing

ilog.level = 3
ilog.error(new Error('test error'))
// Output: [2015-11-02T14:07:52.368Z] ERROR {"message":"test error","name":"Error","stack":"Error: test error\n ..."}

ilog.error('test error 2')
// Output: [2015-11-02T14:07:52.368Z] ERROR {"name":"Error","message":"test error 2"}

ilog.warning(new Error('test warning'))
// Nothing, because log level is lower than warning level[level 4]

Source Code:

// ilog.emerg, ilog.alert, ilog.crit, ilog.error, ilog.warning
levels.slice(0, 5).map(function (level, index) {
  ilog[level.toLowerCase()] = function (error) {
    if (error != null && index <= ilog.level) {
      error = ilog._stringify(ilog._errorify(error))
      ilog._stderr.write(ilog._assembleLog(error, level, ilog._time(new Date())))
    }
  }
})

ilog.notice(message) [level 5]

ilog.info(message) [level 6]

Format the message object to string and write it to ilog._stdout.

Example:

ilog.info()
// Nothing

ilog.info(null)
// Nothing

ilog.notice({a: 1, b: 2})
// Output: [2015-11-02T14:11:44.588Z] NOTICE {"a":1,"b":2}

ilog.info('{a: 1, b: 2}')
// [2015-11-05T07:21:36.916Z] INFO "{a: 1, b: 2}"

Source Code:

// ilog.notice, ilog.info
levels.slice(5, 7).map(function (level, index) {
  index += 5
  ilog[level.toLowerCase()] = function (message) {
    if (message != null && index <= ilog.level) {
      message = ilog._stringify(message)
      ilog._stdout.write(ilog._assembleLog(message, level, ilog._time(new Date())))
    }
  }
})

ilog.debug(message[, message, ...]) [level 7]

Format one or more arguments to string and write it to ilog._stdout. if only one argument, use JSON.stringify, else use util.format

Example:

ilog.debug({a: 1, b: 2})
// [2015-11-05T07:24:55.551Z] DEBUG {"a":1,"b":2}

ilog.debug('{a: 1, b: 2}')
// [2015-11-05T07:25:20.103Z] DEBUG "{a: 1, b: 2}"

ilog.debug(null, {a: 1, b: 2}, null, [1, 2, 3])
// [2015-11-05T07:26:03.119Z] DEBUG null { a: 1, b: 2 } null [ 1, 2, 3 ]

ilog.debug('Hello, %s', [1, 2, 3], {a: 1, b: 2})
// [2015-11-05T07:27:02.020Z] DEBUG Hello, 1,2,3 { a: 1, b: 2 }

Source Code:

// ilog.notice, ilog.info
ilog.debug = function () {
  if (arguments.length && ilog.level >= 7) {
    let messages = arguments.length === 1
      ? ilog._stringify(arguments[0]) : util.format.apply(null, arguments)
    ilog._stdout.write(ilog._assembleLog(messages, 'DEBUG', ilog._time(new Date())))
  }
}

ilog.auto(error[, message]) [level error, info, debug]

A error (error instanceof Error) will log to ilog.error. A message will log to ilog.info. One more message will log to ilog.debug.

Example:

ilog.auto(new Error('some error'), {a: 1, b: 2})
// Output: [2015-11-02T14:13:24.409Z] ERROR {"message":"some error","name":"Error","stack":"Error: some error\n ..."}
ilog.auto(null, {a: 1, b: 2})
// Output: [2015-11-02T14:14:18.483Z] INFO {"a":1,"b":2}
ilog.auto({a: 1, b: 2})
// Output: [2015-11-02T14:14:53.412Z] INFO {"a":1,"b":2}
ilog.auto(null, {a: 1, b: 2}, [1, 2, 3])
// Output: [2015-11-02T14:15:16.933Z] DEBUG { a: 1, b: 2 } [ 1, 2, 3 ]
ilog.auto({a: 1, b: 2}, [1, 2, 3])
// Output: [2015-11-02T14:15:41.398Z] DEBUG { a: 1, b: 2 } [ 1, 2, 3 ]

Source Code:

ilog.auto = function (error) {
  if (error instanceof Error) return ilog.error(error)
  let args = slice.call(arguments, +(error == null))
  if (args.length === 1) ilog.info(args[0])
  else if (args.length > 1) ilog.debug.apply(null, args)
}

ilog.setLevel(level)

Set the log level, any value in ilog.levels will be fine, default to DEBUG

ilog.levels

All log levels: ['EMERG', 'ALERT', 'CRIT', 'ERR', 'WARNING', 'NOTICE', 'INFO', 'DEBUG'].

ilog._stdout

Set the log standard out stream, default to process.stdout

ilog._stderr

Set the log error out stream, default to process.stderr

ilog._time

Set the time format function, default to:

ilog._time = function (time) {
  return '[' + time.toISOString() + ']'
}

ilog._stringify

Set the object format function, default to:

ilog._stringify = function (obj) {
  try {
    return JSON.stringify(obj)
  } catch (e) {
    return util.format(obj)
  }
}

ilog._assembleLog

Set the log format function, default to:

ilog._assembleLog = function (log, level, time) {
  log = log + '\n'
  if (level) log = level + ' ' + log
  if (time) log = time + ' ' + log
  return log
}

ilog._errorify

Set the error object format function, default to:

ilog._errorify = function (error) {
  return new Errorify(error)
}