UNPKG

8.39 kBJavaScriptView Raw
1"use strict";
2// *****************************************************************************
3// Copyright (C) 2017 Ericsson and others.
4//
5// This program and the accompanying materials are made available under the
6// terms of the Eclipse Public License v. 2.0 which is available at
7// http://www.eclipse.org/legal/epl-2.0.
8//
9// This Source Code may also be made available under the following Secondary
10// Licenses when the conditions for such availability set forth in the Eclipse
11// Public License v. 2.0 are satisfied: GNU General Public License, version 2
12// with the GNU Classpath Exception which is available at
13// https://www.gnu.org/software/classpath/license.html.
14//
15// SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0
16// *****************************************************************************
17var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
18 var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
19 if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
20 else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
21 return c > 3 && r && Object.defineProperty(target, key, r), r;
22};
23var __metadata = (this && this.__metadata) || function (k, v) {
24 if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
25};
26var __param = (this && this.__param) || function (paramIndex, decorator) {
27 return function (target, key) { decorator(target, key, paramIndex); }
28};
29Object.defineProperty(exports, "__esModule", { value: true });
30exports.Logger = exports.ILogger = exports.LoggerName = exports.LoggerFactory = exports.setRootLogger = exports.unsetRootLogger = exports.logger = exports.rootLoggerName = exports.LogLevel = void 0;
31const inversify_1 = require("inversify");
32const logger_watcher_1 = require("./logger-watcher");
33const logger_protocol_1 = require("./logger-protocol");
34Object.defineProperty(exports, "LogLevel", { enumerable: true, get: function () { return logger_protocol_1.LogLevel; } });
35Object.defineProperty(exports, "rootLoggerName", { enumerable: true, get: function () { return logger_protocol_1.rootLoggerName; } });
36/**
37 * Counterpart of the `#setRootLogger(ILogger)`. Restores the `console.xxx` bindings to the original one.
38 * Invoking has no side-effect if `setRootLogger` was not called before. Multiple function invocation has
39 * no side-effect either.
40 */
41function unsetRootLogger() {
42 if (exports.logger !== undefined) {
43 logger_protocol_1.ConsoleLogger.reset();
44 exports.logger = undefined;
45 }
46}
47exports.unsetRootLogger = unsetRootLogger;
48function setRootLogger(aLogger) {
49 exports.logger = aLogger;
50 const log = (logLevel, message, ...optionalParams) => exports.logger.log(logLevel, message, ...optionalParams);
51 console.error = log.bind(undefined, logger_protocol_1.LogLevel.ERROR);
52 console.warn = log.bind(undefined, logger_protocol_1.LogLevel.WARN);
53 console.info = log.bind(undefined, logger_protocol_1.LogLevel.INFO);
54 console.debug = log.bind(undefined, logger_protocol_1.LogLevel.DEBUG);
55 console.trace = log.bind(undefined, logger_protocol_1.LogLevel.TRACE);
56 console.log = log.bind(undefined, logger_protocol_1.LogLevel.INFO);
57}
58exports.setRootLogger = setRootLogger;
59exports.LoggerFactory = Symbol('LoggerFactory');
60exports.LoggerName = Symbol('LoggerName');
61exports.ILogger = Symbol('ILogger');
62let Logger = class Logger {
63 /**
64 * Build a new Logger.
65 */
66 constructor(server, loggerWatcher, factory, name) {
67 this.server = server;
68 this.loggerWatcher = loggerWatcher;
69 this.factory = factory;
70 this.name = name;
71 if (name !== logger_protocol_1.rootLoggerName) {
72 /* Creating a child logger. */
73 this.created = server.child(name);
74 }
75 else {
76 /* Creating the root logger (it already exists at startup). */
77 this.created = Promise.resolve();
78 }
79 /* Fetch the log level so it's cached in the frontend. */
80 this._logLevel = this.created.then(_ => this.server.getLogLevel(name));
81 /* Update the log level if it changes in the backend. */
82 loggerWatcher.onLogLevelChanged(event => {
83 this.created.then(() => {
84 if (event.loggerName === name) {
85 this._logLevel = Promise.resolve(event.newLogLevel);
86 }
87 });
88 });
89 }
90 setLogLevel(logLevel) {
91 return new Promise(resolve => {
92 this.created.then(() => {
93 this._logLevel.then(oldLevel => {
94 this.server.setLogLevel(this.name, logLevel).then(() => {
95 this._logLevel = Promise.resolve(logLevel);
96 resolve();
97 });
98 });
99 });
100 });
101 }
102 getLogLevel() {
103 return this._logLevel;
104 }
105 isEnabled(logLevel) {
106 return this._logLevel.then(level => logLevel >= level);
107 }
108 ifEnabled(logLevel) {
109 return new Promise(resolve => this.isEnabled(logLevel).then(enabled => {
110 if (enabled) {
111 resolve();
112 }
113 }));
114 }
115 log(logLevel, arg2, ...params) {
116 return this.getLog(logLevel).then(log => {
117 if (typeof arg2 === 'function') {
118 const loggable = arg2;
119 loggable(log);
120 }
121 else if (arg2) {
122 log(arg2, ...params);
123 }
124 });
125 }
126 getLog(logLevel) {
127 return this.ifEnabled(logLevel).then(() => this.created.then(() => (message, ...params) => this.server.log(this.name, logLevel, this.format(message), params.map(p => this.format(p)))));
128 }
129 format(value) {
130 if (value instanceof Error) {
131 return value.stack || value.toString();
132 }
133 return value;
134 }
135 isTrace() {
136 return this.isEnabled(logger_protocol_1.LogLevel.TRACE);
137 }
138 ifTrace() {
139 return this.ifEnabled(logger_protocol_1.LogLevel.TRACE);
140 }
141 trace(arg, ...params) {
142 return this.log(logger_protocol_1.LogLevel.TRACE, arg, ...params);
143 }
144 isDebug() {
145 return this.isEnabled(logger_protocol_1.LogLevel.DEBUG);
146 }
147 ifDebug() {
148 return this.ifEnabled(logger_protocol_1.LogLevel.DEBUG);
149 }
150 debug(arg, ...params) {
151 return this.log(logger_protocol_1.LogLevel.DEBUG, arg, ...params);
152 }
153 isInfo() {
154 return this.isEnabled(logger_protocol_1.LogLevel.INFO);
155 }
156 ifInfo() {
157 return this.ifEnabled(logger_protocol_1.LogLevel.INFO);
158 }
159 info(arg, ...params) {
160 return this.log(logger_protocol_1.LogLevel.INFO, arg, ...params);
161 }
162 isWarn() {
163 return this.isEnabled(logger_protocol_1.LogLevel.WARN);
164 }
165 ifWarn() {
166 return this.ifEnabled(logger_protocol_1.LogLevel.WARN);
167 }
168 warn(arg, ...params) {
169 return this.log(logger_protocol_1.LogLevel.WARN, arg, ...params);
170 }
171 isError() {
172 return this.isEnabled(logger_protocol_1.LogLevel.ERROR);
173 }
174 ifError() {
175 return this.ifEnabled(logger_protocol_1.LogLevel.ERROR);
176 }
177 error(arg, ...params) {
178 return this.log(logger_protocol_1.LogLevel.ERROR, arg, ...params);
179 }
180 isFatal() {
181 return this.isEnabled(logger_protocol_1.LogLevel.FATAL);
182 }
183 ifFatal() {
184 return this.ifEnabled(logger_protocol_1.LogLevel.FATAL);
185 }
186 fatal(arg, ...params) {
187 return this.log(logger_protocol_1.LogLevel.FATAL, arg, ...params);
188 }
189 child(name) {
190 return this.factory(name);
191 }
192};
193Logger = __decorate([
194 (0, inversify_1.injectable)(),
195 __param(0, (0, inversify_1.inject)(logger_protocol_1.ILoggerServer)),
196 __param(1, (0, inversify_1.inject)(logger_watcher_1.LoggerWatcher)),
197 __param(2, (0, inversify_1.inject)(exports.LoggerFactory)),
198 __param(3, (0, inversify_1.inject)(exports.LoggerName)),
199 __metadata("design:paramtypes", [Object, logger_watcher_1.LoggerWatcher, Function, String])
200], Logger);
201exports.Logger = Logger;
202//# sourceMappingURL=logger.js.map
\No newline at end of file