@campxdev/server-shared 1.1.14 → 1.1.15

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.
Files changed (86) hide show
  1. package/dist/common/config/mongo.config.d.ts +3 -3
  2. package/dist/common/config/mongo.config.js +23 -23
  3. package/dist/common/databases/mongoose.repository.d.ts +40 -40
  4. package/dist/common/databases/mongoose.repository.js +94 -94
  5. package/dist/common/decorators/request.decorators.d.ts +5 -5
  6. package/dist/common/decorators/request.decorators.js +36 -36
  7. package/dist/common/decorators/time-validation.decorator.d.ts +2 -2
  8. package/dist/common/decorators/time-validation.decorator.js +26 -26
  9. package/dist/common/filters/unhandled-exception.filter.d.ts +4 -4
  10. package/dist/common/filters/unhandled-exception.filter.js +38 -38
  11. package/dist/common/guards/guard.d.ts +8 -8
  12. package/dist/common/guards/guard.js +24 -24
  13. package/dist/common/index.d.ts +11 -11
  14. package/dist/common/index.js +27 -27
  15. package/dist/common/interceptors/request.interceptor.d.ts +17 -17
  16. package/dist/common/interceptors/request.interceptor.js +132 -132
  17. package/dist/common/interfaces/context.interface.d.ts +102 -102
  18. package/dist/common/interfaces/context.interface.js +2 -2
  19. package/dist/common/store/request-store.d.ts +32 -32
  20. package/dist/common/store/request-store.js +125 -125
  21. package/dist/common/store/store-config.d.ts +6 -6
  22. package/dist/common/store/store-config.js +23 -23
  23. package/dist/common/store/store.interceptor.d.ts +5 -5
  24. package/dist/common/store/store.interceptor.js +37 -37
  25. package/dist/domain/db-connection.module.d.ts +3 -3
  26. package/dist/domain/db-connection.module.js +29 -29
  27. package/dist/domain/entities/department.entity.d.ts +9 -9
  28. package/dist/domain/entities/department.entity.js +50 -50
  29. package/dist/domain/entities/evaluator.entity.d.ts +17 -17
  30. package/dist/domain/entities/evaluator.entity.js +112 -112
  31. package/dist/domain/entities/leads.entity.d.ts +26 -26
  32. package/dist/domain/entities/leads.entity.js +161 -161
  33. package/dist/domain/entities/profile-permission.entity.d.ts +13 -13
  34. package/dist/domain/entities/profile-permission.entity.js +70 -70
  35. package/dist/domain/entities/profile.entity.d.ts +25 -25
  36. package/dist/domain/entities/profile.entity.js +98 -98
  37. package/dist/domain/entities/program.entity.d.ts +13 -13
  38. package/dist/domain/entities/program.entity.js +70 -70
  39. package/dist/domain/entities/student.entity.d.ts +57 -57
  40. package/dist/domain/entities/student.entity.js +279 -279
  41. package/dist/domain/entities/user.entity.d.ts +23 -23
  42. package/dist/domain/entities/user.entity.js +147 -147
  43. package/dist/domain/index.d.ts +12 -12
  44. package/dist/domain/index.js +28 -28
  45. package/dist/domain/schemas/global-users.schema.d.ts +58 -58
  46. package/dist/domain/schemas/global-users.schema.js +145 -145
  47. package/dist/domain/schemas/tenant.schema.d.ts +114 -114
  48. package/dist/domain/schemas/tenant.schema.js +387 -387
  49. package/dist/domain/shared-domain.module.d.ts +2 -2
  50. package/dist/domain/shared-domain.module.js +27 -27
  51. package/dist/index.d.ts +5 -5
  52. package/dist/index.js +21 -21
  53. package/dist/permissions/app-permissions/enroll-x-permissions.d.ts +375 -375
  54. package/dist/permissions/app-permissions/enroll-x-permissions.d.ts.map +1 -1
  55. package/dist/permissions/app-permissions/enroll-x-permissions.js +468 -520
  56. package/dist/permissions/app-permissions/enroll-x-permissions.js.map +1 -1
  57. package/dist/permissions/app-permissions/exams-permissions.d.ts +730 -730
  58. package/dist/permissions/app-permissions/exams-permissions.js +1137 -1137
  59. package/dist/permissions/app-permissions/hostels-permissions.d.ts +239 -239
  60. package/dist/permissions/app-permissions/hostels-permissions.js +243 -243
  61. package/dist/permissions/app-permissions/payments-permissions.d.ts +337 -331
  62. package/dist/permissions/app-permissions/payments-permissions.d.ts.map +1 -1
  63. package/dist/permissions/app-permissions/payments-permissions.js +454 -483
  64. package/dist/permissions/app-permissions/payments-permissions.js.map +1 -1
  65. package/dist/permissions/app-permissions/square-permissions.d.ts +1084 -1084
  66. package/dist/permissions/app-permissions/square-permissions.js +1992 -1992
  67. package/dist/permissions/check-permission.guard.d.ts +52 -52
  68. package/dist/permissions/check-permission.guard.js +58 -58
  69. package/dist/permissions/index.d.ts +6 -6
  70. package/dist/permissions/index.js +26 -26
  71. package/dist/permissions/permissions.d.ts +5540 -5528
  72. package/dist/permissions/permissions.d.ts.map +1 -1
  73. package/dist/permissions/permissions.js +116 -116
  74. package/dist/shared-module/index.d.ts +2 -2
  75. package/dist/shared-module/index.js +7 -7
  76. package/dist/shared-module/shared.module.d.ts +10 -10
  77. package/dist/shared-module/shared.module.js +37 -37
  78. package/dist/shared-module/shared.service.d.ts +67 -67
  79. package/dist/shared-module/shared.service.js +209 -209
  80. package/dist/utils/constants.d.ts +25 -25
  81. package/dist/utils/constants.js +28 -28
  82. package/dist/utils/index.d.ts +2 -2
  83. package/dist/utils/index.js +18 -18
  84. package/dist/utils/utils.d.ts +24 -24
  85. package/dist/utils/utils.js +234 -234
  86. package/package.json +46 -46
