@decaf-ts/logging 0.0.17 → 0.2.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/logging.cjs +512 -0
- package/dist/logging.esm.cjs +501 -0
- package/lib/constants.cjs +116 -18
- package/lib/constants.d.ts +81 -0
- package/lib/esm/constants.d.ts +81 -0
- package/lib/esm/constants.js +115 -17
- package/{dist/types → lib/esm}/index.d.ts +2 -5
- package/lib/esm/index.js +3 -7
- package/lib/esm/logging.d.ts +178 -0
- package/lib/esm/logging.js +353 -38
- package/lib/esm/types.d.ts +205 -0
- package/lib/esm/types.js +2 -0
- package/lib/esm/winston/index.d.ts +0 -0
- package/lib/esm/winston/index.js +2 -0
- package/lib/esm/winston/winston.d.ts +12 -0
- package/lib/esm/winston/winston.js +44 -0
- package/lib/index.cjs +3 -7
- package/lib/index.d.ts +21 -0
- package/lib/logging.cjs +354 -38
- package/lib/logging.d.ts +178 -0
- package/lib/types.cjs +3 -0
- package/lib/types.d.ts +205 -0
- package/lib/winston/index.cjs +2 -0
- package/lib/winston/index.d.ts +0 -0
- package/lib/winston/winston.cjs +52 -0
- package/lib/winston/winston.d.ts +12 -0
- package/package.json +25 -35
- package/dist/esm/logging.js +0 -1
- package/dist/logging.js +0 -1
- package/dist/types/Factory.d.ts +0 -13
- package/dist/types/constants.d.ts +0 -19
- package/dist/types/default.d.ts +0 -9
- package/dist/types/interfaces.d.ts +0 -21
- package/dist/types/logging.d.ts +0 -25
- package/dist/types/utils.d.ts +0 -2
- package/dist/types/winston.d.ts +0 -15
- package/lib/Factory.cjs +0 -11
- package/lib/default.cjs +0 -77
- package/lib/esm/Factory.js +0 -7
- package/lib/esm/default.js +0 -73
- package/lib/esm/interfaces.js +0 -3
- package/lib/esm/utils.js +0 -9
- package/lib/esm/winston.js +0 -39
- package/lib/interfaces.cjs +0 -4
- package/lib/utils.cjs +0 -12
- package/lib/winston.cjs +0 -43
package/lib/types.cjs
ADDED
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"","sourcesContent":["import { styles } from \"styled-string-builder\";\nimport { LoggingMode, LogLevel } from \"./constants\";\n\nexport type StringLike = string | { toString: () => string };\n\nexport type LoggingContext =\n  | string\n  | { new (...args: any[]): any }\n  | ((...args: any[]) => any);\n\n/**\n * @description Interface for a logger with verbosity levels.\n * @summary Defines methods for logging at different verbosity levels.\n * @interface Logger\n * @memberOf @decaf-ts/utils\n */\nexport interface Logger {\n  /**\n   * @description Logs a `way too verbose` or a silly message.\n   * @param {StringLike} msg - The message to log.\n   */\n  silly(msg: StringLike): void;\n  /**\n   * @description Logs a verbose message.\n   * @param {StringLike} msg - The message to log.\n   * @param {number} verbosity - The verbosity level of the message.\n   */\n  verbose(msg: StringLike, verbosity?: number): void;\n\n  /**\n   * @description Logs an info message.\n   * @param {StringLike} msg - The message to log.\n   */\n  info(msg: StringLike): void;\n\n  /**\n   * @description Logs an error message.\n   * @param {StringLike | Error} msg - The message to log.\n   */\n  error(msg: StringLike | Error): void;\n\n  /**\n   * @description Logs a debug message.\n   * @param {string} msg - The message to log.\n   */\n  debug(msg: StringLike): void;\n\n  for(\n    method?: string | ((...args: any[]) => any),\n    config?: Partial<LoggingConfig>\n  ): Logger;\n\n  setConfig(config: Partial<LoggingConfig>): void;\n}\n\n/**\n * @description Configuration for logging.\n * @summary Defines the log level and verbosity for logging.\n * @typedef {Object} LoggingConfig\n * @property {LogLevel} level - The logging level.\n * @property {number} verbose - The verbosity level.\n * @memberOf @decaf-ts/utils\n */\nexport type LoggingConfig = {\n  level: LogLevel;\n  logLevel?: boolean;\n  verbose: number;\n  mode?: LoggingMode;\n  separator: string;\n  style?: boolean;\n  timestamp?: boolean;\n  timestampFormat?: string;\n  context?: boolean;\n  theme?: Theme;\n};\n\nexport type LoggerFactory<L extends Logger = Logger> = (\n  object: string,\n  config?: Partial<LoggingConfig>,\n  id?: string\n) => L;\n\n/**\n /**\n * @description Represents a theme option for console output styling.\n * @summary Defines the structure for styling a specific element in the console output.\n * It allows for customization of foreground color, background color, and additional styles.\n * Colors can be specified as a single number, an RGB array, or left undefined for default.\n *\n * @interface ThemeOption\n * @memberOf @decaf-ts/utils\n */\nexport interface ThemeOption {\n  fg?: number | [number] | [number, number, number];\n\n  bg?: number | [number] | [number, number, number];\n\n  style?: number[] | [keyof typeof styles];\n}\n\nexport type ThemeOptionByLogLevel = Partial<Record<LogLevel, ThemeOption>>;\n\n/**\n /**\n * @description Defines the color theme for console output.\n * @summary This interface specifies the color scheme for various elements of console output,\n * including styling for different log levels and components. It uses ThemeOption to\n * define the styling for each element, allowing for customization of colors and styles\n * for different parts of the log output.\n *\n * @interface Theme\n * @memberOf @decaf-ts/utils\n */\nexport interface Theme {\n  /**\n   * @description Styling for class names in the output.\n   */\n  class: ThemeOption | ThemeOptionByLogLevel;\n\n  /**\n   * @description Styling for timestamps in the output.\n   */\n  timestamp: ThemeOption | ThemeOptionByLogLevel;\n\n  /**\n   * @description Styling for the main message text in the output.\n   */\n  message: ThemeOption | ThemeOptionByLogLevel;\n\n  /**\n   * @description Styling for method names in the output.\n   */\n  method: ThemeOption | ThemeOptionByLogLevel;\n\n  /**\n   * @description Styling for identifier elements in the output.\n   */\n  id: ThemeOption | ThemeOptionByLogLevel;\n\n  /**\n   * @description Styling for identifier elements in the output.\n   */\n  stack: ThemeOption;\n\n  /**\n   * @description Styling for different log levels in the output.\n   */\n  logLevel: ThemeOptionByLogLevel;\n}\n\n/**\n * @description Represents a color function in the Kleur library.\n * @summary The Color interface defines a function that can be called with or without arguments\n * to apply color styling to text or chain multiple color operations.\n *\n * @interface Color\n * @memberOf module:@decaf-ts/utils\n * */\nexport interface Color {\n  /**\n   * @description Applies the color to the given text.\n   * @param {string | number} x - The text or number to be colored.\n   * @return {string} The colored text.\n   */\n  (x: string | number): string;\n\n  /**\n   * @description Allows chaining of multiple color operations.\n   * @return {Kleur} The Kleur instance for method chaining.\n   */\n  (): Kleur;\n}\n\n/**\n * @description Represents the main Kleur interface with all available color and style methods.\n * @summary The Kleur interface provides methods for applying various colors, background colors,\n * and text styles to strings in terminal output.\n *\n * @interface Kleur\n * @memberOf module:@decaf-ts/utils\n */\nexport interface Kleur {\n  // Colors\n  /** @description Applies black color to the text. */\n  black: Color;\n  /** @description Applies red color to the text. */\n  red: Color;\n  /** @description Applies green color to the text. */\n  green: Color;\n  /** @description Applies yellow color to the text. */\n  yellow: Color;\n  /** @description Applies blue color to the text. */\n  blue: Color;\n  /** @description Applies magenta color to the text. */\n  magenta: Color;\n  /** @description Applies cyan color to the text. */\n  cyan: Color;\n  /** @description Applies white color to the text. */\n  white: Color;\n  /** @description Applies gray color to the text. */\n  gray: Color;\n  /** @description Alias for gray color. */\n  grey: Color;\n\n  // Backgrounds\n  /** @description Applies black background to the text. */\n  bgBlack: Color;\n  /** @description Applies red background to the text. */\n  bgRed: Color;\n  /** @description Applies green background to the text. */\n  bgGreen: Color;\n  /** @description Applies yellow background to the text. */\n  bgYellow: Color;\n  /** @description Applies blue background to the text. */\n  bgBlue: Color;\n  /** @description Applies magenta background to the text. */\n  bgMagenta: Color;\n  /** @description Applies cyan background to the text. */\n  bgCyan: Color;\n  /** @description Applies white background to the text. */\n  bgWhite: Color;\n\n  // Modifiers\n  /** @description Resets all applied styles. */\n  reset: Color;\n  /** @description Applies bold style to the text. */\n  bold: Color;\n  /** @description Applies dim (decreased intensity) style to the text. */\n  dim: Color;\n  /** @description Applies italic style to the text. */\n  italic: Color;\n  /** @description Applies underline style to the text. */\n  underline: Color;\n  /** @description Inverts the foreground and background colors. */\n  inverse: Color;\n  /** @description Hides the text (same color as background). */\n  hidden: Color;\n  /** @description Applies strikethrough style to the text. */\n  strikethrough: Color;\n}\n"]}
|
package/lib/types.d.ts
ADDED
|
@@ -0,0 +1,205 @@
|
|
|
1
|
+
import { styles } from "styled-string-builder";
|
|
2
|
+
import { LoggingMode, LogLevel } from "./constants";
|
|
3
|
+
export type StringLike = string | {
|
|
4
|
+
toString: () => string;
|
|
5
|
+
};
|
|
6
|
+
export type LoggingContext = string | {
|
|
7
|
+
new (...args: any[]): any;
|
|
8
|
+
} | ((...args: any[]) => any);
|
|
9
|
+
/**
|
|
10
|
+
* @description Interface for a logger with verbosity levels.
|
|
11
|
+
* @summary Defines methods for logging at different verbosity levels.
|
|
12
|
+
* @interface Logger
|
|
13
|
+
* @memberOf @decaf-ts/utils
|
|
14
|
+
*/
|
|
15
|
+
export interface Logger {
|
|
16
|
+
/**
|
|
17
|
+
* @description Logs a `way too verbose` or a silly message.
|
|
18
|
+
* @param {StringLike} msg - The message to log.
|
|
19
|
+
*/
|
|
20
|
+
silly(msg: StringLike): void;
|
|
21
|
+
/**
|
|
22
|
+
* @description Logs a verbose message.
|
|
23
|
+
* @param {StringLike} msg - The message to log.
|
|
24
|
+
* @param {number} verbosity - The verbosity level of the message.
|
|
25
|
+
*/
|
|
26
|
+
verbose(msg: StringLike, verbosity?: number): void;
|
|
27
|
+
/**
|
|
28
|
+
* @description Logs an info message.
|
|
29
|
+
* @param {StringLike} msg - The message to log.
|
|
30
|
+
*/
|
|
31
|
+
info(msg: StringLike): void;
|
|
32
|
+
/**
|
|
33
|
+
* @description Logs an error message.
|
|
34
|
+
* @param {StringLike | Error} msg - The message to log.
|
|
35
|
+
*/
|
|
36
|
+
error(msg: StringLike | Error): void;
|
|
37
|
+
/**
|
|
38
|
+
* @description Logs a debug message.
|
|
39
|
+
* @param {string} msg - The message to log.
|
|
40
|
+
*/
|
|
41
|
+
debug(msg: StringLike): void;
|
|
42
|
+
for(method?: string | ((...args: any[]) => any), config?: Partial<LoggingConfig>): Logger;
|
|
43
|
+
setConfig(config: Partial<LoggingConfig>): void;
|
|
44
|
+
}
|
|
45
|
+
/**
|
|
46
|
+
* @description Configuration for logging.
|
|
47
|
+
* @summary Defines the log level and verbosity for logging.
|
|
48
|
+
* @typedef {Object} LoggingConfig
|
|
49
|
+
* @property {LogLevel} level - The logging level.
|
|
50
|
+
* @property {number} verbose - The verbosity level.
|
|
51
|
+
* @memberOf @decaf-ts/utils
|
|
52
|
+
*/
|
|
53
|
+
export type LoggingConfig = {
|
|
54
|
+
level: LogLevel;
|
|
55
|
+
logLevel?: boolean;
|
|
56
|
+
verbose: number;
|
|
57
|
+
mode?: LoggingMode;
|
|
58
|
+
separator: string;
|
|
59
|
+
style?: boolean;
|
|
60
|
+
timestamp?: boolean;
|
|
61
|
+
timestampFormat?: string;
|
|
62
|
+
context?: boolean;
|
|
63
|
+
theme?: Theme;
|
|
64
|
+
};
|
|
65
|
+
export type LoggerFactory<L extends Logger = Logger> = (object: string, config?: Partial<LoggingConfig>, id?: string) => L;
|
|
66
|
+
/**
|
|
67
|
+
/**
|
|
68
|
+
* @description Represents a theme option for console output styling.
|
|
69
|
+
* @summary Defines the structure for styling a specific element in the console output.
|
|
70
|
+
* It allows for customization of foreground color, background color, and additional styles.
|
|
71
|
+
* Colors can be specified as a single number, an RGB array, or left undefined for default.
|
|
72
|
+
*
|
|
73
|
+
* @interface ThemeOption
|
|
74
|
+
* @memberOf @decaf-ts/utils
|
|
75
|
+
*/
|
|
76
|
+
export interface ThemeOption {
|
|
77
|
+
fg?: number | [number] | [number, number, number];
|
|
78
|
+
bg?: number | [number] | [number, number, number];
|
|
79
|
+
style?: number[] | [keyof typeof styles];
|
|
80
|
+
}
|
|
81
|
+
export type ThemeOptionByLogLevel = Partial<Record<LogLevel, ThemeOption>>;
|
|
82
|
+
/**
|
|
83
|
+
/**
|
|
84
|
+
* @description Defines the color theme for console output.
|
|
85
|
+
* @summary This interface specifies the color scheme for various elements of console output,
|
|
86
|
+
* including styling for different log levels and components. It uses ThemeOption to
|
|
87
|
+
* define the styling for each element, allowing for customization of colors and styles
|
|
88
|
+
* for different parts of the log output.
|
|
89
|
+
*
|
|
90
|
+
* @interface Theme
|
|
91
|
+
* @memberOf @decaf-ts/utils
|
|
92
|
+
*/
|
|
93
|
+
export interface Theme {
|
|
94
|
+
/**
|
|
95
|
+
* @description Styling for class names in the output.
|
|
96
|
+
*/
|
|
97
|
+
class: ThemeOption | ThemeOptionByLogLevel;
|
|
98
|
+
/**
|
|
99
|
+
* @description Styling for timestamps in the output.
|
|
100
|
+
*/
|
|
101
|
+
timestamp: ThemeOption | ThemeOptionByLogLevel;
|
|
102
|
+
/**
|
|
103
|
+
* @description Styling for the main message text in the output.
|
|
104
|
+
*/
|
|
105
|
+
message: ThemeOption | ThemeOptionByLogLevel;
|
|
106
|
+
/**
|
|
107
|
+
* @description Styling for method names in the output.
|
|
108
|
+
*/
|
|
109
|
+
method: ThemeOption | ThemeOptionByLogLevel;
|
|
110
|
+
/**
|
|
111
|
+
* @description Styling for identifier elements in the output.
|
|
112
|
+
*/
|
|
113
|
+
id: ThemeOption | ThemeOptionByLogLevel;
|
|
114
|
+
/**
|
|
115
|
+
* @description Styling for identifier elements in the output.
|
|
116
|
+
*/
|
|
117
|
+
stack: ThemeOption;
|
|
118
|
+
/**
|
|
119
|
+
* @description Styling for different log levels in the output.
|
|
120
|
+
*/
|
|
121
|
+
logLevel: ThemeOptionByLogLevel;
|
|
122
|
+
}
|
|
123
|
+
/**
|
|
124
|
+
* @description Represents a color function in the Kleur library.
|
|
125
|
+
* @summary The Color interface defines a function that can be called with or without arguments
|
|
126
|
+
* to apply color styling to text or chain multiple color operations.
|
|
127
|
+
*
|
|
128
|
+
* @interface Color
|
|
129
|
+
* @memberOf module:@decaf-ts/utils
|
|
130
|
+
* */
|
|
131
|
+
export interface Color {
|
|
132
|
+
/**
|
|
133
|
+
* @description Applies the color to the given text.
|
|
134
|
+
* @param {string | number} x - The text or number to be colored.
|
|
135
|
+
* @return {string} The colored text.
|
|
136
|
+
*/
|
|
137
|
+
(x: string | number): string;
|
|
138
|
+
/**
|
|
139
|
+
* @description Allows chaining of multiple color operations.
|
|
140
|
+
* @return {Kleur} The Kleur instance for method chaining.
|
|
141
|
+
*/
|
|
142
|
+
(): Kleur;
|
|
143
|
+
}
|
|
144
|
+
/**
|
|
145
|
+
* @description Represents the main Kleur interface with all available color and style methods.
|
|
146
|
+
* @summary The Kleur interface provides methods for applying various colors, background colors,
|
|
147
|
+
* and text styles to strings in terminal output.
|
|
148
|
+
*
|
|
149
|
+
* @interface Kleur
|
|
150
|
+
* @memberOf module:@decaf-ts/utils
|
|
151
|
+
*/
|
|
152
|
+
export interface Kleur {
|
|
153
|
+
/** @description Applies black color to the text. */
|
|
154
|
+
black: Color;
|
|
155
|
+
/** @description Applies red color to the text. */
|
|
156
|
+
red: Color;
|
|
157
|
+
/** @description Applies green color to the text. */
|
|
158
|
+
green: Color;
|
|
159
|
+
/** @description Applies yellow color to the text. */
|
|
160
|
+
yellow: Color;
|
|
161
|
+
/** @description Applies blue color to the text. */
|
|
162
|
+
blue: Color;
|
|
163
|
+
/** @description Applies magenta color to the text. */
|
|
164
|
+
magenta: Color;
|
|
165
|
+
/** @description Applies cyan color to the text. */
|
|
166
|
+
cyan: Color;
|
|
167
|
+
/** @description Applies white color to the text. */
|
|
168
|
+
white: Color;
|
|
169
|
+
/** @description Applies gray color to the text. */
|
|
170
|
+
gray: Color;
|
|
171
|
+
/** @description Alias for gray color. */
|
|
172
|
+
grey: Color;
|
|
173
|
+
/** @description Applies black background to the text. */
|
|
174
|
+
bgBlack: Color;
|
|
175
|
+
/** @description Applies red background to the text. */
|
|
176
|
+
bgRed: Color;
|
|
177
|
+
/** @description Applies green background to the text. */
|
|
178
|
+
bgGreen: Color;
|
|
179
|
+
/** @description Applies yellow background to the text. */
|
|
180
|
+
bgYellow: Color;
|
|
181
|
+
/** @description Applies blue background to the text. */
|
|
182
|
+
bgBlue: Color;
|
|
183
|
+
/** @description Applies magenta background to the text. */
|
|
184
|
+
bgMagenta: Color;
|
|
185
|
+
/** @description Applies cyan background to the text. */
|
|
186
|
+
bgCyan: Color;
|
|
187
|
+
/** @description Applies white background to the text. */
|
|
188
|
+
bgWhite: Color;
|
|
189
|
+
/** @description Resets all applied styles. */
|
|
190
|
+
reset: Color;
|
|
191
|
+
/** @description Applies bold style to the text. */
|
|
192
|
+
bold: Color;
|
|
193
|
+
/** @description Applies dim (decreased intensity) style to the text. */
|
|
194
|
+
dim: Color;
|
|
195
|
+
/** @description Applies italic style to the text. */
|
|
196
|
+
italic: Color;
|
|
197
|
+
/** @description Applies underline style to the text. */
|
|
198
|
+
underline: Color;
|
|
199
|
+
/** @description Inverts the foreground and background colors. */
|
|
200
|
+
inverse: Color;
|
|
201
|
+
/** @description Hides the text (same color as background). */
|
|
202
|
+
hidden: Color;
|
|
203
|
+
/** @description Applies strikethrough style to the text. */
|
|
204
|
+
strikethrough: Color;
|
|
205
|
+
}
|
|
File without changes
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.WinstonFactory = exports.WinstonLogger = void 0;
|
|
7
|
+
const winston_1 = __importDefault(require("winston"));
|
|
8
|
+
const logging_1 = require("../logging.cjs");
|
|
9
|
+
class WinstonLogger extends logging_1.MiniLogger {
|
|
10
|
+
constructor(cont, conf, id, transports) {
|
|
11
|
+
super(cont, conf, id);
|
|
12
|
+
this.transports = transports;
|
|
13
|
+
const config = Object.assign({}, this.conf || {}, logging_1.Logging.getConfig());
|
|
14
|
+
this.conf = Object.assign({}, this.conf || {}, {
|
|
15
|
+
style: false,
|
|
16
|
+
logLevel: false,
|
|
17
|
+
timestamp: false,
|
|
18
|
+
context: false,
|
|
19
|
+
});
|
|
20
|
+
const { level, context, style, timestamp, timestampFormat } = config;
|
|
21
|
+
const formats = [winston_1.default.format.splat(), winston_1.default.format.simple()];
|
|
22
|
+
if (timestamp)
|
|
23
|
+
formats.unshift(winston_1.default.format.timestamp({ format: timestampFormat }));
|
|
24
|
+
if (style)
|
|
25
|
+
formats.unshift(winston_1.default.format.colorize());
|
|
26
|
+
this.transports = this.transports || [
|
|
27
|
+
new winston_1.default.transports.Console({
|
|
28
|
+
format: winston_1.default.format.combine(...formats),
|
|
29
|
+
}),
|
|
30
|
+
];
|
|
31
|
+
const winstonConfig = {
|
|
32
|
+
level: level,
|
|
33
|
+
defaultMeta: context,
|
|
34
|
+
format: winston_1.default.format.json(),
|
|
35
|
+
transports: transports,
|
|
36
|
+
};
|
|
37
|
+
this.winston = winston_1.default.createLogger(winstonConfig);
|
|
38
|
+
}
|
|
39
|
+
log(level, msg, stack) {
|
|
40
|
+
const logData = {
|
|
41
|
+
level: level,
|
|
42
|
+
message: this.createLog(level, msg, stack),
|
|
43
|
+
};
|
|
44
|
+
if (this.id)
|
|
45
|
+
logData["correlationId"] = this.id;
|
|
46
|
+
this.winston.log(logData);
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
exports.WinstonLogger = WinstonLogger;
|
|
50
|
+
const WinstonFactory = (context, conf, id) => new WinstonLogger(context, conf, id);
|
|
51
|
+
exports.WinstonFactory = WinstonFactory;
|
|
52
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2luc3Rvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy93aW5zdG9uL3dpbnN0b24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsc0RBQTJEO0FBRzNELHdDQUFpRDtBQUdqRCxNQUFhLGFBQWMsU0FBUSxvQkFBVTtJQUczQyxZQUNFLElBQVksRUFDWixJQUE2QixFQUM3QixFQUFXLEVBQ0QsVUFBb0M7UUFFOUMsS0FBSyxDQUFDLElBQUksRUFBRSxJQUFJLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFGWixlQUFVLEdBQVYsVUFBVSxDQUEwQjtRQUc5QyxNQUFNLE1BQU0sR0FBa0IsTUFBTSxDQUFDLE1BQU0sQ0FDekMsRUFBRSxFQUNGLElBQUksQ0FBQyxJQUFJLElBQUksRUFBRSxFQUNmLGlCQUFPLENBQUMsU0FBUyxFQUFFLENBQ3BCLENBQUM7UUFDRixJQUFJLENBQUMsSUFBSSxHQUFHLE1BQU0sQ0FBQyxNQUFNLENBQUMsRUFBRSxFQUFFLElBQUksQ0FBQyxJQUFJLElBQUksRUFBRSxFQUFFO1lBQzdDLEtBQUssRUFBRSxLQUFLO1lBQ1osUUFBUSxFQUFFLEtBQUs7WUFDZixTQUFTLEVBQUUsS0FBSztZQUNoQixPQUFPLEVBQUUsS0FBSztTQUNmLENBQUMsQ0FBQztRQUNILE1BQU0sRUFBRSxLQUFLLEVBQUUsT0FBTyxFQUFFLEtBQUssRUFBRSxTQUFTLEVBQUUsZUFBZSxFQUFFLEdBQUcsTUFBTSxDQUFDO1FBRXJFLE1BQU0sT0FBTyxHQUFHLENBQUMsaUJBQU8sQ0FBQyxNQUFNLENBQUMsS0FBSyxFQUFFLEVBQUUsaUJBQU8sQ0FBQyxNQUFNLENBQUMsTUFBTSxFQUFFLENBQUMsQ0FBQztRQUNsRSxJQUFJLFNBQVM7WUFDWCxPQUFPLENBQUMsT0FBTyxDQUFDLGlCQUFPLENBQUMsTUFBTSxDQUFDLFNBQVMsQ0FBQyxFQUFFLE1BQU0sRUFBRSxlQUFlLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFDekUsSUFBSSxLQUFLO1lBQUUsT0FBTyxDQUFDLE9BQU8sQ0FBQyxpQkFBTyxDQUFDLE1BQU0sQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFDO1FBRXRELElBQUksQ0FBQyxVQUFVLEdBQUcsSUFBSSxDQUFDLFVBQVUsSUFBSTtZQUNuQyxJQUFJLGlCQUFPLENBQUMsVUFBVSxDQUFDLE9BQU8sQ0FBQztnQkFDN0IsTUFBTSxFQUFFLGlCQUFPLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxHQUFHLE9BQU8sQ0FBQzthQUMzQyxDQUFDO1NBQ0gsQ0FBQztRQUVGLE1BQU0sYUFBYSxHQUFrQjtZQUNuQyxLQUFLLEVBQUUsS0FBSztZQUNaLFdBQVcsRUFBRSxPQUFPO1lBQ3BCLE1BQU0sRUFBRSxpQkFBTyxDQUFDLE1BQU0sQ0FBQyxJQUFJLEVBQUU7WUFDN0IsVUFBVSxFQUFFLFVBQVU7U0FDdkIsQ0FBQztRQUNGLElBQUksQ0FBQyxPQUFPLEdBQUcsaUJBQU8sQ0FBQyxZQUFZLENBQUMsYUFBYSxDQUFDLENBQUM7SUFDckQsQ0FBQztJQUVTLEdBQUcsQ0FBQyxLQUFlLEVBQUUsR0FBdUIsRUFBRSxLQUFjO1FBQ3BFLE1BQU0sT0FBTyxHQUFhO1lBQ3hCLEtBQUssRUFBRSxLQUFLO1lBQ1osT0FBTyxFQUFFLElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxFQUFFLEdBQUcsRUFBRSxLQUFLLENBQUM7U0FDM0MsQ0FBQztRQUNGLElBQUksSUFBSSxDQUFDLEVBQUU7WUFBRSxPQUFPLENBQUMsZUFBZSxDQUFDLEdBQUcsSUFBSSxDQUFDLEVBQUUsQ0FBQztRQUNoRCxJQUFJLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUM1QixDQUFDO0NBQ0Y7QUFuREQsc0NBbURDO0FBRU0sTUFBTSxjQUFjLEdBQWtCLENBQzNDLE9BQWUsRUFDZixJQUE2QixFQUM3QixFQUFXLEVBQ1gsRUFBRSxDQUFDLElBQUksYUFBYSxDQUFDLE9BQU8sRUFBRSxJQUFJLEVBQUUsRUFBRSxDQUFDLENBQUM7QUFKN0IsUUFBQSxjQUFjLGtCQUllIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHdpbnN0b24sIHsgTG9nRW50cnksIExvZ2dlck9wdGlvbnMgfSBmcm9tIFwid2luc3RvblwiO1xuaW1wb3J0IFRyYW5zcG9ydCBmcm9tIFwid2luc3Rvbi10cmFuc3BvcnRcIjtcbmltcG9ydCB7IExvZ2dlciwgTG9nZ2VyRmFjdG9yeSwgTG9nZ2luZ0NvbmZpZywgU3RyaW5nTGlrZSB9IGZyb20gXCIuLi90eXBlc1wiO1xuaW1wb3J0IHsgTG9nZ2luZywgTWluaUxvZ2dlciB9IGZyb20gXCIuLi9sb2dnaW5nXCI7XG5pbXBvcnQgeyBMb2dMZXZlbCB9IGZyb20gXCIuLi9jb25zdGFudHNcIjtcblxuZXhwb3J0IGNsYXNzIFdpbnN0b25Mb2dnZXIgZXh0ZW5kcyBNaW5pTG9nZ2VyIGltcGxlbWVudHMgTG9nZ2VyIHtcbiAgcHJvdGVjdGVkIHdpbnN0b246IHdpbnN0b24uTG9nZ2VyO1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIGNvbnQ6IHN0cmluZyxcbiAgICBjb25mPzogUGFydGlhbDxMb2dnaW5nQ29uZmlnPixcbiAgICBpZD86IHN0cmluZyxcbiAgICBwcm90ZWN0ZWQgdHJhbnNwb3J0cz86IFRyYW5zcG9ydFtdIHwgVHJhbnNwb3J0XG4gICkge1xuICAgIHN1cGVyKGNvbnQsIGNvbmYsIGlkKTtcbiAgICBjb25zdCBjb25maWc6IExvZ2dpbmdDb25maWcgPSBPYmplY3QuYXNzaWduKFxuICAgICAge30sXG4gICAgICB0aGlzLmNvbmYgfHwge30sXG4gICAgICBMb2dnaW5nLmdldENvbmZpZygpXG4gICAgKTtcbiAgICB0aGlzLmNvbmYgPSBPYmplY3QuYXNzaWduKHt9LCB0aGlzLmNvbmYgfHwge30sIHtcbiAgICAgIHN0eWxlOiBmYWxzZSxcbiAgICAgIGxvZ0xldmVsOiBmYWxzZSxcbiAgICAgIHRpbWVzdGFtcDogZmFsc2UsXG4gICAgICBjb250ZXh0OiBmYWxzZSxcbiAgICB9KTtcbiAgICBjb25zdCB7IGxldmVsLCBjb250ZXh0LCBzdHlsZSwgdGltZXN0YW1wLCB0aW1lc3RhbXBGb3JtYXQgfSA9IGNvbmZpZztcblxuICAgIGNvbnN0IGZvcm1hdHMgPSBbd2luc3Rvbi5mb3JtYXQuc3BsYXQoKSwgd2luc3Rvbi5mb3JtYXQuc2ltcGxlKCldO1xuICAgIGlmICh0aW1lc3RhbXApXG4gICAgICBmb3JtYXRzLnVuc2hpZnQod2luc3Rvbi5mb3JtYXQudGltZXN0YW1wKHsgZm9ybWF0OiB0aW1lc3RhbXBGb3JtYXQgfSkpO1xuICAgIGlmIChzdHlsZSkgZm9ybWF0cy51bnNoaWZ0KHdpbnN0b24uZm9ybWF0LmNvbG9yaXplKCkpO1xuXG4gICAgdGhpcy50cmFuc3BvcnRzID0gdGhpcy50cmFuc3BvcnRzIHx8IFtcbiAgICAgIG5ldyB3aW5zdG9uLnRyYW5zcG9ydHMuQ29uc29sZSh7XG4gICAgICAgIGZvcm1hdDogd2luc3Rvbi5mb3JtYXQuY29tYmluZSguLi5mb3JtYXRzKSxcbiAgICAgIH0pLFxuICAgIF07XG5cbiAgICBjb25zdCB3aW5zdG9uQ29uZmlnOiBMb2dnZXJPcHRpb25zID0ge1xuICAgICAgbGV2ZWw6IGxldmVsLFxuICAgICAgZGVmYXVsdE1ldGE6IGNvbnRleHQsXG4gICAgICBmb3JtYXQ6IHdpbnN0b24uZm9ybWF0Lmpzb24oKSxcbiAgICAgIHRyYW5zcG9ydHM6IHRyYW5zcG9ydHMsXG4gICAgfTtcbiAgICB0aGlzLndpbnN0b24gPSB3aW5zdG9uLmNyZWF0ZUxvZ2dlcih3aW5zdG9uQ29uZmlnKTtcbiAgfVxuXG4gIHByb3RlY3RlZCBsb2cobGV2ZWw6IExvZ0xldmVsLCBtc2c6IFN0cmluZ0xpa2UgfCBFcnJvciwgc3RhY2s/OiBzdHJpbmcpIHtcbiAgICBjb25zdCBsb2dEYXRhOiBMb2dFbnRyeSA9IHtcbiAgICAgIGxldmVsOiBsZXZlbCxcbiAgICAgIG1lc3NhZ2U6IHRoaXMuY3JlYXRlTG9nKGxldmVsLCBtc2csIHN0YWNrKSxcbiAgICB9O1xuICAgIGlmICh0aGlzLmlkKSBsb2dEYXRhW1wiY29ycmVsYXRpb25JZFwiXSA9IHRoaXMuaWQ7XG4gICAgdGhpcy53aW5zdG9uLmxvZyhsb2dEYXRhKTtcbiAgfVxufVxuXG5leHBvcnQgY29uc3QgV2luc3RvbkZhY3Rvcnk6IExvZ2dlckZhY3RvcnkgPSAoXG4gIGNvbnRleHQ6IHN0cmluZyxcbiAgY29uZj86IFBhcnRpYWw8TG9nZ2luZ0NvbmZpZz4sXG4gIGlkPzogc3RyaW5nXG4pID0+IG5ldyBXaW5zdG9uTG9nZ2VyKGNvbnRleHQsIGNvbmYsIGlkKTtcbiJdfQ==
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import winston from "winston";
|
|
2
|
+
import Transport from "winston-transport";
|
|
3
|
+
import { Logger, LoggerFactory, LoggingConfig, StringLike } from "../types";
|
|
4
|
+
import { MiniLogger } from "../logging";
|
|
5
|
+
import { LogLevel } from "../constants";
|
|
6
|
+
export declare class WinstonLogger extends MiniLogger implements Logger {
|
|
7
|
+
protected transports?: (Transport[] | Transport) | undefined;
|
|
8
|
+
protected winston: winston.Logger;
|
|
9
|
+
constructor(cont: string, conf?: Partial<LoggingConfig>, id?: string, transports?: (Transport[] | Transport) | undefined);
|
|
10
|
+
protected log(level: LogLevel, msg: StringLike | Error, stack?: string): void;
|
|
11
|
+
}
|
|
12
|
+
export declare const WinstonFactory: LoggerFactory;
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@decaf-ts/logging",
|
|
3
|
-
"version": "0.0
|
|
3
|
+
"version": "0.2.0",
|
|
4
4
|
"description": "simple winston inspired wrapper for cross lib logging",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"exports": {
|
|
@@ -13,21 +13,21 @@
|
|
|
13
13
|
"import": "./lib/esm/winston.js"
|
|
14
14
|
}
|
|
15
15
|
},
|
|
16
|
-
"types": "
|
|
16
|
+
"types": "lib/index.d.ts",
|
|
17
17
|
"scripts": {
|
|
18
18
|
"do-install": "TOKEN=$(cat .token) npm install",
|
|
19
|
-
"update-dependencies": "
|
|
20
|
-
"update-scripts": "
|
|
21
|
-
"on-first-run": "
|
|
19
|
+
"update-dependencies": "PREFIX=\"decaf-ts\"; npm ls | grep \"$PREFIX\" | awk -F/ '{print $NF}' | sed 's/@.*//' | xargs -I package npm update @\"$PREFIX\"/package",
|
|
20
|
+
"update-scripts": "npx update-scripts",
|
|
21
|
+
"on-first-run": "npx update-scripts --boot",
|
|
22
22
|
"set-git-auth": "git config url.\"https://api:$(cat .token)@github.com/\".insteadOf \"https://github.com/\" && git config url.\"https://ssh:$(cat .token)@github.com/\".insteadOf \"ssh://git@github.com/\" && git config url.\"https://git:$(cat .token)@github.com/\".insteadOf \"git@github.com:\"",
|
|
23
23
|
"flash-forward": "npx npm-check-updates -u && npm run do-install",
|
|
24
24
|
"reset": "rm -rf * && git checkout . && git pull && npm run do-install",
|
|
25
|
-
"build": "
|
|
26
|
-
"build:prod": "
|
|
25
|
+
"build": "npx build-scripts --dev",
|
|
26
|
+
"build:prod": "npx build-scripts --prod",
|
|
27
27
|
"test": "jest --runInBand --coverage --detectOpenHandles",
|
|
28
28
|
"test:unit": "jest --testPathPattern=\"/tests/unit\" --passWithNoTests --detectOpenHandles",
|
|
29
29
|
"test:integration": "jest --testPathPattern=\"/tests/(integration)\" --passWithNoTests --detectOpenHandles",
|
|
30
|
-
"test:all": "jest --testPathPattern=\"/tests
|
|
30
|
+
"test:all": "jest --testPathPattern=\"/tests\" --passWithNoTests",
|
|
31
31
|
"test:circular": "dpdm -T --no-warning --no-tree ./src/index.ts",
|
|
32
32
|
"coverage": "rimraf ./workdocs/reports/data/*.json && npm run test:all -- --coverage --config=./workdocs/reports/jest.coverage.config.ts",
|
|
33
33
|
"lint": "eslint .",
|
|
@@ -37,7 +37,7 @@
|
|
|
37
37
|
"clean-publish": "npx clean-publish",
|
|
38
38
|
"drawings": "for FILE in workdocs/drawings/*.drawio; do echo \"converting $FILE to image...\" && docker run --rm -v $(pwd):/data rlespinasse/drawio-export --format png $FILE; done && cp -rf workdocs/drawings/export/* workdocs/resources/",
|
|
39
39
|
"uml": "cd workdocs/uml && for FILE in ./*.puml; do docker run --rm -v $(pwd):/work -w /work miy4/plantuml -DPLANTUML_LIMIT_SIZE=8192 -tpng $FILE; done && cd ../.. && cp -fr workdocs/uml/*.png workdocs/resources/",
|
|
40
|
-
"docs": "npx rimraf ./docs && mkdir docs &&
|
|
40
|
+
"docs": "npx rimraf ./docs && mkdir docs && npx build-scripts --docs",
|
|
41
41
|
"publish-docs": "docker run -it --rm --user $(id -u):$(id -g) -v \"$(pwd)/workdocs/confluence:/content\" -e ATLASSIAN_API_TOKEN=$(cat .confluence-token) ghcr.io/markdown-confluence/publish:latest"
|
|
42
42
|
},
|
|
43
43
|
"repository": {
|
|
@@ -64,50 +64,40 @@
|
|
|
64
64
|
},
|
|
65
65
|
"homepage": "https://github.com/decaf-ts/logging#readme",
|
|
66
66
|
"devDependencies": {
|
|
67
|
-
"@
|
|
67
|
+
"@decaf-ts/utils": "latest",
|
|
68
|
+
"@eslint/js": "^9.25.1",
|
|
69
|
+
"@rollup/plugin-commonjs": "^28.0.3",
|
|
70
|
+
"@rollup/plugin-json": "^6.1.0",
|
|
71
|
+
"@rollup/plugin-node-resolve": "^16.0.1",
|
|
72
|
+
"@rollup/plugin-typescript": "^12.1.2",
|
|
68
73
|
"@stylistic/eslint-plugin": "^4.2.0",
|
|
69
74
|
"@types/jest": "^29.5.14",
|
|
70
|
-
"@types/prompts": "^2.4.9",
|
|
71
75
|
"clean-publish": "^5.1.0",
|
|
72
76
|
"dpdm": "^3.14.0",
|
|
73
|
-
"eslint": "^9.
|
|
74
|
-
"eslint-config-prettier": "^10.1.
|
|
75
|
-
"eslint-plugin-prettier": "^5.2.
|
|
77
|
+
"eslint": "^9.25.1",
|
|
78
|
+
"eslint-config-prettier": "^10.1.2",
|
|
79
|
+
"eslint-plugin-prettier": "^5.2.6",
|
|
76
80
|
"globals": "^16.0.0",
|
|
77
|
-
"gulp": "^5.0.0",
|
|
78
|
-
"gulp-if": "^3.0.0",
|
|
79
|
-
"gulp-rename": "^2.0.0",
|
|
80
|
-
"gulp-replace": "^1.1.4",
|
|
81
|
-
"gulp-run-command": "^0.0.10",
|
|
82
|
-
"gulp-sourcemaps": "^2.6.5",
|
|
83
|
-
"gulp-typescript": "^6.0.0-alpha.1",
|
|
84
|
-
"gulp-uglify": "^3.0.2",
|
|
85
81
|
"jest": "^29.7.0",
|
|
86
82
|
"jest-html-reporters": "^3.1.7",
|
|
87
83
|
"jest-junit": "^16.0.0",
|
|
88
84
|
"jsdoc": "^4.0.4",
|
|
89
85
|
"jsdoc-mermaid": "^1.0.0",
|
|
90
86
|
"markdown-include": "^0.4.3",
|
|
91
|
-
"merge-stream": "^2.0.0",
|
|
92
87
|
"minimist": "^1.2.8",
|
|
93
88
|
"nodemon": "^3.1.9",
|
|
94
|
-
"npm-check-updates": "^
|
|
89
|
+
"npm-check-updates": "^18.0.0",
|
|
95
90
|
"prettier": "3.5.3",
|
|
96
|
-
"prompts": "^2.4.2",
|
|
97
91
|
"rimraf": "^6.0.1",
|
|
98
|
-
"
|
|
92
|
+
"rollup": "^4.40.0",
|
|
93
|
+
"ts-jest": "^29.3.2",
|
|
99
94
|
"ts-loader": "^9.5.2",
|
|
100
95
|
"ts-node": "^10.9.2",
|
|
101
|
-
"typescript": "^5.8.
|
|
102
|
-
"typescript-eslint": "^8.
|
|
103
|
-
"vinyl-named": "^1.1.0",
|
|
104
|
-
"webpack-node-externals": "^3.0.0",
|
|
105
|
-
"webpack-stream": "^7.0.0",
|
|
96
|
+
"typescript": "^5.8.3",
|
|
97
|
+
"typescript-eslint": "^8.31.0",
|
|
106
98
|
"winston": "^3.17.0"
|
|
107
99
|
},
|
|
108
|
-
"
|
|
109
|
-
"
|
|
110
|
-
"cross-spawn": "^7.0.6"
|
|
111
|
-
}
|
|
100
|
+
"dependencies": {
|
|
101
|
+
"styled-string-builder": "^1.4.11"
|
|
112
102
|
}
|
|
113
103
|
}
|
package/dist/esm/logging.js
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
var e={317:(e,t)=>{Object.defineProperty(t,"__esModule",{value:!0})},552:(e,t,o)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.toLogLevel=function(e){if(e.toString()in r.NumericLogLevels)return r.NumericLogLevels[e.toString()];throw new Error(`Invalid level: ${e.toString()}`)};const r=o(640)},563:(e,t)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.LoggerFactory=void 0,t.LoggerFactory=class{constructor(e){this.level=e}}},640:(e,t)=>{var o;Object.defineProperty(t,"__esModule",{value:!0}),t.NumericLogLevels=t.LogLevel=void 0,function(e){e.Fatal="fatal",e.Error="error",e.Warn="warn",e.Info="info",e.Http="http",e.Verbose="verbose",e.Debug="debug",e.Silly="silly"}(o||(t.LogLevel=o={})),t.NumericLogLevels={error:0,warn:1,info:2,http:3,verbose:4,debug:5,silly:6}},729:function(e,t,o){var r=this&&this.__createBinding||(Object.create?function(e,t,o,r){void 0===r&&(r=o);var s=Object.getOwnPropertyDescriptor(t,o);s&&!("get"in s?!t.__esModule:s.writable||s.configurable)||(s={enumerable:!0,get:function(){return t[o]}}),Object.defineProperty(e,r,s)}:function(e,t,o,r){void 0===r&&(r=o),e[r]=t[o]}),s=this&&this.__exportStar||function(e,t){for(var o in e)"default"===o||Object.prototype.hasOwnProperty.call(t,o)||r(t,e,o)};Object.defineProperty(t,"__esModule",{value:!0}),t.VERSION=void 0,s(o(640),t),s(o(760),t),s(o(563),t),s(o(317),t),s(o(916),t),s(o(552),t),t.VERSION="0.0.17"},760:(e,t,o)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.DefaultLoggerFactory=void 0;const r=o(563),s=o(640),l=o(552);class n{constructor(e,t,o){this.level=e,this.clazz=t,this.method=o}log(e,t,o,r){if((0,l.toLogLevel)(e)<(0,l.toLogLevel)(this.level))return;const{context:n,app:i}=o||{},a=`${r?`[${r}]`:""}${i?`[${i}]`:""}${n?`[${n}]`:""}${this.clazz?`[${this.clazz}]`:""}${this.method?`[${this.method}]`:""} ${t}`;switch(e){case s.LogLevel.Fatal:case s.LogLevel.Error:return console.error(a);case s.LogLevel.Warn:return console.warn(a);case s.LogLevel.Info:return console.info(a);case s.LogLevel.Http:case s.LogLevel.Verbose:case s.LogLevel.Debug:case s.LogLevel.Silly:return console.debug(a);default:throw new Error(`Invalid log level: ${e}`)}}silly(e,t,o){return this.log(s.LogLevel.Silly,e,t,o)}verbose(e,t,o){return this.log(s.LogLevel.Verbose,e,t,o)}debug(e,t,o){return this.log(s.LogLevel.Debug,e,t,o)}info(e,t,o){return this.log(s.LogLevel.Info,e,t,o)}warn(e,t,o){return this.log(s.LogLevel.Warn,e,t,o)}error(e,t,o){return this.log(s.LogLevel.Error,e,t,o)}emerg(e,t,o){return this.log(s.LogLevel.Fatal,e,t,o)}profile(e,t){throw new Error("Not implemented")}}class i extends r.LoggerFactory{constructor(e){super(e)}forClass(e){return new n(this.level,e.name)}forMethod(e,t){return new n(this.level,e.name,"string"==typeof t?t:t.name)}get(){return new n(this.level)}}t.DefaultLoggerFactory=i},916:(e,t,o)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.Logging=void 0;const r=o(640),s=o(760);class l{static{this._level=r.LogLevel.Info}static{this._factory=s.DefaultLoggerFactory}static{this.cacheByClass={}}static{this.cacheByClassMethod={}}constructor(){}static get level(){return this._level}static set level(e){this._level=e}static get instance(){return this._instance||(this._instance=new this._factory(l.level)),this._instance}static set factory(e){this._factory=e}static forClass(e){const t=e.name;return t in this.cacheByClass||(this.cacheByClass[t]=l.instance.forClass(e)),this.cacheByClass[t]}static forMethod(e,t){const o=e.name;o in this.cacheByClassMethod||(this.cacheByClassMethod[o]={});const r="string"==typeof t?t:t.name;return r in this.cacheByClassMethod[o]||(this.cacheByClassMethod[o][r]=l.instance.forMethod(e,t)),this.cacheByClassMethod[o][r]}static get(){return this.global||(this.global=l.instance.get()),this.global}}t.Logging=l}},t={};!function o(r){var s=t[r];if(void 0!==s)return s.exports;var l=t[r]={exports:{}};return e[r].call(l.exports,l,l.exports,o),l.exports}(729);
|
package/dist/logging.js
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t():"function"==typeof define&&define.amd?define("logging",[],t):"object"==typeof exports?exports.logging=t():e.logging=t()}(this,(()=>(()=>{"use strict";var e={317:(e,t)=>{Object.defineProperty(t,"__esModule",{value:!0})},552:(e,t,o)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.toLogLevel=function(e){if(e.toString()in r.NumericLogLevels)return r.NumericLogLevels[e.toString()];throw new Error(`Invalid level: ${e.toString()}`)};const r=o(640)},563:(e,t)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.LoggerFactory=void 0,t.LoggerFactory=class{constructor(e){this.level=e}}},640:(e,t)=>{var o;Object.defineProperty(t,"__esModule",{value:!0}),t.NumericLogLevels=t.LogLevel=void 0,function(e){e.Fatal="fatal",e.Error="error",e.Warn="warn",e.Info="info",e.Http="http",e.Verbose="verbose",e.Debug="debug",e.Silly="silly"}(o||(t.LogLevel=o={})),t.NumericLogLevels={error:0,warn:1,info:2,http:3,verbose:4,debug:5,silly:6}},729:function(e,t,o){var r=this&&this.__createBinding||(Object.create?function(e,t,o,r){void 0===r&&(r=o);var s=Object.getOwnPropertyDescriptor(t,o);s&&!("get"in s?!t.__esModule:s.writable||s.configurable)||(s={enumerable:!0,get:function(){return t[o]}}),Object.defineProperty(e,r,s)}:function(e,t,o,r){void 0===r&&(r=o),e[r]=t[o]}),s=this&&this.__exportStar||function(e,t){for(var o in e)"default"===o||Object.prototype.hasOwnProperty.call(t,o)||r(t,e,o)};Object.defineProperty(t,"__esModule",{value:!0}),t.VERSION=void 0,s(o(640),t),s(o(760),t),s(o(563),t),s(o(317),t),s(o(916),t),s(o(552),t),t.VERSION="0.0.17"},760:(e,t,o)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.DefaultLoggerFactory=void 0;const r=o(563),s=o(640),l=o(552);class n{constructor(e,t,o){this.level=e,this.clazz=t,this.method=o}log(e,t,o,r){if((0,l.toLogLevel)(e)<(0,l.toLogLevel)(this.level))return;const{context:n,app:i}=o||{},a=`${r?`[${r}]`:""}${i?`[${i}]`:""}${n?`[${n}]`:""}${this.clazz?`[${this.clazz}]`:""}${this.method?`[${this.method}]`:""} ${t}`;switch(e){case s.LogLevel.Fatal:case s.LogLevel.Error:return console.error(a);case s.LogLevel.Warn:return console.warn(a);case s.LogLevel.Info:return console.info(a);case s.LogLevel.Http:case s.LogLevel.Verbose:case s.LogLevel.Debug:case s.LogLevel.Silly:return console.debug(a);default:throw new Error(`Invalid log level: ${e}`)}}silly(e,t,o){return this.log(s.LogLevel.Silly,e,t,o)}verbose(e,t,o){return this.log(s.LogLevel.Verbose,e,t,o)}debug(e,t,o){return this.log(s.LogLevel.Debug,e,t,o)}info(e,t,o){return this.log(s.LogLevel.Info,e,t,o)}warn(e,t,o){return this.log(s.LogLevel.Warn,e,t,o)}error(e,t,o){return this.log(s.LogLevel.Error,e,t,o)}emerg(e,t,o){return this.log(s.LogLevel.Fatal,e,t,o)}profile(e,t){throw new Error("Not implemented")}}class i extends r.LoggerFactory{constructor(e){super(e)}forClass(e){return new n(this.level,e.name)}forMethod(e,t){return new n(this.level,e.name,"string"==typeof t?t:t.name)}get(){return new n(this.level)}}t.DefaultLoggerFactory=i},916:(e,t,o)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.Logging=void 0;const r=o(640),s=o(760);class l{static{this._level=r.LogLevel.Info}static{this._factory=s.DefaultLoggerFactory}static{this.cacheByClass={}}static{this.cacheByClassMethod={}}constructor(){}static get level(){return this._level}static set level(e){this._level=e}static get instance(){return this._instance||(this._instance=new this._factory(l.level)),this._instance}static set factory(e){this._factory=e}static forClass(e){const t=e.name;return t in this.cacheByClass||(this.cacheByClass[t]=l.instance.forClass(e)),this.cacheByClass[t]}static forMethod(e,t){const o=e.name;o in this.cacheByClassMethod||(this.cacheByClassMethod[o]={});const r="string"==typeof t?t:t.name;return r in this.cacheByClassMethod[o]||(this.cacheByClassMethod[o][r]=l.instance.forMethod(e,t)),this.cacheByClassMethod[o][r]}static get(){return this.global||(this.global=l.instance.get()),this.global}}t.Logging=l}},t={};return function o(r){var s=t[r];if(void 0!==s)return s.exports;var l=t[r]={exports:{}};return e[r].call(l.exports,l,l.exports,o),l.exports}(729)})()));
|
package/dist/types/Factory.d.ts
DELETED
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
import { Logger } from "./interfaces";
|
|
2
|
-
import { LogLevel } from "./constants";
|
|
3
|
-
export declare abstract class LoggerFactory {
|
|
4
|
-
protected level: LogLevel;
|
|
5
|
-
protected constructor(level: LogLevel);
|
|
6
|
-
abstract forClass(clazz: {
|
|
7
|
-
new (...args: any[]): any;
|
|
8
|
-
}): Logger;
|
|
9
|
-
abstract forMethod(clazz: {
|
|
10
|
-
new (...args: any[]): any;
|
|
11
|
-
}, method: ((...args: any[]) => any) | string): Logger;
|
|
12
|
-
abstract get(): Logger;
|
|
13
|
-
}
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
export declare enum LogLevel {
|
|
2
|
-
Fatal = "fatal",// A person must take an action immediately
|
|
3
|
-
Error = "error",// Error events are likely to cause problems
|
|
4
|
-
Warn = "warn",// Warning events might cause problems in the future and deserve eyes
|
|
5
|
-
Info = "info",// Routine information, such as ongoing status or performance
|
|
6
|
-
Http = "http",// Http information
|
|
7
|
-
Verbose = "verbose",// Debug or trace information
|
|
8
|
-
Debug = "debug",// Debug or trace information
|
|
9
|
-
Silly = "silly"
|
|
10
|
-
}
|
|
11
|
-
export declare const NumericLogLevels: {
|
|
12
|
-
error: number;
|
|
13
|
-
warn: number;
|
|
14
|
-
info: number;
|
|
15
|
-
http: number;
|
|
16
|
-
verbose: number;
|
|
17
|
-
debug: number;
|
|
18
|
-
silly: number;
|
|
19
|
-
};
|
package/dist/types/default.d.ts
DELETED
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
import { LoggerFactory } from "./Factory";
|
|
2
|
-
import { LogLevel } from "./constants";
|
|
3
|
-
import { Logger } from "./interfaces";
|
|
4
|
-
export declare class DefaultLoggerFactory extends LoggerFactory {
|
|
5
|
-
constructor(level: LogLevel);
|
|
6
|
-
forClass(clazz: new (...args: any[]) => any): Logger;
|
|
7
|
-
forMethod(clazz: new (...args: any[]) => any, method: string | ((...args: any[]) => any)): Logger;
|
|
8
|
-
get(): Logger;
|
|
9
|
-
}
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
import { LogLevel } from "./constants";
|
|
2
|
-
export interface LogData {
|
|
3
|
-
organization?: string;
|
|
4
|
-
context?: string;
|
|
5
|
-
app?: string;
|
|
6
|
-
sourceClass?: string;
|
|
7
|
-
correlationId?: string;
|
|
8
|
-
error?: Error;
|
|
9
|
-
props?: Record<string, any>;
|
|
10
|
-
}
|
|
11
|
-
export interface Logger {
|
|
12
|
-
log(level: LogLevel, message: string | Error, data?: LogData, profile?: string): void;
|
|
13
|
-
silly(message: string, data?: LogData, profile?: string): void;
|
|
14
|
-
verbose(message: string, data?: LogData, profile?: string): void;
|
|
15
|
-
debug(message: string, data?: LogData, profile?: string): void;
|
|
16
|
-
info(message: string, data?: LogData, profile?: string): void;
|
|
17
|
-
warn(message: string | Error, data?: LogData, profile?: string): void;
|
|
18
|
-
error(message: string | Error, data?: LogData, profile?: string): void;
|
|
19
|
-
emerg(message: string | Error, data?: LogData, profile?: string): void;
|
|
20
|
-
profile(id: string | number, meta?: Record<string, any>): void;
|
|
21
|
-
}
|
package/dist/types/logging.d.ts
DELETED
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
import { Logger } from "./interfaces";
|
|
2
|
-
import { LoggerFactory } from "./Factory";
|
|
3
|
-
import { LogLevel } from "./constants";
|
|
4
|
-
export declare class Logging {
|
|
5
|
-
private static _level;
|
|
6
|
-
private static _factory;
|
|
7
|
-
private static _instance;
|
|
8
|
-
private static cacheByClass;
|
|
9
|
-
private static cacheByClassMethod;
|
|
10
|
-
private static global;
|
|
11
|
-
private constructor();
|
|
12
|
-
static get level(): LogLevel;
|
|
13
|
-
static set level(level: LogLevel);
|
|
14
|
-
protected static get instance(): LoggerFactory;
|
|
15
|
-
static set factory(factory: {
|
|
16
|
-
new (level: LogLevel): LoggerFactory;
|
|
17
|
-
});
|
|
18
|
-
static forClass(clazz: {
|
|
19
|
-
new (...args: any[]): any;
|
|
20
|
-
}): Logger;
|
|
21
|
-
static forMethod(clazz: {
|
|
22
|
-
new (...args: any[]): any;
|
|
23
|
-
}, method: ((...args: any[]) => any) | string): Logger;
|
|
24
|
-
static get(): Logger;
|
|
25
|
-
}
|
package/dist/types/utils.d.ts
DELETED
package/dist/types/winston.d.ts
DELETED
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
import { LoggerFactory } from "./Factory";
|
|
2
|
-
import { Logger } from "./interfaces";
|
|
3
|
-
import * as winston from "winston";
|
|
4
|
-
import { LogLevel } from "./constants";
|
|
5
|
-
export declare class WinstonLoggerFactory extends LoggerFactory {
|
|
6
|
-
constructor(level: LogLevel);
|
|
7
|
-
protected generate(lvl: LogLevel, clazz?: string, method?: string): winston.Logger;
|
|
8
|
-
forClass(clazz: {
|
|
9
|
-
new (...args: any[]): any;
|
|
10
|
-
}): Logger;
|
|
11
|
-
forMethod(clazz: {
|
|
12
|
-
new (...args: any[]): any;
|
|
13
|
-
}, method: ((...args: any[]) => any) | string): Logger;
|
|
14
|
-
get(): Logger;
|
|
15
|
-
}
|
package/lib/Factory.cjs
DELETED
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.LoggerFactory = void 0;
|
|
4
|
-
class LoggerFactory {
|
|
5
|
-
constructor(level) {
|
|
6
|
-
this.level = level;
|
|
7
|
-
}
|
|
8
|
-
}
|
|
9
|
-
exports.LoggerFactory = LoggerFactory;
|
|
10
|
-
|
|
11
|
-
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9GYWN0b3J5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUdBLE1BQXNCLGFBQWE7SUFDakMsWUFBZ0MsS0FBZTtRQUFmLFVBQUssR0FBTCxLQUFLLENBQVU7SUFBRyxDQUFDO0NBT3BEO0FBUkQsc0NBUUMiLCJmaWxlIjoiRmFjdG9yeS5qcyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IExvZ2dlciB9IGZyb20gXCIuL2ludGVyZmFjZXNcIjtcbmltcG9ydCB7IExvZ0xldmVsIH0gZnJvbSBcIi4vY29uc3RhbnRzXCI7XG5cbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBMb2dnZXJGYWN0b3J5IHtcbiAgcHJvdGVjdGVkIGNvbnN0cnVjdG9yKHByb3RlY3RlZCBsZXZlbDogTG9nTGV2ZWwpIHt9XG4gIGFic3RyYWN0IGZvckNsYXNzKGNsYXp6OiB7IG5ldyAoLi4uYXJnczogYW55W10pOiBhbnkgfSk6IExvZ2dlcjtcbiAgYWJzdHJhY3QgZm9yTWV0aG9kKFxuICAgIGNsYXp6OiB7IG5ldyAoLi4uYXJnczogYW55W10pOiBhbnkgfSxcbiAgICBtZXRob2Q6ICgoLi4uYXJnczogYW55W10pID0+IGFueSkgfCBzdHJpbmdcbiAgKTogTG9nZ2VyO1xuICBhYnN0cmFjdCBnZXQoKTogTG9nZ2VyO1xufVxuIl19
|