UNPKG

@aws-amplify/core

Version:
248 lines (247 loc) • 8.36 kB
"use strict"; // 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)); }; Object.defineProperty(exports, "__esModule", { value: true }); exports.ConsoleLogger = exports.LOG_TYPE = void 0; var Constants_1 = require("../Util/Constants"); var LOG_LEVELS = { VERBOSE: 1, DEBUG: 2, INFO: 3, WARN: 4, ERROR: 5, }; 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 = exports.LOG_TYPE || (exports.LOG_TYPE = {})); /** * Write logs * @class Logger */ var ConsoleLogger = exports.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() === Constants_1.AWS_CLOUDWATCH_CATEGORY) { this._pluggables.push(pluggable); pluggable.configure(this._config); } }; ConsoleLogger.prototype.listPluggables = function () { return this._pluggables; }; ConsoleLogger.LOG_LEVEL = null; return ConsoleLogger; }());