@aws-amplify/core
Version:
Core category of aws-amplify
245 lines (244 loc) • 8.2 kB
JavaScript
// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
// SPDX-License-Identifier: Apache-2.0
var __values = (this && this.__values) || function(o) {
var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;
if (m) return m.call(o);
if (o && typeof o.length === "number") return {
next: function () {
if (o && i >= o.length) o = void 0;
return { value: o && o[i++], done: !o };
}
};
throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
};
var __read = (this && this.__read) || function (o, n) {
var m = typeof Symbol === "function" && o[Symbol.iterator];
if (!m) return o;
var i = m.call(o), r, ar = [], e;
try {
while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
}
catch (error) { e = { error: error }; }
finally {
try {
if (r && !r.done && (m = i["return"])) m.call(i);
}
finally { if (e) throw e.error; }
}
return ar;
};
var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
if (ar || !(i in from)) {
if (!ar) ar = Array.prototype.slice.call(from, 0, i);
ar[i] = from[i];
}
}
return to.concat(ar || Array.prototype.slice.call(from));
};
import { AWS_CLOUDWATCH_CATEGORY } from '../Util/Constants';
var LOG_LEVELS = {
VERBOSE: 1,
DEBUG: 2,
INFO: 3,
WARN: 4,
ERROR: 5,
};
export var LOG_TYPE;
(function (LOG_TYPE) {
LOG_TYPE["DEBUG"] = "DEBUG";
LOG_TYPE["ERROR"] = "ERROR";
LOG_TYPE["INFO"] = "INFO";
LOG_TYPE["WARN"] = "WARN";
LOG_TYPE["VERBOSE"] = "VERBOSE";
})(LOG_TYPE || (LOG_TYPE = {}));
/**
* Write logs
* @class Logger
*/
export var ConsoleLogger = /** @class */ (function () {
/**
* @constructor
* @param {string} name - Name of the logger
*/
function ConsoleLogger(name, level) {
if (level === void 0) { level = LOG_TYPE.WARN; }
this.name = name;
this.level = level;
this._pluggables = [];
}
ConsoleLogger.prototype._padding = function (n) {
return n < 10 ? '0' + n : '' + n;
};
ConsoleLogger.prototype._ts = function () {
var dt = new Date();
return ([this._padding(dt.getMinutes()), this._padding(dt.getSeconds())].join(':') +
'.' +
dt.getMilliseconds());
};
ConsoleLogger.prototype.configure = function (config) {
if (!config)
return this._config;
this._config = config;
return this._config;
};
/**
* Write log
* @method
* @memeberof Logger
* @param {LOG_TYPE|string} type - log type, default INFO
* @param {string|object} msg - Logging message or object
*/
ConsoleLogger.prototype._log = function (type) {
var e_1, _a;
var msg = [];
for (var _i = 1; _i < arguments.length; _i++) {
msg[_i - 1] = arguments[_i];
}
var logger_level_name = this.level;
if (ConsoleLogger.LOG_LEVEL) {
logger_level_name = ConsoleLogger.LOG_LEVEL;
}
if (typeof window !== 'undefined' && window.LOG_LEVEL) {
logger_level_name = window.LOG_LEVEL;
}
var logger_level = LOG_LEVELS[logger_level_name];
var type_level = LOG_LEVELS[type];
if (!(type_level >= logger_level)) {
// Do nothing if type is not greater than or equal to logger level (handle undefined)
return;
}
var log = console.log.bind(console);
if (type === LOG_TYPE.ERROR && console.error) {
log = console.error.bind(console);
}
if (type === LOG_TYPE.WARN && console.warn) {
log = console.warn.bind(console);
}
var prefix = "[".concat(type, "] ").concat(this._ts(), " ").concat(this.name);
var message = '';
if (msg.length === 1 && typeof msg[0] === 'string') {
message = "".concat(prefix, " - ").concat(msg[0]);
log(message);
}
else if (msg.length === 1) {
message = "".concat(prefix, " ").concat(msg[0]);
log(prefix, msg[0]);
}
else if (typeof msg[0] === 'string') {
var obj = msg.slice(1);
if (obj.length === 1) {
obj = obj[0];
}
message = "".concat(prefix, " - ").concat(msg[0], " ").concat(obj);
log("".concat(prefix, " - ").concat(msg[0]), obj);
}
else {
message = "".concat(prefix, " ").concat(msg);
log(prefix, msg);
}
try {
for (var _b = __values(this._pluggables), _c = _b.next(); !_c.done; _c = _b.next()) {
var plugin = _c.value;
var logEvent = { message: message, timestamp: Date.now() };
plugin.pushLogs([logEvent]);
}
}
catch (e_1_1) { e_1 = { error: e_1_1 }; }
finally {
try {
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
}
finally { if (e_1) throw e_1.error; }
}
};
/**
* Write General log. Default to INFO
* @method
* @memeberof Logger
* @param {string|object} msg - Logging message or object
*/
ConsoleLogger.prototype.log = function () {
var msg = [];
for (var _i = 0; _i < arguments.length; _i++) {
msg[_i] = arguments[_i];
}
this._log.apply(this, __spreadArray([LOG_TYPE.INFO], __read(msg), false));
};
/**
* Write INFO log
* @method
* @memeberof Logger
* @param {string|object} msg - Logging message or object
*/
ConsoleLogger.prototype.info = function () {
var msg = [];
for (var _i = 0; _i < arguments.length; _i++) {
msg[_i] = arguments[_i];
}
this._log.apply(this, __spreadArray([LOG_TYPE.INFO], __read(msg), false));
};
/**
* Write WARN log
* @method
* @memeberof Logger
* @param {string|object} msg - Logging message or object
*/
ConsoleLogger.prototype.warn = function () {
var msg = [];
for (var _i = 0; _i < arguments.length; _i++) {
msg[_i] = arguments[_i];
}
this._log.apply(this, __spreadArray([LOG_TYPE.WARN], __read(msg), false));
};
/**
* Write ERROR log
* @method
* @memeberof Logger
* @param {string|object} msg - Logging message or object
*/
ConsoleLogger.prototype.error = function () {
var msg = [];
for (var _i = 0; _i < arguments.length; _i++) {
msg[_i] = arguments[_i];
}
this._log.apply(this, __spreadArray([LOG_TYPE.ERROR], __read(msg), false));
};
/**
* Write DEBUG log
* @method
* @memeberof Logger
* @param {string|object} msg - Logging message or object
*/
ConsoleLogger.prototype.debug = function () {
var msg = [];
for (var _i = 0; _i < arguments.length; _i++) {
msg[_i] = arguments[_i];
}
this._log.apply(this, __spreadArray([LOG_TYPE.DEBUG], __read(msg), false));
};
/**
* Write VERBOSE log
* @method
* @memeberof Logger
* @param {string|object} msg - Logging message or object
*/
ConsoleLogger.prototype.verbose = function () {
var msg = [];
for (var _i = 0; _i < arguments.length; _i++) {
msg[_i] = arguments[_i];
}
this._log.apply(this, __spreadArray([LOG_TYPE.VERBOSE], __read(msg), false));
};
ConsoleLogger.prototype.addPluggable = function (pluggable) {
if (pluggable && pluggable.getCategoryName() === AWS_CLOUDWATCH_CATEGORY) {
this._pluggables.push(pluggable);
pluggable.configure(this._config);
}
};
ConsoleLogger.prototype.listPluggables = function () {
return this._pluggables;
};
ConsoleLogger.LOG_LEVEL = null;
return ConsoleLogger;
}());