2014-03-04 14:08:29 +01:00
|
|
|
/**
|
|
|
|
* Icinga.Logger
|
|
|
|
*
|
|
|
|
* Well, log output. Rocket science.
|
|
|
|
*/
|
|
|
|
(function (Icinga) {
|
2014-02-18 19:34:39 +01:00
|
|
|
|
2014-03-04 14:08:29 +01:00
|
|
|
'use strict';
|
2014-02-18 19:34:39 +01:00
|
|
|
|
2014-03-04 14:08:29 +01:00
|
|
|
Icinga.Logger = function (icinga) {
|
2014-02-18 19:34:39 +01:00
|
|
|
|
2014-03-04 14:08:29 +01:00
|
|
|
this.icinga = icinga;
|
|
|
|
|
|
|
|
this.logLevel = 'info';
|
|
|
|
|
|
|
|
this.logLevels = {
|
|
|
|
'debug': 0,
|
|
|
|
'info' : 1,
|
|
|
|
'warn' : 2,
|
|
|
|
'error': 3
|
|
|
|
};
|
2014-02-18 19:34:39 +01:00
|
|
|
|
|
|
|
};
|
|
|
|
|
2014-03-04 14:08:29 +01:00
|
|
|
Icinga.Logger.prototype = {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Whether the browser has a console object
|
|
|
|
*/
|
|
|
|
hasConsole: function () {
|
|
|
|
return 'undefined' !== typeof console;
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Raise or lower current log level
|
|
|
|
*
|
|
|
|
* Messages blow this threshold will be silently discarded
|
|
|
|
*/
|
|
|
|
setLevel: function (level) {
|
|
|
|
if ('undefined' !== typeof this.numericLevel(level)) {
|
|
|
|
this.logLevel = level;
|
|
|
|
}
|
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Log a debug message
|
|
|
|
*/
|
|
|
|
debug: function () {
|
|
|
|
return this.writeToConsole('debug', arguments);
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Log an informational message
|
|
|
|
*/
|
|
|
|
info: function () {
|
|
|
|
return this.writeToConsole('info', arguments);
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Log a warning message
|
|
|
|
*/
|
|
|
|
warn: function () {
|
|
|
|
return this.writeToConsole('warn', arguments);
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Log an error message
|
|
|
|
*/
|
|
|
|
error: function () {
|
|
|
|
return this.writeToConsole('error', arguments);
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
2014-03-06 13:08:11 +01:00
|
|
|
* Write a log message with the given level to the console
|
2014-03-04 14:08:29 +01:00
|
|
|
*/
|
|
|
|
writeToConsole: function (level, args) {
|
|
|
|
|
|
|
|
args = Array.prototype.slice.call(args);
|
|
|
|
|
|
|
|
// We want our log messages to carry precise timestamps
|
|
|
|
args.unshift(this.icinga.utils.timeWithMs());
|
|
|
|
|
2014-06-06 07:23:57 +02:00
|
|
|
if (this.hasConsole() && this.hasLogLevel(level)) {
|
|
|
|
if (typeof console[level] !== 'undefined') {
|
|
|
|
if (typeof console[level].apply === 'function') {
|
|
|
|
console[level].apply(console, args);
|
|
|
|
} else {
|
|
|
|
args.unshift('[' + level + ']');
|
|
|
|
console[level](args.join(' '));
|
|
|
|
}
|
|
|
|
} else if ('undefined' !== typeof console.log) {
|
|
|
|
args.unshift('[' + level + ']');
|
|
|
|
console.log(args.join(' '));
|
|
|
|
}
|
2014-03-04 14:08:29 +01:00
|
|
|
}
|
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return the numeric identifier fot a given log level
|
|
|
|
*/
|
|
|
|
numericLevel: function (level) {
|
|
|
|
var ret = this.logLevels[level];
|
|
|
|
if ('undefined' === typeof ret) {
|
|
|
|
throw 'Got invalid log level ' + level;
|
|
|
|
}
|
|
|
|
return ret;
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Whether a given log level exists
|
|
|
|
*/
|
|
|
|
hasLogLevel: function (level) {
|
|
|
|
return this.numericLevel(level) >= this.numericLevel(this.logLevel);
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* There isn't much to clean up here
|
|
|
|
*/
|
|
|
|
destroy: function () {
|
|
|
|
this.enabled = false;
|
|
|
|
this.icinga = null;
|
|
|
|
}
|
|
|
|
};
|
2014-02-18 19:34:39 +01:00
|
|
|
|
|
|
|
}(Icinga));
|