@campxdev/server-shared 1.2.37 → 1.2.38
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/common/config/mongo.config.d.ts +3 -3
- package/dist/common/config/mongo.config.js +23 -23
- package/dist/common/decorators/request.decorators.d.ts +5 -5
- package/dist/common/decorators/request.decorators.js +36 -36
- package/dist/common/decorators/time-validation.decorator.d.ts +2 -2
- package/dist/common/decorators/time-validation.decorator.js +26 -26
- package/dist/common/filters/unhandled-exception.filter.d.ts +4 -4
- package/dist/common/filters/unhandled-exception.filter.js +37 -38
- package/dist/common/filters/unhandled-exception.filter.js.map +1 -1
- package/dist/common/guards/guard.d.ts +8 -8
- package/dist/common/guards/guard.js +24 -24
- package/dist/common/index.d.ts +10 -10
- package/dist/common/index.js +26 -26
- package/dist/common/interceptors/request.interceptor.d.ts +20 -20
- package/dist/common/interceptors/request.interceptor.js +142 -143
- package/dist/common/interceptors/request.interceptor.js.map +1 -1
- package/dist/common/interfaces/context.interface.d.ts +125 -125
- package/dist/common/interfaces/context.interface.js +2 -2
- package/dist/common/store/request-store.d.ts +44 -44
- package/dist/common/store/request-store.js +166 -166
- package/dist/common/store/store-config.d.ts +6 -6
- package/dist/common/store/store-config.js +23 -23
- package/dist/common/store/store.interceptor.d.ts +5 -5
- package/dist/common/store/store.interceptor.js +36 -37
- package/dist/common/store/store.interceptor.js.map +1 -1
- package/dist/domain/db-connection.module.d.ts +3 -3
- package/dist/domain/db-connection.module.js +28 -29
- package/dist/domain/db-connection.module.js.map +1 -1
- package/dist/domain/entities/evaluator.entity.d.ts +17 -17
- package/dist/domain/entities/evaluator.entity.js +111 -112
- package/dist/domain/entities/evaluator.entity.js.map +1 -1
- package/dist/domain/entities/leads.entity.d.ts +26 -26
- package/dist/domain/entities/leads.entity.js +160 -161
- package/dist/domain/entities/leads.entity.js.map +1 -1
- package/dist/domain/entities/profile-permission.entity.d.ts +13 -13
- package/dist/domain/entities/profile-permission.entity.js +69 -70
- package/dist/domain/entities/profile-permission.entity.js.map +1 -1
- package/dist/domain/entities/profile.entity.d.ts +26 -26
- package/dist/domain/entities/profile.entity.js +98 -99
- package/dist/domain/entities/profile.entity.js.map +1 -1
- package/dist/domain/entities/student.entity.d.ts +26 -26
- package/dist/domain/entities/student.entity.js +123 -124
- package/dist/domain/entities/student.entity.js.map +1 -1
- package/dist/domain/entities/user.entity.d.ts +20 -20
- package/dist/domain/entities/user.entity.js +135 -136
- package/dist/domain/entities/user.entity.js.map +1 -1
- package/dist/domain/index.d.ts +10 -10
- package/dist/domain/index.js +26 -26
- package/dist/domain/schemas/global-users.schema.d.ts +60 -60
- package/dist/domain/schemas/global-users.schema.d.ts.map +1 -1
- package/dist/domain/schemas/global-users.schema.js +156 -158
- package/dist/domain/schemas/global-users.schema.js.map +1 -1
- package/dist/domain/schemas/tenant.schema.d.ts +109 -106
- package/dist/domain/schemas/tenant.schema.d.ts.map +1 -1
- package/dist/domain/schemas/tenant.schema.js +349 -347
- package/dist/domain/schemas/tenant.schema.js.map +1 -1
- package/dist/domain/shared-domain.module.d.ts +2 -2
- package/dist/domain/shared-domain.module.js +26 -27
- package/dist/domain/shared-domain.module.js.map +1 -1
- package/dist/index.d.ts +5 -5
- package/dist/index.js +21 -21
- package/dist/permissions/app-permissions/commute-x-permissions.d.ts +118 -118
- package/dist/permissions/app-permissions/commute-x-permissions.js +128 -128
- package/dist/permissions/app-permissions/enroll-x-permissions.d.ts +498 -498
- package/dist/permissions/app-permissions/enroll-x-permissions.js +816 -816
- package/dist/permissions/app-permissions/exams-permissions.d.ts +745 -745
- package/dist/permissions/app-permissions/exams-permissions.js +1218 -1218
- package/dist/permissions/app-permissions/hostels-permissions.d.ts +424 -424
- package/dist/permissions/app-permissions/hostels-permissions.js +537 -537
- package/dist/permissions/app-permissions/payments-permissions.d.ts +364 -364
- package/dist/permissions/app-permissions/payments-permissions.js +486 -486
- package/dist/permissions/app-permissions/people-x-permissions.d.ts +346 -346
- package/dist/permissions/app-permissions/people-x-permissions.js +356 -356
- package/dist/permissions/app-permissions/square-permissions.d.ts +1240 -1240
- package/dist/permissions/app-permissions/square-permissions.js +2263 -2263
- package/dist/permissions/check-permission.guard.d.ts +9 -9
- package/dist/permissions/check-permission.guard.js +60 -60
- package/dist/permissions/index.d.ts +9 -9
- package/dist/permissions/index.js +32 -32
- package/dist/permissions/permissions.d.ts +7464 -7464
- package/dist/permissions/permissions.js +122 -122
- package/dist/shared-module/index.d.ts +2 -2
- package/dist/shared-module/index.js +7 -7
- package/dist/shared-module/shared.module.d.ts +10 -10
- package/dist/shared-module/shared.module.js +36 -37
- package/dist/shared-module/shared.module.js.map +1 -1
- package/dist/shared-module/shared.service.d.ts +67 -67
- package/dist/shared-module/shared.service.js +211 -212
- package/dist/shared-module/shared.service.js.map +1 -1
- package/dist/utils/constants.d.ts +25 -25
- package/dist/utils/constants.js +28 -28
- package/dist/utils/index.d.ts +2 -2
- package/dist/utils/index.js +18 -18
- package/dist/utils/utils.d.ts +26 -26
- package/dist/utils/utils.js +250 -250
- package/package.json +46 -46
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
import { Model } from 'mongoose';
|
|
2
|
-
import { EntityManager } from 'typeorm';
|
|
3
|
-
import { IRequest } from '../common';
|
|
4
|
-
import { GlobalUser, ProfilePermission, User } from '../domain';
|
|
5
|
-
export type CheckFn = (manager: EntityManager, user: User, permission: ProfilePermission, req: IRequest, globalUser: GlobalUser) => Promise<boolean> | boolean;
|
|
6
|
-
export type CheckPermissions = {
|
|
7
|
-
[key: string]: CheckFn | boolean;
|
|
8
|
-
};
|
|
9
|
-
export declare function validateRequestPermission(permissionName: string, fns: CheckPermissions, globalUserModel: Model<GlobalUser>): Promise<boolean>;
|
|
1
|
+
import { Model } from 'mongoose';
|
|
2
|
+
import { EntityManager } from 'typeorm';
|
|
3
|
+
import { IRequest } from '../common';
|
|
4
|
+
import { GlobalUser, ProfilePermission, User } from '../domain';
|
|
5
|
+
export type CheckFn = (manager: EntityManager, user: User, permission: ProfilePermission, req: IRequest, globalUser: GlobalUser) => Promise<boolean> | boolean;
|
|
6
|
+
export type CheckPermissions = {
|
|
7
|
+
[key: string]: CheckFn | boolean;
|
|
8
|
+
};
|
|
9
|
+
export declare function validateRequestPermission(permissionName: string, fns: CheckPermissions, globalUserModel: Model<GlobalUser>): Promise<boolean>;
|
|
10
10
|
//# sourceMappingURL=check-permission.guard.d.ts.map
|
|
@@ -1,61 +1,61 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.validateRequestPermission = void 0;
|
|
4
|
-
const lodash_1 = require("lodash");
|
|
5
|
-
const common_1 = require("../common");
|
|
6
|
-
const domain_1 = require("../domain");
|
|
7
|
-
const permissions_1 = require("./permissions");
|
|
8
|
-
async function validateRequestPermission(permissionName, fns, globalUserModel) {
|
|
9
|
-
const reqUser = (0, common_1.getUserData)();
|
|
10
|
-
if (!reqUser || !reqUser.id)
|
|
11
|
-
return false;
|
|
12
|
-
const req = (0, common_1.getRequest)();
|
|
13
|
-
const permission = (0, permissions_1.permissionGroupedBySlug)()[permissionName];
|
|
14
|
-
if (!permission)
|
|
15
|
-
return false;
|
|
16
|
-
const user = await (0, common_1.getDataSource)().manager.findOne(domain_1.User, {
|
|
17
|
-
where: { id: reqUser.id },
|
|
18
|
-
relations: { profiles: true },
|
|
19
|
-
});
|
|
20
|
-
if (!user)
|
|
21
|
-
return false;
|
|
22
|
-
if (user.isSuperuser ||
|
|
23
|
-
user.profiles.some((p) => p.application === permission.application && p.isAdmin)) {
|
|
24
|
-
return true;
|
|
25
|
-
}
|
|
26
|
-
const profilePermission = await (0, common_1.getDataSource)()
|
|
27
|
-
.manager.createQueryBuilder(domain_1.ProfilePermission, 'pp')
|
|
28
|
-
.andWhere('pp.permissionSlug = :name', { name: permissionName })
|
|
29
|
-
.andWhere('pp.profileId in (:profileIds)', {
|
|
30
|
-
profileIds: user.profiles.length > 0 ? user.profiles.map((p) => p.id) : [0],
|
|
31
|
-
})
|
|
32
|
-
.getMany()
|
|
33
|
-
.then((res) => {
|
|
34
|
-
if (res.length === 0)
|
|
35
|
-
return null;
|
|
36
|
-
const value = res[0];
|
|
37
|
-
value.hasPermission = res.some((r) => r.hasPermission);
|
|
38
|
-
value.permissions = (0, lodash_1.uniq)(res.map((val) => val.permissions ?? []).flat());
|
|
39
|
-
return value;
|
|
40
|
-
});
|
|
41
|
-
if (!profilePermission)
|
|
42
|
-
return false;
|
|
43
|
-
if (!profilePermission.hasPermission)
|
|
44
|
-
return false;
|
|
45
|
-
if (permission.permissions.length === 0)
|
|
46
|
-
return true;
|
|
47
|
-
if (profilePermission.permissions.length === 0)
|
|
48
|
-
return false;
|
|
49
|
-
const pp = fns?.[permission.groupSlug];
|
|
50
|
-
if (pp === null || pp === undefined)
|
|
51
|
-
return true;
|
|
52
|
-
if (typeof pp === 'function') {
|
|
53
|
-
const globalUser = await globalUserModel.findById(reqUser.userId);
|
|
54
|
-
return pp((0, common_1.getDataSource)().manager, user, profilePermission, req, globalUser);
|
|
55
|
-
}
|
|
56
|
-
if (typeof pp === 'boolean')
|
|
57
|
-
return pp;
|
|
58
|
-
return true;
|
|
59
|
-
}
|
|
60
|
-
exports.validateRequestPermission = validateRequestPermission;
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.validateRequestPermission = void 0;
|
|
4
|
+
const lodash_1 = require("lodash");
|
|
5
|
+
const common_1 = require("../common");
|
|
6
|
+
const domain_1 = require("../domain");
|
|
7
|
+
const permissions_1 = require("./permissions");
|
|
8
|
+
async function validateRequestPermission(permissionName, fns, globalUserModel) {
|
|
9
|
+
const reqUser = (0, common_1.getUserData)();
|
|
10
|
+
if (!reqUser || !reqUser.id)
|
|
11
|
+
return false;
|
|
12
|
+
const req = (0, common_1.getRequest)();
|
|
13
|
+
const permission = (0, permissions_1.permissionGroupedBySlug)()[permissionName];
|
|
14
|
+
if (!permission)
|
|
15
|
+
return false;
|
|
16
|
+
const user = await (0, common_1.getDataSource)().manager.findOne(domain_1.User, {
|
|
17
|
+
where: { id: reqUser.id },
|
|
18
|
+
relations: { profiles: true },
|
|
19
|
+
});
|
|
20
|
+
if (!user)
|
|
21
|
+
return false;
|
|
22
|
+
if (user.isSuperuser ||
|
|
23
|
+
user.profiles.some((p) => p.application === permission.application && p.isAdmin)) {
|
|
24
|
+
return true;
|
|
25
|
+
}
|
|
26
|
+
const profilePermission = await (0, common_1.getDataSource)()
|
|
27
|
+
.manager.createQueryBuilder(domain_1.ProfilePermission, 'pp')
|
|
28
|
+
.andWhere('pp.permissionSlug = :name', { name: permissionName })
|
|
29
|
+
.andWhere('pp.profileId in (:profileIds)', {
|
|
30
|
+
profileIds: user.profiles.length > 0 ? user.profiles.map((p) => p.id) : [0],
|
|
31
|
+
})
|
|
32
|
+
.getMany()
|
|
33
|
+
.then((res) => {
|
|
34
|
+
if (res.length === 0)
|
|
35
|
+
return null;
|
|
36
|
+
const value = res[0];
|
|
37
|
+
value.hasPermission = res.some((r) => r.hasPermission);
|
|
38
|
+
value.permissions = (0, lodash_1.uniq)(res.map((val) => val.permissions ?? []).flat());
|
|
39
|
+
return value;
|
|
40
|
+
});
|
|
41
|
+
if (!profilePermission)
|
|
42
|
+
return false;
|
|
43
|
+
if (!profilePermission.hasPermission)
|
|
44
|
+
return false;
|
|
45
|
+
if (permission.permissions.length === 0)
|
|
46
|
+
return true;
|
|
47
|
+
if (profilePermission.permissions.length === 0)
|
|
48
|
+
return false;
|
|
49
|
+
const pp = fns?.[permission.groupSlug];
|
|
50
|
+
if (pp === null || pp === undefined)
|
|
51
|
+
return true;
|
|
52
|
+
if (typeof pp === 'function') {
|
|
53
|
+
const globalUser = await globalUserModel.findById(reqUser.userId);
|
|
54
|
+
return pp((0, common_1.getDataSource)().manager, user, profilePermission, req, globalUser);
|
|
55
|
+
}
|
|
56
|
+
if (typeof pp === 'boolean')
|
|
57
|
+
return pp;
|
|
58
|
+
return true;
|
|
59
|
+
}
|
|
60
|
+
exports.validateRequestPermission = validateRequestPermission;
|
|
61
61
|
//# sourceMappingURL=check-permission.guard.js.map
|
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
export { EnrollXDefaultProfiles } from './app-permissions/enroll-x-permissions';
|
|
2
|
-
export { ExamsDefaultProfiles } from './app-permissions/exams-permissions';
|
|
3
|
-
export { PaymentsDefaultProfiles } from './app-permissions/payments-permissions';
|
|
4
|
-
export { SquareDefaultProfiles } from './app-permissions/square-permissions';
|
|
5
|
-
export { HostelsDefaultProfiles } from './app-permissions/hostels-permissions';
|
|
6
|
-
export { PeopleDefaultProfiles } from './app-permissions/people-x-permissions';
|
|
7
|
-
export { CommuteXDefaultProfiles } from './app-permissions/commute-x-permissions';
|
|
8
|
-
export { CheckPermissions } from './check-permission.guard';
|
|
9
|
-
export * from './permissions';
|
|
1
|
+
export { EnrollXDefaultProfiles } from './app-permissions/enroll-x-permissions';
|
|
2
|
+
export { ExamsDefaultProfiles } from './app-permissions/exams-permissions';
|
|
3
|
+
export { PaymentsDefaultProfiles } from './app-permissions/payments-permissions';
|
|
4
|
+
export { SquareDefaultProfiles } from './app-permissions/square-permissions';
|
|
5
|
+
export { HostelsDefaultProfiles } from './app-permissions/hostels-permissions';
|
|
6
|
+
export { PeopleDefaultProfiles } from './app-permissions/people-x-permissions';
|
|
7
|
+
export { CommuteXDefaultProfiles } from './app-permissions/commute-x-permissions';
|
|
8
|
+
export { CheckPermissions } from './check-permission.guard';
|
|
9
|
+
export * from './permissions';
|
|
10
10
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1,33 +1,33 @@
|
|
|
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.CommuteXDefaultProfiles = exports.PeopleDefaultProfiles = exports.HostelsDefaultProfiles = exports.SquareDefaultProfiles = exports.PaymentsDefaultProfiles = exports.ExamsDefaultProfiles = exports.EnrollXDefaultProfiles = void 0;
|
|
18
|
-
var enroll_x_permissions_1 = require("./app-permissions/enroll-x-permissions");
|
|
19
|
-
Object.defineProperty(exports, "EnrollXDefaultProfiles", { enumerable: true, get: function () { return enroll_x_permissions_1.EnrollXDefaultProfiles; } });
|
|
20
|
-
var exams_permissions_1 = require("./app-permissions/exams-permissions");
|
|
21
|
-
Object.defineProperty(exports, "ExamsDefaultProfiles", { enumerable: true, get: function () { return exams_permissions_1.ExamsDefaultProfiles; } });
|
|
22
|
-
var payments_permissions_1 = require("./app-permissions/payments-permissions");
|
|
23
|
-
Object.defineProperty(exports, "PaymentsDefaultProfiles", { enumerable: true, get: function () { return payments_permissions_1.PaymentsDefaultProfiles; } });
|
|
24
|
-
var square_permissions_1 = require("./app-permissions/square-permissions");
|
|
25
|
-
Object.defineProperty(exports, "SquareDefaultProfiles", { enumerable: true, get: function () { return square_permissions_1.SquareDefaultProfiles; } });
|
|
26
|
-
var hostels_permissions_1 = require("./app-permissions/hostels-permissions");
|
|
27
|
-
Object.defineProperty(exports, "HostelsDefaultProfiles", { enumerable: true, get: function () { return hostels_permissions_1.HostelsDefaultProfiles; } });
|
|
28
|
-
var people_x_permissions_1 = require("./app-permissions/people-x-permissions");
|
|
29
|
-
Object.defineProperty(exports, "PeopleDefaultProfiles", { enumerable: true, get: function () { return people_x_permissions_1.PeopleDefaultProfiles; } });
|
|
30
|
-
var commute_x_permissions_1 = require("./app-permissions/commute-x-permissions");
|
|
31
|
-
Object.defineProperty(exports, "CommuteXDefaultProfiles", { enumerable: true, get: function () { return commute_x_permissions_1.CommuteXDefaultProfiles; } });
|
|
32
|
-
__exportStar(require("./permissions"), exports);
|
|
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.CommuteXDefaultProfiles = exports.PeopleDefaultProfiles = exports.HostelsDefaultProfiles = exports.SquareDefaultProfiles = exports.PaymentsDefaultProfiles = exports.ExamsDefaultProfiles = exports.EnrollXDefaultProfiles = void 0;
|
|
18
|
+
var enroll_x_permissions_1 = require("./app-permissions/enroll-x-permissions");
|
|
19
|
+
Object.defineProperty(exports, "EnrollXDefaultProfiles", { enumerable: true, get: function () { return enroll_x_permissions_1.EnrollXDefaultProfiles; } });
|
|
20
|
+
var exams_permissions_1 = require("./app-permissions/exams-permissions");
|
|
21
|
+
Object.defineProperty(exports, "ExamsDefaultProfiles", { enumerable: true, get: function () { return exams_permissions_1.ExamsDefaultProfiles; } });
|
|
22
|
+
var payments_permissions_1 = require("./app-permissions/payments-permissions");
|
|
23
|
+
Object.defineProperty(exports, "PaymentsDefaultProfiles", { enumerable: true, get: function () { return payments_permissions_1.PaymentsDefaultProfiles; } });
|
|
24
|
+
var square_permissions_1 = require("./app-permissions/square-permissions");
|
|
25
|
+
Object.defineProperty(exports, "SquareDefaultProfiles", { enumerable: true, get: function () { return square_permissions_1.SquareDefaultProfiles; } });
|
|
26
|
+
var hostels_permissions_1 = require("./app-permissions/hostels-permissions");
|
|
27
|
+
Object.defineProperty(exports, "HostelsDefaultProfiles", { enumerable: true, get: function () { return hostels_permissions_1.HostelsDefaultProfiles; } });
|
|
28
|
+
var people_x_permissions_1 = require("./app-permissions/people-x-permissions");
|
|
29
|
+
Object.defineProperty(exports, "PeopleDefaultProfiles", { enumerable: true, get: function () { return people_x_permissions_1.PeopleDefaultProfiles; } });
|
|
30
|
+
var commute_x_permissions_1 = require("./app-permissions/commute-x-permissions");
|
|
31
|
+
Object.defineProperty(exports, "CommuteXDefaultProfiles", { enumerable: true, get: function () { return commute_x_permissions_1.CommuteXDefaultProfiles; } });
|
|
32
|
+
__exportStar(require("./permissions"), exports);
|
|
33
33
|
//# sourceMappingURL=index.js.map
|