@autofleet/zehut 2.0.2 → 2.0.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/lib/index.d.ts CHANGED
@@ -1,4 +1,5 @@
1
1
  import User, { middleware, eagerLoadPermissionsMiddleware, middlewareWithDecode, getDecodedBearer, appMiddleware } from './user';
2
+ import { newTrace, traceTypes } from './tracer';
2
3
  import { checkFleetPermission, checkBusinessModelPermission, checkDemandSourcePermission, isUserExist, getUser } from './check-permission';
3
4
  import { UnauthorizedAccessError } from './errors';
4
5
  import { getRefreshTokenSecret, getTokenSecret } from './secret-getter';
@@ -6,8 +7,14 @@ declare const getCurrentPayload: () => any;
6
7
  declare const enableTracing: ({ outbreakOptions }?: {
7
8
  outbreakOptions?: {};
8
9
  }) => void;
9
- export { enableTracing, User, middleware, middlewareWithDecode, eagerLoadPermissionsMiddleware, getCurrentPayload, getDecodedBearer, checkFleetPermission, checkBusinessModelPermission, checkDemandSourcePermission, isUserExist, getUser, getRefreshTokenSecret, getTokenSecret, UnauthorizedAccessError, appMiddleware, };
10
+ export { traceTypes, newTrace, enableTracing, User, middleware, middlewareWithDecode, eagerLoadPermissionsMiddleware, getCurrentPayload, getDecodedBearer, checkFleetPermission, checkBusinessModelPermission, checkDemandSourcePermission, isUserExist, getUser, getRefreshTokenSecret, getTokenSecret, UnauthorizedAccessError, appMiddleware, };
10
11
  declare const _default: {
12
+ traceTypes: {
13
+ HTTP_REQUEST: string;
14
+ WEB_SOCKET: string;
15
+ RABBIT: string;
16
+ };
17
+ newTrace: (type: any) => import("./tracer").Trace;
11
18
  User: typeof User;
12
19
  middleware: (options?: {
13
20
  eagerLoadUserPermissions?: boolean;
package/lib/index.js CHANGED
@@ -22,7 +22,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
22
22
  return (mod && mod.__esModule) ? mod : { "default": mod };
23
23
  };
24
24
  Object.defineProperty(exports, "__esModule", { value: true });
25
- exports.appMiddleware = exports.UnauthorizedAccessError = exports.getTokenSecret = exports.getRefreshTokenSecret = exports.getUser = exports.isUserExist = exports.checkDemandSourcePermission = exports.checkBusinessModelPermission = exports.checkFleetPermission = exports.getDecodedBearer = exports.getCurrentPayload = exports.eagerLoadPermissionsMiddleware = exports.middlewareWithDecode = exports.middleware = exports.User = exports.enableTracing = void 0;
25
+ exports.appMiddleware = exports.UnauthorizedAccessError = exports.getTokenSecret = exports.getRefreshTokenSecret = exports.getUser = exports.isUserExist = exports.checkDemandSourcePermission = exports.checkBusinessModelPermission = exports.checkFleetPermission = exports.getDecodedBearer = exports.getCurrentPayload = exports.eagerLoadPermissionsMiddleware = exports.middlewareWithDecode = exports.middleware = exports.User = exports.enableTracing = exports.newTrace = exports.traceTypes = void 0;
26
26
  const outbreak_1 = __importDefault(require("@autofleet/outbreak"));
27
27
  const user_1 = __importStar(require("./user"));
28
28
  exports.User = user_1.default;
@@ -32,6 +32,8 @@ Object.defineProperty(exports, "middlewareWithDecode", { enumerable: true, get:
32
32
  Object.defineProperty(exports, "getDecodedBearer", { enumerable: true, get: function () { return user_1.getDecodedBearer; } });
33
33
  Object.defineProperty(exports, "appMiddleware", { enumerable: true, get: function () { return user_1.appMiddleware; } });
34
34
  const tracer_1 = require("./tracer");
35
+ Object.defineProperty(exports, "newTrace", { enumerable: true, get: function () { return tracer_1.newTrace; } });
36
+ Object.defineProperty(exports, "traceTypes", { enumerable: true, get: function () { return tracer_1.traceTypes; } });
35
37
  const check_permission_1 = require("./check-permission");
36
38
  Object.defineProperty(exports, "checkFleetPermission", { enumerable: true, get: function () { return check_permission_1.checkFleetPermission; } });
37
39
  Object.defineProperty(exports, "checkBusinessModelPermission", { enumerable: true, get: function () { return check_permission_1.checkBusinessModelPermission; } });
@@ -51,6 +53,8 @@ const enableTracing = ({ outbreakOptions = {} } = {}) => {
51
53
  };
52
54
  exports.enableTracing = enableTracing;
53
55
  exports.default = {
56
+ traceTypes: tracer_1.traceTypes,
57
+ newTrace: tracer_1.newTrace,
54
58
  User: user_1.default,
55
59
  middleware: user_1.middleware,
56
60
  middlewareWithDecode: user_1.middlewareWithDecode,
@@ -0,0 +1,9 @@
1
+ import { AccountType, PartialUserPayload } from '../user/ApiUser';
2
+ export declare type UserCustomAttributes = {
3
+ id?: string;
4
+ accountType?: AccountType;
5
+ elevatedPermissions?: PartialUserPayload;
6
+ permissions?: PartialUserPayload;
7
+ };
8
+ export declare const setIdentityNock: (userAttributes: any) => void;
9
+ export declare const mockRequestAndUser: (app: any, userCustomAttributes: any) => {};
@@ -0,0 +1,34 @@
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.mockRequestAndUser = exports.setIdentityNock = void 0;
7
+ const supertest_1 = __importDefault(require("supertest"));
8
+ const nock_1 = __importDefault(require("nock"));
9
+ const http_1 = __importDefault(require("http"));
10
+ const uuid_1 = require("uuid");
11
+ exports.setIdentityNock = (userAttributes) => {
12
+ nock_1.default(`http://${process.env.IDENTITY_MS_SERVICE_HOST}`)
13
+ .get(`/api/v1/users/${userAttributes.id}/authorization-payload`)
14
+ .reply(200, userAttributes.permissions);
15
+ };
16
+ exports.mockRequestAndUser = (app, userCustomAttributes) => {
17
+ var _a, _b, _c;
18
+ const agent = supertest_1.default.agent(app);
19
+ const userAttributes = {
20
+ id: userCustomAttributes.id || uuid_1.v4(),
21
+ permissions: {
22
+ businessModels: ((_a = userCustomAttributes === null || userCustomAttributes === void 0 ? void 0 : userCustomAttributes.permissions) === null || _a === void 0 ? void 0 : _a.businessModels) || {},
23
+ fleets: ((_b = userCustomAttributes === null || userCustomAttributes === void 0 ? void 0 : userCustomAttributes.permissions) === null || _b === void 0 ? void 0 : _b.fleets) || {},
24
+ demandSources: ((_c = userCustomAttributes === null || userCustomAttributes === void 0 ? void 0 : userCustomAttributes.permissions) === null || _c === void 0 ? void 0 : _c.demandSources) || {},
25
+ },
26
+ };
27
+ agent.set('x-af-user-id', userAttributes.id);
28
+ exports.setIdentityNock(userAttributes);
29
+ const agentObject = {};
30
+ http_1.default.METHODS.forEach((method) => {
31
+ agentObject[method.toLowerCase()] = (path) => agent[method.toLowerCase()](path).set('x-af-user-id', userAttributes.id);
32
+ });
33
+ return agentObject;
34
+ };
package/lib/tracer.d.ts CHANGED
@@ -3,7 +3,7 @@ declare const tracer: {
3
3
  currentTrace: any;
4
4
  traces: {};
5
5
  };
6
- declare class Trace {
6
+ export declare class Trace {
7
7
  id: string;
8
8
  type: string;
9
9
  context: Map<string, any>;
@@ -12,4 +12,9 @@ declare class Trace {
12
12
  export declare const newTrace: (type: any) => Trace;
13
13
  export declare const enable: () => asyncHooks.AsyncHook;
14
14
  export declare const getCurrentTrace: () => any;
15
+ export declare const traceTypes: {
16
+ HTTP_REQUEST: string;
17
+ WEB_SOCKET: string;
18
+ RABBIT: string;
19
+ };
15
20
  export default tracer;
package/lib/tracer.js CHANGED
@@ -3,7 +3,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
3
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.getCurrentTrace = exports.enable = exports.newTrace = void 0;
6
+ exports.traceTypes = exports.getCurrentTrace = exports.enable = exports.newTrace = exports.Trace = void 0;
7
7
  const async_hooks_1 = __importDefault(require("async_hooks"));
8
8
  const uuid_1 = require("uuid");
9
9
  const prevStates = {};
@@ -45,6 +45,7 @@ class Trace {
45
45
  this.context = new Map();
46
46
  }
47
47
  }
48
+ exports.Trace = Trace;
48
49
  exports.newTrace = (type) => {
49
50
  tracer.currentTrace = new Trace(type);
50
51
  tracer.traces[async_hooks_1.default.executionAsyncId()] = tracer.currentTrace;
@@ -52,4 +53,9 @@ exports.newTrace = (type) => {
52
53
  };
53
54
  exports.enable = () => hook.enable();
54
55
  exports.getCurrentTrace = () => tracer.currentTrace || {};
56
+ exports.traceTypes = {
57
+ HTTP_REQUEST: 'httpRequest',
58
+ WEB_SOCKET: 'webSocket',
59
+ RABBIT: 'rabbit',
60
+ };
55
61
  exports.default = tracer;
@@ -1,4 +1,4 @@
1
- declare type AccountType = 'client' | 'user' | 'service';
1
+ export declare type AccountType = 'client' | 'user' | 'service';
2
2
  interface EntityPermissions {
3
3
  [key: string]: string[];
4
4
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@autofleet/zehut",
3
- "version": "2.0.2",
3
+ "version": "2.0.4",
4
4
  "description": "manage user's identity",
5
5
  "main": "lib/index.js",
6
6
  "types": "lib/index.d.ts",
@@ -34,8 +34,11 @@
34
34
  "express": "^4.18.1",
35
35
  "jsonwebtoken": "^8.5.1",
36
36
  "merge-deep": "^3.0.3",
37
+ "methods": "^1.1.2",
37
38
  "moment": "^2.29.1",
39
+ "nock": "^13.2.9",
38
40
  "node-cache": "^5.1.2",
41
+ "supertest": "^6.2.4",
39
42
  "uuid": "^8.3.2"
40
43
  },
41
44
  "devDependencies": {