@autofleet/zehut 1.4.12 → 1.5.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,5 +1,8 @@
1
- import User from './user';
1
+ import User, { middleware, eagerLoadPermissionsMiddleware, middlewareWithDecode, getDecodedBearer } from './user';
2
+ import { checkFleetPermission, checkBusinessModelPermission, checkDemandSourcePermission, isUserExist, getUser } from './check-permission';
2
3
  import { UnauthorizedAccessError } from './errors';
4
+ declare const getCurrentPayload: () => any;
5
+ export { User, middleware, middlewareWithDecode, eagerLoadPermissionsMiddleware, getCurrentPayload, getDecodedBearer, checkFleetPermission, checkBusinessModelPermission, checkDemandSourcePermission, isUserExist, getUser, UnauthorizedAccessError, };
3
6
  declare const _default: {
4
7
  User: typeof User;
5
8
  middleware: (options?: {
package/lib/index.js CHANGED
@@ -19,17 +19,31 @@ var __importStar = (this && this.__importStar) || function (mod) {
19
19
  return result;
20
20
  };
21
21
  Object.defineProperty(exports, "__esModule", { value: true });
22
+ exports.UnauthorizedAccessError = exports.getUser = exports.isUserExist = exports.checkDemandSourcePermission = exports.checkBusinessModelPermission = exports.checkFleetPermission = exports.getDecodedBearer = exports.getCurrentPayload = exports.eagerLoadPermissionsMiddleware = exports.middlewareWithDecode = exports.middleware = exports.User = void 0;
22
23
  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; } });
28
+ Object.defineProperty(exports, "getDecodedBearer", { enumerable: true, get: function () { return user_1.getDecodedBearer; } });
23
29
  const tracer_1 = require("./tracer");
24
30
  const check_permission_1 = require("./check-permission");
31
+ Object.defineProperty(exports, "checkFleetPermission", { enumerable: true, get: function () { return check_permission_1.checkFleetPermission; } });
32
+ Object.defineProperty(exports, "checkBusinessModelPermission", { enumerable: true, get: function () { return check_permission_1.checkBusinessModelPermission; } });
33
+ Object.defineProperty(exports, "checkDemandSourcePermission", { enumerable: true, get: function () { return check_permission_1.checkDemandSourcePermission; } });
34
+ Object.defineProperty(exports, "isUserExist", { enumerable: true, get: function () { return check_permission_1.isUserExist; } });
35
+ Object.defineProperty(exports, "getUser", { enumerable: true, get: function () { return check_permission_1.getUser; } });
25
36
  const errors_1 = require("./errors");
37
+ Object.defineProperty(exports, "UnauthorizedAccessError", { enumerable: true, get: function () { return errors_1.UnauthorizedAccessError; } });
26
38
  tracer_1.enable();
39
+ const getCurrentPayload = tracer_1.getCurrentTrace;
40
+ exports.getCurrentPayload = getCurrentPayload;
27
41
  exports.default = {
28
42
  User: user_1.default,
29
43
  middleware: user_1.middleware,
30
44
  middlewareWithDecode: user_1.middlewareWithDecode,
31
45
  eagerLoadPermissionsMiddleware: user_1.eagerLoadPermissionsMiddleware,
32
- getCurrentPayload: tracer_1.getCurrentTrace,
46
+ getCurrentPayload,
33
47
  getDecodedBearer: user_1.getDecodedBearer,
34
48
  checkFleetPermission: check_permission_1.checkFleetPermission,
35
49
  checkBusinessModelPermission: check_permission_1.checkBusinessModelPermission,
package/lib/user/index.js CHANGED
@@ -13,6 +13,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
13
13
  };
14
14
  Object.defineProperty(exports, "__esModule", { value: true });
15
15
  exports.getDecodedBearer = exports.eagerLoadPermissionsMiddleware = exports.middlewareWithDecode = exports.middleware = void 0;
16
+ const jsonwebtoken_1 = require("jsonwebtoken");
16
17
  const ApiUser_1 = __importDefault(require("./ApiUser"));
17
18
  const utils_1 = require("../utils");
18
19
  const tracer_1 = require("../tracer");
@@ -39,8 +40,32 @@ exports.middleware = (options = {}) => (req, res, next) => __awaiter(void 0, voi
39
40
  exports.middlewareWithDecode = (options = {}) => (req, res, next) => __awaiter(void 0, void 0, void 0, function* () {
40
41
  var _a;
41
42
  const trace = tracer_1.newTrace('userPayload');
43
+ let decoded;
42
44
  if (req.headers.authorization) {
43
- const decoded = utils_1.decodeBearer(req.headers.authorization);
45
+ try {
46
+ decoded = utils_1.decodeBearer(req.headers.authorization);
47
+ }
48
+ catch (e) {
49
+ if (e instanceof jsonwebtoken_1.TokenExpiredError) {
50
+ res.status(401);
51
+ res.json({
52
+ errors: ['Access token expired'],
53
+ });
54
+ }
55
+ else if (e instanceof jsonwebtoken_1.JsonWebTokenError) {
56
+ res.status(400);
57
+ res.json({
58
+ errors: [e.message],
59
+ });
60
+ }
61
+ else {
62
+ res.status(500);
63
+ res.json({
64
+ errors: ['Server error while parsing token'],
65
+ });
66
+ }
67
+ return;
68
+ }
44
69
  const userId = (_a = decoded === null || decoded === void 0 ? void 0 : decoded.user) === null || _a === void 0 ? void 0 : _a.id;
45
70
  if (userId) {
46
71
  req.headers['X-AF-USER-ID'] = userId;
package/lib/utils.js CHANGED
@@ -31,7 +31,7 @@ const CONTEXT_MAP_PROPS = {
31
31
  exports.getAuthFromBearer = (bearer) => bearer.replace('Bearer ', '');
32
32
  exports.decodeBearer = (bearer) => {
33
33
  const token = bearer.replace('Bearer ', '');
34
- const decoded = jwt.decode(token);
34
+ const decoded = jwt.verify(token);
35
35
  return decoded;
36
36
  };
37
37
  exports.parsePermissions = (contextId, decodedToken) => {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@autofleet/zehut",
3
- "version": "1.4.12",
3
+ "version": "1.5.1",
4
4
  "description": "manage user's identity",
5
5
  "main": "lib/index.js",
6
6
  "types": "lib/index.d.ts",