@modernlock/common 1.0.57 → 1.0.59
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/build/@types/express/index.d.ts +14 -0
- package/build/@types/express/index.js +2 -0
- package/build/index.d.ts +2 -0
- package/build/index.js +2 -0
- package/build/middlewares/checkPermissions.d.ts +3 -3
- package/build/middlewares/checkPermissions.js +2 -3
- package/build/middlewares/permission.d.ts +4 -0
- package/build/middlewares/permission.js +15 -0
- package/build/utils/enums.d.ts +29 -0
- package/build/utils/enums.js +47 -0
- package/package.json +3 -3
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
interface User {
|
|
2
|
+
_id: string;
|
|
3
|
+
permissions: string;
|
|
4
|
+
isAdmin: boolean;
|
|
5
|
+
propertyId: string;
|
|
6
|
+
allowed: boolean;
|
|
7
|
+
accountType: "client" | "owner" | "superAdmin" | "developer" | "supportAgent";
|
|
8
|
+
}
|
|
9
|
+
declare module "express-serve-static-core" {
|
|
10
|
+
interface Request {
|
|
11
|
+
user: User;
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
export {};
|
package/build/index.d.ts
CHANGED
|
@@ -26,9 +26,11 @@ export * from "./middlewares/checkPermissions";
|
|
|
26
26
|
export * from "./middlewares/checkAuth";
|
|
27
27
|
export * from "./middlewares/error-handler";
|
|
28
28
|
export * from "./middlewares/session";
|
|
29
|
+
export * from "./middlewares/permission";
|
|
29
30
|
export * from "./utils/jwtEncryption";
|
|
30
31
|
export * from "./utils/logger";
|
|
31
32
|
export * from "./utils/create-notification-helper";
|
|
33
|
+
export * from "./utils/enums";
|
|
32
34
|
export * from "./logger/custom-logger";
|
|
33
35
|
export * from "./logger/transporterOptions";
|
|
34
36
|
export * from "./logger/console-transporter";
|
package/build/index.js
CHANGED
|
@@ -42,9 +42,11 @@ __exportStar(require("./middlewares/checkPermissions"), exports);
|
|
|
42
42
|
__exportStar(require("./middlewares/checkAuth"), exports);
|
|
43
43
|
__exportStar(require("./middlewares/error-handler"), exports);
|
|
44
44
|
__exportStar(require("./middlewares/session"), exports);
|
|
45
|
+
__exportStar(require("./middlewares/permission"), exports);
|
|
45
46
|
__exportStar(require("./utils/jwtEncryption"), exports);
|
|
46
47
|
__exportStar(require("./utils/logger"), exports);
|
|
47
48
|
__exportStar(require("./utils/create-notification-helper"), exports);
|
|
49
|
+
__exportStar(require("./utils/enums"), exports);
|
|
48
50
|
__exportStar(require("./logger/custom-logger"), exports);
|
|
49
51
|
__exportStar(require("./logger/transporterOptions"), exports);
|
|
50
52
|
__exportStar(require("./logger/console-transporter"), exports);
|
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
import { Request, Response, NextFunction } from "express";
|
|
2
|
-
type Role = "client" | "owner" | "superAdmin" | "developer" | "supportAgent";
|
|
3
|
-
|
|
4
|
-
export
|
|
2
|
+
type Role = ("client" | "owner" | "superAdmin" | "developer" | "supportAgent")[];
|
|
3
|
+
declare const verifyPermission: (role: Role) => (req: Request, res: Response, next: NextFunction) => void;
|
|
4
|
+
export default verifyPermission;
|
|
@@ -1,12 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.verifyPermission = void 0;
|
|
4
3
|
const auth_error_1 = require("../errors/auth-error");
|
|
5
4
|
const verifyPermission = (role) => {
|
|
6
5
|
return (req, res, next) => {
|
|
7
|
-
if (role
|
|
6
|
+
if (!role.includes(req.user.accountType))
|
|
8
7
|
throw new auth_error_1.AuthenticationError();
|
|
9
8
|
next();
|
|
10
9
|
};
|
|
11
10
|
};
|
|
12
|
-
exports.
|
|
11
|
+
exports.default = verifyPermission;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.verifyPermission = void 0;
|
|
4
|
+
const authorization_error_1 = require("../errors/authorization-error");
|
|
5
|
+
const verifyPermission = (role) => {
|
|
6
|
+
return (req, res, next) => {
|
|
7
|
+
var _a;
|
|
8
|
+
// if (!role.includes(req.user.role)) throw new AuthenticationError();
|
|
9
|
+
const userRole = (_a = req.user) === null || _a === void 0 ? void 0 : _a.role;
|
|
10
|
+
if (!userRole || !role.includes(userRole))
|
|
11
|
+
throw new authorization_error_1.AuthorizationError();
|
|
12
|
+
next();
|
|
13
|
+
};
|
|
14
|
+
};
|
|
15
|
+
exports.verifyPermission = verifyPermission;
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
export declare enum accountType {
|
|
2
|
+
Owner = "owner",
|
|
3
|
+
Client = "client"
|
|
4
|
+
}
|
|
5
|
+
export declare enum WalletProvider {
|
|
6
|
+
Metamask = "metamask",
|
|
7
|
+
WalletConnect = "walletconnect"
|
|
8
|
+
}
|
|
9
|
+
export declare const enums: {
|
|
10
|
+
currencies: readonly {
|
|
11
|
+
name: string;
|
|
12
|
+
code: string;
|
|
13
|
+
}[];
|
|
14
|
+
languages: readonly {
|
|
15
|
+
name: string;
|
|
16
|
+
code: string;
|
|
17
|
+
}[];
|
|
18
|
+
permission: readonly string[];
|
|
19
|
+
};
|
|
20
|
+
export declare enum ETemplate {
|
|
21
|
+
team = "team",
|
|
22
|
+
aboutUs = "about-us",
|
|
23
|
+
portfolio = "portfolio"
|
|
24
|
+
}
|
|
25
|
+
export declare enum EAdminRole {
|
|
26
|
+
SuperAdmin = "superAdmin",
|
|
27
|
+
developer = "developer",
|
|
28
|
+
supportAgent = "supportAgent"
|
|
29
|
+
}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.EAdminRole = exports.ETemplate = exports.enums = exports.WalletProvider = exports.accountType = void 0;
|
|
4
|
+
const languages = Object.freeze([
|
|
5
|
+
{ name: "english", code: "usa" },
|
|
6
|
+
{ name: "english", code: "cad" },
|
|
7
|
+
{ name: "english", code: "eng" },
|
|
8
|
+
{ name: "french", code: "fr" },
|
|
9
|
+
{ name: "urdu", code: "pak" },
|
|
10
|
+
{ name: "urdu", code: "ind" },
|
|
11
|
+
]);
|
|
12
|
+
const currencies = Object.freeze([
|
|
13
|
+
{ name: "canada", code: "CAD $" },
|
|
14
|
+
{ name: "usa", code: "USA $" },
|
|
15
|
+
{ name: "england", code: "GBR £" },
|
|
16
|
+
{ name: "france", code: "FR €" },
|
|
17
|
+
{ name: "germany", code: "DE €" },
|
|
18
|
+
{ name: "india", code: "RS ₹" },
|
|
19
|
+
]);
|
|
20
|
+
const permission = Object.freeze(["finances", "orders", "services", "users"]);
|
|
21
|
+
var accountType;
|
|
22
|
+
(function (accountType) {
|
|
23
|
+
accountType["Owner"] = "owner";
|
|
24
|
+
accountType["Client"] = "client";
|
|
25
|
+
})(accountType = exports.accountType || (exports.accountType = {}));
|
|
26
|
+
var WalletProvider;
|
|
27
|
+
(function (WalletProvider) {
|
|
28
|
+
WalletProvider["Metamask"] = "metamask";
|
|
29
|
+
WalletProvider["WalletConnect"] = "walletconnect";
|
|
30
|
+
})(WalletProvider = exports.WalletProvider || (exports.WalletProvider = {}));
|
|
31
|
+
exports.enums = {
|
|
32
|
+
currencies,
|
|
33
|
+
languages,
|
|
34
|
+
permission,
|
|
35
|
+
};
|
|
36
|
+
var ETemplate;
|
|
37
|
+
(function (ETemplate) {
|
|
38
|
+
ETemplate["team"] = "team";
|
|
39
|
+
ETemplate["aboutUs"] = "about-us";
|
|
40
|
+
ETemplate["portfolio"] = "portfolio";
|
|
41
|
+
})(ETemplate = exports.ETemplate || (exports.ETemplate = {}));
|
|
42
|
+
var EAdminRole;
|
|
43
|
+
(function (EAdminRole) {
|
|
44
|
+
EAdminRole["SuperAdmin"] = "superAdmin";
|
|
45
|
+
EAdminRole["developer"] = "developer";
|
|
46
|
+
EAdminRole["supportAgent"] = "supportAgent";
|
|
47
|
+
})(EAdminRole = exports.EAdminRole || (exports.EAdminRole = {}));
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@modernlock/common",
|
|
3
|
-
"version": "1.0.
|
|
3
|
+
"version": "1.0.59",
|
|
4
4
|
"main": "./build/index.js",
|
|
5
5
|
"types": "./build/index.d.ts",
|
|
6
6
|
"files": [
|
|
@@ -21,10 +21,10 @@
|
|
|
21
21
|
},
|
|
22
22
|
"dependencies": {
|
|
23
23
|
"@elastic/elasticsearch": "^8.12.2",
|
|
24
|
-
"@types/cookie-session": "2.0.44",
|
|
24
|
+
"@types/cookie-session": "^2.0.44",
|
|
25
25
|
"@types/express": "4.17.17",
|
|
26
26
|
"amqplib": "0.10.3",
|
|
27
|
-
"cookie-session": "2.0.0",
|
|
27
|
+
"cookie-session": "^2.0.0",
|
|
28
28
|
"express": "4.18.2",
|
|
29
29
|
"jsonwebtoken": "9.0.0",
|
|
30
30
|
"winston": "^3.12.0",
|