@axinom/mosaic-service-common 0.69.0 → 0.70.0-rc.4
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/common/index.d.ts +1 -0
- package/dist/common/index.d.ts.map +1 -1
- package/dist/common/index.js +1 -0
- package/dist/common/index.js.map +1 -1
- package/dist/common/logging/index.d.ts +1 -0
- package/dist/common/logging/index.d.ts.map +1 -1
- package/dist/common/logging/index.js +1 -0
- package/dist/common/logging/index.js.map +1 -1
- package/dist/common/logging/request-id-log-middleware.d.ts +3 -0
- package/dist/common/logging/request-id-log-middleware.d.ts.map +1 -0
- package/dist/common/logging/request-id-log-middleware.js +14 -0
- package/dist/common/logging/request-id-log-middleware.js.map +1 -0
- package/dist/common/request-context/index.d.ts +2 -0
- package/dist/common/request-context/index.d.ts.map +1 -0
- package/dist/common/request-context/index.js +18 -0
- package/dist/common/request-context/index.js.map +1 -0
- package/dist/common/request-context/request-context.d.ts +9 -0
- package/dist/common/request-context/request-context.d.ts.map +1 -0
- package/dist/common/request-context/request-context.js +13 -0
- package/dist/common/request-context/request-context.js.map +1 -0
- package/dist/middleware/index.d.ts +1 -0
- package/dist/middleware/index.d.ts.map +1 -1
- package/dist/middleware/index.js +1 -0
- package/dist/middleware/index.js.map +1 -1
- package/dist/middleware/request-id-middleware.d.ts +3 -0
- package/dist/middleware/request-id-middleware.d.ts.map +1 -0
- package/dist/middleware/request-id-middleware.js +13 -0
- package/dist/middleware/request-id-middleware.js.map +1 -0
- package/package.json +3 -3
- package/src/common/index.ts +1 -0
- package/src/common/logging/index.ts +1 -0
- package/src/common/logging/request-id-log-middleware.ts +10 -0
- package/src/common/request-context/index.ts +1 -0
- package/src/common/request-context/request-context.ts +14 -0
- package/src/middleware/index.ts +1 -0
- package/src/middleware/request-id-middleware.ts +11 -0
package/dist/common/index.d.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/common/index.ts"],"names":[],"mappings":"AAAA,cAAc,UAAU,CAAC;AACzB,cAAc,UAAU,CAAC;AACzB,cAAc,WAAW,CAAC;AAC1B,cAAc,WAAW,CAAC;AAC1B,cAAc,WAAW,CAAC;AAC1B,cAAc,SAAS,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/common/index.ts"],"names":[],"mappings":"AAAA,cAAc,UAAU,CAAC;AACzB,cAAc,UAAU,CAAC;AACzB,cAAc,WAAW,CAAC;AAC1B,cAAc,WAAW,CAAC;AAC1B,cAAc,mBAAmB,CAAC;AAClC,cAAc,WAAW,CAAC;AAC1B,cAAc,SAAS,CAAC"}
|
package/dist/common/index.js
CHANGED
|
@@ -18,6 +18,7 @@ __exportStar(require("./config"), exports);
|
|
|
18
18
|
__exportStar(require("./errors"), exports);
|
|
19
19
|
__exportStar(require("./helpers"), exports);
|
|
20
20
|
__exportStar(require("./logging"), exports);
|
|
21
|
+
__exportStar(require("./request-context"), exports);
|
|
21
22
|
__exportStar(require("./signing"), exports);
|
|
22
23
|
__exportStar(require("./types"), exports);
|
|
23
24
|
//# sourceMappingURL=index.js.map
|
package/dist/common/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/common/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,2CAAyB;AACzB,2CAAyB;AACzB,4CAA0B;AAC1B,4CAA0B;AAC1B,4CAA0B;AAC1B,0CAAwB"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/common/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,2CAAyB;AACzB,2CAAyB;AACzB,4CAA0B;AAC1B,4CAA0B;AAC1B,oDAAkC;AAClC,4CAA0B;AAC1B,0CAAwB"}
|
|
@@ -6,6 +6,7 @@ export * from './log-message';
|
|
|
6
6
|
export * from './log-retention';
|
|
7
7
|
export * from './logger';
|
|
8
8
|
export * from './mask-middleware';
|
|
9
|
+
export * from './request-id-log-middleware';
|
|
9
10
|
export * from './setup-global-console-override';
|
|
10
11
|
export * from './skip-mask-middleware';
|
|
11
12
|
export * from './tenant-environment-ids-log-middleware';
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/common/logging/index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAC;AAC/B,cAAc,OAAO,CAAC;AACtB,cAAc,iBAAiB,CAAC;AAChC,cAAc,aAAa,CAAC;AAC5B,cAAc,eAAe,CAAC;AAC9B,cAAc,iBAAiB,CAAC;AAChC,cAAc,UAAU,CAAC;AACzB,cAAc,mBAAmB,CAAC;AAClC,cAAc,iCAAiC,CAAC;AAChD,cAAc,wBAAwB,CAAC;AACvC,cAAc,yCAAyC,CAAC;AACxD,cAAc,mBAAmB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/common/logging/index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAC;AAC/B,cAAc,OAAO,CAAC;AACtB,cAAc,iBAAiB,CAAC;AAChC,cAAc,aAAa,CAAC;AAC5B,cAAc,eAAe,CAAC;AAC9B,cAAc,iBAAiB,CAAC;AAChC,cAAc,UAAU,CAAC;AACzB,cAAc,mBAAmB,CAAC;AAClC,cAAc,6BAA6B,CAAC;AAC5C,cAAc,iCAAiC,CAAC;AAChD,cAAc,wBAAwB,CAAC;AACvC,cAAc,yCAAyC,CAAC;AACxD,cAAc,mBAAmB,CAAC"}
|
|
@@ -22,6 +22,7 @@ __exportStar(require("./log-message"), exports);
|
|
|
22
22
|
__exportStar(require("./log-retention"), exports);
|
|
23
23
|
__exportStar(require("./logger"), exports);
|
|
24
24
|
__exportStar(require("./mask-middleware"), exports);
|
|
25
|
+
__exportStar(require("./request-id-log-middleware"), exports);
|
|
25
26
|
__exportStar(require("./setup-global-console-override"), exports);
|
|
26
27
|
__exportStar(require("./skip-mask-middleware"), exports);
|
|
27
28
|
__exportStar(require("./tenant-environment-ids-log-middleware"), exports);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/common/logging/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,iDAA+B;AAC/B,wCAAsB;AACtB,kDAAgC;AAChC,8CAA4B;AAC5B,gDAA8B;AAC9B,kDAAgC;AAChC,2CAAyB;AACzB,oDAAkC;AAClC,kEAAgD;AAChD,yDAAuC;AACvC,0EAAwD;AACxD,oDAAkC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/common/logging/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,iDAA+B;AAC/B,wCAAsB;AACtB,kDAAgC;AAChC,8CAA4B;AAC5B,gDAA8B;AAC9B,kDAAgC;AAChC,2CAAyB;AACzB,oDAAkC;AAClC,8DAA4C;AAC5C,kEAAgD;AAChD,yDAAuC;AACvC,0EAAwD;AACxD,oDAAkC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"request-id-log-middleware.d.ts","sourceRoot":"","sources":["../../../src/common/logging/request-id-log-middleware.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAC;AAE/C,eAAO,MAAM,0BAA0B,EAAE,aAMxC,CAAC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.mosaicContextLogMiddleware = void 0;
|
|
4
|
+
const request_context_1 = require("../request-context");
|
|
5
|
+
const mosaicContextLogMiddleware = (log) => {
|
|
6
|
+
var _a;
|
|
7
|
+
const mosaicRequestId = (_a = request_context_1.requestContext.getStore()) === null || _a === void 0 ? void 0 : _a.mosaicRequestId;
|
|
8
|
+
if (mosaicRequestId) {
|
|
9
|
+
log.details = Object.assign(Object.assign({}, log.details), { mosaicRequestId });
|
|
10
|
+
}
|
|
11
|
+
return log;
|
|
12
|
+
};
|
|
13
|
+
exports.mosaicContextLogMiddleware = mosaicContextLogMiddleware;
|
|
14
|
+
//# sourceMappingURL=request-id-log-middleware.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"request-id-log-middleware.js","sourceRoot":"","sources":["../../../src/common/logging/request-id-log-middleware.ts"],"names":[],"mappings":";;;AAAA,wDAAoD;AAG7C,MAAM,0BAA0B,GAAkB,CAAC,GAAG,EAAE,EAAE;;IAC/D,MAAM,eAAe,GAAG,MAAA,gCAAc,CAAC,QAAQ,EAAE,0CAAE,eAAe,CAAC;IACnE,IAAI,eAAe,EAAE,CAAC;QACpB,GAAG,CAAC,OAAO,mCAAQ,GAAG,CAAC,OAAO,KAAE,eAAe,GAAE,CAAC;IACpD,CAAC;IACD,OAAO,GAAG,CAAC;AACb,CAAC,CAAC;AANW,QAAA,0BAA0B,8BAMrC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/common/request-context/index.ts"],"names":[],"mappings":"AAAA,cAAc,mBAAmB,CAAC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./request-context"), exports);
|
|
18
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/common/request-context/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,oDAAkC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { AsyncLocalStorage } from 'async_hooks';
|
|
2
|
+
export declare const REQUEST_ID_HEADER = "x-mosaic-request-id";
|
|
3
|
+
interface RequestContext {
|
|
4
|
+
mosaicRequestId: string;
|
|
5
|
+
}
|
|
6
|
+
export declare const requestContext: AsyncLocalStorage<RequestContext>;
|
|
7
|
+
export declare const getRequestContextHeaders: () => Record<string, string>;
|
|
8
|
+
export {};
|
|
9
|
+
//# sourceMappingURL=request-context.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"request-context.d.ts","sourceRoot":"","sources":["../../../src/common/request-context/request-context.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC;AAEhD,eAAO,MAAM,iBAAiB,wBAAwB,CAAC;AAEvD,UAAU,cAAc;IACtB,eAAe,EAAE,MAAM,CAAC;CACzB;AAED,eAAO,MAAM,cAAc,mCAA0C,CAAC;AAEtE,eAAO,MAAM,wBAAwB,QAAO,MAAM,CAAC,MAAM,EAAE,MAAM,CAGhE,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getRequestContextHeaders = exports.requestContext = exports.REQUEST_ID_HEADER = void 0;
|
|
4
|
+
const async_hooks_1 = require("async_hooks");
|
|
5
|
+
exports.REQUEST_ID_HEADER = 'x-mosaic-request-id';
|
|
6
|
+
exports.requestContext = new async_hooks_1.AsyncLocalStorage();
|
|
7
|
+
const getRequestContextHeaders = () => {
|
|
8
|
+
var _a;
|
|
9
|
+
const mosaicRequestId = (_a = exports.requestContext.getStore()) === null || _a === void 0 ? void 0 : _a.mosaicRequestId;
|
|
10
|
+
return mosaicRequestId ? { [exports.REQUEST_ID_HEADER]: mosaicRequestId } : {};
|
|
11
|
+
};
|
|
12
|
+
exports.getRequestContextHeaders = getRequestContextHeaders;
|
|
13
|
+
//# sourceMappingURL=request-context.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"request-context.js","sourceRoot":"","sources":["../../../src/common/request-context/request-context.ts"],"names":[],"mappings":";;;AAAA,6CAAgD;AAEnC,QAAA,iBAAiB,GAAG,qBAAqB,CAAC;AAM1C,QAAA,cAAc,GAAG,IAAI,+BAAiB,EAAkB,CAAC;AAE/D,MAAM,wBAAwB,GAAG,GAA2B,EAAE;;IACnE,MAAM,eAAe,GAAG,MAAA,sBAAc,CAAC,QAAQ,EAAE,0CAAE,eAAe,CAAC;IACnE,OAAO,eAAe,CAAC,CAAC,CAAC,EAAE,CAAC,yBAAiB,CAAC,EAAE,eAAe,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;AACzE,CAAC,CAAC;AAHW,QAAA,wBAAwB,4BAGnC"}
|
|
@@ -4,6 +4,7 @@ export * from './liveness-readiness-middleware';
|
|
|
4
4
|
export * from './maintenance-middleware';
|
|
5
5
|
export * from './monitoring-middleware';
|
|
6
6
|
export * from './mosaic-favicon';
|
|
7
|
+
export * from './request-id-middleware';
|
|
7
8
|
export * from './service-health-check-middleware';
|
|
8
9
|
export * from './shutdown-actions-middleware';
|
|
9
10
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/middleware/index.ts"],"names":[],"mappings":"AAAA,cAAc,uCAAuC,CAAC;AACtD,cAAc,0CAA0C,CAAC;AACzD,cAAc,iCAAiC,CAAC;AAChD,cAAc,0BAA0B,CAAC;AACzC,cAAc,yBAAyB,CAAC;AACxC,cAAc,kBAAkB,CAAC;AACjC,cAAc,mCAAmC,CAAC;AAClD,cAAc,+BAA+B,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/middleware/index.ts"],"names":[],"mappings":"AAAA,cAAc,uCAAuC,CAAC;AACtD,cAAc,0CAA0C,CAAC;AACzD,cAAc,iCAAiC,CAAC;AAChD,cAAc,0BAA0B,CAAC;AACzC,cAAc,yBAAyB,CAAC;AACxC,cAAc,kBAAkB,CAAC;AACjC,cAAc,yBAAyB,CAAC;AACxC,cAAc,mCAAmC,CAAC;AAClD,cAAc,+BAA+B,CAAC"}
|
package/dist/middleware/index.js
CHANGED
|
@@ -20,6 +20,7 @@ __exportStar(require("./liveness-readiness-middleware"), exports);
|
|
|
20
20
|
__exportStar(require("./maintenance-middleware"), exports);
|
|
21
21
|
__exportStar(require("./monitoring-middleware"), exports);
|
|
22
22
|
__exportStar(require("./mosaic-favicon"), exports);
|
|
23
|
+
__exportStar(require("./request-id-middleware"), exports);
|
|
23
24
|
__exportStar(require("./service-health-check-middleware"), exports);
|
|
24
25
|
__exportStar(require("./shutdown-actions-middleware"), exports);
|
|
25
26
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/middleware/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,wEAAsD;AACtD,2EAAyD;AACzD,kEAAgD;AAChD,2DAAyC;AACzC,0DAAwC;AACxC,mDAAiC;AACjC,oEAAkD;AAClD,gEAA8C"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/middleware/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,wEAAsD;AACtD,2EAAyD;AACzD,kEAAgD;AAChD,2DAAyC;AACzC,0DAAwC;AACxC,mDAAiC;AACjC,0DAAwC;AACxC,oEAAkD;AAClD,gEAA8C"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"request-id-middleware.d.ts","sourceRoot":"","sources":["../../src/middleware/request-id-middleware.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAIzC,eAAO,MAAM,uBAAuB,QAC9B,cAKH,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.mosaicContextMiddleware = void 0;
|
|
4
|
+
const uuid_1 = require("uuid");
|
|
5
|
+
const request_context_1 = require("../common/request-context");
|
|
6
|
+
const mosaicContextMiddleware = () => (req, res, next) => {
|
|
7
|
+
var _a;
|
|
8
|
+
const mosaicRequestId = (_a = req.headers[request_context_1.REQUEST_ID_HEADER]) !== null && _a !== void 0 ? _a : (0, uuid_1.v4)();
|
|
9
|
+
res.setHeader(request_context_1.REQUEST_ID_HEADER, mosaicRequestId);
|
|
10
|
+
request_context_1.requestContext.run({ mosaicRequestId }, next);
|
|
11
|
+
};
|
|
12
|
+
exports.mosaicContextMiddleware = mosaicContextMiddleware;
|
|
13
|
+
//# sourceMappingURL=request-id-middleware.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"request-id-middleware.js","sourceRoot":"","sources":["../../src/middleware/request-id-middleware.ts"],"names":[],"mappings":";;;AACA,+BAAkC;AAClC,+DAA8E;AAEvE,MAAM,uBAAuB,GAClC,GAAmB,EAAE,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE;;IACvC,MAAM,eAAe,GACnB,MAAC,GAAG,CAAC,OAAO,CAAC,mCAAiB,CAAY,mCAAI,IAAA,SAAI,GAAE,CAAC;IACvD,GAAG,CAAC,SAAS,CAAC,mCAAiB,EAAE,eAAe,CAAC,CAAC;IAClD,gCAAc,CAAC,GAAG,CAAC,EAAE,eAAe,EAAE,EAAE,IAAI,CAAC,CAAC;AAChD,CAAC,CAAC;AANS,QAAA,uBAAuB,2BAMhC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@axinom/mosaic-service-common",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.70.0-rc.4",
|
|
4
4
|
"description": "Common helpers and PostgreSQL-related functionality",
|
|
5
5
|
"author": "Axinom",
|
|
6
6
|
"license": "PROPRIETARY",
|
|
@@ -53,7 +53,7 @@
|
|
|
53
53
|
"verror": "^1.10.1"
|
|
54
54
|
},
|
|
55
55
|
"devDependencies": {
|
|
56
|
-
"@axinom/mosaic-dev-be-common": "^0.
|
|
56
|
+
"@axinom/mosaic-dev-be-common": "^0.19.0-rc.4",
|
|
57
57
|
"@types/express": "^4.17.17",
|
|
58
58
|
"@types/inflection": "^1.5.28",
|
|
59
59
|
"@types/node": "^22.0.0",
|
|
@@ -70,5 +70,5 @@
|
|
|
70
70
|
"publishConfig": {
|
|
71
71
|
"access": "public"
|
|
72
72
|
},
|
|
73
|
-
"gitHead": "
|
|
73
|
+
"gitHead": "1286a116f2e06be15726a9094b19987c56d3bc49"
|
|
74
74
|
}
|
package/src/common/index.ts
CHANGED
|
@@ -6,6 +6,7 @@ export * from './log-message';
|
|
|
6
6
|
export * from './log-retention';
|
|
7
7
|
export * from './logger';
|
|
8
8
|
export * from './mask-middleware';
|
|
9
|
+
export * from './request-id-log-middleware';
|
|
9
10
|
export * from './setup-global-console-override';
|
|
10
11
|
export * from './skip-mask-middleware';
|
|
11
12
|
export * from './tenant-environment-ids-log-middleware';
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { requestContext } from '../request-context';
|
|
2
|
+
import { LogMiddleware } from './generate-log';
|
|
3
|
+
|
|
4
|
+
export const mosaicContextLogMiddleware: LogMiddleware = (log) => {
|
|
5
|
+
const mosaicRequestId = requestContext.getStore()?.mosaicRequestId;
|
|
6
|
+
if (mosaicRequestId) {
|
|
7
|
+
log.details = { ...log.details, mosaicRequestId };
|
|
8
|
+
}
|
|
9
|
+
return log;
|
|
10
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './request-context';
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { AsyncLocalStorage } from 'async_hooks';
|
|
2
|
+
|
|
3
|
+
export const REQUEST_ID_HEADER = 'x-mosaic-request-id';
|
|
4
|
+
|
|
5
|
+
interface RequestContext {
|
|
6
|
+
mosaicRequestId: string;
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
export const requestContext = new AsyncLocalStorage<RequestContext>();
|
|
10
|
+
|
|
11
|
+
export const getRequestContextHeaders = (): Record<string, string> => {
|
|
12
|
+
const mosaicRequestId = requestContext.getStore()?.mosaicRequestId;
|
|
13
|
+
return mosaicRequestId ? { [REQUEST_ID_HEADER]: mosaicRequestId } : {};
|
|
14
|
+
};
|
package/src/middleware/index.ts
CHANGED
|
@@ -4,5 +4,6 @@ export * from './liveness-readiness-middleware';
|
|
|
4
4
|
export * from './maintenance-middleware';
|
|
5
5
|
export * from './monitoring-middleware';
|
|
6
6
|
export * from './mosaic-favicon';
|
|
7
|
+
export * from './request-id-middleware';
|
|
7
8
|
export * from './service-health-check-middleware';
|
|
8
9
|
export * from './shutdown-actions-middleware';
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { RequestHandler } from 'express';
|
|
2
|
+
import { v4 as uuid } from 'uuid';
|
|
3
|
+
import { REQUEST_ID_HEADER, requestContext } from '../common/request-context';
|
|
4
|
+
|
|
5
|
+
export const mosaicContextMiddleware =
|
|
6
|
+
(): RequestHandler => (req, res, next) => {
|
|
7
|
+
const mosaicRequestId =
|
|
8
|
+
(req.headers[REQUEST_ID_HEADER] as string) ?? uuid();
|
|
9
|
+
res.setHeader(REQUEST_ID_HEADER, mosaicRequestId);
|
|
10
|
+
requestContext.run({ mosaicRequestId }, next);
|
|
11
|
+
};
|