1 | "use strict";
|
2 |
|
3 |
|
4 |
|
5 |
|
6 |
|
7 |
|
8 |
|
9 |
|
10 |
|
11 |
|
12 |
|
13 |
|
14 |
|
15 |
|
16 |
|
17 | var __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 | };
|
23 | var __metadata = (this && this.__metadata) || function (k, v) {
|
24 | if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
25 | };
|
26 | var __param = (this && this.__param) || function (paramIndex, decorator) {
|
27 | return function (target, key) { decorator(target, key, paramIndex); }
|
28 | };
|
29 | Object.defineProperty(exports, "__esModule", { value: true });
|
30 | exports.Logger = exports.ILogger = exports.LoggerName = exports.LoggerFactory = exports.setRootLogger = exports.unsetRootLogger = exports.logger = exports.rootLoggerName = exports.LogLevel = void 0;
|
31 | const inversify_1 = require("inversify");
|
32 | const logger_watcher_1 = require("./logger-watcher");
|
33 | const logger_protocol_1 = require("./logger-protocol");
|
34 | Object.defineProperty(exports, "LogLevel", { enumerable: true, get: function () { return logger_protocol_1.LogLevel; } });
|
35 | Object.defineProperty(exports, "rootLoggerName", { enumerable: true, get: function () { return logger_protocol_1.rootLoggerName; } });
|
36 |
|
37 |
|
38 |
|
39 |
|
40 |
|
41 | function unsetRootLogger() {
|
42 | if (exports.logger !== undefined) {
|
43 | logger_protocol_1.ConsoleLogger.reset();
|
44 | exports.logger = undefined;
|
45 | }
|
46 | }
|
47 | exports.unsetRootLogger = unsetRootLogger;
|
48 | function 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 | }
|
58 | exports.setRootLogger = setRootLogger;
|
59 | exports.LoggerFactory = Symbol('LoggerFactory');
|
60 | exports.LoggerName = Symbol('LoggerName');
|
61 | exports.ILogger = Symbol('ILogger');
|
62 | let Logger = class Logger {
|
63 | |
64 |
|
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 |
|
73 | this.created = server.child(name);
|
74 | }
|
75 | else {
|
76 |
|
77 | this.created = Promise.resolve();
|
78 | }
|
79 |
|
80 | this._logLevel = this.created.then(_ => this.server.getLogLevel(name));
|
81 |
|
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 | };
|
193 | Logger = __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);
|
201 | exports.Logger = Logger;
|
202 |
|
\ | No newline at end of file |