@campxdev/server-shared 1.1.13 → 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 (88) 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 -697
  58. package/dist/permissions/app-permissions/exams-permissions.d.ts.map +1 -1
  59. package/dist/permissions/app-permissions/exams-permissions.js +1137 -1084
  60. package/dist/permissions/app-permissions/exams-permissions.js.map +1 -1
  61. package/dist/permissions/app-permissions/hostels-permissions.d.ts +239 -239
  62. package/dist/permissions/app-permissions/hostels-permissions.js +243 -243
  63. package/dist/permissions/app-permissions/payments-permissions.d.ts +337 -331
  64. package/dist/permissions/app-permissions/payments-permissions.d.ts.map +1 -1
  65. package/dist/permissions/app-permissions/payments-permissions.js +454 -483
  66. package/dist/permissions/app-permissions/payments-permissions.js.map +1 -1
  67. package/dist/permissions/app-permissions/square-permissions.d.ts +1084 -1084
  68. package/dist/permissions/app-permissions/square-permissions.js +1992 -1992
  69. package/dist/permissions/check-permission.guard.d.ts +52 -52
  70. package/dist/permissions/check-permission.guard.js +58 -58
  71. package/dist/permissions/index.d.ts +6 -6
  72. package/dist/permissions/index.js +26 -26
  73. package/dist/permissions/permissions.d.ts +5540 -5462
  74. package/dist/permissions/permissions.d.ts.map +1 -1
  75. package/dist/permissions/permissions.js +116 -116
  76. package/dist/shared-module/index.d.ts +2 -2
  77. package/dist/shared-module/index.js +7 -7
  78. package/dist/shared-module/shared.module.d.ts +10 -10
  79. package/dist/shared-module/shared.module.js +37 -37
  80. package/dist/shared-module/shared.service.d.ts +67 -67
  81. package/dist/shared-module/shared.service.js +209 -209
  82. package/dist/utils/constants.d.ts +25 -25
  83. package/dist/utils/constants.js +28 -28
  84. package/dist/utils/index.d.ts +2 -2
  85. package/dist/utils/index.js +18 -18
  86. package/dist/utils/utils.d.ts +24 -24
  87. package/dist/utils/utils.js +234 -234
  88. 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