@punks/backend-core 0.0.29 → 0.0.31

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.
@@ -5,6 +5,10 @@ export declare enum LogLevel {
5
5
  Error = 3,
6
6
  Fatal = 4
7
7
  }
8
+ export declare enum MetaSerializationType {
9
+ None = 0,
10
+ JSON = 1
11
+ }
8
12
  export interface ILoggerProvider {
9
13
  debug(message: string, meta?: any): void;
10
14
  info(message: string, meta?: any): void;
@@ -1,7 +1,9 @@
1
- import { ILogger, LogLevel } from "../abstractions";
1
+ import { ILogger, LogLevel, MetaSerializationType } from "../abstractions";
2
2
  export declare class Log {
3
3
  private static enabled;
4
4
  private static level;
5
+ private static metaSerialization;
6
+ static setSerializationType(type: MetaSerializationType): void;
5
7
  static setLevel(level: LogLevel): void;
6
8
  static enable(): void;
7
9
  static disable(): void;
@@ -4,4 +4,4 @@ export type TreeNodeBuilder<TKey, TRecord, TTreeNode extends ITreeNode<TKey, TRe
4
4
  parentIdSelector: (record: TRecord) => TKey | undefined;
5
5
  additionalPropsBuilder?: (record: TRecord, ancestors: TRecord[], children: TRecord[]) => Promise<Omit<TTreeNode, "id" | "children" | "value">>;
6
6
  };
7
- export declare const buildTree: <TKey, TRecord, TTreeNode extends ITreeNode<TKey, TRecord>>(data: TRecord[], nodeBuilder: TreeNodeBuilder<TKey, TRecord, TTreeNode>) => Promise<ITree<TKey, TRecord>>;
7
+ export declare const buildTree: <TKey, TRecord, TTreeNode extends ITreeNode<TKey, TRecord>, TTree extends ITree<TKey, TRecord>>(data: TRecord[], nodeBuilder: TreeNodeBuilder<TKey, TRecord, TTreeNode>) => Promise<TTree>;
package/dist/esm/index.js CHANGED
@@ -10,6 +10,11 @@ var LogLevel;
10
10
  LogLevel[LogLevel["Error"] = 3] = "Error";
11
11
  LogLevel[LogLevel["Fatal"] = 4] = "Fatal";
12
12
  })(LogLevel || (LogLevel = {}));
13
+ var MetaSerializationType;
14
+ (function (MetaSerializationType) {
15
+ MetaSerializationType[MetaSerializationType["None"] = 0] = "None";
16
+ MetaSerializationType[MetaSerializationType["JSON"] = 1] = "JSON";
17
+ })(MetaSerializationType || (MetaSerializationType = {}));
13
18
 
