@xfe-repo/bff-logger 1.0.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/README.md +3 -0
- package/dist/chunk-D7DXVRGN.mjs +108 -0
- package/dist/chunk-LCUFGSVV.mjs +36 -0
- package/dist/index.d.mts +4 -0
- package/dist/index.d.ts +4 -0
- package/dist/index.js +163 -0
- package/dist/index.mjs +10 -0
- package/dist/logger.module.d.mts +11 -0
- package/dist/logger.module.d.ts +11 -0
- package/dist/logger.module.js +159 -0
- package/dist/logger.module.mjs +7 -0
- package/dist/pino.logger.d.mts +7 -0
- package/dist/pino.logger.d.ts +7 -0
- package/dist/pino.logger.js +57 -0
- package/dist/pino.logger.mjs +6 -0
- package/package.json +43 -0
package/README.md
ADDED
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
import {
|
|
2
|
+
PinoLogger,
|
|
3
|
+
__name
|
|
4
|
+
} from "./chunk-LCUFGSVV.mjs";
|
|
5
|
+
|
|
6
|
+
// src/logger.module.ts
|
|
7
|
+
import { Module } from "@nestjs/common";
|
|
8
|
+
import { CtxService } from "@xfe-repo/bff-core";
|
|
9
|
+
import { LoggerModule as PinoLoggerModule } from "nestjs-pino";
|
|
10
|
+
function _ts_decorate(decorators, target, key, desc) {
|
|
11
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
12
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
13
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
14
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
15
|
+
}
|
|
16
|
+
__name(_ts_decorate, "_ts_decorate");
|
|
17
|
+
var _LoggerModule = class _LoggerModule {
|
|
18
|
+
static register(options) {
|
|
19
|
+
const { global, logDir = "./var/log" } = options;
|
|
20
|
+
return {
|
|
21
|
+
global,
|
|
22
|
+
module: _LoggerModule,
|
|
23
|
+
imports: [
|
|
24
|
+
PinoLoggerModule.forRootAsync({
|
|
25
|
+
inject: [
|
|
26
|
+
CtxService
|
|
27
|
+
],
|
|
28
|
+
useFactory: /* @__PURE__ */ __name((ctx) => {
|
|
29
|
+
const isProd = process.env.NODE_ENV === "production";
|
|
30
|
+
const stdTargets = [
|
|
31
|
+
{
|
|
32
|
+
target: "pino-pretty",
|
|
33
|
+
options: {
|
|
34
|
+
colorize: true,
|
|
35
|
+
minimumLevel: "debug",
|
|
36
|
+
ignore: "pid,hostname",
|
|
37
|
+
messageFormat: "{if context}[{context}]: {end} {msg} {if responseTime}{responseTime}ms {end}",
|
|
38
|
+
singleLine: true
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
];
|
|
42
|
+
const fileTargets = [
|
|
43
|
+
{
|
|
44
|
+
level: "error",
|
|
45
|
+
target: "pino/file",
|
|
46
|
+
options: {
|
|
47
|
+
destination: `${logDir}/bff-err.log`,
|
|
48
|
+
mkdir: true
|
|
49
|
+
}
|
|
50
|
+
},
|
|
51
|
+
{
|
|
52
|
+
level: "debug",
|
|
53
|
+
target: "pino/file",
|
|
54
|
+
options: {
|
|
55
|
+
destination: `${logDir}/bff-out.log`,
|
|
56
|
+
mkdir: true
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
];
|
|
60
|
+
return {
|
|
61
|
+
pinoHttp: {
|
|
62
|
+
transport: {
|
|
63
|
+
targets: isProd ? [
|
|
64
|
+
...stdTargets,
|
|
65
|
+
...fileTargets
|
|
66
|
+
] : stdTargets
|
|
67
|
+
},
|
|
68
|
+
// genReqId: _req => ctx.traceid,
|
|
69
|
+
// customAttributeKeys: { reqId: 'traceid' },
|
|
70
|
+
serializers: {
|
|
71
|
+
req(req) {
|
|
72
|
+
delete req.id;
|
|
73
|
+
req.traceid = ctx.traceid;
|
|
74
|
+
req.headers.business = req.raw.headers.business;
|
|
75
|
+
req.headers.usertoken = req.raw.headers.usertoken;
|
|
76
|
+
req.headers.authorization = req.raw.headers.authorization;
|
|
77
|
+
req.headers.version = req.raw.headers.version;
|
|
78
|
+
req.url = `${req.raw.protocol}://${req.headers.host}${req.url}`;
|
|
79
|
+
req.body = req.raw.body;
|
|
80
|
+
req.user = req.raw.user;
|
|
81
|
+
req.tracks = ctx.tracks;
|
|
82
|
+
return req;
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
};
|
|
87
|
+
}, "useFactory")
|
|
88
|
+
})
|
|
89
|
+
]
|
|
90
|
+
};
|
|
91
|
+
}
|
|
92
|
+
};
|
|
93
|
+
__name(_LoggerModule, "LoggerModule");
|
|
94
|
+
var LoggerModule = _LoggerModule;
|
|
95
|
+
LoggerModule = _ts_decorate([
|
|
96
|
+
Module({
|
|
97
|
+
providers: [
|
|
98
|
+
PinoLogger
|
|
99
|
+
],
|
|
100
|
+
exports: [
|
|
101
|
+
PinoLogger
|
|
102
|
+
]
|
|
103
|
+
})
|
|
104
|
+
], LoggerModule);
|
|
105
|
+
|
|
106
|
+
export {
|
|
107
|
+
LoggerModule
|
|
108
|
+
};
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
3
|
+
|
|
4
|
+
// src/pino.logger.ts
|
|
5
|
+
import { Injectable } from "@nestjs/common";
|
|
6
|
+
import { Logger } from "nestjs-pino";
|
|
7
|
+
function _ts_decorate(decorators, target, key, desc) {
|
|
8
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
10
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
11
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
12
|
+
}
|
|
13
|
+
__name(_ts_decorate, "_ts_decorate");
|
|
14
|
+
var SKIP_CONTEXTS = [
|
|
15
|
+
"NestFactory",
|
|
16
|
+
"InstanceLoader",
|
|
17
|
+
"RoutesResolver",
|
|
18
|
+
"RouterExplorer",
|
|
19
|
+
"ClientProxy"
|
|
20
|
+
];
|
|
21
|
+
var _PinoLogger = class _PinoLogger extends Logger {
|
|
22
|
+
log(message, context) {
|
|
23
|
+
if (context && SKIP_CONTEXTS.includes(context)) return;
|
|
24
|
+
super.log(message, context);
|
|
25
|
+
}
|
|
26
|
+
};
|
|
27
|
+
__name(_PinoLogger, "PinoLogger");
|
|
28
|
+
var PinoLogger = _PinoLogger;
|
|
29
|
+
PinoLogger = _ts_decorate([
|
|
30
|
+
Injectable()
|
|
31
|
+
], PinoLogger);
|
|
32
|
+
|
|
33
|
+
export {
|
|
34
|
+
__name,
|
|
35
|
+
PinoLogger
|
|
36
|
+
};
|
package/dist/index.d.mts
ADDED
package/dist/index.d.ts
ADDED
package/dist/index.js
ADDED
|
@@ -0,0 +1,163 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
7
|
+
var __export = (target, all) => {
|
|
8
|
+
for (var name in all)
|
|
9
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
10
|
+
};
|
|
11
|
+
var __copyProps = (to, from, except, desc) => {
|
|
12
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
13
|
+
for (let key of __getOwnPropNames(from))
|
|
14
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
15
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
16
|
+
}
|
|
17
|
+
return to;
|
|
18
|
+
};
|
|
19
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
20
|
+
|
|
21
|
+
// src/index.ts
|
|
22
|
+
var index_exports = {};
|
|
23
|
+
__export(index_exports, {
|
|
24
|
+
LoggerModule: () => LoggerModule,
|
|
25
|
+
PinoLogger: () => PinoLogger
|
|
26
|
+
});
|
|
27
|
+
module.exports = __toCommonJS(index_exports);
|
|
28
|
+
|
|
29
|
+
// src/logger.module.ts
|
|
30
|
+
var import_common2 = require("@nestjs/common");
|
|
31
|
+
var import_bff_core = require("@xfe-repo/bff-core");
|
|
32
|
+
var import_nestjs_pino2 = require("nestjs-pino");
|
|
33
|
+
|
|
34
|
+
// src/pino.logger.ts
|
|
35
|
+
var import_common = require("@nestjs/common");
|
|
36
|
+
var import_nestjs_pino = require("nestjs-pino");
|
|
37
|
+
function _ts_decorate(decorators, target, key, desc) {
|
|
38
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
39
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
40
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
41
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
42
|
+
}
|
|
43
|
+
__name(_ts_decorate, "_ts_decorate");
|
|
44
|
+
var SKIP_CONTEXTS = [
|
|
45
|
+
"NestFactory",
|
|
46
|
+
"InstanceLoader",
|
|
47
|
+
"RoutesResolver",
|
|
48
|
+
"RouterExplorer",
|
|
49
|
+
"ClientProxy"
|
|
50
|
+
];
|
|
51
|
+
var _PinoLogger = class _PinoLogger extends import_nestjs_pino.Logger {
|
|
52
|
+
log(message, context) {
|
|
53
|
+
if (context && SKIP_CONTEXTS.includes(context)) return;
|
|
54
|
+
super.log(message, context);
|
|
55
|
+
}
|
|
56
|
+
};
|
|
57
|
+
__name(_PinoLogger, "PinoLogger");
|
|
58
|
+
var PinoLogger = _PinoLogger;
|
|
59
|
+
PinoLogger = _ts_decorate([
|
|
60
|
+
(0, import_common.Injectable)()
|
|
61
|
+
], PinoLogger);
|
|
62
|
+
|
|
63
|
+
// src/logger.module.ts
|
|
64
|
+
function _ts_decorate2(decorators, target, key, desc) {
|
|
65
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
66
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
67
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
68
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
69
|
+
}
|
|
70
|
+
__name(_ts_decorate2, "_ts_decorate");
|
|
71
|
+
var _LoggerModule = class _LoggerModule {
|
|
72
|
+
static register(options) {
|
|
73
|
+
const { global, logDir = "./var/log" } = options;
|
|
74
|
+
return {
|
|
75
|
+
global,
|
|
76
|
+
module: _LoggerModule,
|
|
77
|
+
imports: [
|
|
78
|
+
import_nestjs_pino2.LoggerModule.forRootAsync({
|
|
79
|
+
inject: [
|
|
80
|
+
import_bff_core.CtxService
|
|
81
|
+
],
|
|
82
|
+
useFactory: /* @__PURE__ */ __name((ctx) => {
|
|
83
|
+
const isProd = process.env.NODE_ENV === "production";
|
|
84
|
+
const stdTargets = [
|
|
85
|
+
{
|
|
86
|
+
target: "pino-pretty",
|
|
87
|
+
options: {
|
|
88
|
+
colorize: true,
|
|
89
|
+
minimumLevel: "debug",
|
|
90
|
+
ignore: "pid,hostname",
|
|
91
|
+
messageFormat: "{if context}[{context}]: {end} {msg} {if responseTime}{responseTime}ms {end}",
|
|
92
|
+
singleLine: true
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
];
|
|
96
|
+
const fileTargets = [
|
|
97
|
+
{
|
|
98
|
+
level: "error",
|
|
99
|
+
target: "pino/file",
|
|
100
|
+
options: {
|
|
101
|
+
destination: `${logDir}/bff-err.log`,
|
|
102
|
+
mkdir: true
|
|
103
|
+
}
|
|
104
|
+
},
|
|
105
|
+
{
|
|
106
|
+
level: "debug",
|
|
107
|
+
target: "pino/file",
|
|
108
|
+
options: {
|
|
109
|
+
destination: `${logDir}/bff-out.log`,
|
|
110
|
+
mkdir: true
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
];
|
|
114
|
+
return {
|
|
115
|
+
pinoHttp: {
|
|
116
|
+
transport: {
|
|
117
|
+
targets: isProd ? [
|
|
118
|
+
...stdTargets,
|
|
119
|
+
...fileTargets
|
|
120
|
+
] : stdTargets
|
|
121
|
+
},
|
|
122
|
+
// genReqId: _req => ctx.traceid,
|
|
123
|
+
// customAttributeKeys: { reqId: 'traceid' },
|
|
124
|
+
serializers: {
|
|
125
|
+
req(req) {
|
|
126
|
+
delete req.id;
|
|
127
|
+
req.traceid = ctx.traceid;
|
|
128
|
+
req.headers.business = req.raw.headers.business;
|
|
129
|
+
req.headers.usertoken = req.raw.headers.usertoken;
|
|
130
|
+
req.headers.authorization = req.raw.headers.authorization;
|
|
131
|
+
req.headers.version = req.raw.headers.version;
|
|
132
|
+
req.url = `${req.raw.protocol}://${req.headers.host}${req.url}`;
|
|
133
|
+
req.body = req.raw.body;
|
|
134
|
+
req.user = req.raw.user;
|
|
135
|
+
req.tracks = ctx.tracks;
|
|
136
|
+
return req;
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
};
|
|
141
|
+
}, "useFactory")
|
|
142
|
+
})
|
|
143
|
+
]
|
|
144
|
+
};
|
|
145
|
+
}
|
|
146
|
+
};
|
|
147
|
+
__name(_LoggerModule, "LoggerModule");
|
|
148
|
+
var LoggerModule = _LoggerModule;
|
|
149
|
+
LoggerModule = _ts_decorate2([
|
|
150
|
+
(0, import_common2.Module)({
|
|
151
|
+
providers: [
|
|
152
|
+
PinoLogger
|
|
153
|
+
],
|
|
154
|
+
exports: [
|
|
155
|
+
PinoLogger
|
|
156
|
+
]
|
|
157
|
+
})
|
|
158
|
+
], LoggerModule);
|
|
159
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
160
|
+
0 && (module.exports = {
|
|
161
|
+
LoggerModule,
|
|
162
|
+
PinoLogger
|
|
163
|
+
});
|
package/dist/index.mjs
ADDED
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { DynamicModule } from '@nestjs/common';
|
|
2
|
+
|
|
3
|
+
interface LoggerModuleOptions {
|
|
4
|
+
global?: boolean;
|
|
5
|
+
logDir?: string;
|
|
6
|
+
}
|
|
7
|
+
declare class LoggerModule {
|
|
8
|
+
static register(options: LoggerModuleOptions): DynamicModule;
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
export { LoggerModule, type LoggerModuleOptions };
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { DynamicModule } from '@nestjs/common';
|
|
2
|
+
|
|
3
|
+
interface LoggerModuleOptions {
|
|
4
|
+
global?: boolean;
|
|
5
|
+
logDir?: string;
|
|
6
|
+
}
|
|
7
|
+
declare class LoggerModule {
|
|
8
|
+
static register(options: LoggerModuleOptions): DynamicModule;
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
export { LoggerModule, type LoggerModuleOptions };
|
|
@@ -0,0 +1,159 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
7
|
+
var __export = (target, all) => {
|
|
8
|
+
for (var name in all)
|
|
9
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
10
|
+
};
|
|
11
|
+
var __copyProps = (to, from, except, desc) => {
|
|
12
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
13
|
+
for (let key of __getOwnPropNames(from))
|
|
14
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
15
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
16
|
+
}
|
|
17
|
+
return to;
|
|
18
|
+
};
|
|
19
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
20
|
+
|
|
21
|
+
// src/logger.module.ts
|
|
22
|
+
var logger_module_exports = {};
|
|
23
|
+
__export(logger_module_exports, {
|
|
24
|
+
LoggerModule: () => LoggerModule
|
|
25
|
+
});
|
|
26
|
+
module.exports = __toCommonJS(logger_module_exports);
|
|
27
|
+
var import_common2 = require("@nestjs/common");
|
|
28
|
+
var import_bff_core = require("@xfe-repo/bff-core");
|
|
29
|
+
var import_nestjs_pino2 = require("nestjs-pino");
|
|
30
|
+
|
|
31
|
+
// src/pino.logger.ts
|
|
32
|
+
var import_common = require("@nestjs/common");
|
|
33
|
+
var import_nestjs_pino = require("nestjs-pino");
|
|
34
|
+
function _ts_decorate(decorators, target, key, desc) {
|
|
35
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
36
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
37
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
38
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
39
|
+
}
|
|
40
|
+
__name(_ts_decorate, "_ts_decorate");
|
|
41
|
+
var SKIP_CONTEXTS = [
|
|
42
|
+
"NestFactory",
|
|
43
|
+
"InstanceLoader",
|
|
44
|
+
"RoutesResolver",
|
|
45
|
+
"RouterExplorer",
|
|
46
|
+
"ClientProxy"
|
|
47
|
+
];
|
|
48
|
+
var _PinoLogger = class _PinoLogger extends import_nestjs_pino.Logger {
|
|
49
|
+
log(message, context) {
|
|
50
|
+
if (context && SKIP_CONTEXTS.includes(context)) return;
|
|
51
|
+
super.log(message, context);
|
|
52
|
+
}
|
|
53
|
+
};
|
|
54
|
+
__name(_PinoLogger, "PinoLogger");
|
|
55
|
+
var PinoLogger = _PinoLogger;
|
|
56
|
+
PinoLogger = _ts_decorate([
|
|
57
|
+
(0, import_common.Injectable)()
|
|
58
|
+
], PinoLogger);
|
|
59
|
+
|
|
60
|
+
// src/logger.module.ts
|
|
61
|
+
function _ts_decorate2(decorators, target, key, desc) {
|
|
62
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
63
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
64
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
65
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
66
|
+
}
|
|
67
|
+
__name(_ts_decorate2, "_ts_decorate");
|
|
68
|
+
var _LoggerModule = class _LoggerModule {
|
|
69
|
+
static register(options) {
|
|
70
|
+
const { global, logDir = "./var/log" } = options;
|
|
71
|
+
return {
|
|
72
|
+
global,
|
|
73
|
+
module: _LoggerModule,
|
|
74
|
+
imports: [
|
|
75
|
+
import_nestjs_pino2.LoggerModule.forRootAsync({
|
|
76
|
+
inject: [
|
|
77
|
+
import_bff_core.CtxService
|
|
78
|
+
],
|
|
79
|
+
useFactory: /* @__PURE__ */ __name((ctx) => {
|
|
80
|
+
const isProd = process.env.NODE_ENV === "production";
|
|
81
|
+
const stdTargets = [
|
|
82
|
+
{
|
|
83
|
+
target: "pino-pretty",
|
|
84
|
+
options: {
|
|
85
|
+
colorize: true,
|
|
86
|
+
minimumLevel: "debug",
|
|
87
|
+
ignore: "pid,hostname",
|
|
88
|
+
messageFormat: "{if context}[{context}]: {end} {msg} {if responseTime}{responseTime}ms {end}",
|
|
89
|
+
singleLine: true
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
];
|
|
93
|
+
const fileTargets = [
|
|
94
|
+
{
|
|
95
|
+
level: "error",
|
|
96
|
+
target: "pino/file",
|
|
97
|
+
options: {
|
|
98
|
+
destination: `${logDir}/bff-err.log`,
|
|
99
|
+
mkdir: true
|
|
100
|
+
}
|
|
101
|
+
},
|
|
102
|
+
{
|
|
103
|
+
level: "debug",
|
|
104
|
+
target: "pino/file",
|
|
105
|
+
options: {
|
|
106
|
+
destination: `${logDir}/bff-out.log`,
|
|
107
|
+
mkdir: true
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
];
|
|
111
|
+
return {
|
|
112
|
+
pinoHttp: {
|
|
113
|
+
transport: {
|
|
114
|
+
targets: isProd ? [
|
|
115
|
+
...stdTargets,
|
|
116
|
+
...fileTargets
|
|
117
|
+
] : stdTargets
|
|
118
|
+
},
|
|
119
|
+
// genReqId: _req => ctx.traceid,
|
|
120
|
+
// customAttributeKeys: { reqId: 'traceid' },
|
|
121
|
+
serializers: {
|
|
122
|
+
req(req) {
|
|
123
|
+
delete req.id;
|
|
124
|
+
req.traceid = ctx.traceid;
|
|
125
|
+
req.headers.business = req.raw.headers.business;
|
|
126
|
+
req.headers.usertoken = req.raw.headers.usertoken;
|
|
127
|
+
req.headers.authorization = req.raw.headers.authorization;
|
|
128
|
+
req.headers.version = req.raw.headers.version;
|
|
129
|
+
req.url = `${req.raw.protocol}://${req.headers.host}${req.url}`;
|
|
130
|
+
req.body = req.raw.body;
|
|
131
|
+
req.user = req.raw.user;
|
|
132
|
+
req.tracks = ctx.tracks;
|
|
133
|
+
return req;
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
};
|
|
138
|
+
}, "useFactory")
|
|
139
|
+
})
|
|
140
|
+
]
|
|
141
|
+
};
|
|
142
|
+
}
|
|
143
|
+
};
|
|
144
|
+
__name(_LoggerModule, "LoggerModule");
|
|
145
|
+
var LoggerModule = _LoggerModule;
|
|
146
|
+
LoggerModule = _ts_decorate2([
|
|
147
|
+
(0, import_common2.Module)({
|
|
148
|
+
providers: [
|
|
149
|
+
PinoLogger
|
|
150
|
+
],
|
|
151
|
+
exports: [
|
|
152
|
+
PinoLogger
|
|
153
|
+
]
|
|
154
|
+
})
|
|
155
|
+
], LoggerModule);
|
|
156
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
157
|
+
0 && (module.exports = {
|
|
158
|
+
LoggerModule
|
|
159
|
+
});
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
7
|
+
var __export = (target, all) => {
|
|
8
|
+
for (var name in all)
|
|
9
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
10
|
+
};
|
|
11
|
+
var __copyProps = (to, from, except, desc) => {
|
|
12
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
13
|
+
for (let key of __getOwnPropNames(from))
|
|
14
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
15
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
16
|
+
}
|
|
17
|
+
return to;
|
|
18
|
+
};
|
|
19
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
20
|
+
|
|
21
|
+
// src/pino.logger.ts
|
|
22
|
+
var pino_logger_exports = {};
|
|
23
|
+
__export(pino_logger_exports, {
|
|
24
|
+
PinoLogger: () => PinoLogger
|
|
25
|
+
});
|
|
26
|
+
module.exports = __toCommonJS(pino_logger_exports);
|
|
27
|
+
var import_common = require("@nestjs/common");
|
|
28
|
+
var import_nestjs_pino = require("nestjs-pino");
|
|
29
|
+
function _ts_decorate(decorators, target, key, desc) {
|
|
30
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
31
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
32
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
33
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
34
|
+
}
|
|
35
|
+
__name(_ts_decorate, "_ts_decorate");
|
|
36
|
+
var SKIP_CONTEXTS = [
|
|
37
|
+
"NestFactory",
|
|
38
|
+
"InstanceLoader",
|
|
39
|
+
"RoutesResolver",
|
|
40
|
+
"RouterExplorer",
|
|
41
|
+
"ClientProxy"
|
|
42
|
+
];
|
|
43
|
+
var _PinoLogger = class _PinoLogger extends import_nestjs_pino.Logger {
|
|
44
|
+
log(message, context) {
|
|
45
|
+
if (context && SKIP_CONTEXTS.includes(context)) return;
|
|
46
|
+
super.log(message, context);
|
|
47
|
+
}
|
|
48
|
+
};
|
|
49
|
+
__name(_PinoLogger, "PinoLogger");
|
|
50
|
+
var PinoLogger = _PinoLogger;
|
|
51
|
+
PinoLogger = _ts_decorate([
|
|
52
|
+
(0, import_common.Injectable)()
|
|
53
|
+
], PinoLogger);
|
|
54
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
55
|
+
0 && (module.exports = {
|
|
56
|
+
PinoLogger
|
|
57
|
+
});
|
package/package.json
ADDED
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@xfe-repo/bff-logger",
|
|
3
|
+
"version": "1.0.0",
|
|
4
|
+
"sideEffects": false,
|
|
5
|
+
"module": "dist/index.js",
|
|
6
|
+
"types": "dist/index.d.ts",
|
|
7
|
+
"exports": {
|
|
8
|
+
".": {
|
|
9
|
+
"import": {
|
|
10
|
+
"types": "./dist/index.d.mts",
|
|
11
|
+
"default": "./dist/index.mjs"
|
|
12
|
+
},
|
|
13
|
+
"require": {
|
|
14
|
+
"types": "./dist/index.d.ts",
|
|
15
|
+
"default": "./dist/index.js"
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
},
|
|
19
|
+
"files": [
|
|
20
|
+
"dist"
|
|
21
|
+
],
|
|
22
|
+
"dependencies": {
|
|
23
|
+
"@nestjs/common": "^11.1.12",
|
|
24
|
+
"nestjs-pino": "^4.5.0",
|
|
25
|
+
"pino-pretty": "^13.1.3",
|
|
26
|
+
"@xfe-repo/bff-core": "1.2.3"
|
|
27
|
+
},
|
|
28
|
+
"devDependencies": {
|
|
29
|
+
"@types/node": "^25.0.10",
|
|
30
|
+
"@xfe-repo/eslint-config": "0.0.5",
|
|
31
|
+
"@xfe-repo/typescript-config": "0.0.6"
|
|
32
|
+
},
|
|
33
|
+
"peerDependencies": {},
|
|
34
|
+
"publishConfig": {
|
|
35
|
+
"registry": "https://registry.npmjs.org/"
|
|
36
|
+
},
|
|
37
|
+
"scripts": {
|
|
38
|
+
"build": "tsup",
|
|
39
|
+
"dev": "tsup --watch",
|
|
40
|
+
"lint": "eslint \"src/**/*.ts*\"",
|
|
41
|
+
"clean": "rm -rf .turbo && rm -rf node_modules && rm -rf dist"
|
|
42
|
+
}
|
|
43
|
+
}
|