@@ -1,53 +1,53 @@
1
- import { EntityManager } from 'typeorm';
2
- import { IRequest } from '../common';
3
- import { ProfilePermission, User } from '../domain';
4
- export type CheckFn = (manager: EntityManager, user: User, permission: ProfilePermission, req: IRequest) => Promise<boolean> | boolean;
5
- export type CheckPermissions = {
6
- organisation?: CheckFn | boolean;
7
- users?: CheckFn | boolean;
8
- admissions?: CheckFn | boolean;
9
- students?: CheckFn | boolean;
10
- subjects?: CheckFn | boolean;
11
- course_registration?: CheckFn | boolean;
12
- end_semester_examinations?: CheckFn | boolean;
13
- internal_examinations?: CheckFn | boolean;
14
- extra_curricular_activities?: CheckFn | boolean;
15
- bundling?: CheckFn | boolean;
16
- classroom?: CheckFn | boolean;
17
- feed?: CheckFn | boolean;
18
- programs?: CheckFn | boolean;
19
- degrees?: CheckFn | boolean;
20
- semesters?: CheckFn | boolean;
21
- curriculums?: CheckFn | boolean;
22
- assessment_templates?: CheckFn | boolean;
23
- assessment_rules?: CheckFn | boolean;
24
- examinations?: CheckFn | boolean;
25
- results_processing?: CheckFn | boolean;
26
- lead_status?: CheckFn | boolean;
27
- hosteler?: CheckFn | boolean;
28
- hosteler_settings?: CheckFn | boolean;
29
- schools?: CheckFn | boolean;
30
- subject_types?: CheckFn | boolean;
31
- assessment_types?: CheckFn | boolean;
32
- master_subject?: CheckFn | boolean;
33
- academic_calendar?: CheckFn | boolean;
34
- designations?: CheckFn | boolean;
35
- tasks?: CheckFn | boolean;
36
- fee_counters?: CheckFn | boolean;
37
- evaluators?: CheckFn | boolean;
38
- exam_registrations?: CheckFn | boolean;
39
- hall_tickets?: CheckFn | boolean;
40
- omrs?: CheckFn | boolean;
41
- paper_configuration?: CheckFn | boolean;
42
- internal_marks?: CheckFn | boolean;
43
- external_marks?: CheckFn | boolean;
44
- d_forms?: CheckFn | boolean;
45
- exam_rooms?: CheckFn | boolean;
46
- exam_timetable?: CheckFn | boolean;
47
- time_slots?: CheckFn | boolean;
48
- quotas?: CheckFn | boolean;
49
- grades?: CheckFn | boolean;
50
- departments?: CheckFn | boolean;
51
- };
52
- export declare function validateRequestPermission(permissionName: string, fns: CheckPermissions): Promise<boolean>;
1
+ import { EntityManager } from 'typeorm';
2
+ import { IRequest } from '../common';
3
+ import { ProfilePermission, User } from '../domain';
4
+ export type CheckFn = (manager: EntityManager, user: User, permission: ProfilePermission, req: IRequest) => Promise<boolean> | boolean;
5
+ export type CheckPermissions = {
6
+ organisation?: CheckFn | boolean;
7
+ users?: CheckFn | boolean;
8
+ admissions?: CheckFn | boolean;
9
+ students?: CheckFn | boolean;
10
+ subjects?: CheckFn | boolean;
11
+ course_registration?: CheckFn | boolean;
12
+ end_semester_examinations?: CheckFn | boolean;
13
+ internal_examinations?: CheckFn | boolean;
14
+ extra_curricular_activities?: CheckFn | boolean;
15
+ bundling?: CheckFn | boolean;
16
+ classroom?: CheckFn | boolean;
17
+ feed?: CheckFn | boolean;
18
+ programs?: CheckFn | boolean;
19
+ degrees?: CheckFn | boolean;
20
+ semesters?: CheckFn | boolean;
21
+ curriculums?: CheckFn | boolean;
22
+ assessment_templates?: CheckFn | boolean;
23
+ assessment_rules?: CheckFn | boolean;
24
+ examinations?: CheckFn | boolean;
25
+ results_processing?: CheckFn | boolean;
26
+ lead_status?: CheckFn | boolean;
27
+ hosteler?: CheckFn | boolean;
28
+ hosteler_settings?: CheckFn | boolean;
29
+ schools?: CheckFn | boolean;
30
+ subject_types?: CheckFn | boolean;
31
+ assessment_types?: CheckFn | boolean;
32
+ master_subject?: CheckFn | boolean;
33
+ academic_calendar?: CheckFn | boolean;
34
+ designations?: CheckFn | boolean;
35
+ tasks?: CheckFn | boolean;
36
+ fee_counters?: CheckFn | boolean;
37
+ evaluators?: CheckFn | boolean;
38
+ exam_registrations?: CheckFn | boolean;
39
+ hall_tickets?: CheckFn | boolean;
40
+ omrs?: CheckFn | boolean;
41
+ paper_configuration?: CheckFn | boolean;
42
+ internal_marks?: CheckFn | boolean;
43
+ external_marks?: CheckFn | boolean;
44
+ d_forms?: CheckFn | boolean;
45
+ exam_rooms?: CheckFn | boolean;
46
+ exam_timetable?: CheckFn | boolean;
47
+ time_slots?: CheckFn | boolean;
48
+ quotas?: CheckFn | boolean;
49
+ grades?: CheckFn | boolean;
50
+ departments?: CheckFn | boolean;
51
+ };
52
+ export declare function validateRequestPermission(permissionName: string, fns: CheckPermissions): Promise<boolean>;
53
53
  //# sourceMappingURL=check-permission.guard.d.ts.map
@@ -1,59 +1,59 @@
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) {
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: ['department', 'department.programs', 'profiles'],
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
- return pp((0, common_1.getDataSource)().manager, user, profilePermission, req);
54
- if (typeof pp === 'boolean')
55
- return pp;
56
- return true;
57
- }
58
- 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) {
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: ['department', 'department.programs', 'profiles'],
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
+ return pp((0, common_1.getDataSource)().manager, user, profilePermission, req);
54
+ if (typeof pp === 'boolean')
55
+ return pp;
56
+ return true;
57
+ }
58
+ exports.validateRequestPermission = validateRequestPermission;
59
59
  //# sourceMappingURL=check-permission.guard.js.map
@@ -1,7 +1,7 @@
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 { CheckPermissions } from './check-permission.guard';
6
- 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 { CheckPermissions } from './check-permission.guard';
6
+ export * from './permissions';
7
7
  //# sourceMappingURL=index.d.ts.map
@@ -1,27 +1,27 @@
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.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
- __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.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
+ __exportStar(require("./permissions"), exports);
27
27
  //# sourceMappingURL=index.js.map