[6a3a178] | 1 | var util = require('util')
|
---|
| 2 | var _ = require('lodash')
|
---|
| 3 |
|
---|
| 4 | var loggerInstance
|
---|
| 5 |
|
---|
| 6 | var defaultProvider = {
|
---|
| 7 | log: console.log,
|
---|
| 8 | debug: console.log, // use .log(); since console does not have .debug()
|
---|
| 9 | info: console.info,
|
---|
| 10 | warn: console.warn,
|
---|
| 11 | error: console.error
|
---|
| 12 | }
|
---|
| 13 |
|
---|
| 14 | // log level 'weight'
|
---|
| 15 | var LEVELS = {
|
---|
| 16 | debug: 10,
|
---|
| 17 | info: 20,
|
---|
| 18 | warn: 30,
|
---|
| 19 | error: 50,
|
---|
| 20 | silent: 80
|
---|
| 21 | }
|
---|
| 22 |
|
---|
| 23 | module.exports = {
|
---|
| 24 | // singleton
|
---|
| 25 | getInstance: function() {
|
---|
| 26 | if (!loggerInstance) {
|
---|
| 27 | loggerInstance = new Logger()
|
---|
| 28 | }
|
---|
| 29 |
|
---|
| 30 | return loggerInstance
|
---|
| 31 | },
|
---|
| 32 | getArrow: getArrow
|
---|
| 33 | }
|
---|
| 34 |
|
---|
| 35 | function Logger() {
|
---|
| 36 | var logLevel
|
---|
| 37 | var provider
|
---|
| 38 |
|
---|
| 39 | var api = {
|
---|
| 40 | log: log,
|
---|
| 41 | debug: debug,
|
---|
| 42 | info: info,
|
---|
| 43 | warn: warn,
|
---|
| 44 | error: error,
|
---|
| 45 | setLevel: function(v) {
|
---|
| 46 | if (isValidLevel(v)) {
|
---|
| 47 | logLevel = v
|
---|
| 48 | }
|
---|
| 49 | },
|
---|
| 50 | setProvider: function(fn) {
|
---|
| 51 | if (fn && isValidProvider(fn)) {
|
---|
| 52 | provider = fn(defaultProvider)
|
---|
| 53 | }
|
---|
| 54 | }
|
---|
| 55 | }
|
---|
| 56 |
|
---|
| 57 | init()
|
---|
| 58 |
|
---|
| 59 | return api
|
---|
| 60 |
|
---|
| 61 | function init() {
|
---|
| 62 | api.setLevel('info')
|
---|
| 63 | api.setProvider(function() {
|
---|
| 64 | return defaultProvider
|
---|
| 65 | })
|
---|
| 66 | }
|
---|
| 67 |
|
---|
| 68 | // log will log messages, regardless of logLevels
|
---|
| 69 | function log() {
|
---|
| 70 | provider.log(_interpolate.apply(null, arguments))
|
---|
| 71 | }
|
---|
| 72 |
|
---|
| 73 | function debug() {
|
---|
| 74 | if (_showLevel('debug')) {
|
---|
| 75 | provider.debug(_interpolate.apply(null, arguments))
|
---|
| 76 | }
|
---|
| 77 | }
|
---|
| 78 |
|
---|
| 79 | function info() {
|
---|
| 80 | if (_showLevel('info')) {
|
---|
| 81 | provider.info(_interpolate.apply(null, arguments))
|
---|
| 82 | }
|
---|
| 83 | }
|
---|
| 84 |
|
---|
| 85 | function warn() {
|
---|
| 86 | if (_showLevel('warn')) {
|
---|
| 87 | provider.warn(_interpolate.apply(null, arguments))
|
---|
| 88 | }
|
---|
| 89 | }
|
---|
| 90 |
|
---|
| 91 | function error() {
|
---|
| 92 | if (_showLevel('error')) {
|
---|
| 93 | provider.error(_interpolate.apply(null, arguments))
|
---|
| 94 | }
|
---|
| 95 | }
|
---|
| 96 |
|
---|
| 97 | /**
|
---|
| 98 | * Decide to log or not to log, based on the log levels 'weight'
|
---|
| 99 | * @param {String} showLevel [debug, info, warn, error, silent]
|
---|
| 100 | * @return {Boolean}
|
---|
| 101 | */
|
---|
| 102 | function _showLevel(showLevel) {
|
---|
| 103 | var result = false
|
---|
| 104 | var currentLogLevel = LEVELS[logLevel]
|
---|
| 105 |
|
---|
| 106 | if (currentLogLevel && currentLogLevel <= LEVELS[showLevel]) {
|
---|
| 107 | result = true
|
---|
| 108 | }
|
---|
| 109 |
|
---|
| 110 | return result
|
---|
| 111 | }
|
---|
| 112 |
|
---|
| 113 | // make sure logged messages and its data are return interpolated
|
---|
| 114 | // make it possible for additional log data, such date/time or custom prefix.
|
---|
| 115 | function _interpolate() {
|
---|
| 116 | var fn = _.spread(util.format)
|
---|
| 117 | var result = fn(_.slice(arguments))
|
---|
| 118 |
|
---|
| 119 | return result
|
---|
| 120 | }
|
---|
| 121 |
|
---|
| 122 | function isValidProvider(fnProvider) {
|
---|
| 123 | var result = true
|
---|
| 124 |
|
---|
| 125 | if (fnProvider && !_.isFunction(fnProvider)) {
|
---|
| 126 | throw new Error('[HPM] Log provider config error. Expecting a function.')
|
---|
| 127 | }
|
---|
| 128 |
|
---|
| 129 | return result
|
---|
| 130 | }
|
---|
| 131 |
|
---|
| 132 | function isValidLevel(levelName) {
|
---|
| 133 | var validLevels = _.keys(LEVELS)
|
---|
| 134 | var isValid = _.includes(validLevels, levelName)
|
---|
| 135 |
|
---|
| 136 | if (!isValid) {
|
---|
| 137 | throw new Error('[HPM] Log level error. Invalid logLevel.')
|
---|
| 138 | }
|
---|
| 139 |
|
---|
| 140 | return isValid
|
---|
| 141 | }
|
---|
| 142 | }
|
---|
| 143 |
|
---|
| 144 | /**
|
---|
| 145 | * -> normal proxy
|
---|
| 146 | * => router
|
---|
| 147 | * ~> pathRewrite
|
---|
| 148 | * ≈> router + pathRewrite
|
---|
| 149 | *
|
---|
| 150 | * @param {String} originalPath
|
---|
| 151 | * @param {String} newPath
|
---|
| 152 | * @param {String} originalTarget
|
---|
| 153 | * @param {String} newTarget
|
---|
| 154 | * @return {String}
|
---|
| 155 | */
|
---|
| 156 | function getArrow(originalPath, newPath, originalTarget, newTarget) {
|
---|
| 157 | var arrow = ['>']
|
---|
| 158 | var isNewTarget = originalTarget !== newTarget // router
|
---|
| 159 | var isNewPath = originalPath !== newPath // pathRewrite
|
---|
| 160 |
|
---|
| 161 | if (isNewPath && !isNewTarget) {
|
---|
| 162 | arrow.unshift('~')
|
---|
| 163 | } else if (!isNewPath && isNewTarget) {
|
---|
| 164 | arrow.unshift('=')
|
---|
| 165 | } else if (isNewPath && isNewTarget) {
|
---|
| 166 | arrow.unshift('≈')
|
---|
| 167 | } else {
|
---|
| 168 | arrow.unshift('-')
|
---|
| 169 | }
|
---|
| 170 |
|
---|
| 171 | return arrow.join('')
|
---|
| 172 | }
|
---|