@autofleet/zehut 1.5.13 → 1.6.0-beta-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.
- package/lib/check-permission.d.ts +5 -4
- package/lib/check-permission.js +5 -5
- package/lib/context-manager/context.d.ts +7 -0
- package/lib/context-manager/context.js +19 -0
- package/lib/context-manager/index.d.ts +4 -0
- package/lib/context-manager/index.js +11 -0
- package/lib/context-manager/manager.d.ts +6 -0
- package/lib/context-manager/manager.js +9 -0
- package/lib/index.d.ts +2 -23
- package/lib/index.js +5 -19
- package/lib/user/index.d.ts +3 -3
- package/lib/user/index.js +33 -35
- package/package.json +1 -1
- package/lib/tracer.d.ts +0 -15
- package/lib/tracer.js +0 -55
|
@@ -1,5 +1,6 @@
|
|
|
1
|
-
|
|
1
|
+
import ApiUser from './user/ApiUser';
|
|
2
|
+
export declare const getUser: () => ApiUser;
|
|
2
3
|
export declare const isUserExist: () => boolean;
|
|
3
|
-
export declare const checkFleetPermission: (fleetId:
|
|
4
|
-
export declare const checkBusinessModelPermission: (businessModelId:
|
|
5
|
-
export declare const checkDemandSourcePermission: (demandSourceId:
|
|
4
|
+
export declare const checkFleetPermission: (fleetId: string) => boolean;
|
|
5
|
+
export declare const checkBusinessModelPermission: (businessModelId: string) => boolean;
|
|
6
|
+
export declare const checkDemandSourcePermission: (demandSourceId: string) => boolean;
|
package/lib/check-permission.js
CHANGED
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.checkDemandSourcePermission = exports.checkBusinessModelPermission = exports.checkFleetPermission = exports.isUserExist = exports.getUser = void 0;
|
|
4
|
-
const
|
|
5
|
-
exports.getUser = () =>
|
|
4
|
+
const context_manager_1 = require("./context-manager");
|
|
5
|
+
exports.getUser = () => context_manager_1.contextManager.getContext().get('user');
|
|
6
6
|
exports.isUserExist = () => !!exports.getUser();
|
|
7
7
|
exports.checkFleetPermission = (fleetId) => {
|
|
8
8
|
if (exports.isUserExist()) {
|
|
9
|
-
const
|
|
9
|
+
const context = context_manager_1.contextManager.getContext();
|
|
10
10
|
const user = context === null || context === void 0 ? void 0 : context.get('userObject');
|
|
11
11
|
return !user || Object.keys(user.permissions.fleets).includes(fleetId);
|
|
12
12
|
}
|
|
@@ -14,7 +14,7 @@ exports.checkFleetPermission = (fleetId) => {
|
|
|
14
14
|
};
|
|
15
15
|
exports.checkBusinessModelPermission = (businessModelId) => {
|
|
16
16
|
if (exports.isUserExist()) {
|
|
17
|
-
const
|
|
17
|
+
const context = context_manager_1.contextManager.getContext();
|
|
18
18
|
const user = context === null || context === void 0 ? void 0 : context.get('userObject');
|
|
19
19
|
return !user || Object.keys(user.permissions.businessModels).includes(businessModelId);
|
|
20
20
|
}
|
|
@@ -22,7 +22,7 @@ exports.checkBusinessModelPermission = (businessModelId) => {
|
|
|
22
22
|
};
|
|
23
23
|
exports.checkDemandSourcePermission = (demandSourceId) => {
|
|
24
24
|
if (exports.isUserExist()) {
|
|
25
|
-
const
|
|
25
|
+
const context = context_manager_1.contextManager.getContext();
|
|
26
26
|
const user = context === null || context === void 0 ? void 0 : context.get('userObject');
|
|
27
27
|
return !user || Object.keys(user.permissions.demandSources).includes(demandSourceId);
|
|
28
28
|
}
|
|
@@ -0,0 +1,19 @@
|
|
|
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
|
+
const uuid_1 = __importDefault(require("uuid"));
|
|
7
|
+
class Context {
|
|
8
|
+
constructor() {
|
|
9
|
+
this.id = uuid_1.default.v4();
|
|
10
|
+
this.store = new Map();
|
|
11
|
+
}
|
|
12
|
+
set(key, value) {
|
|
13
|
+
this.store.set(key, value);
|
|
14
|
+
}
|
|
15
|
+
get(key) {
|
|
16
|
+
return this.store.get(key);
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
exports.default = Context;
|
|
@@ -0,0 +1,11 @@
|
|
|
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.Context = exports.contextManager = void 0;
|
|
7
|
+
const manager_1 = __importDefault(require("./manager"));
|
|
8
|
+
const context_1 = __importDefault(require("./context"));
|
|
9
|
+
exports.Context = context_1.default;
|
|
10
|
+
const contextManager = new manager_1.default();
|
|
11
|
+
exports.contextManager = contextManager;
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const async_hooks_1 = require("async_hooks");
|
|
4
|
+
class ContextManager extends async_hooks_1.AsyncLocalStorage {
|
|
5
|
+
getContext() {
|
|
6
|
+
return this.getStore();
|
|
7
|
+
}
|
|
8
|
+
}
|
|
9
|
+
exports.default = ContextManager;
|
package/lib/index.d.ts
CHANGED
|
@@ -2,26 +2,5 @@ import User, { middleware, eagerLoadPermissionsMiddleware, middlewareWithDecode,
|
|
|
2
2
|
import { checkFleetPermission, checkBusinessModelPermission, checkDemandSourcePermission, isUserExist, getUser } from './check-permission';
|
|
3
3
|
import { UnauthorizedAccessError } from './errors';
|
|
4
4
|
import { getRefreshTokenSecret, getTokenSecret } from './secret-getter';
|
|
5
|
-
|
|
6
|
-
export { User, middleware, middlewareWithDecode, eagerLoadPermissionsMiddleware,
|
|
7
|
-
declare const _default: {
|
|
8
|
-
User: typeof User;
|
|
9
|
-
middleware: (options?: {
|
|
10
|
-
eagerLoadUserPermissions?: boolean;
|
|
11
|
-
eagerLoadUserPermissionsLegacy?: boolean;
|
|
12
|
-
}) => (req: any, res: any, next: any) => Promise<void>;
|
|
13
|
-
middlewareWithDecode: (options?: {
|
|
14
|
-
eagerLoadUserPermissions?: boolean;
|
|
15
|
-
eagerLoadUserPermissionsLegacy?: boolean;
|
|
16
|
-
}) => (req: any, res: any, next: any) => Promise<void>;
|
|
17
|
-
eagerLoadPermissionsMiddleware: (req: any, res: any, next: any) => Promise<any>;
|
|
18
|
-
getCurrentPayload: () => any;
|
|
19
|
-
getDecodedBearer: (req: any) => any;
|
|
20
|
-
checkFleetPermission: (fleetId: any) => boolean;
|
|
21
|
-
checkBusinessModelPermission: (businessModelId: any) => boolean;
|
|
22
|
-
checkDemandSourcePermission: (demandSourceId: any) => boolean;
|
|
23
|
-
isUserExist: () => boolean;
|
|
24
|
-
getUser: () => any;
|
|
25
|
-
UnauthorizedAccessError: typeof UnauthorizedAccessError;
|
|
26
|
-
};
|
|
27
|
-
export default _default;
|
|
5
|
+
export * from './context-manager';
|
|
6
|
+
export { User, middleware, middlewareWithDecode, eagerLoadPermissionsMiddleware, getDecodedBearer, checkFleetPermission, checkBusinessModelPermission, checkDemandSourcePermission, isUserExist, getUser, getRefreshTokenSecret, getTokenSecret, UnauthorizedAccessError, };
|
package/lib/index.js
CHANGED
|
@@ -18,15 +18,17 @@ var __importStar = (this && this.__importStar) || function (mod) {
|
|
|
18
18
|
__setModuleDefault(result, mod);
|
|
19
19
|
return result;
|
|
20
20
|
};
|
|
21
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
22
|
+
for (var p in m) if (p !== "default" && !exports.hasOwnProperty(p)) __createBinding(exports, m, p);
|
|
23
|
+
};
|
|
21
24
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
22
|
-
exports.UnauthorizedAccessError = exports.getTokenSecret = exports.getRefreshTokenSecret = exports.getUser = exports.isUserExist = exports.checkDemandSourcePermission = exports.checkBusinessModelPermission = exports.checkFleetPermission = exports.getDecodedBearer = exports.
|
|
25
|
+
exports.UnauthorizedAccessError = exports.getTokenSecret = exports.getRefreshTokenSecret = exports.getUser = exports.isUserExist = exports.checkDemandSourcePermission = exports.checkBusinessModelPermission = exports.checkFleetPermission = exports.getDecodedBearer = exports.eagerLoadPermissionsMiddleware = exports.middlewareWithDecode = exports.middleware = exports.User = void 0;
|
|
23
26
|
const user_1 = __importStar(require("./user"));
|
|
24
27
|
exports.User = user_1.default;
|
|
25
28
|
Object.defineProperty(exports, "middleware", { enumerable: true, get: function () { return user_1.middleware; } });
|
|
26
29
|
Object.defineProperty(exports, "eagerLoadPermissionsMiddleware", { enumerable: true, get: function () { return user_1.eagerLoadPermissionsMiddleware; } });
|
|
27
30
|
Object.defineProperty(exports, "middlewareWithDecode", { enumerable: true, get: function () { return user_1.middlewareWithDecode; } });
|
|
28
31
|
Object.defineProperty(exports, "getDecodedBearer", { enumerable: true, get: function () { return user_1.getDecodedBearer; } });
|
|
29
|
-
const tracer_1 = require("./tracer");
|
|
30
32
|
const check_permission_1 = require("./check-permission");
|
|
31
33
|
Object.defineProperty(exports, "checkFleetPermission", { enumerable: true, get: function () { return check_permission_1.checkFleetPermission; } });
|
|
32
34
|
Object.defineProperty(exports, "checkBusinessModelPermission", { enumerable: true, get: function () { return check_permission_1.checkBusinessModelPermission; } });
|
|
@@ -38,20 +40,4 @@ Object.defineProperty(exports, "UnauthorizedAccessError", { enumerable: true, ge
|
|
|
38
40
|
const secret_getter_1 = require("./secret-getter");
|
|
39
41
|
Object.defineProperty(exports, "getRefreshTokenSecret", { enumerable: true, get: function () { return secret_getter_1.getRefreshTokenSecret; } });
|
|
40
42
|
Object.defineProperty(exports, "getTokenSecret", { enumerable: true, get: function () { return secret_getter_1.getTokenSecret; } });
|
|
41
|
-
|
|
42
|
-
const getCurrentPayload = tracer_1.getCurrentTrace;
|
|
43
|
-
exports.getCurrentPayload = getCurrentPayload;
|
|
44
|
-
exports.default = {
|
|
45
|
-
User: user_1.default,
|
|
46
|
-
middleware: user_1.middleware,
|
|
47
|
-
middlewareWithDecode: user_1.middlewareWithDecode,
|
|
48
|
-
eagerLoadPermissionsMiddleware: user_1.eagerLoadPermissionsMiddleware,
|
|
49
|
-
getCurrentPayload,
|
|
50
|
-
getDecodedBearer: user_1.getDecodedBearer,
|
|
51
|
-
checkFleetPermission: check_permission_1.checkFleetPermission,
|
|
52
|
-
checkBusinessModelPermission: check_permission_1.checkBusinessModelPermission,
|
|
53
|
-
checkDemandSourcePermission: check_permission_1.checkDemandSourcePermission,
|
|
54
|
-
isUserExist: check_permission_1.isUserExist,
|
|
55
|
-
getUser: check_permission_1.getUser,
|
|
56
|
-
UnauthorizedAccessError: errors_1.UnauthorizedAccessError,
|
|
57
|
-
};
|
|
43
|
+
__exportStar(require("./context-manager"), exports);
|
package/lib/user/index.d.ts
CHANGED
|
@@ -2,11 +2,11 @@ import ApiUser from './ApiUser';
|
|
|
2
2
|
export declare const middleware: (options?: {
|
|
3
3
|
eagerLoadUserPermissions?: boolean;
|
|
4
4
|
eagerLoadUserPermissionsLegacy?: boolean;
|
|
5
|
-
}) => (req: any, res: any, next: any) => Promise<
|
|
5
|
+
}) => (req: any, res: any, next: any) => Promise<any>;
|
|
6
6
|
export declare const middlewareWithDecode: (options?: {
|
|
7
7
|
eagerLoadUserPermissions?: boolean;
|
|
8
8
|
eagerLoadUserPermissionsLegacy?: boolean;
|
|
9
|
-
}) => (req: any, res: any, next: any) => Promise<
|
|
10
|
-
export declare const eagerLoadPermissionsMiddleware: (req: any, res: any, next: any) => Promise<
|
|
9
|
+
}) => (req: any, res: any, next: any) => Promise<any>;
|
|
10
|
+
export declare const eagerLoadPermissionsMiddleware: (req: any, res: any, next: any) => Promise<void>;
|
|
11
11
|
export declare const getDecodedBearer: (req: any) => any;
|
|
12
12
|
export default ApiUser;
|
package/lib/user/index.js
CHANGED
|
@@ -16,30 +16,31 @@ exports.getDecodedBearer = exports.eagerLoadPermissionsMiddleware = exports.midd
|
|
|
16
16
|
const jsonwebtoken_1 = require("jsonwebtoken");
|
|
17
17
|
const ApiUser_1 = __importDefault(require("./ApiUser"));
|
|
18
18
|
const utils_1 = require("../utils");
|
|
19
|
-
const
|
|
19
|
+
const context_manager_1 = require("../context-manager");
|
|
20
20
|
exports.middleware = (options = {}) => (req, res, next) => __awaiter(void 0, void 0, void 0, function* () {
|
|
21
21
|
const userId = req.headers['x-af-user-id'];
|
|
22
|
-
const
|
|
22
|
+
const context = new context_manager_1.Context();
|
|
23
23
|
if (!userId) {
|
|
24
|
-
|
|
25
|
-
return next();
|
|
24
|
+
context.set('userObject', {});
|
|
26
25
|
}
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
26
|
+
else {
|
|
27
|
+
const userObject = new ApiUser_1.default(userId);
|
|
28
|
+
if (options.eagerLoadUserPermissions) {
|
|
29
|
+
yield userObject.getUserPermissions();
|
|
30
|
+
}
|
|
31
|
+
if (options.eagerLoadUserPermissionsLegacy) {
|
|
32
|
+
yield userObject.getUserPermissionsLegacy();
|
|
33
|
+
}
|
|
34
|
+
req.user = userObject;
|
|
35
|
+
context.set('userObject', userObject);
|
|
33
36
|
}
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
req.headers['x-af-user-permissions'] = userObject;
|
|
38
|
-
return next();
|
|
37
|
+
return context_manager_1.contextManager.run(context, () => {
|
|
38
|
+
next();
|
|
39
|
+
});
|
|
39
40
|
});
|
|
40
41
|
exports.middlewareWithDecode = (options = {}) => (req, res, next) => __awaiter(void 0, void 0, void 0, function* () {
|
|
41
42
|
var _a;
|
|
42
|
-
const
|
|
43
|
+
const context = new context_manager_1.Context();
|
|
43
44
|
let decoded;
|
|
44
45
|
if (req.headers.authorization) {
|
|
45
46
|
try {
|
|
@@ -47,24 +48,18 @@ exports.middlewareWithDecode = (options = {}) => (req, res, next) => __awaiter(v
|
|
|
47
48
|
}
|
|
48
49
|
catch (e) {
|
|
49
50
|
if (e instanceof jsonwebtoken_1.TokenExpiredError) {
|
|
50
|
-
res.status(401)
|
|
51
|
-
res.json({
|
|
51
|
+
return res.status(401).json({
|
|
52
52
|
errors: ['Access token expired'],
|
|
53
53
|
});
|
|
54
54
|
}
|
|
55
|
-
|
|
56
|
-
res.status(400)
|
|
57
|
-
res.json({
|
|
55
|
+
if (e instanceof jsonwebtoken_1.JsonWebTokenError) {
|
|
56
|
+
return res.status(400).json({
|
|
58
57
|
errors: [e.message],
|
|
59
58
|
});
|
|
60
59
|
}
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
errors: ['Server error while parsing token'],
|
|
65
|
-
});
|
|
66
|
-
}
|
|
67
|
-
return;
|
|
60
|
+
return res.status(500).json({
|
|
61
|
+
errors: ['Server error while parsing token'],
|
|
62
|
+
});
|
|
68
63
|
}
|
|
69
64
|
const userId = (_a = decoded === null || decoded === void 0 ? void 0 : decoded.user) === null || _a === void 0 ? void 0 : _a.id;
|
|
70
65
|
if (userId) {
|
|
@@ -78,17 +73,20 @@ exports.middlewareWithDecode = (options = {}) => (req, res, next) => __awaiter(v
|
|
|
78
73
|
yield userObject.getUserPermissionsLegacy();
|
|
79
74
|
}
|
|
80
75
|
req.user = userObject;
|
|
81
|
-
|
|
82
|
-
// Added in order to support outbreak.
|
|
83
|
-
req.headers['x-af-user-permissions'] = userObject;
|
|
76
|
+
context.set('userObject', userObject);
|
|
84
77
|
}
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
78
|
+
else {
|
|
79
|
+
context.set('userObject', {});
|
|
80
|
+
}
|
|
81
|
+
return context_manager_1.contextManager.run(context, () => {
|
|
82
|
+
next();
|
|
83
|
+
});
|
|
88
84
|
});
|
|
89
85
|
exports.eagerLoadPermissionsMiddleware = (req, res, next) => __awaiter(void 0, void 0, void 0, function* () {
|
|
90
86
|
yield req.user.getUserPermissions();
|
|
91
|
-
return
|
|
87
|
+
return context_manager_1.contextManager.run(new context_manager_1.Context(), () => {
|
|
88
|
+
next();
|
|
89
|
+
});
|
|
92
90
|
});
|
|
93
91
|
exports.getDecodedBearer = (req) => {
|
|
94
92
|
if (req.headers.authorization) {
|
package/package.json
CHANGED
package/lib/tracer.d.ts
DELETED
|
@@ -1,15 +0,0 @@
|
|
|
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
DELETED
|
@@ -1,55 +0,0 @@
|
|
|
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 = 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.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;
|