@foxford/logger 1.0.2 → 1.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/browser.js +292 -400
- package/browser.mjs +295 -399
- package/index.d.ts +170 -11
- package/node.js +257 -373
- package/node.mjs +260 -372
- package/package.json +5 -4
package/node.js
CHANGED
|
@@ -1,426 +1,310 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
/**
|
|
7
|
-
* Генерирует hex-код цвета на основе строки, избегая оттенков красного
|
|
8
|
-
* @param {string} str - Строка, для которой нужно сгенерировать цвет
|
|
9
|
-
* @returns {string} - Hex-код цвета
|
|
10
|
-
*/
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
3
|
+
const log = require("loglevel");
|
|
4
|
+
const chalk = require("chalk");
|
|
11
5
|
function generateHexByString(str) {
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
}
|
|
44
|
-
const m = lightness / 100 - chroma / 2;
|
|
45
|
-
const [r, g, b] = [r1, g1, b1].map((v) => Math.round((v + m) * 255));
|
|
46
|
-
// Добавляем проверку и значения по умолчанию
|
|
47
|
-
const rValue = r !== null && r !== void 0 ? r : 0;
|
|
48
|
-
const gValue = g !== null && g !== void 0 ? g : 0;
|
|
49
|
-
const bValue = b !== null && b !== void 0 ? b : 0;
|
|
50
|
-
const color = `#${((rValue << 16) | (gValue << 8) | bValue).toString(16).padStart(6, '0')}`;
|
|
51
|
-
return color;
|
|
6
|
+
let hash = 0;
|
|
7
|
+
for (let i = 0; i < str.length; i++) {
|
|
8
|
+
hash = str.charCodeAt(i) + ((hash << 5) - hash);
|
|
9
|
+
}
|
|
10
|
+
const hue = Math.abs(hash) % 300;
|
|
11
|
+
const saturation = 60 + Math.abs(hash) % 40;
|
|
12
|
+
const lightness = 30 + Math.abs(hash) % 40;
|
|
13
|
+
const chroma = (1 - Math.abs(2 * lightness / 100 - 1)) * saturation / 100;
|
|
14
|
+
const huePrime = hue / 60;
|
|
15
|
+
const x = chroma * (1 - Math.abs(huePrime % 2 - 1));
|
|
16
|
+
let r1 = 0, g1 = 0, b1 = 0;
|
|
17
|
+
if (huePrime >= 0 && huePrime < 1) {
|
|
18
|
+
[r1, g1, b1] = [chroma, x, 0];
|
|
19
|
+
} else if (huePrime >= 1 && huePrime < 2) {
|
|
20
|
+
[r1, g1, b1] = [x, chroma, 0];
|
|
21
|
+
} else if (huePrime >= 2 && huePrime < 3) {
|
|
22
|
+
[r1, g1, b1] = [0, chroma, x];
|
|
23
|
+
} else if (huePrime >= 3 && huePrime < 4) {
|
|
24
|
+
[r1, g1, b1] = [0, x, chroma];
|
|
25
|
+
} else if (huePrime >= 4 && huePrime < 5) {
|
|
26
|
+
[r1, g1, b1] = [x, 0, chroma];
|
|
27
|
+
} else {
|
|
28
|
+
[r1, g1, b1] = [chroma, 0, x];
|
|
29
|
+
}
|
|
30
|
+
const m = lightness / 100 - chroma / 2;
|
|
31
|
+
const [r, g, b] = [r1, g1, b1].map((v) => Math.round((v + m) * 255));
|
|
32
|
+
const rValue = r ?? 0;
|
|
33
|
+
const gValue = g ?? 0;
|
|
34
|
+
const bValue = b ?? 0;
|
|
35
|
+
const color = `#${(rValue << 16 | gValue << 8 | bValue).toString(16).padStart(6, "0")}`;
|
|
36
|
+
return color;
|
|
52
37
|
}
|
|
53
|
-
|
|
54
|
-
/**
|
|
55
|
-
* Кеш для хранения сгенерированных цветов
|
|
56
|
-
* могут быть заранее предустановлены по имени логгера
|
|
57
|
-
**/
|
|
58
38
|
const colorCache = {};
|
|
59
|
-
/** Цвета для различных уровней логирования */
|
|
60
39
|
const levelColors = {
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
40
|
+
TRACE: chalk.gray,
|
|
41
|
+
LOG: chalk.cyan,
|
|
42
|
+
DEBUG: chalk.cyan,
|
|
43
|
+
INFO: chalk.green,
|
|
44
|
+
WARN: chalk.yellow,
|
|
45
|
+
ERROR: chalk.red
|
|
67
46
|
};
|
|
68
|
-
|
|
69
|
-
const debugStorage = new Set();
|
|
70
|
-
/**
|
|
71
|
-
* Генерирует hex-код цвета на основе строки, избегая оттенков красного
|
|
72
|
-
* @param {string} str - Строка, для которой нужно сгенерировать цвет
|
|
73
|
-
* @returns {string} - Hex-код цвета
|
|
74
|
-
*/
|
|
47
|
+
const debugStorage = /* @__PURE__ */ new Set();
|
|
75
48
|
function stringToColorCode(str) {
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
// Сохраняем цвет в кеш
|
|
83
|
-
colorCache[str] = color;
|
|
84
|
-
return color;
|
|
49
|
+
if (str in colorCache) {
|
|
50
|
+
return colorCache[str] ?? "inherit";
|
|
51
|
+
}
|
|
52
|
+
const color = generateHexByString(str);
|
|
53
|
+
colorCache[str] = color;
|
|
54
|
+
return color;
|
|
85
55
|
}
|
|
86
|
-
/**
|
|
87
|
-
* Форматирует сообщение лога
|
|
88
|
-
* @param {string} level - Уровень лога
|
|
89
|
-
* @param {string} name - Имя логгера
|
|
90
|
-
* @param {Date} timestamp - Временная метка
|
|
91
|
-
* @returns {string} Отформатированное сообщение
|
|
92
|
-
*/
|
|
93
56
|
function formatter(level, name, timestamp) {
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
57
|
+
const levelColor = levelColors[level.toUpperCase()] || chalk.gray;
|
|
58
|
+
let date;
|
|
59
|
+
let nameHex;
|
|
60
|
+
let loggerName;
|
|
61
|
+
let loggerLevel;
|
|
62
|
+
switch (name) {
|
|
63
|
+
// предустановленнный цветовой шаблон по имени логгера
|
|
64
|
+
case "critical":
|
|
65
|
+
date = chalk.red(`[${timestamp.toISOString()}]`);
|
|
66
|
+
loggerName = chalk.red(`[${name}]`);
|
|
67
|
+
loggerLevel = chalk.red(`[${level}]`);
|
|
68
|
+
break;
|
|
69
|
+
default:
|
|
70
|
+
date = chalk.gray(`[${timestamp.toISOString()}]`);
|
|
71
|
+
nameHex = stringToColorCode(name);
|
|
72
|
+
loggerName = chalk.hex(nameHex)(`[${name}]`);
|
|
73
|
+
loggerLevel = levelColor(`[${level}]`);
|
|
74
|
+
break;
|
|
75
|
+
}
|
|
76
|
+
return `${date} ${loggerLevel} ${loggerName} ${chalk.cyan("•")}`;
|
|
114
77
|
}
|
|
115
|
-
/**
|
|
116
|
-
* Получает текущее значение debug
|
|
117
|
-
* @returns {string | undefined} Строка с debug значениями или undefined, если значений нет
|
|
118
|
-
*/
|
|
119
78
|
function getDebugValue() {
|
|
120
|
-
|
|
121
|
-
|
|
79
|
+
const value = Array.from(debugStorage).join(",");
|
|
80
|
+
return value.length ? value : void 0;
|
|
122
81
|
}
|
|
123
|
-
/**
|
|
124
|
-
* Устанавливает значение debug
|
|
125
|
-
* @param {string | null} value - Новое значение debug
|
|
126
|
-
*/
|
|
127
82
|
function setDebugValue(value) {
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
}
|
|
83
|
+
if (value === null || value === void 0) {
|
|
84
|
+
debugStorage.clear();
|
|
85
|
+
} else {
|
|
86
|
+
debugStorage.add(value.trim());
|
|
87
|
+
}
|
|
134
88
|
}
|
|
135
|
-
/**
|
|
136
|
-
* Функция для подписки на изменения значения debug
|
|
137
|
-
* @param {function} callback - Функция, вызываемая при изменении значения debug
|
|
138
|
-
* @returns {function} Функция для отписки от изменений
|
|
139
|
-
*/
|
|
140
89
|
function onDebugValueChange(_callback) {
|
|
141
|
-
|
|
142
|
-
|
|
90
|
+
return () => {
|
|
91
|
+
};
|
|
143
92
|
}
|
|
144
93
|
if (process.env.DEBUG) {
|
|
145
|
-
|
|
94
|
+
setDebugValue(process.env.DEBUG);
|
|
146
95
|
}
|
|
147
96
|
const environment = {
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
97
|
+
getDebugValue,
|
|
98
|
+
setDebugValue,
|
|
99
|
+
formatter,
|
|
100
|
+
onDebugValueChange
|
|
152
101
|
};
|
|
153
|
-
|
|
154
|
-
/**
|
|
155
|
-
* Генерирует UUID версии 4.
|
|
156
|
-
* @returns {string} Строка, представляющая UUID версии 4.
|
|
157
|
-
*/
|
|
158
102
|
function generateUUIDv4() {
|
|
159
|
-
|
|
103
|
+
return "10000000-1000-4000-8000-100000000000".replace(
|
|
104
|
+
/[018]/g,
|
|
105
|
+
(char) => (parseInt(char, 10) ^ crypto.getRandomValues(new Uint8Array(1))[0] & 15 >> parseInt(char, 10) / 4).toString(
|
|
106
|
+
16
|
|
107
|
+
)
|
|
108
|
+
);
|
|
160
109
|
}
|
|
161
|
-
|
|
162
|
-
/*
|
|
163
|
-
const loggerCache = new Map();
|
|
164
|
-
const previousLevels = new Map();
|
|
110
|
+
const loggerCache = /* @__PURE__ */ new Map();
|
|
111
|
+
const previousLevels = /* @__PURE__ */ new Map();
|
|
165
112
|
let isInitialized = false;
|
|
166
|
-
/**
|
|
167
|
-
* Создает экземпляр HierarchicalLogger
|
|
168
|
-
* @param fullName Имя логгера
|
|
169
|
-
* @param parent Родительский логгер (если есть)
|
|
170
|
-
*/
|
|
171
113
|
function createHierarchicalLogger(originalGetLogger, fullName, parent) {
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
}
|
|
213
|
-
}
|
|
214
|
-
else {
|
|
215
|
-
let newLevel;
|
|
216
|
-
if (parentLevel !== undefined) {
|
|
217
|
-
// Используем уровень родительского логгера, если он существует
|
|
218
|
-
newLevel = parentLevel;
|
|
219
|
-
}
|
|
220
|
-
else {
|
|
221
|
-
// Если родительского логгера нет, используем предыдущий сохраненный уровень или уровень по умолчанию
|
|
222
|
-
newLevel = previousLevels.get(this.id) || log.levels.WARN;
|
|
223
|
-
}
|
|
224
|
-
baseLogger.setLevel(newLevel, false);
|
|
225
|
-
previousLevels.delete(this.id);
|
|
226
|
-
// Если выключаем отладку
|
|
227
|
-
const index = currentPatterns.findIndex((pattern) => pattern === fullName || pattern === `${fullName}:*`);
|
|
228
|
-
if (index !== -1) {
|
|
229
|
-
currentPatterns.splice(index, 1);
|
|
230
|
-
}
|
|
231
|
-
}
|
|
232
|
-
// Оптимизируем паттерны
|
|
233
|
-
const optimizedPatterns = optimizePatterns(currentPatterns);
|
|
234
|
-
// Сохраняем оптимизированные паттерны
|
|
235
|
-
environment.setDebugValue(optimizedPatterns.join(',') || null);
|
|
236
|
-
},
|
|
237
|
-
getLogger(name) {
|
|
238
|
-
const childLogger = createHierarchicalLogger(originalGetLogger, `${fullName}:${name}`, this);
|
|
239
|
-
this.children.add(childLogger);
|
|
240
|
-
return childLogger;
|
|
241
|
-
},
|
|
242
|
-
setLevel(level) {
|
|
243
|
-
baseLogger.setLevel(level, false);
|
|
244
|
-
// Обновляем уровень для всех дочерних логгеров
|
|
245
|
-
this.children.forEach((child) => child.setLevel(level, false));
|
|
246
|
-
// Если логгер в режиме отладки, сохраняем новый уровень
|
|
247
|
-
if (this.isDebugEnabled()) {
|
|
248
|
-
previousLevels.set(loggerId, level);
|
|
249
|
-
}
|
|
250
|
-
} });
|
|
251
|
-
const originalFactory = baseLogger.methodFactory;
|
|
252
|
-
// Переопределяем методы логирования для учета режима отладки
|
|
253
|
-
const logMethods = ['trace', 'debug', 'info', 'warn', 'error', 'log'];
|
|
254
|
-
logMethods.forEach((method) => {
|
|
255
|
-
const originalMethod = originalFactory(method, baseLogger.getLevel(), fullName);
|
|
256
|
-
hierarchicalLogger[method] = function (...args) {
|
|
257
|
-
var _a;
|
|
258
|
-
const debugEnabled = this.isDebugEnabled();
|
|
259
|
-
const messageLevel = (_a = log.levels[method.toUpperCase()]) !== null && _a !== void 0 ? _a : 0;
|
|
260
|
-
const currentLevel = baseLogger.getLevel();
|
|
261
|
-
if (debugEnabled || messageLevel >= currentLevel) {
|
|
262
|
-
return originalMethod.apply(baseLogger, args);
|
|
114
|
+
const loggerId = generateUUIDv4();
|
|
115
|
+
const baseLogger = originalGetLogger(fullName);
|
|
116
|
+
const name = parent ? fullName.slice(parent.getFullName().length + 1) : fullName;
|
|
117
|
+
const hierarchicalLogger = {
|
|
118
|
+
...baseLogger,
|
|
119
|
+
id: loggerId,
|
|
120
|
+
parent: parent ?? null,
|
|
121
|
+
children: /* @__PURE__ */ new Set(),
|
|
122
|
+
name,
|
|
123
|
+
debugEnabled: false,
|
|
124
|
+
isDebugEnabled() {
|
|
125
|
+
return this.debugEnabled;
|
|
126
|
+
},
|
|
127
|
+
getDebugPattern() {
|
|
128
|
+
return environment.getDebugValue() ?? null;
|
|
129
|
+
},
|
|
130
|
+
// Добавим вспомогательный метод для получения полного имени логгера
|
|
131
|
+
getFullName() {
|
|
132
|
+
if (!this.parent) {
|
|
133
|
+
return this.name;
|
|
134
|
+
}
|
|
135
|
+
const parentFullName = this.parent.getFullName();
|
|
136
|
+
return parentFullName ? `${parentFullName}:${this.name}` : this.name;
|
|
137
|
+
},
|
|
138
|
+
setDebug(enabled) {
|
|
139
|
+
this.debugEnabled = enabled;
|
|
140
|
+
const parentLevel = this.parent ? this.parent.getLevel() : void 0;
|
|
141
|
+
const currentPatterns = (environment.getDebugValue() || "").split(",").filter(Boolean);
|
|
142
|
+
const fullName2 = this.getFullName();
|
|
143
|
+
if (enabled) {
|
|
144
|
+
if (!previousLevels.has(this.id)) {
|
|
145
|
+
previousLevels.set(this.id, baseLogger.getLevel());
|
|
146
|
+
}
|
|
147
|
+
baseLogger.setLevel(log.levels.TRACE, false);
|
|
148
|
+
if (!currentPatterns.some((pattern) => fullName2 === pattern || `${fullName2}:*` === pattern)) {
|
|
149
|
+
const childrenPatterns = currentPatterns.filter((pattern) => pattern.startsWith(`${fullName2}:`));
|
|
150
|
+
childrenPatterns.forEach((pattern) => {
|
|
151
|
+
const index = currentPatterns.indexOf(pattern);
|
|
152
|
+
if (index !== -1) {
|
|
153
|
+
currentPatterns.splice(index, 1);
|
|
263
154
|
}
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
155
|
+
});
|
|
156
|
+
currentPatterns.push(fullName2);
|
|
157
|
+
}
|
|
158
|
+
} else {
|
|
159
|
+
let newLevel;
|
|
160
|
+
if (parentLevel !== void 0) {
|
|
161
|
+
newLevel = parentLevel;
|
|
162
|
+
} else {
|
|
163
|
+
newLevel = previousLevels.get(this.id) || log.levels.WARN;
|
|
164
|
+
}
|
|
165
|
+
baseLogger.setLevel(newLevel, false);
|
|
166
|
+
previousLevels.delete(this.id);
|
|
167
|
+
const index = currentPatterns.findIndex((pattern) => pattern === fullName2 || pattern === `${fullName2}:*`);
|
|
168
|
+
if (index !== -1) {
|
|
169
|
+
currentPatterns.splice(index, 1);
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
const optimizedPatterns = optimizePatterns(currentPatterns);
|
|
173
|
+
environment.setDebugValue(optimizedPatterns.join(",") || null);
|
|
174
|
+
},
|
|
175
|
+
getLogger(name2) {
|
|
176
|
+
const childLogger = createHierarchicalLogger(originalGetLogger, `${fullName}:${name2}`, this);
|
|
177
|
+
this.children.add(childLogger);
|
|
178
|
+
return childLogger;
|
|
179
|
+
},
|
|
180
|
+
setLevel(level) {
|
|
181
|
+
baseLogger.setLevel(level, false);
|
|
182
|
+
this.children.forEach((child) => child.setLevel(level, false));
|
|
183
|
+
if (this.isDebugEnabled()) {
|
|
184
|
+
previousLevels.set(loggerId, level);
|
|
185
|
+
}
|
|
278
186
|
}
|
|
279
|
-
|
|
187
|
+
};
|
|
188
|
+
const originalFactory = baseLogger.methodFactory;
|
|
189
|
+
const logMethods = ["trace", "debug", "info", "warn", "error", "log"];
|
|
190
|
+
logMethods.forEach((method) => {
|
|
191
|
+
const originalMethod = originalFactory(method, baseLogger.getLevel(), fullName);
|
|
192
|
+
hierarchicalLogger[method] = function(...args) {
|
|
193
|
+
const debugEnabled = this.isDebugEnabled();
|
|
194
|
+
const messageLevel = log.levels[method.toUpperCase()] ?? 0;
|
|
195
|
+
const currentLevel = baseLogger.getLevel();
|
|
196
|
+
if (debugEnabled || messageLevel >= currentLevel) {
|
|
197
|
+
return originalMethod.apply(baseLogger, args);
|
|
198
|
+
}
|
|
199
|
+
};
|
|
200
|
+
});
|
|
201
|
+
loggerCache.set(loggerId, hierarchicalLogger);
|
|
202
|
+
if (!isInitialized) {
|
|
203
|
+
isInitialized = true;
|
|
204
|
+
initializeDebugPatterns();
|
|
205
|
+
} else {
|
|
206
|
+
const debugPattern = environment.getDebugValue() || "";
|
|
207
|
+
const patterns = debugPattern.split(",").map((p) => p.trim()).filter(Boolean);
|
|
208
|
+
configureLogger(hierarchicalLogger, patterns);
|
|
209
|
+
}
|
|
210
|
+
return hierarchicalLogger;
|
|
280
211
|
}
|
|
281
|
-
/**
|
|
282
|
-
* Оптимизирует паттерны отладки
|
|
283
|
-
* @param patterns Массив паттернов отладки
|
|
284
|
-
* @returns Оптимизированный массив паттернов
|
|
285
|
-
*/
|
|
286
212
|
function optimizePatterns(patterns) {
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
295
|
-
|
|
296
|
-
}
|
|
297
|
-
}
|
|
298
|
-
if (!isRedundant) {
|
|
299
|
-
optimized.add(pattern);
|
|
300
|
-
}
|
|
213
|
+
const optimized = /* @__PURE__ */ new Set();
|
|
214
|
+
patterns.sort((a, b) => a.split(":").length - b.split(":").length);
|
|
215
|
+
for (const pattern of patterns) {
|
|
216
|
+
let isRedundant = false;
|
|
217
|
+
for (const existingPattern of optimized) {
|
|
218
|
+
if (pattern === existingPattern || pattern.startsWith(existingPattern + ":")) {
|
|
219
|
+
isRedundant = true;
|
|
220
|
+
break;
|
|
221
|
+
}
|
|
301
222
|
}
|
|
302
|
-
|
|
223
|
+
if (!isRedundant) {
|
|
224
|
+
optimized.add(pattern);
|
|
225
|
+
}
|
|
226
|
+
}
|
|
227
|
+
return Array.from(optimized);
|
|
303
228
|
}
|
|
304
|
-
/**
|
|
305
|
-
* Проверяет, должен ли логгер быть в режиме отладки
|
|
306
|
-
* @param fullName Полное имя логгера
|
|
307
|
-
* @param patterns Массив паттернов отладки
|
|
308
|
-
* @returns true, если логгер должен быть в режиме отладки
|
|
309
|
-
*/
|
|
310
229
|
function shouldEnableDebug(fullName, patterns) {
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
return false;
|
|
321
|
-
});
|
|
230
|
+
return patterns.some((pattern) => {
|
|
231
|
+
if (pattern === "*") return true;
|
|
232
|
+
if (fullName === pattern) return true;
|
|
233
|
+
if (pattern.endsWith(":*")) {
|
|
234
|
+
const patternPrefix = pattern.slice(0, -2);
|
|
235
|
+
return fullName.startsWith(patternPrefix + ":");
|
|
236
|
+
}
|
|
237
|
+
return false;
|
|
238
|
+
});
|
|
322
239
|
}
|
|
323
|
-
/**
|
|
324
|
-
* Настраивает логгер в соответствии с текущими паттернами отладки
|
|
325
|
-
* @param logger Логгер для настройки
|
|
326
|
-
* @param patterns Массив паттернов отладки
|
|
327
|
-
*/
|
|
328
240
|
function configureLogger(logger, patterns) {
|
|
329
|
-
|
|
330
|
-
|
|
331
|
-
|
|
332
|
-
|
|
333
|
-
|
|
334
|
-
|
|
335
|
-
|
|
336
|
-
|
|
337
|
-
}
|
|
241
|
+
const fullName = logger.getFullName();
|
|
242
|
+
const debugEnabled = shouldEnableDebug(fullName, patterns);
|
|
243
|
+
logger.debugEnabled = debugEnabled;
|
|
244
|
+
if (debugEnabled) {
|
|
245
|
+
logger.setLevel(previousLevels.get(logger.id) || log.levels.TRACE);
|
|
246
|
+
} else {
|
|
247
|
+
logger.setLevel(previousLevels.get(logger.id) || log.levels.WARN);
|
|
248
|
+
}
|
|
338
249
|
}
|
|
339
|
-
/**
|
|
340
|
-
* Инициализирует паттерны отладки из environment
|
|
341
|
-
*/
|
|
342
250
|
function initializeDebugPatterns() {
|
|
343
|
-
|
|
344
|
-
|
|
345
|
-
|
|
346
|
-
|
|
347
|
-
|
|
348
|
-
|
|
349
|
-
|
|
350
|
-
|
|
351
|
-
|
|
352
|
-
|
|
353
|
-
|
|
354
|
-
|
|
355
|
-
|
|
356
|
-
logger.children.forEach(processLogger);
|
|
357
|
-
}
|
|
358
|
-
// Обрабатываем все существующие логгеры
|
|
359
|
-
loggerCache.forEach(processLogger);
|
|
360
|
-
// Обрабатываем все существующие логгеры
|
|
361
|
-
Array.from(loggerCache).forEach(([, logger]) => {
|
|
362
|
-
processLogger(logger);
|
|
363
|
-
});
|
|
251
|
+
const debugPattern = environment.getDebugValue() || "";
|
|
252
|
+
const patterns = debugPattern.split(",").map((p) => p.trim()).filter(Boolean);
|
|
253
|
+
const processedLoggers = /* @__PURE__ */ new Set();
|
|
254
|
+
function processLogger(logger) {
|
|
255
|
+
if (processedLoggers.has(logger.id)) return;
|
|
256
|
+
processedLoggers.add(logger.id);
|
|
257
|
+
configureLogger(logger, patterns);
|
|
258
|
+
logger.children.forEach(processLogger);
|
|
259
|
+
}
|
|
260
|
+
loggerCache.forEach(processLogger);
|
|
261
|
+
Array.from(loggerCache).forEach(([, logger]) => {
|
|
262
|
+
processLogger(logger);
|
|
263
|
+
});
|
|
364
264
|
}
|
|
365
|
-
/**
|
|
366
|
-
* Плагин иерархического логгера для loglevel
|
|
367
|
-
*/
|
|
368
265
|
const hierarchicalPlugin = {
|
|
369
|
-
|
|
370
|
-
|
|
371
|
-
|
|
372
|
-
|
|
373
|
-
|
|
374
|
-
|
|
375
|
-
},
|
|
266
|
+
apply(rootLogger) {
|
|
267
|
+
const originalGetLogger = rootLogger.getLogger.bind(rootLogger);
|
|
268
|
+
rootLogger.getLogger = (name) => {
|
|
269
|
+
return createHierarchicalLogger(originalGetLogger, name);
|
|
270
|
+
};
|
|
271
|
+
}
|
|
376
272
|
};
|
|
377
|
-
|
|
378
273
|
const defaultOptions = {
|
|
379
|
-
|
|
274
|
+
format: (level, name, timestamp) => `[${timestamp.toISOString()}] [${level}] [${name}]`
|
|
380
275
|
};
|
|
381
|
-
/**
|
|
382
|
-
* Плагин для добавления префикса к логам
|
|
383
|
-
* @param logger Инстанс логгера
|
|
384
|
-
* @param options Опции плагина
|
|
385
|
-
*/
|
|
386
276
|
function prefix(logger, options = {}) {
|
|
387
|
-
|
|
388
|
-
|
|
389
|
-
|
|
390
|
-
|
|
391
|
-
|
|
392
|
-
|
|
393
|
-
|
|
394
|
-
|
|
395
|
-
|
|
396
|
-
|
|
397
|
-
|
|
398
|
-
|
|
399
|
-
|
|
400
|
-
}
|
|
401
|
-
};
|
|
277
|
+
const mergedOptions = { ...defaultOptions, ...options };
|
|
278
|
+
const originalFactory = logger.methodFactory;
|
|
279
|
+
logger.methodFactory = function(methodName, logLevel, loggerName) {
|
|
280
|
+
const rawMethod = originalFactory(methodName, logLevel, loggerName);
|
|
281
|
+
return function(...args) {
|
|
282
|
+
const level = methodName.toUpperCase();
|
|
283
|
+
const timestamp = /* @__PURE__ */ new Date();
|
|
284
|
+
const prefix2 = mergedOptions.format(level, typeof loggerName === "string" ? loggerName : "", timestamp);
|
|
285
|
+
if (Array.isArray(prefix2)) {
|
|
286
|
+
rawMethod.apply(this, [...prefix2, ...args]);
|
|
287
|
+
} else {
|
|
288
|
+
rawMethod.apply(this, [prefix2, ...args]);
|
|
289
|
+
}
|
|
402
290
|
};
|
|
403
|
-
|
|
291
|
+
};
|
|
292
|
+
return logger;
|
|
404
293
|
}
|
|
405
294
|
const prefixPlugin = {
|
|
406
|
-
|
|
407
|
-
|
|
408
|
-
|
|
295
|
+
apply(rootLogger, options = {}) {
|
|
296
|
+
prefix(rootLogger, options);
|
|
297
|
+
}
|
|
409
298
|
};
|
|
410
|
-
|
|
411
|
-
// Применяем плагины
|
|
412
299
|
hierarchicalPlugin.apply(log);
|
|
413
300
|
prefixPlugin.apply(log, {
|
|
414
|
-
|
|
415
|
-
|
|
416
|
-
|
|
301
|
+
format: (level, name, timestamp) => {
|
|
302
|
+
return environment.formatter(level, name, timestamp);
|
|
303
|
+
}
|
|
417
304
|
});
|
|
418
|
-
// сброс левела чтобы игнорировать запись в сторадже в браузерной имплементации
|
|
419
305
|
log.resetLevel();
|
|
420
|
-
// Пересоздаем методы логгера
|
|
421
306
|
log.rebuild();
|
|
422
307
|
const extendedLog = Object.assign(log, {});
|
|
423
|
-
|
|
424
308
|
exports.hierarchicalPlugin = hierarchicalPlugin;
|
|
425
309
|
exports.log = extendedLog;
|
|
426
310
|
exports.prefixPlugin = prefixPlugin;
|