logcontext/ts/logcontext.classes.logger.ts

124 lines
2.7 KiB
TypeScript
Raw Normal View History

2023-01-12 10:58:34 +00:00
import * as plugins from './logcontext.plugins.js';
import { LogMap } from './logcontext.classes.logmap.js';
2018-03-03 13:11:27 +00:00
export class Logger {
2021-09-17 17:21:34 +00:00
public namespaceString: string;
2020-07-20 11:57:20 +00:00
smartcls: plugins.smartcls.SmartCls;
2021-09-17 17:21:34 +00:00
public logmap: LogMap;
public thirdPartyLogger: any;
2018-03-03 13:11:27 +00:00
settings = {
enableScope: () => {
this.settingsParams.scope = true;
},
disableScope: () => {
this.settingsParams.scope = false;
},
enableAddData: () => {
this.settingsParams.addData = true;
},
disableAddData: () => {
this.settingsParams.addData = false;
2020-07-20 11:57:20 +00:00
},
2018-03-03 13:11:27 +00:00
};
private settingsParams: { scope: boolean; addData: boolean } = {
scope: true,
2020-07-20 11:57:20 +00:00
addData: true,
2018-03-03 13:11:27 +00:00
};
2020-07-20 11:57:20 +00:00
constructor(namespaceArg: string = plugins.smartunique.shortId()) {
2018-03-03 13:11:27 +00:00
this.namespaceString = namespaceArg;
2020-07-20 11:57:20 +00:00
this.smartcls = new plugins.smartcls.SmartCls();
this.logmap = new LogMap(this.smartcls);
2018-03-03 13:11:27 +00:00
}
addData(paramNameArg: string, dataArg: any) {
if (this.settingsParams.addData) {
this.logmap.addData(paramNameArg, dataArg);
}
}
2021-09-17 17:21:34 +00:00
addThirdPartyLogger(thirdPartyLoggerArg: any) {
2018-03-03 13:11:27 +00:00
this.thirdPartyLogger = thirdPartyLoggerArg;
}
/**
* debug
* @param logMessageArg
*/
2021-09-17 17:21:34 +00:00
debug(logMessageArg: string) {
2018-03-03 13:11:27 +00:00
this.routeLog('debug', logMessageArg);
}
/**
* log
* @param logMessageArg
*/
2021-09-17 17:21:34 +00:00
log(logMessageArg: string) {
2018-03-03 13:11:27 +00:00
this.routeLog('log', logMessageArg);
}
/**
* info
2021-09-17 17:21:34 +00:00
* @param logMessageArg
2018-03-03 13:11:27 +00:00
*/
2021-09-17 17:21:34 +00:00
info(logMessageArg: string) {
this.routeLog('info', logMessageArg);
2018-03-03 13:11:27 +00:00
}
/**
* error
* @param logMessageArg
* @param args
*/
2021-09-17 17:21:34 +00:00
error(logMessageArg: string, ...args: any) {
2018-03-03 13:11:27 +00:00
this.routeLog('error', logMessageArg, ...args);
}
/**
* warn
* @param logMessageArg
* @param args
*/
2021-09-17 17:21:34 +00:00
warn(logMessageArg: string, ...args: any) {
2018-03-03 13:11:27 +00:00
this.routeLog('warn', logMessageArg, ...args);
}
/**
* fatal
* @param logMessageArg
* @param args
*/
2021-09-17 17:21:34 +00:00
fatal(logMessageArg: string, ...args: any) {
2018-03-03 13:11:27 +00:00
this.routeLog('fatal', logMessageArg, ...args);
}
// creates a new async scope
scope(funcArg: any) {
// create node continuation scope
if (this.settingsParams.scope) {
2020-07-20 11:57:20 +00:00
this.smartcls.run(funcArg);
2018-03-03 13:11:27 +00:00
} else {
funcArg();
}
}
/**
* routes the log according to whats available in the environment
* @param {string} logMethod
2021-09-17 17:21:34 +00:00
* @param {any} messageArg
2018-03-03 13:11:27 +00:00
* @param {any[]} ...args
*/
2021-09-17 17:21:34 +00:00
private routeLog(logMethod: string, messageArg: string, ...args: any) {
2020-07-20 11:57:20 +00:00
const logObject = {
2021-09-17 17:21:34 +00:00
message: messageArg,
2018-03-03 13:11:27 +00:00
type: logMethod,
2020-07-20 11:57:20 +00:00
logContext: this.logmap.getAllData(),
2018-03-03 13:11:27 +00:00
};
if (this.thirdPartyLogger && this.thirdPartyLogger[logMethod]) {
this.thirdPartyLogger[logMethod](logObject, ...args);
} else {
console.log(logObject);
}
}
}