2022-12-29 23:52:51 +08:00
|
|
|
import log4js, { LoggingEvent, Logger } from "log4js";
|
2022-10-28 16:08:12 +08:00
|
|
|
|
|
|
|
|
const OutputAppender = {
|
|
|
|
|
configure: (config: any, layouts: any, findAppender: any, levels: any) => {
|
2022-10-31 15:01:50 +08:00
|
|
|
let layout = layouts.basicLayout;
|
2022-10-28 16:08:12 +08:00
|
|
|
if (config.layout) {
|
|
|
|
|
layout = layouts.layout(config.layout.type, config.layout);
|
|
|
|
|
}
|
|
|
|
|
function customAppender(layout: any, timezoneOffset: any) {
|
|
|
|
|
return (loggingEvent: LoggingEvent) => {
|
|
|
|
|
if (loggingEvent.context.outputHandler?.write) {
|
|
|
|
|
const text = `${layout(loggingEvent, timezoneOffset)}\n`;
|
|
|
|
|
loggingEvent.context.outputHandler.write(text);
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
return customAppender(layout, config.timezoneOffset);
|
|
|
|
|
},
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
// @ts-ignore
|
2022-10-26 09:02:47 +08:00
|
|
|
log4js.configure({
|
2022-10-28 16:08:12 +08:00
|
|
|
appenders: { std: { type: "stdout" }, output: { type: OutputAppender } },
|
|
|
|
|
categories: { default: { appenders: ["std"], level: "info" }, pipeline: { appenders: ["std", "output"], level: "info" } },
|
2022-10-26 09:02:47 +08:00
|
|
|
});
|
2022-10-28 16:08:12 +08:00
|
|
|
export const logger = log4js.getLogger("default");
|
|
|
|
|
|
|
|
|
|
export function buildLogger(write: (text: string) => void) {
|
|
|
|
|
const logger = log4js.getLogger("pipeline");
|
|
|
|
|
logger.addContext("outputHandler", {
|
|
|
|
|
write,
|
|
|
|
|
});
|
|
|
|
|
return logger;
|
|
|
|
|
}
|
2023-01-11 20:39:48 +08:00
|
|
|
export type ILogger = Logger;
|