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