@autofleet/zehut 1.3.1 → 1.4.1

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/lib/index.d.ts CHANGED
@@ -1,2 +1,16 @@
1
- import User, { middleware, eagerLoadPermissionsMiddleware, middlewareWithDecode } from './user';
2
- export { User, middleware, middlewareWithDecode, eagerLoadPermissionsMiddleware, };
1
+ import User from './user';
2
+ declare const _default: {
3
+ User: typeof User;
4
+ middleware: (options?: {
5
+ eagerLoadUserPermissions?: boolean;
6
+ eagerLoadUserPermissionsLegacy?: boolean;
7
+ }) => (req: any, res: any, next: any) => Promise<void>;
8
+ middlewareWithDecode: (options?: {
9
+ eagerLoadUserPermissions?: boolean;
10
+ eagerLoadUserPermissionsLegacy?: boolean;
11
+ }) => (req: any, res: any, next: any) => Promise<void>;
12
+ eagerLoadPermissionsMiddleware: (req: any, res: any, next: any) => Promise<void>;
13
+ getCurrentPayload: () => any;
14
+ getDecodedBearer: (req: any) => any;
15
+ };
16
+ export default _default;
package/lib/index.js CHANGED
@@ -19,9 +19,14 @@ var __importStar = (this && this.__importStar) || function (mod) {
19
19
  return result;
20
20
  };
21
21
  Object.defineProperty(exports, "__esModule", { value: true });
22
- exports.eagerLoadPermissionsMiddleware = exports.middlewareWithDecode = exports.middleware = exports.User = void 0;
23
22
  const user_1 = __importStar(require("./user"));
24
- exports.User = user_1.default;
25
- Object.defineProperty(exports, "middleware", { enumerable: true, get: function () { return user_1.middleware; } });
26
- Object.defineProperty(exports, "eagerLoadPermissionsMiddleware", { enumerable: true, get: function () { return user_1.eagerLoadPermissionsMiddleware; } });
27
- Object.defineProperty(exports, "middlewareWithDecode", { enumerable: true, get: function () { return user_1.middlewareWithDecode; } });
23
+ const tracer_1 = require("./tracer");
24
+ tracer_1.enable();
25
+ exports.default = {
26
+ User: user_1.default,
27
+ middleware: user_1.middleware,
28
+ middlewareWithDecode: user_1.middlewareWithDecode,
29
+ eagerLoadPermissionsMiddleware: user_1.eagerLoadPermissionsMiddleware,
30
+ getCurrentPayload: tracer_1.getCurrentTrace,
31
+ getDecodedBearer: user_1.getDecodedBearer
32
+ };
@@ -0,0 +1,15 @@
1
+ import asyncHooks from 'async_hooks';
2
+ declare const tracer: {
3
+ currentTrace: any;
4
+ traces: {};
5
+ };
6
+ declare class Trace {
7
+ id: string;
8
+ type: string;
9
+ context: Map<string, any>;
10
+ constructor(type: any);
11
+ }
12
+ export declare const newTrace: (type: any) => Trace;
13
+ export declare const enable: () => () => asyncHooks.AsyncHook;
14
+ export declare const getCurrentTrace: () => any;
15
+ export default tracer;
package/lib/tracer.js ADDED
@@ -0,0 +1,55 @@
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.getCurrentTrace = exports.enable = exports.newTrace = void 0;
7
+ const async_hooks_1 = __importDefault(require("async_hooks"));
8
+ const uuid_1 = __importDefault(require("uuid"));
9
+ const prevStates = {};
10
+ const tracer = {
11
+ currentTrace: null,
12
+ traces: {},
13
+ };
14
+ function init(asyncId, type, triggerAsyncId) {
15
+ if (tracer.traces[triggerAsyncId]) {
16
+ tracer.traces[asyncId] = tracer.traces[triggerAsyncId];
17
+ }
18
+ }
19
+ function before(asyncId) {
20
+ if (!tracer.traces[asyncId]) {
21
+ return;
22
+ }
23
+ prevStates[asyncId] = tracer.currentTrace;
24
+ tracer.currentTrace = tracer.traces[asyncId];
25
+ }
26
+ function after(asyncId) {
27
+ if (!tracer.traces[asyncId]) {
28
+ return;
29
+ }
30
+ tracer.currentTrace = prevStates[asyncId];
31
+ }
32
+ function destroy(asyncId) {
33
+ if (tracer.traces[asyncId]) {
34
+ delete tracer.traces[asyncId];
35
+ delete prevStates[asyncId];
36
+ }
37
+ }
38
+ const hook = async_hooks_1.default.createHook({
39
+ init, before, after, destroy,
40
+ });
41
+ class Trace {
42
+ constructor(type) {
43
+ this.id = uuid_1.default.v1();
44
+ this.type = type;
45
+ this.context = new Map();
46
+ }
47
+ }
48
+ exports.newTrace = (type) => {
49
+ tracer.currentTrace = new Trace(type);
50
+ tracer.traces[async_hooks_1.default.executionAsyncId()] = tracer.currentTrace;
51
+ return tracer.currentTrace;
52
+ };
53
+ exports.enable = () => () => hook.enable();
54
+ exports.getCurrentTrace = () => tracer.currentTrace || {};
55
+ exports.default = tracer;
@@ -8,4 +8,5 @@ export declare const middlewareWithDecode: (options?: {
8
8
  eagerLoadUserPermissionsLegacy?: boolean;
9
9
  }) => (req: any, res: any, next: any) => Promise<void>;
