From 6fe003db5882f1dec756f3a1fbf2d3309d961d93 Mon Sep 17 00:00:00 2001 From: Michael Lin Date: Wed, 18 Dec 2024 10:49:53 +0800 Subject: [PATCH] fix(logger): add logger ignoreRule (#13) --- packages/logger/src/transports/console.ts | 19 +++++++++++++++++++ 1 file changed, 19 insertions(+) diff --git a/packages/logger/src/transports/console.ts b/packages/logger/src/transports/console.ts index fff54ab..cbd1d61 100644 --- a/packages/logger/src/transports/console.ts +++ b/packages/logger/src/transports/console.ts @@ -14,16 +14,34 @@ export class ConsoleTransport implements ITransport { protected _consoleWrite: LogWriter; + protected _ignoreRules: RegExp[] = []; + constructor( protected _options?: { + /** + * By default the console transport is disabled. + */ enabled?: boolean; + /** + * By default all logs are displayed. + */ filter?: string; + /** + * The storage to save the log. + */ storage?: Storage; + /** + * Ignore logs that match the rules. + */ + ignoreRule?: (string | RegExp)[]; } ) { this._consoleWrite = createLogWriter({ storage: this._options?.storage, }); + this._ignoreRules = (this._options?.ignoreRule ?? []).map((rule) => + rule instanceof RegExp ? rule : new RegExp(rule) + ); } protected get _storage() { @@ -48,6 +66,7 @@ export class ConsoleTransport implements ITransport { } write({ message }: SerializedMessage) { + if (this._ignoreRules.some((regex) => regex.test(message))) return; if (this._options?.enabled) { this._consoleWrite(message); }