@campxdev/server-shared 1.1.22-alpha.4 → 1.1.23

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 (84) 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 +390 -390
  54. package/dist/permissions/app-permissions/enroll-x-permissions.js +458 -458
  55. package/dist/permissions/app-permissions/enroll-x-permissions.js.map +1 -1
  56. package/dist/permissions/app-permissions/exams-permissions.d.ts +745 -745
  57. package/dist/permissions/app-permissions/exams-permissions.js +1213 -1213
  58. package/dist/permissions/app-permissions/hostels-permissions.d.ts +241 -241
  59. package/dist/permissions/app-permissions/hostels-permissions.js +251 -251
  60. package/dist/permissions/app-permissions/payments-permissions.d.ts +352 -352
  61. package/dist/permissions/app-permissions/payments-permissions.js +474 -474
  62. package/dist/permissions/app-permissions/square-permissions.d.ts +1123 -1123
  63. package/dist/permissions/app-permissions/square-permissions.js +2085 -2085
  64. package/dist/permissions/check-permission.guard.d.ts +52 -52
  65. package/dist/permissions/check-permission.guard.js +58 -58
  66. package/dist/permissions/index.d.ts +7 -7
  67. package/dist/permissions/index.js +28 -28
  68. package/dist/permissions/permissions.d.ts +5708 -5708
  69. package/dist/permissions/permissions.js +116 -116
  70. package/dist/shared-module/index.d.ts +2 -2
  71. package/dist/shared-module/index.js +7 -7
  72. package/dist/shared-module/shared.module.d.ts +10 -10
  73. package/dist/shared-module/shared.module.js +37 -37
  74. package/dist/shared-module/shared.service.d.ts +67 -67
  75. package/dist/shared-module/shared.service.d.ts.map +1 -1
  76. package/dist/shared-module/shared.service.js +209 -210
  77. package/dist/shared-module/shared.service.js.map +1 -1
  78. package/dist/utils/constants.d.ts +25 -25
  79. package/dist/utils/constants.js +28 -28
  80. package/dist/utils/index.d.ts +2 -2
  81. package/dist/utils/index.js +18 -18
  82. package/dist/utils/utils.d.ts +24 -24
  83. package/dist/utils/utils.js +234 -234
  84. 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,8 +1,8 @@
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 { CheckPermissions } from './check-permission.guard';
7
- 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 { CheckPermissions } from './check-permission.guard';
7
+ export * from './permissions';
8
8
  //# sourceMappingURL=index.d.ts.map
@@ -1,29 +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.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
- __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.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
+ __exportStar(require("./permissions"), exports);
29
29
  //# sourceMappingURL=index.js.map