biz-email-builder-shared 1.0.1 → 1.0.3
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/dist/entity/index.js +17 -0
- package/dist/entity/user.entity.js +13 -0
- package/dist/index.js +21 -0
- package/dist/middleware/authentication.js +44 -0
- package/dist/middleware/index.js +18 -0
- package/{middleware → dist/middleware}/schemaValidate.js +5 -1
- package/{resHandler → dist/resHandler}/errorHandler.js +11 -6
- package/dist/resHandler/index.js +18 -0
- package/dist/resHandler/successHandler.js +7 -0
- package/dist/types/IController.js +2 -0
- package/dist/types/IRequest.js +2 -0
- package/dist/types/index.js +18 -0
- package/dist/utilities/callWithRetries.js +15 -0
- package/dist/utilities/createFolder.js +18 -0
- package/dist/utilities/encryptionUtils.js +26 -0
- package/dist/utilities/index.js +29 -0
- package/package.json +4 -3
- package/entity/index.js +0 -1
- package/entity/user.entity.js +0 -10
- package/index.js +0 -5
- package/middleware/authentication.js +0 -30
- package/middleware/index.js +0 -2
- package/resHandler/index.js +0 -2
- package/resHandler/successHandler.js +0 -3
- package/types/IController.js +0 -1
- package/types/IRequest.js +0 -1
- package/types/index.js +0 -2
- package/utilities/callWithRetries.js +0 -11
- package/utilities/createFolder.js +0 -11
- package/utilities/encryptionUtils.js +0 -19
- package/utilities/index.js +0 -12
- /package/{entity → dist/entity}/index.d.ts +0 -0
- /package/{entity → dist/entity}/index.d.ts.map +0 -0
- /package/{entity → dist/entity}/user.entity.d.ts +0 -0
- /package/{entity → dist/entity}/user.entity.d.ts.map +0 -0
- /package/{index.d.ts → dist/index.d.ts} +0 -0
- /package/{index.d.ts.map → dist/index.d.ts.map} +0 -0
- /package/{middleware → dist/middleware}/authentication.d.ts +0 -0
- /package/{middleware → dist/middleware}/authentication.d.ts.map +0 -0
- /package/{middleware → dist/middleware}/index.d.ts +0 -0
- /package/{middleware → dist/middleware}/index.d.ts.map +0 -0
- /package/{middleware → dist/middleware}/schemaValidate.d.ts +0 -0
- /package/{middleware → dist/middleware}/schemaValidate.d.ts.map +0 -0
- /package/{resHandler → dist/resHandler}/errorHandler.d.ts +0 -0
- /package/{resHandler → dist/resHandler}/errorHandler.d.ts.map +0 -0
- /package/{resHandler → dist/resHandler}/index.d.ts +0 -0
- /package/{resHandler → dist/resHandler}/index.d.ts.map +0 -0
- /package/{resHandler → dist/resHandler}/successHandler.d.ts +0 -0
- /package/{resHandler → dist/resHandler}/successHandler.d.ts.map +0 -0
- /package/{types → dist/types}/IController.d.ts +0 -0
- /package/{types → dist/types}/IController.d.ts.map +0 -0
- /package/{types → dist/types}/IRequest.d.ts +0 -0
- /package/{types → dist/types}/IRequest.d.ts.map +0 -0
- /package/{types → dist/types}/index.d.ts +0 -0
- /package/{types → dist/types}/index.d.ts.map +0 -0
- /package/{utilities → dist/utilities}/callWithRetries.d.ts +0 -0
- /package/{utilities → dist/utilities}/callWithRetries.d.ts.map +0 -0
- /package/{utilities → dist/utilities}/createFolder.d.ts +0 -0
- /package/{utilities → dist/utilities}/createFolder.d.ts.map +0 -0
- /package/{utilities → dist/utilities}/encryptionUtils.d.ts +0 -0
- /package/{utilities → dist/utilities}/encryptionUtils.d.ts.map +0 -0
- /package/{utilities → dist/utilities}/index.d.ts +0 -0
- /package/{utilities → dist/utilities}/index.d.ts.map +0 -0
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./user.entity"), exports);
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.UserModel = void 0;
|
|
4
|
+
const mongoose_1 = require("mongoose");
|
|
5
|
+
const UserSchema = new mongoose_1.Schema({
|
|
6
|
+
email: { type: String, unique: true, sparse: true },
|
|
7
|
+
password: { type: String, default: null },
|
|
8
|
+
role: { type: String, default: null },
|
|
9
|
+
deletedAt: { type: Date, default: null },
|
|
10
|
+
}, {
|
|
11
|
+
timestamps: true,
|
|
12
|
+
});
|
|
13
|
+
exports.UserModel = (0, mongoose_1.model)("user", UserSchema);
|
package/dist/index.js
ADDED
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./entity"), exports);
|
|
18
|
+
__exportStar(require("./middleware"), exports);
|
|
19
|
+
__exportStar(require("./resHandler"), exports);
|
|
20
|
+
__exportStar(require("./types"), exports);
|
|
21
|
+
__exportStar(require("./utilities"), exports);
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __rest = (this && this.__rest) || function (s, e) {
|
|
3
|
+
var t = {};
|
|
4
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
|
|
5
|
+
t[p] = s[p];
|
|
6
|
+
if (s != null && typeof Object.getOwnPropertySymbols === "function")
|
|
7
|
+
for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
|
|
8
|
+
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
|
|
9
|
+
t[p[i]] = s[p[i]];
|
|
10
|
+
}
|
|
11
|
+
return t;
|
|
12
|
+
};
|
|
13
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
14
|
+
exports.authorize = void 0;
|
|
15
|
+
const utilities_1 = require("../utilities");
|
|
16
|
+
const entity_1 = require("../entity");
|
|
17
|
+
const authorize = (roles) => {
|
|
18
|
+
return async function (req, res, next) {
|
|
19
|
+
if (!req.headers.authorization) {
|
|
20
|
+
return res.status(401).json({ message: 'Unauthorized' });
|
|
21
|
+
}
|
|
22
|
+
if (!roles.length) {
|
|
23
|
+
return res.status(401).json({ message: 'Unauthorized' });
|
|
24
|
+
}
|
|
25
|
+
if (req.headers.authorization) {
|
|
26
|
+
const token = await (0, utilities_1.verifyUid)(req.headers.authorization);
|
|
27
|
+
if (!token) {
|
|
28
|
+
return res.status(401).json({ message: 'Session Expired' });
|
|
29
|
+
}
|
|
30
|
+
let user = await entity_1.UserModel.findOne({ email: token.value.email });
|
|
31
|
+
if (!user) {
|
|
32
|
+
return res.status(401).json({ message: 'No User Found' });
|
|
33
|
+
}
|
|
34
|
+
const hasAccess = roles.find(role => role === user.role);
|
|
35
|
+
if (!hasAccess) {
|
|
36
|
+
return res.status(403).json({ message: 'Forbbiden' });
|
|
37
|
+
}
|
|
38
|
+
const _a = user.toObject(), { createdAt, updatedAt, deletedAt, password } = _a, rest = __rest(_a, ["createdAt", "updatedAt", "deletedAt", "password"]);
|
|
39
|
+
req.user = Object.assign(Object.assign({}, rest), { userId: rest.email });
|
|
40
|
+
next();
|
|
41
|
+
}
|
|
42
|
+
};
|
|
43
|
+
};
|
|
44
|
+
exports.authorize = authorize;
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./authentication"), exports);
|
|
18
|
+
__exportStar(require("./schemaValidate"), exports);
|
|
@@ -1,4 +1,7 @@
|
|
|
1
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.validateSchema = void 0;
|
|
4
|
+
const validateSchema = (schema) => {
|
|
2
5
|
return async function (req, res, next) {
|
|
3
6
|
const { error } = schema.validate(req.body, { abortEarly: false });
|
|
4
7
|
if (error) {
|
|
@@ -10,3 +13,4 @@ export const validateSchema = (schema) => {
|
|
|
10
13
|
}
|
|
11
14
|
};
|
|
12
15
|
};
|
|
16
|
+
exports.validateSchema = validateSchema;
|
|
@@ -1,20 +1,23 @@
|
|
|
1
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.errorHandler = exports.CustomRequestError = exports.NotFoundRequestError = exports.BadRequestError = void 0;
|
|
4
|
+
class BadRequestError extends Error {
|
|
2
5
|
constructor(message) {
|
|
3
6
|
super(message);
|
|
4
7
|
Object.setPrototypeOf(this, BadRequestError.prototype);
|
|
5
8
|
this.name = 'BadRequestError';
|
|
6
9
|
}
|
|
7
10
|
}
|
|
8
|
-
|
|
11
|
+
exports.BadRequestError = BadRequestError;
|
|
12
|
+
class NotFoundRequestError extends Error {
|
|
9
13
|
constructor(message) {
|
|
10
14
|
super(message);
|
|
11
15
|
Object.setPrototypeOf(this, NotFoundRequestError.prototype);
|
|
12
16
|
this.name = 'NotFoundRequestError';
|
|
13
17
|
}
|
|
14
18
|
}
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
message;
|
|
19
|
+
exports.NotFoundRequestError = NotFoundRequestError;
|
|
20
|
+
class CustomRequestError {
|
|
18
21
|
constructor(title, description) {
|
|
19
22
|
this.name = 'CustomRequestError';
|
|
20
23
|
this.message = {
|
|
@@ -23,8 +26,9 @@ export class CustomRequestError {
|
|
|
23
26
|
};
|
|
24
27
|
}
|
|
25
28
|
}
|
|
29
|
+
exports.CustomRequestError = CustomRequestError;
|
|
26
30
|
// Custom error handler middleware
|
|
27
|
-
|
|
31
|
+
const errorHandler = (err, req, res, next) => {
|
|
28
32
|
let statusCode = 500; // Default status code
|
|
29
33
|
let errorMessage = 'Internal Server Error'; // Default error message
|
|
30
34
|
if (err instanceof BadRequestError) {
|
|
@@ -48,3 +52,4 @@ export const errorHandler = (err, req, res, next) => {
|
|
|
48
52
|
error: err.name // Optionally send the error name/type
|
|
49
53
|
});
|
|
50
54
|
};
|
|
55
|
+
exports.errorHandler = errorHandler;
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./errorHandler"), exports);
|
|
18
|
+
__exportStar(require("./successHandler"), exports);
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./IController"), exports);
|
|
18
|
+
__exportStar(require("./IRequest"), exports);
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.callWithRetries = void 0;
|
|
4
|
+
async function callWithRetries(retryCount, failedMessage, functionRef, ...args) {
|
|
5
|
+
try {
|
|
6
|
+
return await functionRef(...args);
|
|
7
|
+
}
|
|
8
|
+
catch (error) {
|
|
9
|
+
if (retryCount <= 0)
|
|
10
|
+
throw error;
|
|
11
|
+
console.log("callWithRetries", (error === null || error === void 0 ? void 0 : error.message) || error);
|
|
12
|
+
return callWithRetries(retryCount - 1, failedMessage, functionRef, ...args);
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
exports.callWithRetries = callWithRetries;
|
|
@@ -0,0 +1,18 @@
|
|
|
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.createFolder = void 0;
|
|
7
|
+
const fs_1 = __importDefault(require("fs"));
|
|
8
|
+
async function createFolder(folderPath) {
|
|
9
|
+
try {
|
|
10
|
+
if (!fs_1.default.existsSync(folderPath)) {
|
|
11
|
+
fs_1.default.mkdirSync(folderPath);
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
catch (error) {
|
|
15
|
+
console.error(`Error: ${error.message}`);
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
exports.createFolder = createFolder;
|
|
@@ -0,0 +1,26 @@
|
|
|
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.verifyUid = exports.signUid = void 0;
|
|
7
|
+
const jsonwebtoken_1 = __importDefault(require("jsonwebtoken"));
|
|
8
|
+
const signUid = (value) => {
|
|
9
|
+
return jsonwebtoken_1.default.sign({ value }, process.env.JWTSECRET || 'secret', {
|
|
10
|
+
expiresIn: '8h' // expires in 8 hours
|
|
11
|
+
});
|
|
12
|
+
};
|
|
13
|
+
exports.signUid = signUid;
|
|
14
|
+
const verifyUid = async (token) => new Promise(resolve => {
|
|
15
|
+
const jwtToken = token.split(" ")[1] || token;
|
|
16
|
+
jsonwebtoken_1.default.verify(jwtToken, process.env.JWTSECRET || 'secret', (err, decoded) => {
|
|
17
|
+
if (err) {
|
|
18
|
+
// console.log("error verifyUid", err)
|
|
19
|
+
resolve(null);
|
|
20
|
+
}
|
|
21
|
+
else {
|
|
22
|
+
resolve(decoded);
|
|
23
|
+
}
|
|
24
|
+
});
|
|
25
|
+
});
|
|
26
|
+
exports.verifyUid = verifyUid;
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
exports.FEATURES = exports.ROLES = void 0;
|
|
18
|
+
__exportStar(require("./callWithRetries"), exports);
|
|
19
|
+
__exportStar(require("./createFolder"), exports);
|
|
20
|
+
__exportStar(require("./encryptionUtils"), exports);
|
|
21
|
+
var ROLES;
|
|
22
|
+
(function (ROLES) {
|
|
23
|
+
ROLES["ADMIN"] = "ADMIN";
|
|
24
|
+
ROLES["USER"] = "USER";
|
|
25
|
+
})(ROLES || (exports.ROLES = ROLES = {}));
|
|
26
|
+
var FEATURES;
|
|
27
|
+
(function (FEATURES) {
|
|
28
|
+
// We will add features here
|
|
29
|
+
})(FEATURES || (exports.FEATURES = FEATURES = {}));
|
package/package.json
CHANGED
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "biz-email-builder-shared",
|
|
3
|
-
"version": "1.0.
|
|
4
|
-
"main": "index.js",
|
|
5
|
-
"types": "index.d.ts",
|
|
3
|
+
"version": "1.0.3",
|
|
4
|
+
"main": "dist/index.js",
|
|
5
|
+
"types": "dist/index.d.ts",
|
|
6
|
+
"files": ["dist"],
|
|
6
7
|
"scripts": {
|
|
7
8
|
"test": "echo \"Error: no test specified\" && exit 1",
|
|
8
9
|
"build": "tsc"
|
package/entity/index.js
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export * from "./user.entity";
|
package/entity/user.entity.js
DELETED
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
import { Schema, model } from "mongoose";
|
|
2
|
-
const UserSchema = new Schema({
|
|
3
|
-
email: { type: String, unique: true, sparse: true },
|
|
4
|
-
password: { type: String, default: null },
|
|
5
|
-
role: { type: String, default: null },
|
|
6
|
-
deletedAt: { type: Date, default: null },
|
|
7
|
-
}, {
|
|
8
|
-
timestamps: true,
|
|
9
|
-
});
|
|
10
|
-
export const UserModel = model("user", UserSchema);
|
package/index.js
DELETED
|
@@ -1,30 +0,0 @@
|
|
|
1
|
-
import { verifyUid } from "../utilities";
|
|
2
|
-
import { UserModel } from "../entity";
|
|
3
|
-
const authorize = (roles) => {
|
|
4
|
-
return async function (req, res, next) {
|
|
5
|
-
if (!req.headers.authorization) {
|
|
6
|
-
return res.status(401).json({ message: 'Unauthorized' });
|
|
7
|
-
}
|
|
8
|
-
if (!roles.length) {
|
|
9
|
-
return res.status(401).json({ message: 'Unauthorized' });
|
|
10
|
-
}
|
|
11
|
-
if (req.headers.authorization) {
|
|
12
|
-
const token = await verifyUid(req.headers.authorization);
|
|
13
|
-
if (!token) {
|
|
14
|
-
return res.status(401).json({ message: 'Session Expired' });
|
|
15
|
-
}
|
|
16
|
-
let user = await UserModel.findOne({ email: token.value.email });
|
|
17
|
-
if (!user) {
|
|
18
|
-
return res.status(401).json({ message: 'No User Found' });
|
|
19
|
-
}
|
|
20
|
-
const hasAccess = roles.find(role => role === user.role);
|
|
21
|
-
if (!hasAccess) {
|
|
22
|
-
return res.status(403).json({ message: 'Forbbiden' });
|
|
23
|
-
}
|
|
24
|
-
const { createdAt, updatedAt, deletedAt, password, ...rest } = user.toObject();
|
|
25
|
-
req.user = { ...rest, userId: rest.email };
|
|
26
|
-
next();
|
|
27
|
-
}
|
|
28
|
-
};
|
|
29
|
-
};
|
|
30
|
-
export { authorize };
|
package/middleware/index.js
DELETED
package/resHandler/index.js
DELETED
package/types/IController.js
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
package/types/IRequest.js
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export {};
|
package/types/index.js
DELETED
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
export async function callWithRetries(retryCount, failedMessage, functionRef, ...args) {
|
|
2
|
-
try {
|
|
3
|
-
return await functionRef(...args);
|
|
4
|
-
}
|
|
5
|
-
catch (error) {
|
|
6
|
-
if (retryCount <= 0)
|
|
7
|
-
throw error;
|
|
8
|
-
console.log("callWithRetries", error?.message || error);
|
|
9
|
-
return callWithRetries(retryCount - 1, failedMessage, functionRef, ...args);
|
|
10
|
-
}
|
|
11
|
-
}
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
import jwt from 'jsonwebtoken';
|
|
2
|
-
const signUid = (value) => {
|
|
3
|
-
return jwt.sign({ value }, process.env.JWTSECRET || 'secret', {
|
|
4
|
-
expiresIn: '8h' // expires in 8 hours
|
|
5
|
-
});
|
|
6
|
-
};
|
|
7
|
-
const verifyUid = async (token) => new Promise(resolve => {
|
|
8
|
-
const jwtToken = token.split(" ")[1] || token;
|
|
9
|
-
jwt.verify(jwtToken, process.env.JWTSECRET || 'secret', (err, decoded) => {
|
|
10
|
-
if (err) {
|
|
11
|
-
// console.log("error verifyUid", err)
|
|
12
|
-
resolve(null);
|
|
13
|
-
}
|
|
14
|
-
else {
|
|
15
|
-
resolve(decoded);
|
|
16
|
-
}
|
|
17
|
-
});
|
|
18
|
-
});
|
|
19
|
-
export { signUid, verifyUid };
|
package/utilities/index.js
DELETED
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
export * from "./callWithRetries";
|
|
2
|
-
export * from "./createFolder";
|
|
3
|
-
export * from "./encryptionUtils";
|
|
4
|
-
export var ROLES;
|
|
5
|
-
(function (ROLES) {
|
|
6
|
-
ROLES["ADMIN"] = "ADMIN";
|
|
7
|
-
ROLES["USER"] = "USER";
|
|
8
|
-
})(ROLES || (ROLES = {}));
|
|
9
|
-
export var FEATURES;
|
|
10
|
-
(function (FEATURES) {
|
|
11
|
-
// We will add features here
|
|
12
|
-
})(FEATURES || (FEATURES = {}));
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|