@sapphire-sh/utils 1.16.0 → 1.18.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/lib/index.d.ts +2 -0
- package/lib/index.js +3 -1
- package/lib/logger.d.ts +15 -0
- package/lib/logger.js +45 -0
- package/package.json +1 -1
package/lib/index.d.ts
CHANGED
|
@@ -1,5 +1,7 @@
|
|
|
1
1
|
export { getEnumValue } from './getEnumValue';
|
|
2
2
|
export { isNonNullable } from './isNonNullable';
|
|
3
|
+
export { logger } from './logger';
|
|
4
|
+
export type { LogLevel } from './logger';
|
|
3
5
|
export { Queue } from './queue';
|
|
4
6
|
export { sleep } from './sleep';
|
|
5
7
|
export { throttle } from './throttle';
|
package/lib/index.js
CHANGED
|
@@ -1,10 +1,12 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.throttle = exports.sleep = exports.Queue = exports.isNonNullable = exports.getEnumValue = void 0;
|
|
3
|
+
exports.throttle = exports.sleep = exports.Queue = exports.logger = exports.isNonNullable = exports.getEnumValue = void 0;
|
|
4
4
|
var getEnumValue_1 = require("./getEnumValue");
|
|
5
5
|
Object.defineProperty(exports, "getEnumValue", { enumerable: true, get: function () { return getEnumValue_1.getEnumValue; } });
|
|
6
6
|
var isNonNullable_1 = require("./isNonNullable");
|
|
7
7
|
Object.defineProperty(exports, "isNonNullable", { enumerable: true, get: function () { return isNonNullable_1.isNonNullable; } });
|
|
8
|
+
var logger_1 = require("./logger");
|
|
9
|
+
Object.defineProperty(exports, "logger", { enumerable: true, get: function () { return logger_1.logger; } });
|
|
8
10
|
var queue_1 = require("./queue");
|
|
9
11
|
Object.defineProperty(exports, "Queue", { enumerable: true, get: function () { return queue_1.Queue; } });
|
|
10
12
|
var sleep_1 = require("./sleep");
|
package/lib/logger.d.ts
ADDED
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
export declare enum LogLevel {
|
|
2
|
+
DEBUG = 1,
|
|
3
|
+
INFO = 2,
|
|
4
|
+
WARN = 3,
|
|
5
|
+
ERROR = 4
|
|
6
|
+
}
|
|
7
|
+
declare type Payload = Record<string, unknown> | Error;
|
|
8
|
+
export declare const logger: {
|
|
9
|
+
debug: (message: string, payload?: Payload) => void;
|
|
10
|
+
info: (message: string, payload?: Payload) => void;
|
|
11
|
+
warn: (message: string, payload?: Payload) => void;
|
|
12
|
+
error: (message: string, payload?: Payload) => void;
|
|
13
|
+
setLevel: (level: LogLevel) => void;
|
|
14
|
+
};
|
|
15
|
+
export {};
|
package/lib/logger.js
ADDED
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.logger = exports.LogLevel = void 0;
|
|
4
|
+
var LogLevel;
|
|
5
|
+
(function (LogLevel) {
|
|
6
|
+
LogLevel[LogLevel["DEBUG"] = 1] = "DEBUG";
|
|
7
|
+
LogLevel[LogLevel["INFO"] = 2] = "INFO";
|
|
8
|
+
LogLevel[LogLevel["WARN"] = 3] = "WARN";
|
|
9
|
+
LogLevel[LogLevel["ERROR"] = 4] = "ERROR";
|
|
10
|
+
})(LogLevel = exports.LogLevel || (exports.LogLevel = {}));
|
|
11
|
+
function serializePayload(payload) {
|
|
12
|
+
const json = JSON.stringify(payload instanceof Error ? { error: payload.message, name: payload.name, stack: payload.stack } : payload);
|
|
13
|
+
return json.padStart(json.length + 1);
|
|
14
|
+
}
|
|
15
|
+
let currentLevel = LogLevel.INFO;
|
|
16
|
+
function log(level, message, payload) {
|
|
17
|
+
if (level < currentLevel) {
|
|
18
|
+
return;
|
|
19
|
+
}
|
|
20
|
+
const ts = new Date().toISOString();
|
|
21
|
+
const prefix = `[${ts}] [${LogLevel[level].toUpperCase()}]`;
|
|
22
|
+
const payloadStr = payload !== undefined ? serializePayload(payload) : '';
|
|
23
|
+
const output = `${prefix} ${message}${payloadStr}`;
|
|
24
|
+
if (level === LogLevel.ERROR) {
|
|
25
|
+
console.error(output);
|
|
26
|
+
}
|
|
27
|
+
else if (level === LogLevel.WARN) {
|
|
28
|
+
console.warn(output);
|
|
29
|
+
}
|
|
30
|
+
else if (level === LogLevel.DEBUG) {
|
|
31
|
+
console.debug(output);
|
|
32
|
+
}
|
|
33
|
+
else {
|
|
34
|
+
console.log(output);
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
exports.logger = {
|
|
38
|
+
debug: (message, payload) => log(LogLevel.DEBUG, message, payload),
|
|
39
|
+
info: (message, payload) => log(LogLevel.INFO, message, payload),
|
|
40
|
+
warn: (message, payload) => log(LogLevel.WARN, message, payload),
|
|
41
|
+
error: (message, payload) => log(LogLevel.ERROR, message, payload),
|
|
42
|
+
setLevel: (level) => {
|
|
43
|
+
currentLevel = level;
|
|
44
|
+
},
|
|
45
|
+
};
|