@ncoderz/log-m8 1.0.2 → 1.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.cjs CHANGED
@@ -23,8 +23,8 @@ var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "sy
23
23
  var index_exports = {};
24
24
  __export(index_exports, {
25
25
  LogLevel: () => LogLevel,
26
+ LogM8: () => LogM82,
26
27
  LogM8Utils: () => LogM8Utils,
27
- Logging: () => Logging,
28
28
  PluginKind: () => PluginKind
29
29
  });
30
30
  module.exports = __toCommonJS(index_exports);
@@ -1027,16 +1027,27 @@ var DEFAULT_APPENDERS = [
1027
1027
  ];
1028
1028
  var LogM8 = class {
1029
1029
  constructor() {
1030
- __publicField(this, "_initialized", false);
1031
- __publicField(this, "_pluginManager", new PluginManager());
1032
- __publicField(this, "_loggers", /* @__PURE__ */ new Map());
1033
- __publicField(this, "_appenders", []);
1030
+ __publicField(this, "_initialized");
1031
+ __publicField(this, "_pluginManager");
1032
+ __publicField(this, "_loggers");
1033
+ __publicField(this, "_appenders");
1034
1034
  __publicField(this, "_filters", []);
1035
- __publicField(this, "_defaultLevel", LogLevel.info);
1036
- __publicField(this, "_logLevelValues", Object.values(LogLevel));
1037
- __publicField(this, "_logLevelSet", new Set(this._logLevelValues));
1035
+ __publicField(this, "_globalLogLevel");
1036
+ __publicField(this, "_globalLogLevelNumber");
1037
+ __publicField(this, "_logLevelValues");
1038
+ __publicField(this, "_logLevelSet");
1038
1039
  // Buffer for log events before the system is initialized
1039
- __publicField(this, "_logBuffer", []);
1040
+ __publicField(this, "_logBuffer");
1041
+ this._initialized = false;
1042
+ this._pluginManager = new PluginManager();
1043
+ this._loggers = /* @__PURE__ */ new Map();
1044
+ this._appenders = [];
1045
+ this._filters = [];
1046
+ this._logLevelValues = Object.values(LogLevel);
1047
+ this._logLevelSet = new Set(this._logLevelValues);
1048
+ this._globalLogLevel = LogLevel.info;
1049
+ this._globalLogLevelNumber = this._logLevelValues.indexOf(LogLevel.info);
1050
+ this._logBuffer = [];
1040
1051
  this._pluginManager.registerPluginFactory(new ConsoleAppenderFactory());
1041
1052
  this._pluginManager.registerPluginFactory(new FileAppenderFactory());
1042
1053
  this._pluginManager.registerPluginFactory(new DefaultFormatterFactory());
@@ -1073,10 +1084,10 @@ var LogM8 = class {
1073
1084
  init(config) {
1074
1085
  config = Object.assign({}, config);
1075
1086
  this._reset();
1076
- this._defaultLevel = this._logLevelSet.has(config.level) ? config.level : LogLevel.info;
1087
+ this._globalLogLevel = this._logLevelSet.has(config.level) ? config.level : LogLevel.info;
1077
1088
  for (const [name, level] of Object.entries(config.loggers ?? {})) {
1078
1089
  const logger = this.getLogger(name);
1079
- const l = this._logLevelSet.has(level) ? level : this._defaultLevel;
1090
+ const l = this._logLevelSet.has(level) ? level : this._globalLogLevel;
1080
1091
  logger.setLevel(l);
1081
1092
  }
1082
1093
  const appenderConfigs = config.appenders ?? DEFAULT_APPENDERS;
@@ -1173,7 +1184,7 @@ var LogM8 = class {
1173
1184
  if (existingLogger) return existingLogger;
1174
1185
  const logger = {
1175
1186
  name: nameStr,
1176
- level: this._defaultLevel,
1187
+ level: this._globalLogLevel,
1177
1188
  context: {}
1178
1189
  };
1179
1190
  logger.fatal = this._log.bind(this, logger, LogLevel.fatal);
@@ -1186,10 +1197,24 @@ var LogM8 = class {
1186
1197
  logger.setLevel = this._setLevel.bind(this, logger);
1187
1198
  logger.setContext = this._setContext.bind(this, logger);
1188
1199
  logger.getLogger = (name2) => this.getLogger([logger.name, name2]);
1189
- this._setLevel(logger, this._defaultLevel);
1200
+ this._setLevel(logger, this._globalLogLevel);
1190
1201
  this._loggers.set(logger.name, logger);
1191
1202
  return logger;
1192
1203
  }
1204
+ /**
1205
+ * Sets the global logging level or a specific logger's level.
1206
+ *
1207
+ * @param level - New logging level name (e.g., 'info', 'debug', 'off')
1208
+ * @param logger - Optional logger name to set level for a specific logger
1209
+ */
1210
+ setLevel(level, logger) {
1211
+ if (logger) {
1212
+ this.getLogger(logger).setLevel(level);
1213
+ } else {
1214
+ this._globalLogLevel = this._logLevelSet.has(level) ? level : this._globalLogLevel;
1215
+ this._globalLogLevelNumber = this._logLevelValues.indexOf(this._globalLogLevel);
1216
+ }
1217
+ }
1193
1218
  /**
1194
1219
  * Enables an appender to resume processing log events.
1195
1220
  *
@@ -1320,7 +1345,7 @@ var LogM8 = class {
1320
1345
  }
1321
1346
  _log(logger, level, message, ...data) {
1322
1347
  const levelNumber = this._logLevelValues.indexOf(level);
1323
- if (levelNumber > logger._levelNumber) return;
1348
+ if (levelNumber > logger._levelNumber || levelNumber > this._globalLogLevelNumber) return;
1324
1349
  const logEvent = {
1325
1350
  logger: logger.name,
1326
1351
  level,
@@ -1345,9 +1370,9 @@ var LogM8 = class {
1345
1370
  }
1346
1371
  }
1347
1372
  _setLevel(logger, level) {
1348
- logger.level = level;
1373
+ logger.level = this._logLevelSet.has(level) ? level : logger.level;
1349
1374
  logger._levelNumber = this._logLevelValues.indexOf(level);
1350
- logger.isEnabled = level !== LogLevel.off;
1375
+ logger.isEnabled = logger.level !== LogLevel.off;
1351
1376
  const levelNumber = logger._levelNumber;
1352
1377
  logger.isFatal = this._logLevelValues.indexOf(LogLevel.fatal) <= levelNumber;
1353
1378
  logger.isError = this._logLevelValues.indexOf(LogLevel.error) <= levelNumber;
@@ -1395,18 +1420,18 @@ var LogM8 = class {
1395
1420
  this.flushAppenders();
1396
1421
  this._appenders = [];
1397
1422
  this._loggers.clear();
1398
- this._defaultLevel = LogLevel.info;
1423
+ this._globalLogLevel = LogLevel.info;
1399
1424
  this._pluginManager.disposePlugins();
1400
1425
  }
1401
1426
  };
1402
1427
 
1403
1428
  // src/index.ts
1404
- var Logging = new LogM8();
1429
+ var LogM82 = new LogM8();
1405
1430
  // Annotate the CommonJS export names for ESM import in node:
1406
1431
  0 && (module.exports = {
1407
1432
  LogLevel,
1433
+ LogM8,
1408
1434
  LogM8Utils,
1409
- Logging,
1410
1435
  PluginKind
1411
1436
  });
1412
1437
  //# sourceMappingURL=index.cjs.map