@gaias/basenode 1.5.9 → 1.6.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.
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"FSBackendMiddleware.d.ts","sourceRoot":"","sources":["../../../../src/libs/cls/FSBackendMiddleware.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,WAAW,MAAM,KAAK,CAAC;
|
|
1
|
+
{"version":3,"file":"FSBackendMiddleware.d.ts","sourceRoot":"","sources":["../../../../src/libs/cls/FSBackendMiddleware.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,WAAW,MAAM,KAAK,CAAC;AAanC,eAAO,MAAM,aAAa,EAAE,WAAW,CAAC,UA8EvC,CAAC"}
|
|
@@ -2,29 +2,68 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.clsMiddleware = void 0;
|
|
4
4
|
const client_node_1 = require("@sight-saber/client_node");
|
|
5
|
+
const cls_hooked_1 = require("cls-hooked");
|
|
5
6
|
const logger_1 = require("../logger");
|
|
7
|
+
const API_SESSION = 'API_SESSION';
|
|
6
8
|
const clsMiddleware = async (ctx, next) => {
|
|
7
9
|
const logger = logger_1.Logger.getLogger('clsMiddleware');
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
if (
|
|
13
|
-
|
|
14
|
-
|
|
10
|
+
let namespace;
|
|
11
|
+
let namespaceCreated = false;
|
|
12
|
+
try {
|
|
13
|
+
const existingNamespace = (0, cls_hooked_1.getNamespace)(API_SESSION);
|
|
14
|
+
if (existingNamespace) {
|
|
15
|
+
namespace = existingNamespace;
|
|
16
|
+
logger.debug('Using existing namespace');
|
|
15
17
|
}
|
|
16
|
-
|
|
17
|
-
.
|
|
18
|
+
else {
|
|
19
|
+
namespace = client_node_1.FSBackend.createNamespace();
|
|
20
|
+
namespaceCreated = true;
|
|
21
|
+
logger.debug('Created new namespace');
|
|
22
|
+
}
|
|
23
|
+
await new Promise(namespace.bind((resolve, reject) => {
|
|
24
|
+
namespace.bindEmitter(ctx.req);
|
|
25
|
+
namespace.bindEmitter(ctx.res);
|
|
26
|
+
if (ctx.header && ctx.header.authorization) {
|
|
27
|
+
client_node_1.FSBackend.setForwardHeader(namespace, 'Authorization', ctx.header.authorization);
|
|
28
|
+
logger.debug('Stored Authorization header in namespace');
|
|
29
|
+
}
|
|
30
|
+
next()
|
|
31
|
+
.then(() => {
|
|
32
|
+
if (namespaceCreated) {
|
|
33
|
+
try {
|
|
34
|
+
const nsToDestroy = (0, cls_hooked_1.getNamespace)(API_SESSION);
|
|
35
|
+
if (nsToDestroy) {
|
|
36
|
+
client_node_1.FSBackend.destoryNamespace();
|
|
37
|
+
logger.debug('Namespace destroyed successfully');
|
|
38
|
+
}
|
|
39
|
+
else {
|
|
40
|
+
logger.debug('Namespace already destroyed, skipping');
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
catch (error) {
|
|
44
|
+
logger.warn('Error destroying namespace:', error.message);
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
resolve();
|
|
48
|
+
})
|
|
49
|
+
.catch(reject);
|
|
50
|
+
}));
|
|
51
|
+
}
|
|
52
|
+
catch (error) {
|
|
53
|
+
logger.error('Error in CLS middleware:', error);
|
|
54
|
+
if (namespaceCreated) {
|
|
18
55
|
try {
|
|
19
|
-
|
|
56
|
+
const nsToDestroy = (0, cls_hooked_1.getNamespace)(API_SESSION);
|
|
57
|
+
if (nsToDestroy) {
|
|
58
|
+
client_node_1.FSBackend.destoryNamespace();
|
|
59
|
+
}
|
|
20
60
|
}
|
|
21
|
-
catch (
|
|
22
|
-
logger.
|
|
61
|
+
catch (cleanupError) {
|
|
62
|
+
logger.warn('Error during error cleanup:', cleanupError.message);
|
|
23
63
|
}
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
}));
|
|
64
|
+
}
|
|
65
|
+
throw error;
|
|
66
|
+
}
|
|
28
67
|
};
|
|
29
68
|
exports.clsMiddleware = clsMiddleware;
|
|
30
69
|
//# sourceMappingURL=FSBackendMiddleware.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"FSBackendMiddleware.js","sourceRoot":"","sources":["../../../../src/libs/cls/FSBackendMiddleware.ts"],"names":[],"mappings":";;;AAEA,0DAAqD;AACrD,sCAAmC;
|
|
1
|
+
{"version":3,"file":"FSBackendMiddleware.js","sourceRoot":"","sources":["../../../../src/libs/cls/FSBackendMiddleware.ts"],"names":[],"mappings":";;;AAEA,0DAAqD;AACrD,2CAAqD;AACrD,sCAAmC;AAEnC,MAAM,WAAW,GAAG,aAAa,CAAC;AAQ3B,MAAM,aAAa,GAA2B,KAAK,EAAE,GAAY,EAAE,IAAU,EAAiB,EAAE;IACrG,MAAM,MAAM,GAAG,eAAM,CAAC,SAAS,CAAC,eAAe,CAAC,CAAC;IAEjD,IAAI,SAAoB,CAAC;IACzB,IAAI,gBAAgB,GAAG,KAAK,CAAC;IAE7B,IAAI,CAAC;QAEH,MAAM,iBAAiB,GAAG,IAAA,yBAAY,EAAC,WAAW,CAAC,CAAC;QAEpD,IAAI,iBAAiB,EAAE,CAAC;YAEtB,SAAS,GAAG,iBAAiB,CAAC;YAC9B,MAAM,CAAC,KAAK,CAAC,0BAA0B,CAAC,CAAC;QAC3C,CAAC;aAAM,CAAC;YAEN,SAAS,GAAG,uBAAS,CAAC,eAAe,EAAE,CAAC;YACxC,gBAAgB,GAAG,IAAI,CAAC;YACxB,MAAM,CAAC,KAAK,CAAC,uBAAuB,CAAC,CAAC;QACxC,CAAC;QAED,MAAM,IAAI,OAAO,CACf,SAAS,CAAC,IAAI,CAAC,CAAC,OAAmB,EAAE,MAA8B,EAAE,EAAE;YAErE,SAAS,CAAC,WAAW,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;YAC/B,SAAS,CAAC,WAAW,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;YAG/B,IAAI,GAAG,CAAC,MAAM,IAAI,GAAG,CAAC,MAAM,CAAC,aAAa,EAAE,CAAC;gBAC3C,uBAAS,CAAC,gBAAgB,CACxB,SAAS,EACT,eAAe,EACf,GAAG,CAAC,MAAM,CAAC,aAAa,CACzB,CAAC;gBACF,MAAM,CAAC,KAAK,CAAC,0CAA0C,CAAC,CAAC;YAC3D,CAAC;YAGD,IAAI,EAAE;iBACH,IAAI,CAAC,GAAG,EAAE;gBAET,IAAI,gBAAgB,EAAE,CAAC;oBACrB,IAAI,CAAC;wBAEH,MAAM,WAAW,GAAG,IAAA,yBAAY,EAAC,WAAW,CAAC,CAAC;wBAC9C,IAAI,WAAW,EAAE,CAAC;4BAChB,uBAAS,CAAC,gBAAgB,EAAE,CAAC;4BAC7B,MAAM,CAAC,KAAK,CAAC,kCAAkC,CAAC,CAAC;wBACnD,CAAC;6BAAM,CAAC;4BACN,MAAM,CAAC,KAAK,CAAC,uCAAuC,CAAC,CAAC;wBACxD,CAAC;oBACH,CAAC;oBAAC,OAAO,KAAU,EAAE,CAAC;wBAEpB,MAAM,CAAC,IAAI,CAAC,6BAA6B,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC;oBAC5D,CAAC;gBACH,CAAC;gBACD,OAAO,EAAE,CAAC;YACZ,CAAC,CAAC;iBACD,KAAK,CAAC,MAAM,CAAC,CAAC;QACnB,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAAC,OAAO,KAAU,EAAE,CAAC;QACpB,MAAM,CAAC,KAAK,CAAC,0BAA0B,EAAE,KAAK,CAAC,CAAC;QAGhD,IAAI,gBAAgB,EAAE,CAAC;YACrB,IAAI,CAAC;gBACH,MAAM,WAAW,GAAG,IAAA,yBAAY,EAAC,WAAW,CAAC,CAAC;gBAC9C,IAAI,WAAW,EAAE,CAAC;oBAChB,uBAAS,CAAC,gBAAgB,EAAE,CAAC;gBAC/B,CAAC;YACH,CAAC;YAAC,OAAO,YAAiB,EAAE,CAAC;gBAC3B,MAAM,CAAC,IAAI,CAAC,6BAA6B,EAAE,YAAY,CAAC,OAAO,CAAC,CAAC;YACnE,CAAC;QACH,CAAC;QAED,MAAM,KAAK,CAAC;IACd,CAAC;AACH,CAAC,CAAC;AA9EW,QAAA,aAAa,iBA8ExB"}
|