111 lines
14 KiB
JavaScript
111 lines
14 KiB
JavaScript
import config from "config";
|
|
import { v4 as uuid } from "uuid";
|
|
import Log from "./models/Log";
|
|
const LOG_LEVEL = config.get('log_level');
|
|
const DB_LOG_LEVEL = config.get('db_log_level');
|
|
export default class Logger {
|
|
static silentError(error, ...message) {
|
|
return this.log('ERROR', message, error, true) || '';
|
|
}
|
|
static error(error, ...message) {
|
|
return this.log('ERROR', message, error) || '';
|
|
}
|
|
static warn(...message) {
|
|
this.log('WARN', message);
|
|
}
|
|
static info(...message) {
|
|
this.log('INFO', message);
|
|
}
|
|
static debug(...message) {
|
|
this.log('DEBUG', message);
|
|
}
|
|
static dev(...message) {
|
|
this.log('DEV', message);
|
|
}
|
|
static log(level, message, error, silent = false) {
|
|
const levelIndex = LogLevel[level];
|
|
if (levelIndex <= LogLevel[LOG_LEVEL]) {
|
|
if (error) {
|
|
if (levelIndex > LogLevel.ERROR)
|
|
this.warn(`Wrong log level ${level} with attached error.`);
|
|
}
|
|
else {
|
|
if (levelIndex <= LogLevel.ERROR)
|
|
this.warn(`No error attached with log level ${level}.`);
|
|
}
|
|
const computedMsg = message.map(v => {
|
|
if (typeof v === 'string') {
|
|
return v;
|
|
}
|
|
else {
|
|
return JSON.stringify(v, (key, value) => {
|
|
if (value instanceof Object) {
|
|
if (value.type === 'Buffer') {
|
|
return `Buffer<${Buffer.from(value.data).toString('hex')}>`;
|
|
}
|
|
else if (value !== v) {
|
|
return `[object Object]`;
|
|
}
|
|
}
|
|
if (typeof value === 'string' && value.length > 96) {
|
|
return value.substr(0, 96) + '...';
|
|
}
|
|
return value;
|
|
}, 4);
|
|
}
|
|
}).join(' ');
|
|
const log = new Log({});
|
|
log.setLevel(level);
|
|
log.message = computedMsg;
|
|
log.setError(error);
|
|
let logID = Buffer.alloc(16);
|
|
uuid({}, logID);
|
|
log.setLogID(logID);
|
|
let output = `[${level}] `;
|
|
let pad = output.length;
|
|
if (levelIndex <= LogLevel[DB_LOG_LEVEL])
|
|
output += `${log.getLogID()} - `;
|
|
output += computedMsg.replace(/\n/g, '\n' + ' '.repeat(pad));
|
|
switch (level) {
|
|
case "ERROR":
|
|
if (silent || !error) {
|
|
console.error(output);
|
|
}
|
|
else {
|
|
console.error(output, error);
|
|
}
|
|
break;
|
|
case "WARN":
|
|
console.warn(output);
|
|
break;
|
|
case "INFO":
|
|
console.info(output);
|
|
break;
|
|
case "DEBUG":
|
|
case "DEV":
|
|
console.debug(output);
|
|
break;
|
|
}
|
|
if (levelIndex <= LogLevel[DB_LOG_LEVEL]) {
|
|
log.save().catch(err => {
|
|
if (!silent && err.message.indexOf('ECONNREFUSED') < 0) {
|
|
console.error({ save_err: err, error });
|
|
}
|
|
});
|
|
}
|
|
return log.getLogID();
|
|
}
|
|
return null;
|
|
}
|
|
constructor() {
|
|
}
|
|
}
|
|
export var LogLevel;
|
|
(function (LogLevel) {
|
|
LogLevel[LogLevel["ERROR"] = 0] = "ERROR";
|
|
LogLevel[LogLevel["WARN"] = 1] = "WARN";
|
|
LogLevel[LogLevel["INFO"] = 2] = "INFO";
|
|
LogLevel[LogLevel["DEBUG"] = 3] = "DEBUG";
|
|
LogLevel[LogLevel["DEV"] = 4] = "DEV";
|
|
})(LogLevel || (LogLevel = {}));
|
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Logger.js","sourceRoot":"./","sources":["Logger.ts"],"names":[],"mappings":"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","sourcesContent":["import config from \"config\";\nimport {v4 as uuid} from \"uuid\";\nimport Log from \"./models/Log\";\n\nconst LOG_LEVEL: LogLevelKeys = <LogLevelKeys>config.get<string>('log_level');\nconst DB_LOG_LEVEL: LogLevelKeys = <LogLevelKeys>config.get<string>('db_log_level');\n\nexport default class Logger {\n    public static silentError(error: Error, ...message: any[]): string {\n        return this.log('ERROR', message, error, true) || '';\n    }\n\n    public static error(error: Error, ...message: any[]): string {\n        return this.log('ERROR', message, error) || '';\n    }\n\n    public static warn(...message: any[]) {\n        this.log('WARN', message);\n    }\n\n    public static info(...message: any[]) {\n        this.log('INFO', message);\n    }\n\n    public static debug(...message: any[]) {\n        this.log('DEBUG', message);\n    }\n\n    public static dev(...message: any[]) {\n        this.log('DEV', message);\n    }\n\n    private static log(level: LogLevelKeys, message: any[], error?: Error, silent: boolean = false): string | null {\n        const levelIndex = LogLevel[level];\n        if (levelIndex <= LogLevel[LOG_LEVEL]) {\n            if (error) {\n                if (levelIndex > LogLevel.ERROR) this.warn(`Wrong log level ${level} with attached error.`);\n            } else {\n                if (levelIndex <= LogLevel.ERROR) this.warn(`No error attached with log level ${level}.`);\n            }\n\n            const computedMsg = message.map(v => {\n                if (typeof v === 'string') {\n                    return v;\n                } else {\n                    return JSON.stringify(v, (key: string, value: any) => {\n                        if (value instanceof Object) {\n                            if (value.type === 'Buffer') {\n                                return `Buffer<${Buffer.from(value.data).toString('hex')}>`;\n                            } else if (value !== v) {\n                                return `[object Object]`;\n                            }\n                        }\n                        if (typeof value === 'string' && value.length > 96) {\n                            return value.substr(0, 96) + '...';\n                        }\n                        return value;\n                    }, 4);\n                }\n            }).join(' ');\n\n            const log = new Log({});\n            log.setLevel(level);\n            log.message = computedMsg;\n            log.setError(error);\n\n            let logID = Buffer.alloc(16);\n            uuid({}, logID);\n            log.setLogID(logID);\n\n\n            let output = `[${level}] `;\n            let pad = output.length;\n            if (levelIndex <= LogLevel[DB_LOG_LEVEL]) output += `${log.getLogID()} - `;\n            output += computedMsg.replace(/\\n/g, '\\n' + ' '.repeat(pad));\n\n            switch (level) {\n                case \"ERROR\":\n                    if (silent || !error) {\n                        console.error(output);\n                    } else {\n                        console.error(output, error);\n                    }\n                    break;\n                case \"WARN\":\n                    console.warn(output);\n                    break;\n                case \"INFO\":\n                    console.info(output);\n                    break;\n                case \"DEBUG\":\n                case \"DEV\":\n                    console.debug(output);\n                    break;\n            }\n\n            if (levelIndex <= LogLevel[DB_LOG_LEVEL]) {\n                log.save().catch(err => {\n                    if (!silent && err.message.indexOf('ECONNREFUSED') < 0) {\n                        console.error({save_err: err, error});\n                    }\n                });\n            }\n            return log.getLogID();\n        }\n        return null;\n    }\n\n    private constructor() {\n    }\n}\n\nexport enum LogLevel {\n    ERROR,\n    WARN,\n    INFO,\n    DEBUG,\n    DEV,\n}\n\nexport type LogLevelKeys = keyof typeof LogLevel;\n"]}
|