@lark-apaas/nestjs-logger 1.0.2-alpha.23 → 1.0.2-alpha.24
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 +129 -351
- package/dist/index.cjs.map +1 -1
- package/dist/index.js +120 -342
- package/dist/index.js.map +1 -1
- package/package.json +2 -2
package/dist/index.cjs
CHANGED
|
@@ -1361,10 +1361,10 @@ var SpanStatusCode;
|
|
|
1361
1361
|
var init_status = __esm({
|
|
1362
1362
|
"../../../node_modules/@opentelemetry/api/build/esm/trace/status.js"() {
|
|
1363
1363
|
"use strict";
|
|
1364
|
-
(function(
|
|
1365
|
-
|
|
1366
|
-
|
|
1367
|
-
|
|
1364
|
+
(function(SpanStatusCode2) {
|
|
1365
|
+
SpanStatusCode2[SpanStatusCode2["UNSET"] = 0] = "UNSET";
|
|
1366
|
+
SpanStatusCode2[SpanStatusCode2["OK"] = 1] = "OK";
|
|
1367
|
+
SpanStatusCode2[SpanStatusCode2["ERROR"] = 2] = "ERROR";
|
|
1368
1368
|
})(SpanStatusCode || (SpanStatusCode = {}));
|
|
1369
1369
|
}
|
|
1370
1370
|
});
|
|
@@ -65612,20 +65612,16 @@ var METRICS_LOGGER = Symbol("METRICS_LOGGER");
|
|
|
65612
65612
|
var import_nestjs_common3 = require("@lark-apaas/nestjs-common");
|
|
65613
65613
|
|
|
65614
65614
|
// ../nestjs-observable/dist/index.js
|
|
65615
|
-
var
|
|
65615
|
+
var import_common4 = require("@nestjs/common");
|
|
65616
65616
|
|
|
65617
65617
|
// ../observable-server/dist/index.js
|
|
65618
65618
|
var import_sdk_node = __toESM(require_src12(), 1);
|
|
65619
65619
|
init_esm6();
|
|
65620
|
-
var import_sdk_trace_node = __toESM(require_src2(), 1);
|
|
65621
65620
|
init_esm5();
|
|
65622
|
-
init_esm();
|
|
65623
65621
|
init_esm4();
|
|
65624
65622
|
init_esm3();
|
|
65623
|
+
var import_common3 = require("@nestjs/common");
|
|
65625
65624
|
var import_crypto2 = require("crypto");
|
|
65626
|
-
init_esm4();
|
|
65627
|
-
init_esm3();
|
|
65628
|
-
init_esm();
|
|
65629
65625
|
var __defProp2 = Object.defineProperty;
|
|
65630
65626
|
var __name2 = /* @__PURE__ */ __name((target, value) => __defProp2(target, "name", {
|
|
65631
65627
|
value,
|
|
@@ -65687,11 +65683,6 @@ var AppEnv = /* @__PURE__ */ (function(AppEnv2) {
|
|
|
65687
65683
|
AppEnv2["Prod"] = "runtime";
|
|
65688
65684
|
return AppEnv2;
|
|
65689
65685
|
})({});
|
|
65690
|
-
var defaultResourceAttr = {
|
|
65691
|
-
"sdk_version": "1.0.1-alpha.18",
|
|
65692
|
-
"sdk_type": "client-backend",
|
|
65693
|
-
"sdk_language": "node"
|
|
65694
|
-
};
|
|
65695
65686
|
var safeStringify = /* @__PURE__ */ __name2((obj) => {
|
|
65696
65687
|
try {
|
|
65697
65688
|
return JSON.stringify(obj);
|
|
@@ -65708,6 +65699,19 @@ function convertAttributesToString(attributes) {
|
|
|
65708
65699
|
}
|
|
65709
65700
|
__name(convertAttributesToString, "convertAttributesToString");
|
|
65710
65701
|
__name2(convertAttributesToString, "convertAttributesToString");
|
|
65702
|
+
function _ts_decorate(decorators, target, key, desc) {
|
|
65703
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
65704
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
65705
|
+
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;
|
|
65706
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
65707
|
+
}
|
|
65708
|
+
__name(_ts_decorate, "_ts_decorate");
|
|
65709
|
+
__name2(_ts_decorate, "_ts_decorate");
|
|
65710
|
+
function _ts_metadata(k, v) {
|
|
65711
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
65712
|
+
}
|
|
65713
|
+
__name(_ts_metadata, "_ts_metadata");
|
|
65714
|
+
__name2(_ts_metadata, "_ts_metadata");
|
|
65711
65715
|
var CustomExporter = class {
|
|
65712
65716
|
static {
|
|
65713
65717
|
__name(this, "CustomExporter");
|
|
@@ -65727,113 +65731,28 @@ var CustomExporter = class {
|
|
|
65727
65731
|
};
|
|
65728
65732
|
const otlpLikeStructure = {
|
|
65729
65733
|
resource: {
|
|
65730
|
-
|
|
65731
|
-
|
|
65732
|
-
}
|
|
65734
|
+
// 合并 OTel Resource(此处暂留空,真实场景可由 sdk.resource 提供)
|
|
65735
|
+
attributes: {}
|
|
65733
65736
|
},
|
|
65734
|
-
logRecords: logs2.map((log) =>
|
|
65735
|
-
timeUnixNano: hrTimeToNanosNumber(log.hrTime),
|
|
65736
|
-
observedTimeUnixNano: hrTimeToNanosNumber(log.hrTimeObserved),
|
|
65737
|
-
severityNumber: log.severityNumber,
|
|
65738
|
-
severityText: log.severityText,
|
|
65739
|
-
body: log.body,
|
|
65740
|
-
attributes: convertAttributesToString({
|
|
65741
|
-
...defaultAttributes,
|
|
65742
|
-
...log.attributes ?? {}
|
|
65743
|
-
}),
|
|
65744
|
-
traceID: log.spanContext?.traceId,
|
|
65745
|
-
spanID: log.spanContext?.spanId
|
|
65746
|
-
}))
|
|
65747
|
-
};
|
|
65748
|
-
console.log(this.logPrefix + JSON.stringify(otlpLikeStructure) + this.logSuffix);
|
|
65749
|
-
resultCallback({
|
|
65750
|
-
code: ExportResultCode.SUCCESS
|
|
65751
|
-
});
|
|
65752
|
-
}
|
|
65753
|
-
async shutdown() {
|
|
65754
|
-
}
|
|
65755
|
-
};
|
|
65756
|
-
function mapSeverity(level) {
|
|
65757
|
-
switch (level.toLowerCase()) {
|
|
65758
|
-
case "trace":
|
|
65759
|
-
return SeverityNumber.TRACE;
|
|
65760
|
-
case "debug":
|
|
65761
|
-
return SeverityNumber.DEBUG;
|
|
65762
|
-
case "info":
|
|
65763
|
-
return SeverityNumber.INFO;
|
|
65764
|
-
case "warn":
|
|
65765
|
-
return SeverityNumber.WARN;
|
|
65766
|
-
case "error":
|
|
65767
|
-
return SeverityNumber.ERROR;
|
|
65768
|
-
case "fatal":
|
|
65769
|
-
return SeverityNumber.FATAL;
|
|
65770
|
-
default:
|
|
65771
|
-
return SeverityNumber.INFO;
|
|
65772
|
-
}
|
|
65773
|
-
}
|
|
65774
|
-
__name(mapSeverity, "mapSeverity");
|
|
65775
|
-
__name2(mapSeverity, "mapSeverity");
|
|
65776
|
-
function mapSeverityText(level) {
|
|
65777
|
-
switch (level.toLowerCase()) {
|
|
65778
|
-
case "trace":
|
|
65779
|
-
return "INFO";
|
|
65780
|
-
case "debug":
|
|
65781
|
-
return "DEBUG";
|
|
65782
|
-
case "info":
|
|
65783
|
-
return "INFO";
|
|
65784
|
-
case "warn":
|
|
65785
|
-
return "WARN";
|
|
65786
|
-
case "error":
|
|
65787
|
-
return "ERROR";
|
|
65788
|
-
case "fatal":
|
|
65789
|
-
return "ERROR";
|
|
65790
|
-
default:
|
|
65791
|
-
return "INFO";
|
|
65792
|
-
}
|
|
65793
|
-
}
|
|
65794
|
-
__name(mapSeverityText, "mapSeverityText");
|
|
65795
|
-
__name2(mapSeverityText, "mapSeverityText");
|
|
65796
|
-
var CustomTraceExporter = class {
|
|
65797
|
-
static {
|
|
65798
|
-
__name(this, "CustomTraceExporter");
|
|
65799
|
-
}
|
|
65800
|
-
static {
|
|
65801
|
-
__name2(this, "CustomTraceExporter");
|
|
65802
|
-
}
|
|
65803
|
-
tracePrefix = "force-trace-prefix";
|
|
65804
|
-
traceSuffix = "force-trace-suffix";
|
|
65805
|
-
export(spans, resultCallback) {
|
|
65806
|
-
const isDev = process.env.NODE_ENV === "development";
|
|
65807
|
-
const defaultAttributes = {
|
|
65808
|
-
uuid: idGenerator.generateTraceId(),
|
|
65809
|
-
app_env: isDev ? AppEnv.Dev : AppEnv.Prod
|
|
65810
|
-
};
|
|
65811
|
-
const otlpLikeStructure = {
|
|
65812
|
-
resource: {
|
|
65813
|
-
attributes: {
|
|
65814
|
-
...defaultResourceAttr
|
|
65815
|
-
}
|
|
65816
|
-
},
|
|
65817
|
-
spans: spans.map((span) => {
|
|
65737
|
+
logRecords: logs2.map((log) => {
|
|
65818
65738
|
const rawAttributes = {
|
|
65819
65739
|
...defaultAttributes,
|
|
65820
|
-
...
|
|
65740
|
+
...log.attributes ?? {}
|
|
65821
65741
|
};
|
|
65822
65742
|
const attributes = convertAttributesToString(rawAttributes);
|
|
65823
65743
|
return {
|
|
65824
|
-
|
|
65825
|
-
|
|
65826
|
-
|
|
65744
|
+
timeUnixNano: hrTimeToNanosNumber(log.hrTime),
|
|
65745
|
+
observedTimeUnixNano: hrTimeToNanosNumber(log.hrTimeObserved),
|
|
65746
|
+
severityNumber: log.severityNumber,
|
|
65747
|
+
severityText: log.severityText,
|
|
65748
|
+
body: log.body,
|
|
65827
65749
|
attributes,
|
|
65828
|
-
|
|
65829
|
-
|
|
65830
|
-
parentSpanID: span.parentSpanContext?.spanId,
|
|
65831
|
-
status: span.status,
|
|
65832
|
-
kind: SpanKind.SERVER
|
|
65750
|
+
traceId: log.spanContext?.traceId,
|
|
65751
|
+
spanId: log.spanContext?.spanId
|
|
65833
65752
|
};
|
|
65834
65753
|
})
|
|
65835
65754
|
};
|
|
65836
|
-
console.log(this.
|
|
65755
|
+
console.log(this.logPrefix + JSON.stringify(otlpLikeStructure) + this.logSuffix);
|
|
65837
65756
|
resultCallback({
|
|
65838
65757
|
code: ExportResultCode.SUCCESS
|
|
65839
65758
|
});
|
|
@@ -65841,17 +65760,20 @@ var CustomTraceExporter = class {
|
|
|
65841
65760
|
async shutdown() {
|
|
65842
65761
|
}
|
|
65843
65762
|
};
|
|
65844
|
-
|
|
65763
|
+
CustomExporter = _ts_decorate([
|
|
65764
|
+
(0, import_common3.Injectable)(),
|
|
65765
|
+
_ts_metadata("design:type", Function),
|
|
65766
|
+
_ts_metadata("design:paramtypes", [])
|
|
65767
|
+
], CustomExporter);
|
|
65768
|
+
var AppOTelLoggerSDK = class {
|
|
65845
65769
|
static {
|
|
65846
|
-
__name(this, "
|
|
65770
|
+
__name(this, "AppOTelLoggerSDK");
|
|
65847
65771
|
}
|
|
65848
65772
|
static {
|
|
65849
|
-
__name2(this, "
|
|
65773
|
+
__name2(this, "AppOTelLoggerSDK");
|
|
65850
65774
|
}
|
|
65851
65775
|
sdk = null;
|
|
65852
65776
|
logProcessor = null;
|
|
65853
|
-
spanProcessor = null;
|
|
65854
|
-
static CUSTOM_FORMAT_REGEX = /^[0-9a-fA-F]{32}-[0-9a-fA-F]{16}$/;
|
|
65855
65777
|
start() {
|
|
65856
65778
|
const resource = detectResources({
|
|
65857
65779
|
detectors: [
|
|
@@ -65861,68 +65783,24 @@ var AppOTelSDK = class _AppOTelSDK {
|
|
|
65861
65783
|
const logExporter = new CustomExporter();
|
|
65862
65784
|
this.logProcessor = new BatchLogRecordProcessor(logExporter, {
|
|
65863
65785
|
scheduledDelayMillis: 2e3,
|
|
65864
|
-
maxExportBatchSize:
|
|
65865
|
-
});
|
|
65866
|
-
const traceExporter = new CustomTraceExporter();
|
|
65867
|
-
this.spanProcessor = new import_sdk_trace_node.BatchSpanProcessor(traceExporter, {
|
|
65868
|
-
scheduledDelayMillis: 2e3,
|
|
65869
|
-
maxExportBatchSize: 2
|
|
65786
|
+
maxExportBatchSize: 10
|
|
65870
65787
|
});
|
|
65871
65788
|
this.sdk = new import_sdk_node.NodeSDK({
|
|
65872
65789
|
resource,
|
|
65873
65790
|
logRecordProcessor: this.logProcessor,
|
|
65874
|
-
|
|
65791
|
+
traceExporter: void 0
|
|
65875
65792
|
});
|
|
65876
65793
|
this.sdk.start();
|
|
65877
65794
|
}
|
|
65878
65795
|
/**
|
|
65879
|
-
*
|
|
65880
|
-
*
|
|
65881
|
-
*/
|
|
65882
|
-
startContext(headers, name, fn) {
|
|
65883
|
-
const carrier = {};
|
|
65884
|
-
const customTraceId = headers["rpc-persist-apaas-observability-trace"];
|
|
65885
|
-
if (customTraceId && _AppOTelSDK.CUSTOM_FORMAT_REGEX.test(customTraceId)) {
|
|
65886
|
-
carrier["traceparent"] = `00-${customTraceId}-01`;
|
|
65887
|
-
}
|
|
65888
|
-
const activeContext = propagation.extract(context.active(), carrier);
|
|
65889
|
-
const tracer = trace.getTracer("app-core");
|
|
65890
|
-
tracer.startActiveSpan(name, {}, activeContext, (span) => {
|
|
65891
|
-
fn(span);
|
|
65892
|
-
});
|
|
65893
|
-
}
|
|
65894
|
-
/**
|
|
65895
|
-
* [用户专用 API] 手动打点 (Child Span)
|
|
65896
|
-
* 用户在 Service 中调用此方法,会自动挂载到 Middleware 创建的 Root Span 下
|
|
65897
|
-
*/
|
|
65898
|
-
async trace(name, fn) {
|
|
65899
|
-
const tracer = trace.getTracer("user-trace");
|
|
65900
|
-
return tracer.startActiveSpan(name, async (span) => {
|
|
65901
|
-
try {
|
|
65902
|
-
const res = await fn(span);
|
|
65903
|
-
span.setStatus({
|
|
65904
|
-
code: SpanStatusCode.OK
|
|
65905
|
-
});
|
|
65906
|
-
return res;
|
|
65907
|
-
} catch (e) {
|
|
65908
|
-
span.recordException(e);
|
|
65909
|
-
span.setStatus({
|
|
65910
|
-
code: SpanStatusCode.ERROR
|
|
65911
|
-
});
|
|
65912
|
-
throw e;
|
|
65913
|
-
} finally {
|
|
65914
|
-
span.end();
|
|
65915
|
-
}
|
|
65916
|
-
});
|
|
65917
|
-
}
|
|
65918
|
-
/**
|
|
65919
|
-
* [Log API] 自动关联 TraceContext
|
|
65796
|
+
* 用户使用的日志接口
|
|
65797
|
+
* 自动合并请求级上下文(由 ContextProvider 提供)
|
|
65920
65798
|
*/
|
|
65921
65799
|
log(level, message, extra = {}) {
|
|
65922
65800
|
const logger2 = logs.getLogger("app-logger");
|
|
65923
|
-
const severityNumber = mapSeverity(level);
|
|
65924
|
-
const severityText = mapSeverityText(level);
|
|
65925
|
-
const
|
|
65801
|
+
const severityNumber = this.mapSeverity(level);
|
|
65802
|
+
const severityText = this.mapSeverityText(level);
|
|
65803
|
+
const mergedAttributes = {
|
|
65926
65804
|
...extra || {},
|
|
65927
65805
|
pid: process.pid
|
|
65928
65806
|
};
|
|
@@ -65930,150 +65808,136 @@ var AppOTelSDK = class _AppOTelSDK {
|
|
|
65930
65808
|
body: message,
|
|
65931
65809
|
severityNumber,
|
|
65932
65810
|
severityText,
|
|
65933
|
-
attributes,
|
|
65934
|
-
timestamp: /* @__PURE__ */ new Date()
|
|
65935
|
-
// 自动关联当前上下文
|
|
65936
|
-
context: context.active()
|
|
65811
|
+
attributes: mergedAttributes,
|
|
65812
|
+
timestamp: /* @__PURE__ */ new Date()
|
|
65937
65813
|
});
|
|
65938
65814
|
}
|
|
65939
|
-
/**
|
|
65940
|
-
* [框架专用] 强制刷新
|
|
65941
|
-
*/
|
|
65942
65815
|
async flush() {
|
|
65943
|
-
|
|
65944
|
-
this.logProcessor
|
|
65945
|
-
|
|
65946
|
-
|
|
65816
|
+
if (this.logProcessor) {
|
|
65817
|
+
await this.logProcessor.forceFlush();
|
|
65818
|
+
}
|
|
65819
|
+
}
|
|
65820
|
+
mapSeverity(level) {
|
|
65821
|
+
switch (level.toLowerCase()) {
|
|
65822
|
+
case "trace":
|
|
65823
|
+
return SeverityNumber.TRACE;
|
|
65824
|
+
case "debug":
|
|
65825
|
+
return SeverityNumber.DEBUG;
|
|
65826
|
+
case "info":
|
|
65827
|
+
return SeverityNumber.INFO;
|
|
65828
|
+
case "warn":
|
|
65829
|
+
return SeverityNumber.WARN;
|
|
65830
|
+
case "error":
|
|
65831
|
+
return SeverityNumber.ERROR;
|
|
65832
|
+
case "fatal":
|
|
65833
|
+
return SeverityNumber.FATAL;
|
|
65834
|
+
default:
|
|
65835
|
+
return SeverityNumber.INFO;
|
|
65836
|
+
}
|
|
65837
|
+
}
|
|
65838
|
+
mapSeverityText(level) {
|
|
65839
|
+
switch (level.toLowerCase()) {
|
|
65840
|
+
case "trace":
|
|
65841
|
+
return "INFO";
|
|
65842
|
+
case "debug":
|
|
65843
|
+
return "DEBUG";
|
|
65844
|
+
case "info":
|
|
65845
|
+
return "INFO";
|
|
65846
|
+
case "warn":
|
|
65847
|
+
return "WARN";
|
|
65848
|
+
case "error":
|
|
65849
|
+
return "ERROR";
|
|
65850
|
+
case "fatal":
|
|
65851
|
+
return "ERROR";
|
|
65852
|
+
default:
|
|
65853
|
+
return "INFO";
|
|
65854
|
+
}
|
|
65947
65855
|
}
|
|
65948
65856
|
};
|
|
65949
|
-
var appSdk = new
|
|
65857
|
+
var appSdk = new AppOTelLoggerSDK();
|
|
65950
65858
|
|
|
65951
65859
|
// ../nestjs-observable/dist/index.js
|
|
65952
65860
|
var import_nestjs_common = require("@lark-apaas/nestjs-common");
|
|
65953
|
-
var import_common4 = require("@nestjs/common");
|
|
65954
|
-
var import_nestjs_common2 = require("@lark-apaas/nestjs-common");
|
|
65955
65861
|
var import_common5 = require("@nestjs/common");
|
|
65862
|
+
var import_nestjs_common2 = require("@lark-apaas/nestjs-common");
|
|
65956
65863
|
var __defProp3 = Object.defineProperty;
|
|
65957
65864
|
var __name3 = /* @__PURE__ */ __name((target, value) => __defProp3(target, "name", {
|
|
65958
65865
|
value,
|
|
65959
65866
|
configurable: true
|
|
65960
65867
|
}), "__name");
|
|
65961
|
-
function
|
|
65868
|
+
function _ts_decorate2(decorators, target, key, desc) {
|
|
65962
65869
|
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
65963
65870
|
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
65964
65871
|
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;
|
|
65965
65872
|
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
65966
65873
|
}
|
|
65967
|
-
__name(
|
|
65968
|
-
__name3(
|
|
65969
|
-
function
|
|
65874
|
+
__name(_ts_decorate2, "_ts_decorate");
|
|
65875
|
+
__name3(_ts_decorate2, "_ts_decorate");
|
|
65876
|
+
function _ts_metadata2(k, v) {
|
|
65970
65877
|
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
65971
65878
|
}
|
|
65972
|
-
__name(
|
|
65973
|
-
__name3(
|
|
65974
|
-
var ObservableService = class
|
|
65879
|
+
__name(_ts_metadata2, "_ts_metadata");
|
|
65880
|
+
__name3(_ts_metadata2, "_ts_metadata");
|
|
65881
|
+
var ObservableService = class {
|
|
65975
65882
|
static {
|
|
65976
|
-
__name(this, "
|
|
65883
|
+
__name(this, "ObservableService");
|
|
65977
65884
|
}
|
|
65978
65885
|
static {
|
|
65979
65886
|
__name3(this, "ObservableService");
|
|
65980
65887
|
}
|
|
65981
65888
|
reqCtx;
|
|
65982
|
-
static _instance = null;
|
|
65983
65889
|
constructor(reqCtx) {
|
|
65984
65890
|
this.reqCtx = reqCtx;
|
|
65985
|
-
if (!_ObservableService._instance) {
|
|
65986
|
-
_ObservableService._instance = this;
|
|
65987
|
-
}
|
|
65988
|
-
}
|
|
65989
|
-
/** 获取全局单例(需确保模块已初始化) */
|
|
65990
|
-
static getInstance() {
|
|
65991
|
-
if (!_ObservableService._instance) {
|
|
65992
|
-
throw new Error("[nestjs-observable] ObservableService \u5C1A\u672A\u521D\u59CB\u5316\uFF0C\u8BF7\u786E\u4FDD\u5728\u6839\u6A21\u5757\u5F15\u5165 NestjsObservableModule.forRoot()");
|
|
65993
|
-
}
|
|
65994
|
-
return _ObservableService._instance;
|
|
65995
65891
|
}
|
|
65996
65892
|
/** 记录日志(自动合并上下文) */
|
|
65997
65893
|
log(level, message, attributes = {}) {
|
|
65998
65894
|
const contextAttributes = this.reqCtx.getContext() || {};
|
|
65999
65895
|
appSdk.log(level, message, {
|
|
66000
|
-
module: "app_server",
|
|
66001
|
-
source_type: "user",
|
|
66002
65896
|
...contextAttributes,
|
|
66003
65897
|
...attributes
|
|
66004
65898
|
});
|
|
66005
65899
|
}
|
|
66006
|
-
/** 记录链路 for user,供用户调用 */
|
|
66007
|
-
trace(name, fn) {
|
|
66008
|
-
const contextAttributes = this.reqCtx.getContext() || {};
|
|
66009
|
-
return appSdk.trace(name, (span) => {
|
|
66010
|
-
span.setAttributes({
|
|
66011
|
-
module: "app_server",
|
|
66012
|
-
source_type: "user",
|
|
66013
|
-
...contextAttributes
|
|
66014
|
-
});
|
|
66015
|
-
return fn(span);
|
|
66016
|
-
});
|
|
66017
|
-
}
|
|
66018
65900
|
/** 手动刷新(FaaS/请求结束时可调用) */
|
|
66019
65901
|
async flush() {
|
|
66020
65902
|
await appSdk.flush();
|
|
66021
65903
|
}
|
|
66022
65904
|
};
|
|
66023
|
-
ObservableService =
|
|
66024
|
-
(0,
|
|
66025
|
-
|
|
66026
|
-
|
|
65905
|
+
ObservableService = _ts_decorate2([
|
|
65906
|
+
(0, import_common5.Injectable)(),
|
|
65907
|
+
_ts_metadata2("design:type", Function),
|
|
65908
|
+
_ts_metadata2("design:paramtypes", [
|
|
66027
65909
|
typeof import_nestjs_common2.RequestContextService === "undefined" ? Object : import_nestjs_common2.RequestContextService
|
|
66028
65910
|
])
|
|
66029
65911
|
], ObservableService);
|
|
66030
|
-
function
|
|
65912
|
+
function _ts_decorate22(decorators, target, key, desc) {
|
|
66031
65913
|
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
66032
65914
|
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
66033
65915
|
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;
|
|
66034
65916
|
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
66035
65917
|
}
|
|
66036
|
-
__name(
|
|
66037
|
-
__name3(
|
|
66038
|
-
function
|
|
65918
|
+
__name(_ts_decorate22, "_ts_decorate2");
|
|
65919
|
+
__name3(_ts_decorate22, "_ts_decorate");
|
|
65920
|
+
function _ts_metadata22(k, v) {
|
|
66039
65921
|
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
66040
65922
|
}
|
|
66041
|
-
__name(
|
|
66042
|
-
__name3(
|
|
66043
|
-
var
|
|
66044
|
-
function getObservableService() {
|
|
66045
|
-
if (!OBSERVABLE_SINGLETON) {
|
|
66046
|
-
throw new Error("[nestjs-observable] ObservableService \u5C1A\u672A\u521D\u59CB\u5316\uFF0C\u8BF7\u786E\u4FDD\u5728\u6839\u6A21\u5757\u5F15\u5165 NestjsObservableModule.forRoot()");
|
|
66047
|
-
}
|
|
66048
|
-
return OBSERVABLE_SINGLETON;
|
|
66049
|
-
}
|
|
66050
|
-
__name(getObservableService, "getObservableService");
|
|
66051
|
-
__name3(getObservableService, "getObservableService");
|
|
66052
|
-
var NestjsObservableModule = class _NestjsObservableModule {
|
|
65923
|
+
__name(_ts_metadata22, "_ts_metadata2");
|
|
65924
|
+
__name3(_ts_metadata22, "_ts_metadata");
|
|
65925
|
+
var NestjsObservableModule = class {
|
|
66053
65926
|
static {
|
|
66054
|
-
__name(this, "
|
|
65927
|
+
__name(this, "NestjsObservableModule");
|
|
66055
65928
|
}
|
|
66056
65929
|
static {
|
|
66057
65930
|
__name3(this, "NestjsObservableModule");
|
|
66058
65931
|
}
|
|
66059
|
-
|
|
66060
|
-
constructor(observableService) {
|
|
66061
|
-
this.observableService = observableService;
|
|
66062
|
-
}
|
|
66063
|
-
static forRoot() {
|
|
66064
|
-
return {
|
|
66065
|
-
module: _NestjsObservableModule,
|
|
66066
|
-
global: true
|
|
66067
|
-
};
|
|
65932
|
+
constructor() {
|
|
66068
65933
|
}
|
|
66069
65934
|
onModuleInit() {
|
|
66070
65935
|
appSdk.start();
|
|
66071
|
-
OBSERVABLE_SINGLETON = this.observableService;
|
|
66072
65936
|
}
|
|
66073
65937
|
};
|
|
66074
|
-
NestjsObservableModule =
|
|
66075
|
-
(0,
|
|
66076
|
-
(0,
|
|
65938
|
+
NestjsObservableModule = _ts_decorate22([
|
|
65939
|
+
(0, import_common4.Global)(),
|
|
65940
|
+
(0, import_common4.Module)({
|
|
66077
65941
|
imports: [
|
|
66078
65942
|
import_nestjs_common.CommonModule
|
|
66079
65943
|
],
|
|
@@ -66084,104 +65948,18 @@ NestjsObservableModule = _ts_decorate2([
|
|
|
66084
65948
|
ObservableService
|
|
66085
65949
|
]
|
|
66086
65950
|
}),
|
|
66087
|
-
|
|
66088
|
-
|
|
66089
|
-
typeof ObservableService === "undefined" ? Object : ObservableService
|
|
66090
|
-
])
|
|
65951
|
+
_ts_metadata22("design:type", Function),
|
|
65952
|
+
_ts_metadata22("design:paramtypes", [])
|
|
66091
65953
|
], NestjsObservableModule);
|
|
66092
|
-
var SpanStatusCode2;
|
|
66093
|
-
(function(SpanStatusCode22) {
|
|
66094
|
-
SpanStatusCode22[SpanStatusCode22["UNSET"] = 0] = "UNSET";
|
|
66095
|
-
SpanStatusCode22[SpanStatusCode22["OK"] = 1] = "OK";
|
|
66096
|
-
SpanStatusCode22[SpanStatusCode22["ERROR"] = 2] = "ERROR";
|
|
66097
|
-
})(SpanStatusCode2 || (SpanStatusCode2 = {}));
|
|
66098
|
-
function _ts_decorate3(decorators, target, key, desc) {
|
|
66099
|
-
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
66100
|
-
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
66101
|
-
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;
|
|
66102
|
-
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
66103
|
-
}
|
|
66104
|
-
__name(_ts_decorate3, "_ts_decorate3");
|
|
66105
|
-
__name3(_ts_decorate3, "_ts_decorate");
|
|
66106
|
-
var ObservableTraceMiddleware = class {
|
|
66107
|
-
static {
|
|
66108
|
-
__name(this, "ObservableTraceMiddleware");
|
|
66109
|
-
}
|
|
66110
|
-
static {
|
|
66111
|
-
__name3(this, "ObservableTraceMiddleware");
|
|
66112
|
-
}
|
|
66113
|
-
use(req, res, next) {
|
|
66114
|
-
const spanName = `${req.method} ${req.originalUrl || req.url}`;
|
|
66115
|
-
appSdk.startContext(req.headers, spanName, (span) => {
|
|
66116
|
-
res.on("finish", () => {
|
|
66117
|
-
const status = res.statusCode;
|
|
66118
|
-
span.setAttribute("http_status_code", status);
|
|
66119
|
-
if (status >= 500) {
|
|
66120
|
-
span.setStatus({
|
|
66121
|
-
code: SpanStatusCode2.ERROR,
|
|
66122
|
-
message: `Server Error ${status}`
|
|
66123
|
-
});
|
|
66124
|
-
} else if (status >= 400) {
|
|
66125
|
-
span.setStatus({
|
|
66126
|
-
code: SpanStatusCode2.UNSET
|
|
66127
|
-
});
|
|
66128
|
-
} else {
|
|
66129
|
-
span.setStatus({
|
|
66130
|
-
code: SpanStatusCode2.OK
|
|
66131
|
-
});
|
|
66132
|
-
}
|
|
66133
|
-
span.end();
|
|
66134
|
-
appSdk.flush().catch((err) => {
|
|
66135
|
-
console.error("[OtelMiddleware] Flush failed:", err);
|
|
66136
|
-
});
|
|
66137
|
-
});
|
|
66138
|
-
next();
|
|
66139
|
-
});
|
|
66140
|
-
}
|
|
66141
|
-
};
|
|
66142
|
-
ObservableTraceMiddleware = _ts_decorate3([
|
|
66143
|
-
(0, import_common5.Injectable)()
|
|
66144
|
-
], ObservableTraceMiddleware);
|
|
66145
|
-
function Trace(name) {
|
|
66146
|
-
return function(target, propertyKey, descriptor) {
|
|
66147
|
-
const originalMethod = descriptor.value;
|
|
66148
|
-
if (!originalMethod) {
|
|
66149
|
-
return descriptor;
|
|
66150
|
-
}
|
|
66151
|
-
descriptor.value = async function(...args) {
|
|
66152
|
-
const spanName = name || `${target?.constructor?.name}.${String(propertyKey)}`;
|
|
66153
|
-
const context2 = this.reqCtx?.getContext?.() || {};
|
|
66154
|
-
const contextAttributes = {
|
|
66155
|
-
user_id: context2.userId || "",
|
|
66156
|
-
app_id: context2.appId || "",
|
|
66157
|
-
tenant_id: context2.tenantId || ""
|
|
66158
|
-
};
|
|
66159
|
-
return await appSdk.trace(spanName, async (span) => {
|
|
66160
|
-
if (contextAttributes && typeof contextAttributes === "object") {
|
|
66161
|
-
span.setAttributes({
|
|
66162
|
-
module: "app_server",
|
|
66163
|
-
source_type: "user",
|
|
66164
|
-
...contextAttributes
|
|
66165
|
-
});
|
|
66166
|
-
}
|
|
66167
|
-
const result = await originalMethod.apply(this, args);
|
|
66168
|
-
return result;
|
|
66169
|
-
});
|
|
66170
|
-
};
|
|
66171
|
-
return descriptor;
|
|
66172
|
-
};
|
|
66173
|
-
}
|
|
66174
|
-
__name(Trace, "Trace");
|
|
66175
|
-
__name3(Trace, "Trace");
|
|
66176
65954
|
|
|
66177
65955
|
// src/service/app-logger.service.ts
|
|
66178
|
-
function
|
|
65956
|
+
function _ts_decorate3(decorators, target, key, desc) {
|
|
66179
65957
|
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
66180
65958
|
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
66181
65959
|
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;
|
|
66182
65960
|
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
66183
65961
|
}
|
|
66184
|
-
__name(
|
|
65962
|
+
__name(_ts_decorate3, "_ts_decorate");
|
|
66185
65963
|
function _ts_metadata3(k, v) {
|
|
66186
65964
|
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
66187
65965
|
}
|
|
@@ -66475,7 +66253,7 @@ var AppLogger = class extends BasePinoLogger {
|
|
|
66475
66253
|
import_common6.Logger.overrideLogger(this);
|
|
66476
66254
|
}
|
|
66477
66255
|
};
|
|
66478
|
-
AppLogger =
|
|
66256
|
+
AppLogger = _ts_decorate3([
|
|
66479
66257
|
(0, import_common6.Injectable)(),
|
|
66480
66258
|
_ts_param(0, (0, import_common6.Inject)(PINO_ROOT_LOGGER)),
|
|
66481
66259
|
_ts_param(1, (0, import_common6.Inject)(import_nestjs_common3.OBSERVABLE_SERVICE_TOKEN)),
|
|
@@ -66532,7 +66310,7 @@ __name(sanitizeValue, "sanitizeValue");
|
|
|
66532
66310
|
|
|
66533
66311
|
// src/module.ts
|
|
66534
66312
|
var import_common9 = require("@nestjs/common");
|
|
66535
|
-
var
|
|
66313
|
+
var import_core41 = require("@nestjs/core");
|
|
66536
66314
|
var import_config6 = __toESM(require_config2(), 1);
|
|
66537
66315
|
var import_nestjs_common6 = require("@lark-apaas/nestjs-common");
|
|
66538
66316
|
|
|
@@ -66573,13 +66351,13 @@ var import_config5 = __toESM(require_config2(), 1);
|
|
|
66573
66351
|
var import_operators = __toESM(require_operators(), 1);
|
|
66574
66352
|
var import_util6 = require("util");
|
|
66575
66353
|
var import_nestjs_common4 = require("@lark-apaas/nestjs-common");
|
|
66576
|
-
function
|
|
66354
|
+
function _ts_decorate4(decorators, target, key, desc) {
|
|
66577
66355
|
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
66578
66356
|
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
66579
66357
|
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;
|
|
66580
66358
|
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
66581
66359
|
}
|
|
66582
|
-
__name(
|
|
66360
|
+
__name(_ts_decorate4, "_ts_decorate");
|
|
66583
66361
|
function _ts_metadata4(k, v) {
|
|
66584
66362
|
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
66585
66363
|
}
|
|
@@ -66734,7 +66512,7 @@ duration_ms=${durationMs}`, "HTTPTraceInterceptor");
|
|
|
66734
66512
|
}
|
|
66735
66513
|
}
|
|
66736
66514
|
};
|
|
66737
|
-
LoggingInterceptor =
|
|
66515
|
+
LoggingInterceptor = _ts_decorate4([
|
|
66738
66516
|
(0, import_common7.Injectable)(),
|
|
66739
66517
|
_ts_param2(0, (0, import_common7.Inject)(TRACE_LOGGER)),
|
|
66740
66518
|
_ts_param2(2, (0, import_common7.Inject)(AppLogger)),
|
|
@@ -66802,13 +66580,13 @@ __name(createFileDestination, "createFileDestination");
|
|
|
66802
66580
|
var import_common8 = require("@nestjs/common");
|
|
66803
66581
|
var import_crypto3 = require("crypto");
|
|
66804
66582
|
var import_nestjs_common5 = require("@lark-apaas/nestjs-common");
|
|
66805
|
-
function
|
|
66583
|
+
function _ts_decorate5(decorators, target, key, desc) {
|
|
66806
66584
|
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
66807
66585
|
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
66808
66586
|
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;
|
|
66809
66587
|
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
66810
66588
|
}
|
|
66811
|
-
__name(
|
|
66589
|
+
__name(_ts_decorate5, "_ts_decorate");
|
|
66812
66590
|
function _ts_metadata5(k, v) {
|
|
66813
66591
|
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
66814
66592
|
}
|
|
@@ -66833,7 +66611,7 @@ var LoggerContextMiddleware = class {
|
|
|
66833
66611
|
next();
|
|
66834
66612
|
}
|
|
66835
66613
|
};
|
|
66836
|
-
LoggerContextMiddleware =
|
|
66614
|
+
LoggerContextMiddleware = _ts_decorate5([
|
|
66837
66615
|
(0, import_common8.Injectable)(),
|
|
66838
66616
|
_ts_metadata5("design:type", Function),
|
|
66839
66617
|
_ts_metadata5("design:paramtypes", [
|
|
@@ -66842,19 +66620,19 @@ LoggerContextMiddleware = _ts_decorate6([
|
|
|
66842
66620
|
], LoggerContextMiddleware);
|
|
66843
66621
|
|
|
66844
66622
|
// src/module.ts
|
|
66845
|
-
function
|
|
66623
|
+
function _ts_decorate6(decorators, target, key, desc) {
|
|
66846
66624
|
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
66847
66625
|
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
66848
66626
|
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;
|
|
66849
66627
|
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
66850
66628
|
}
|
|
66851
|
-
__name(
|
|
66629
|
+
__name(_ts_decorate6, "_ts_decorate");
|
|
66852
66630
|
var LoggerModule = class {
|
|
66853
66631
|
static {
|
|
66854
66632
|
__name(this, "LoggerModule");
|
|
66855
66633
|
}
|
|
66856
66634
|
};
|
|
66857
|
-
LoggerModule =
|
|
66635
|
+
LoggerModule = _ts_decorate6([
|
|
66858
66636
|
(0, import_common9.Global)(),
|
|
66859
66637
|
(0, import_common9.Module)({
|
|
66860
66638
|
imports: [
|
|
@@ -66890,7 +66668,7 @@ LoggerModule = _ts_decorate7([
|
|
|
66890
66668
|
AppLogger,
|
|
66891
66669
|
LoggingInterceptor,
|
|
66892
66670
|
{
|
|
66893
|
-
provide:
|
|
66671
|
+
provide: import_core41.APP_INTERCEPTOR,
|
|
66894
66672
|
useClass: LoggingInterceptor
|
|
66895
66673
|
}
|
|
66896
66674
|
],
|