10
10
  export declare const eagerLoadPermissionsMiddleware: (req: any, res: any, next: any) => Promise<void>;
11
+ export declare const getDecodedBearer: (req: any) => any;
11
12
  export default ApiUser;
package/lib/user/index.js CHANGED
@@ -12,26 +12,34 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
12
12
  return (mod && mod.__esModule) ? mod : { "default": mod };
13
13
  };
14
14
  Object.defineProperty(exports, "__esModule", { value: true });
15
- exports.eagerLoadPermissionsMiddleware = exports.middlewareWithDecode = exports.middleware = void 0;
15
+ exports.getDecodedBearer = exports.eagerLoadPermissionsMiddleware = exports.middlewareWithDecode = exports.middleware = void 0;
16
16
  const ApiUser_1 = __importDefault(require("./ApiUser"));
17
17
  const utils_1 = require("../utils");
18
+ const tracer_1 = require("../tracer");
18
19
  exports.middleware = (options = {}) => (req, res, next) => __awaiter(void 0, void 0, void 0, function* () {
19
20
  const userId = req.headers['x-af-user-id'];
21
+ const trace = tracer_1.newTrace('userPayload');
20
22
  if (!userId) {
21
23
  next();
24
+ trace.context.set('userObject', {});
22
25
  return;
23
26
  }
24
- req.user = new ApiUser_1.default(userId);
27
+ const userObject = new ApiUser_1.default(userId);
25
28
  if (options.eagerLoadUserPermissions) {
26
- yield req.user.getUserPermissions();
29
+ yield userObject.getUserPermissions();
27
30
  }
28
31
  if (options.eagerLoadUserPermissionsLegacy) {
29
- yield req.user.getUserPermissionsLegacy();
32
+ yield userObject.getUserPermissionsLegacy();
30
33
  }
34
+ req.user = userObject;
35
+ trace.context.set('userObject', userObject);
36
+ // Added in order to support outbreak.
37
+ req.headers['x-af-user-permissions'] = userObject;
31
38
  next();
32
39
  });
33
40
  exports.middlewareWithDecode = (options = {}) => (req, res, next) => __awaiter(void 0, void 0, void 0, function* () {
34
41
  var _a;
42
+ const trace = tracer_1.newTrace('userPayload');
35
43
  if (req.headers.authorization) {
36
44
  const decoded = utils_1.decodeBearer(req.headers.authorization);
37
45
  const userId = (_a = decoded === null || decoded === void 0 ? void 0 : decoded.user) === null || _a === void 0 ? void 0 : _a.id;
@@ -39,19 +47,29 @@ exports.middlewareWithDecode = (options = {}) => (req, res, next) => __awaiter(v
39
47
  req.headers['X-AF-USER-ID'] = userId;
40
48
  }
41
49
  const userObject = new ApiUser_1.default(userId);
42
- req.user = userObject;
43
50
  if (options.eagerLoadUserPermissions) {
44
- yield req.user.getUserPermissions();
51
+ yield userObject.getUserPermissions();
45
52
  }
46
53
  if (options.eagerLoadUserPermissionsLegacy) {
47
- yield req.user.getUserPermissionsLegacy();
54
+ yield userObject.getUserPermissionsLegacy();
48
55
  }
56
+ req.user = userObject;
57
+ trace.context.set('userObject', userObject);
58
+ // Added in order to support outbreak.
59
+ req.headers['x-af-user-permissions'] = userObject;
49
60
  const entities = req.user.permissions;
50
61
  }
62
+ trace.context.set('userObject', {});
51
63
  next();
52
64
  });
53
65
  exports.eagerLoadPermissionsMiddleware = (req, res, next) => __awaiter(void 0, void 0, void 0, function* () {
54
66
  yield req.user.getUserPermissions();
55
67
  next();
56
68
  });
69
+ exports.getDecodedBearer = (req) => {
70
+ if (req.headers.authorization) {
71
+ return utils_1.decodeBearer(req.headers.authorization);
72
+ }
73
+ return null;
74
+ };
57
75
  exports.default = ApiUser_1.default;
package/package.json CHANGED
@@ -1,12 +1,11 @@
1
1
  {
2
2
  "name": "@autofleet/zehut",
3
- "version": "1.3.1",
3
+ "version": "1.4.1",
4
4
  "description": "manage user's identity",
5
5
  "main": "lib/index.js",
6
6
  "types": "lib/index.d.ts",
7
7
  "scripts": {
8
8
  "build": "rm -rf lib && tsc",
9
- "prepublish": "npm run build",
10
9
  "coverage": "jest --coverage --forceExit --runInBand",
11
10
  "test": "jest --forceExit --runInBand",
12
11
  "test-auto": "jest --watch --runInBand",