14
19
  class DefaultLogger {
15
20
  constructor(loggerName) {
@@ -66,46 +71,59 @@ class DefaultLogger {
66
71
  }
67
72
 
68
73
  class InternalLogger {
69
- constructor(enabled, level, provider) {
74
+ constructor(enabled, level, serialization, provider) {
70
75
  this.enabled = enabled;
71
76
  this.level = level;
77
+ this.serialization = serialization;
72
78
  this.provider = provider;
73
79
  }
74
80
  debug(message, meta) {
75
81
  if (this.enabled && this.level === LogLevel.Debug) {
76
- this.provider.debug(message, meta);
82
+ this.provider.debug(message, this.serializeMeta(meta));
77
83
  }
78
84
  }
79
85
  info(message, meta) {
80
86
  if (this.enabled && this.level <= LogLevel.Info) {
81
- this.provider.info(message, meta);
87
+ this.provider.info(message, this.serializeMeta(meta));
82
88
  }
83
89
  }
84
90
  warn(message, meta) {
85
91
  if (this.enabled && this.level <= LogLevel.Warn) {
86
- this.provider.warn(message, meta);
92
+ this.provider.warn(message, this.serializeMeta(meta));
87
93
  }
88
94
  }
89
95
  error(message, meta) {
90
96
  if (this.enabled && this.level <= LogLevel.Error) {
91
- this.provider.error(message, meta);
97
+ this.provider.error(message, this.serializeMeta(meta));
92
98
  }
93
99
  }
94
100
  fatal(message, meta) {
95
101
  if (this.enabled && this.level <= LogLevel.Fatal) {
96
- this.provider.fatal(message, meta);
102
+ this.provider.fatal(message, this.serializeMeta(meta));
97
103
  }
98
104
  }
99
105
  exception(message, error, meta) {
100
106
  if (this.enabled && this.level <= LogLevel.Error) {
101
- this.provider.exception(message, error, meta);
107
+ this.provider.exception(message, error, this.serializeMeta(meta));
108
+ }
109
+ }
110
+ serializeMeta(meta) {
111
+ switch (this.serialization) {
112
+ case MetaSerializationType.JSON:
113
+ return JSON.stringify(meta, null, 2);
114
+ case MetaSerializationType.None:
115
+ default:
116
+ return meta;
102
117
  }
103
118
  }
104
119
  }
105
- const getLogger = ({ enabled, level, loggerName, }) => {
106
- return new InternalLogger(enabled, level, new DefaultLogger(loggerName));
120
+ const getLogger = ({ enabled, level, loggerName, serialization, }) => {
121
+ return new InternalLogger(enabled, level, serialization, new DefaultLogger(loggerName));
107
122
  };
108
123
  class Log {
124
+ static setSerializationType(type) {
125
+ this.metaSerialization = type;
126
+ }
109
127
  static setLevel(level) {
110
128
  this.level = level;
111
129
  this.enabled = true;
@@ -120,12 +138,14 @@ class Log {
120
138
  return getLogger({
121
139
  enabled: this.enabled,
122
140
  level: this.level,
141
+ serialization: this.metaSerialization,
123
142
  loggerName,
124
143
  });
125
144
  }
126
145
  }
127
146
  Log.enabled = true;
128
147
  Log.level = LogLevel.Debug;
148
+ Log.metaSerialization = MetaSerializationType.None;
129
149
 
130
150
  const range = (start, end) => {
131
151
  return new Array(end - start + 1).fill(undefined).map((x, i) => i + start);
@@ -28416,5 +28436,5 @@ const excelParse = (file, options) => {
28416
28436
  .map((x) => aggregateRow(header, x, options));
28417
28437
  };
28418
28438
 
28419
- export { ExcelKeyTransform, Log, LogLevel, buildObject, buildTree, byField, byFieldDesc, camelToKebabCase, camelToSnakeCase, csvBuild, csvParse, distinct, distinctElements, ensureDirectory, ensureStartSlash, ensureTailingSlash, excelBuild, excelParse, first, flatten, getDirectoryFilePaths, getDirectoryPath, groupBy, indexes, isNullOrUndefined, iterate, joinPath, jsonDistinct, last, mapOrThrow, newUuid, notNull, notUndefined, pluralize, range, removeUndefinedProps, selectMany, sleep, sort, splitPath, toCamelCase, toDict, toItemsDict, toItemsMap, toMap, toTitleCase, trim$1 as trim, trimEnd, trimStart };
28439
+ export { ExcelKeyTransform, Log, LogLevel, MetaSerializationType, buildObject, buildTree, byField, byFieldDesc, camelToKebabCase, camelToSnakeCase, csvBuild, csvParse, distinct, distinctElements, ensureDirectory, ensureStartSlash, ensureTailingSlash, excelBuild, excelParse, first, flatten, getDirectoryFilePaths, getDirectoryPath, groupBy, indexes, isNullOrUndefined, iterate, joinPath, jsonDistinct, last, mapOrThrow, newUuid, notNull, notUndefined, pluralize, range, removeUndefinedProps, selectMany, sleep, sort, splitPath, toCamelCase, toDict, toItemsDict, toItemsMap, toMap, toTitleCase, trim$1 as trim, trimEnd, trimStart };
28420
28440
  //# sourceMappingURL=index.js.map