nope/lib/logger/eventLogging.ts

143 lines
3.4 KiB
TypeScript
Raw Normal View History

2021-09-09 05:36:01 +00:00
/**
* @author Martin Karkowski
* @email m.karkowski@zema.de
* @create date 2021-05-21 16:44:59
2021-10-19 19:27:30 +00:00
* @modify date 2021-10-19 17:47:39
2021-09-09 05:36:01 +00:00
* @desc [description]
*/
import { EventEmitter } from "events";
import { getSingleton } from "../helpers/singletonMethod";
import { getCentralNopeLogger } from "./getLogger";
import { LoggerLevel } from "./nopeLogger";
export type TCallback = (name: string, msg: string) => void;
2021-12-04 07:25:26 +00:00
export type TCallbackWithLevel = (
level: LoggerLevel,
name: string,
msg: string
) => void;
2021-09-09 05:36:01 +00:00
export class LoggerAsEventEmitter {
constructor(protected _emitter = new EventEmitter()) {
this._emitter = new EventEmitter();
}
/**
* Register a Callback for All Log Messages
*
* @author M.Karkowski
* @param {TCallbackWithLevel} callback The callback to use.
* @memberof LoggerAsEventEmitter
*/
onLog(callback: TCallbackWithLevel): void {
this._emitter.on("log", callback);
}
/**
* Register a Callback for debug messages
*
* @author M.Karkowski
* @param {TCallback} callback The callback to use
* @memberof LoggerAsEventEmitter
*/
onDebug(callback: TCallback): void {
this._emitter.on("log.debug", callback);
}
/**
* Register a Callback for info messages
*
* @author M.Karkowski
* @param {TCallback} callback The callback to use
* @memberof LoggerAsEventEmitter
*/
onInfo(callback: TCallback): void {
this._emitter.on("log.info", callback);
}
/**
* Register a Callback for warn messages
*
* @author M.Karkowski
* @param {TCallback} callback The callback to use
* @memberof LoggerAsEventEmitter
*/
onWarn(callback: TCallback): void {
this._emitter.on("log.warn", callback);
}
/**
* Register a Callback for error messages
*
* @author M.Karkowski
* @param {TCallback} callback The callback to use
* @memberof LoggerAsEventEmitter
*/
onError(callback: TCallback): void {
this._emitter.on("log.error", callback);
}
/**
* Emits a logging message.
*
* @author M.Karkowski
* @param {LoggerLevel} level The logging level
* @param {string} name Name of the Logger.
* @param {string} msg Message
* @memberof LoggerAsEventEmitter
*/
emit(level: LoggerLevel, name: string, msg: string): void {
switch (level) {
case "debug":
this._emitter.emit("log.debug", name, msg);
2021-10-19 19:27:30 +00:00
break;
2021-09-09 05:36:01 +00:00
case "info":
this._emitter.emit("log.info", name, msg);
2021-10-19 19:27:30 +00:00
break;
2021-09-09 05:36:01 +00:00
case "warn":
this._emitter.emit("log.warn", name, msg);
2021-10-19 19:27:30 +00:00
break;
2021-09-09 05:36:01 +00:00
case "error":
this._emitter.emit("log.error", name, msg);
2021-10-19 19:27:30 +00:00
break;
2021-09-09 05:36:01 +00:00
}
2021-10-19 19:27:30 +00:00
this._emitter.emit("log", level, name, msg);
2021-09-09 05:36:01 +00:00
}
}
export function getLogerAsEventEmitter(): LoggerAsEventEmitter {
const res = getSingleton("nope.logger.event", () => {
return new LoggerAsEventEmitter();
});
return res.instance;
}
/**
* Function to use a log file instead of the console log.
*
* @export
*/
2021-10-19 19:27:30 +00:00
export function useEventLogger(): LoggerAsEventEmitter {
2021-09-09 05:36:01 +00:00
const logger = getCentralNopeLogger();
# 1.2.0 - Added: - `lib/cli/nope` adding scan for ui service - `lib/decorators/container`: Main Container, holding all `methods` and `classes`. Use `getCentralDecoratedContainer()` to get this decorator. - `types/nope/nopePackage.interface` added `IClassDescription` which contains the class description used in the Package Description. - `logger/nopeLogger`: added methods: `enabledFor`, `enableFor`, `shouldLog` - `package.json`: installed types of `ace` text editor. - `ui/helpers.browser`: Created `convertInstanceRenderPage` and `IUiDefinition` - `ui/helpers.nodejs`: Added a Helper to write the Ui-File (`writeUiFile`) and parse its arguments (`readInwriteUiFileArgs`) - `ui/index.*`: Crated the corresponding exports. - Modified: - `lib/decorators/*` Adding the main `container` where every function, service method etc is added. All decorators now safe the decorated elements in the container. - `helpers/json`: Adding `BEGIN_STR` and `END_STR` for parsing functions as constants. - `logger/eventLogging`: simplify `useEventLogger` - `logger/index.browser`: Adating exports. - `loader/loadPackages`: Modifing `IPackageConfig` now extends Partial the `IPackageDescription` - `types/ui/editor/IEditPage`: adapting Type of `getData` to `T`->`any`. Adapting the return of `getPorts` (The Ports will be generated in the ui then) - `types/ui/editor/helpers.interface`: Adapting the `w2ui` and added `w2uiHelpers` and added `ace`. Rearanging `IRenderData` element. to compact the data. - `types/ui/editor/render.callbacks`: Rearange the Generic Type of `TRenderInstancePage` and Renaming `TCreatorPage` to `TInstanceManagerPage`. Adapting the `option` of `TInstanceManagerPage` regarding the `createInstance` and `instances` - `types/ui/editor/index`: Adapting the Exports. - `lib/index.browser`: Exporting `ui` elements - `lib/index.nodejs`: Exporting `ui` elements - `lib/types/index`: Exporting `ui` elements - Fixes: - `types/nope/nopeInstanceManager.interface`: Fixing Type of createInstance. Now the Type `I` extends `INopeModule` instead of being set to `IGenericNopeModule`
2022-07-02 09:30:10 +00:00
const emitter = getLogerAsEventEmitter();
2021-09-09 05:36:01 +00:00
logger.setHandler((msg, context) => {
const msgs: string[] = [];
// Change the msg to an string based Object.
for (const key in msg) {
msgs.push(msg[key].toString());
}
2021-12-04 07:25:26 +00:00
emitter.emit(
context.level.name.toLowerCase(),
context.name,
msgs.join(" ")
);
2021-09-09 05:36:01 +00:00
});
return emitter;
}