grm-shared-library 1.0.85 → 1.0.86

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 (121) hide show
  1. package/dist/decorators/case-decorators.d.ts +3 -0
  2. package/dist/decorators/case-decorators.js +28 -0
  3. package/dist/exceptions/custom-exception/custom-rpc.exception.d.ts +10 -0
  4. package/dist/exceptions/custom-exception/custom-rpc.exception.js +30 -0
  5. package/dist/exceptions/enums/error-codes.enum.d.ts +6 -0
  6. package/dist/exceptions/enums/error-codes.enum.js +9 -0
  7. package/dist/exceptions/error-logger/error-logger.d.ts +2 -0
  8. package/dist/exceptions/error-logger/error-logger.js +24 -0
  9. package/dist/exceptions/filters/all-exceptions.filter.d.ts +6 -0
  10. package/dist/exceptions/filters/all-exceptions.filter.js +62 -0
  11. package/dist/exceptions/filters/http-exceptions.filter.d.ts +4 -0
  12. package/dist/exceptions/filters/http-exceptions.filter.js +39 -0
  13. package/dist/exceptions/index.d.ts +7 -0
  14. package/dist/exceptions/index.js +23 -0
  15. package/dist/exceptions/interfaces/error-context.d.ts +7 -0
  16. package/dist/exceptions/interfaces/error-context.js +2 -0
  17. package/dist/exceptions/interfaces/error-response.d.ts +8 -0
  18. package/dist/exceptions/interfaces/error-response.js +2 -0
  19. package/dist/index.d.ts +12 -0
  20. package/dist/index.js +33 -0
  21. package/dist/interfaces/server-message.d.ts +6 -0
  22. package/dist/interfaces/server-message.js +2 -0
  23. package/dist/kafka/client-ids.d.ts +6 -0
  24. package/dist/kafka/client-ids.js +9 -0
  25. package/dist/kafka/index.d.ts +4 -0
  26. package/dist/kafka/index.js +20 -0
  27. package/dist/kafka/interfaces/otp-payload.d.ts +9 -0
  28. package/dist/kafka/interfaces/otp-payload.js +2 -0
  29. package/dist/kafka/interfaces/user-payload.d.ts +14 -0
  30. package/dist/kafka/interfaces/user-payload.js +2 -0
  31. package/dist/kafka/topics.d.ts +13 -0
  32. package/dist/kafka/topics.js +20 -0
  33. package/dist/modules/auth/dtos/change-password.dto.d.ts +5 -0
  34. package/dist/modules/auth/dtos/change-password.dto.js +38 -0
  35. package/dist/modules/auth/dtos/forgot-password.dto.d.ts +3 -0
  36. package/dist/modules/auth/dtos/forgot-password.dto.js +21 -0
  37. package/dist/modules/auth/dtos/login.dto.d.ts +4 -0
  38. package/dist/modules/auth/dtos/login.dto.js +29 -0
  39. package/dist/modules/auth/dtos/otp.dto.d.ts +3 -0
  40. package/dist/modules/auth/dtos/otp.dto.js +21 -0
  41. package/dist/modules/auth/dtos/register.dto.d.ts +15 -0
  42. package/dist/modules/auth/dtos/register.dto.js +83 -0
  43. package/dist/modules/auth/dtos/reset-password.dto.d.ts +4 -0
  44. package/dist/modules/auth/dtos/reset-password.dto.js +33 -0
  45. package/dist/modules/auth/index.d.ts +6 -0
  46. package/dist/modules/auth/index.js +22 -0
  47. package/dist/modules/auth/validators/match.decorator.d.ts +2 -0
  48. package/dist/modules/auth/validators/match.decorator.js +24 -0
  49. package/dist/modules/common/constants/password-regex.const.d.ts +3 -0
  50. package/dist/modules/common/constants/password-regex.const.js +7 -0
  51. package/dist/modules/common/dtos/contact-person.dto.d.ts +6 -0
  52. package/dist/modules/common/dtos/contact-person.dto.js +38 -0
  53. package/dist/modules/common/dtos/map-address.dto.d.ts +11 -0
  54. package/dist/modules/common/dtos/map-address.dto.js +51 -0
  55. package/dist/modules/common/dtos/map-location.dto.d.ts +5 -0
  56. package/dist/modules/common/dtos/map-location.dto.js +33 -0
  57. package/dist/modules/common/index.d.ts +2 -0
  58. package/dist/modules/common/index.js +18 -0
  59. package/dist/modules/control-centre/dtos/create-control-centre.dto.d.ts +14 -0
  60. package/dist/modules/control-centre/dtos/create-control-centre.dto.js +68 -0
  61. package/dist/modules/control-centre/dtos/update-control-centre.dto.d.ts +5 -0
  62. package/dist/modules/control-centre/dtos/update-control-centre.dto.js +8 -0
  63. package/dist/modules/control-centre/enums/control-centre.enum.d.ts +5 -0
  64. package/dist/modules/control-centre/enums/control-centre.enum.js +9 -0
  65. package/dist/modules/control-centre/index.d.ts +4 -0
  66. package/dist/modules/control-centre/index.js +20 -0
  67. package/dist/modules/control-centre/interfaces/control-centre.d.ts +16 -0
  68. package/dist/modules/control-centre/interfaces/control-centre.js +2 -0
  69. package/dist/modules/email/index.d.ts +1 -0
  70. package/dist/modules/email/index.js +17 -0
  71. package/dist/modules/email/interfaces/user-created.d.ts +7 -0
  72. package/dist/modules/email/interfaces/user-created.js +2 -0
  73. package/dist/modules/organization/dtos/create-organization.dto.d.ts +16 -0
  74. package/dist/modules/organization/dtos/create-organization.dto.js +75 -0
  75. package/dist/modules/organization/dtos/update-organization.dto.d.ts +5 -0
  76. package/dist/modules/organization/dtos/update-organization.dto.js +8 -0
  77. package/dist/modules/organization/enums/org-status.enum.d.ts +7 -0
  78. package/dist/modules/organization/enums/org-status.enum.js +11 -0
  79. package/dist/modules/organization/enums/org-type.enum.d.ts +6 -0
  80. package/dist/modules/organization/enums/org-type.enum.js +10 -0
  81. package/dist/modules/organization/index.d.ts +4 -0
  82. package/dist/modules/organization/index.js +20 -0
  83. package/dist/modules/organization/interfaces/organization.d.ts +18 -0
  84. package/dist/modules/organization/interfaces/organization.js +2 -0
  85. package/dist/modules/permission/data/permissions.data.d.ts +2 -0
  86. package/dist/modules/permission/data/permissions.data.js +52 -0
  87. package/dist/modules/permission/dtos/create-permission.dto.d.ts +4 -0
  88. package/dist/modules/permission/dtos/create-permission.dto.js +27 -0
  89. package/dist/modules/permission/dtos/update-permission.dto.d.ts +5 -0
  90. package/dist/modules/permission/dtos/update-permission.dto.js +8 -0
  91. package/dist/modules/permission/enums/permission-actions.enum.d.ts +22 -0
  92. package/dist/modules/permission/enums/permission-actions.enum.js +31 -0
  93. package/dist/modules/permission/enums/permissions-moudule.enum.d.ts +7 -0
  94. package/dist/modules/permission/enums/permissions-moudule.enum.js +11 -0
  95. package/dist/modules/permission/index.d.ts +6 -0
  96. package/dist/modules/permission/index.js +23 -0
  97. package/dist/modules/permission/interfaces/permission.d.ts +5 -0
  98. package/dist/modules/permission/interfaces/permission.js +2 -0
  99. package/dist/modules/role/data/roles.data.d.ts +2 -0
  100. package/dist/modules/role/data/roles.data.js +120 -0
  101. package/dist/modules/role/dtos/create-role.dto.d.ts +5 -0
  102. package/dist/modules/role/dtos/create-role.dto.js +33 -0
  103. package/dist/modules/role/dtos/update-tole.dto.d.ts +5 -0
  104. package/dist/modules/role/dtos/update-tole.dto.js +8 -0
  105. package/dist/modules/role/enums/role.enum.d.ts +8 -0
  106. package/dist/modules/role/enums/role.enum.js +12 -0
  107. package/dist/modules/role/index.d.ts +5 -0
  108. package/dist/modules/role/index.js +21 -0
  109. package/dist/modules/role/interfaces/role.d.ts +6 -0
  110. package/dist/modules/role/interfaces/role.js +2 -0
  111. package/dist/modules/user/dtos/create-user.dto.d.ts +15 -0
  112. package/dist/modules/user/dtos/create-user.dto.js +84 -0
  113. package/dist/modules/user/dtos/update-user.dto.d.ts +5 -0
  114. package/dist/modules/user/dtos/update-user.dto.js +8 -0
  115. package/dist/modules/user/enums/user-status.enum.d.ts +5 -0
  116. package/dist/modules/user/enums/user-status.enum.js +9 -0
  117. package/dist/modules/user/index.d.ts +4 -0
  118. package/dist/modules/user/index.js +20 -0
  119. package/dist/modules/user/interfaces/user.d.ts +24 -0
  120. package/dist/modules/user/interfaces/user.js +2 -0
  121. package/package.json +1 -1
@@ -0,0 +1,75 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.CreateOrganizationDto = void 0;
13
+ const class_validator_1 = require("class-validator");
14
+ const class_transformer_1 = require("class-transformer");
15
+ const map_address_dto_1 = require("../../common/dtos/map-address.dto");
16
+ const org_status_enum_1 = require("../enums/org-status.enum");
17
+ const contact_person_dto_1 = require("../../common/dtos/contact-person.dto");
18
+ const org_type_enum_1 = require("../enums/org-type.enum");
19
+ class CreateOrganizationDto {
20
+ }
21
+ exports.CreateOrganizationDto = CreateOrganizationDto;
22
+ __decorate([
23
+ (0, class_validator_1.IsString)(),
24
+ (0, class_validator_1.IsNotEmpty)(),
25
+ (0, class_validator_1.MaxLength)(50),
26
+ __metadata("design:type", String)
27
+ ], CreateOrganizationDto.prototype, "name", void 0);
28
+ __decorate([
29
+ (0, class_validator_1.IsPhoneNumber)(),
30
+ (0, class_validator_1.IsOptional)(),
31
+ (0, class_validator_1.MaxLength)(20),
32
+ __metadata("design:type", String)
33
+ ], CreateOrganizationDto.prototype, "phoneNumber", void 0);
34
+ __decorate([
35
+ (0, class_validator_1.IsEmail)(),
36
+ (0, class_validator_1.IsOptional)(),
37
+ __metadata("design:type", String)
38
+ ], CreateOrganizationDto.prototype, "email", void 0);
39
+ __decorate([
40
+ (0, class_validator_1.ValidateNested)(),
41
+ (0, class_transformer_1.Type)(() => map_address_dto_1.MapAddressDto),
42
+ (0, class_validator_1.IsNotEmpty)(),
43
+ __metadata("design:type", map_address_dto_1.MapAddressDto)
44
+ ], CreateOrganizationDto.prototype, "physicalAddress", void 0);
45
+ __decorate([
46
+ (0, class_validator_1.IsUrl)({}, { message: 'Invalid URL. Format should be http://example.com' }),
47
+ (0, class_validator_1.IsNotEmpty)(),
48
+ __metadata("design:type", String)
49
+ ], CreateOrganizationDto.prototype, "website", void 0);
50
+ __decorate([
51
+ (0, class_validator_1.IsEnum)(org_type_enum_1.OrganizationType),
52
+ (0, class_validator_1.IsNotEmpty)(),
53
+ __metadata("design:type", String)
54
+ ], CreateOrganizationDto.prototype, "type", void 0);
55
+ __decorate([
56
+ (0, class_validator_1.IsString)(),
57
+ (0, class_validator_1.IsOptional)(),
58
+ __metadata("design:type", String)
59
+ ], CreateOrganizationDto.prototype, "description", void 0);
60
+ __decorate([
61
+ (0, class_validator_1.IsEnum)(org_status_enum_1.OrganizationStatus),
62
+ (0, class_validator_1.IsOptional)(),
63
+ __metadata("design:type", String)
64
+ ], CreateOrganizationDto.prototype, "status", void 0);
65
+ __decorate([
66
+ (0, class_validator_1.IsUrl)(),
67
+ (0, class_validator_1.IsOptional)(),
68
+ __metadata("design:type", String)
69
+ ], CreateOrganizationDto.prototype, "logo", void 0);
70
+ __decorate([
71
+ (0, class_validator_1.ValidateNested)(),
72
+ (0, class_transformer_1.Type)(() => contact_person_dto_1.ContactPersonDto),
73
+ (0, class_validator_1.IsNotEmpty)(),
74
+ __metadata("design:type", contact_person_dto_1.ContactPersonDto)
75
+ ], CreateOrganizationDto.prototype, "contactPerson", void 0);
@@ -0,0 +1,5 @@
1
+ import { CreateOrganizationDto } from "./create-organization.dto";
2
+ declare const UpdateOrganizationDto_base: import("@nestjs/mapped-types").MappedType<Partial<CreateOrganizationDto>>;
3
+ export declare class UpdateOrganizationDto extends UpdateOrganizationDto_base {
4
+ }
5
+ export {};
@@ -0,0 +1,8 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.UpdateOrganizationDto = void 0;
4
+ const mapped_types_1 = require("@nestjs/mapped-types");
5
+ const create_organization_dto_1 = require("./create-organization.dto");
6
+ class UpdateOrganizationDto extends (0, mapped_types_1.PartialType)(create_organization_dto_1.CreateOrganizationDto) {
7
+ }
8
+ exports.UpdateOrganizationDto = UpdateOrganizationDto;
@@ -0,0 +1,7 @@
1
+ export declare enum OrganizationStatus {
2
+ ACTIVE = "Active",
3
+ INACTIVE = "Inactive",
4
+ PENDING = "Pending",
5
+ SUSPENDED = "Suspended",
6
+ REJECTED = "Rejected"
7
+ }
@@ -0,0 +1,11 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.OrganizationStatus = void 0;
4
+ var OrganizationStatus;
5
+ (function (OrganizationStatus) {
6
+ OrganizationStatus["ACTIVE"] = "Active";
7
+ OrganizationStatus["INACTIVE"] = "Inactive";
8
+ OrganizationStatus["PENDING"] = "Pending";
9
+ OrganizationStatus["SUSPENDED"] = "Suspended";
10
+ OrganizationStatus["REJECTED"] = "Rejected";
11
+ })(OrganizationStatus || (exports.OrganizationStatus = OrganizationStatus = {}));
@@ -0,0 +1,6 @@
1
+ export declare enum OrganizationType {
2
+ PUBLIC = "Public",
3
+ PRIVATE = "Private",
4
+ NGO = "NGO",
5
+ OTHER = "Other"
6
+ }
@@ -0,0 +1,10 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.OrganizationType = void 0;
4
+ var OrganizationType;
5
+ (function (OrganizationType) {
6
+ OrganizationType["PUBLIC"] = "Public";
7
+ OrganizationType["PRIVATE"] = "Private";
8
+ OrganizationType["NGO"] = "NGO";
9
+ OrganizationType["OTHER"] = "Other";
10
+ })(OrganizationType || (exports.OrganizationType = OrganizationType = {}));
@@ -0,0 +1,4 @@
1
+ export * from './dtos/create-organization.dto';
2
+ export * from './dtos/update-organization.dto';
3
+ export * from './interfaces/organization';
4
+ export * from './enums/org-status.enum';
@@ -0,0 +1,20 @@
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("./dtos/create-organization.dto"), exports);
18
+ __exportStar(require("./dtos/update-organization.dto"), exports);
19
+ __exportStar(require("./interfaces/organization"), exports);
20
+ __exportStar(require("./enums/org-status.enum"), exports);
@@ -0,0 +1,18 @@
1
+ import { ContactPersonDto } from "../../common/dtos/contact-person.dto";
2
+ import { MapAddressDto } from "../../common/dtos/map-address.dto";
3
+ import { OrganizationType } from "../enums/org-type.enum";
4
+ export interface Organization {
5
+ id: number;
6
+ name: string;
7
+ phoneNumber?: string;
8
+ email?: string;
9
+ physicalAddress: MapAddressDto;
10
+ website: string;
11
+ type: OrganizationType;
12
+ description?: string;
13
+ status?: string;
14
+ logo?: string;
15
+ contactPerson: ContactPersonDto;
16
+ createdAt?: Date;
17
+ updatedAt?: Date;
18
+ }
@@ -0,0 +1,2 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
@@ -0,0 +1,2 @@
1
+ import { Permission } from "../interfaces/permission";
2
+ export declare const PERMISSIONS_DATA: Permission[];
@@ -0,0 +1,52 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.PERMISSIONS_DATA = void 0;
4
+ const permission_actions_enum_1 = require("../enums/permission-actions.enum");
5
+ const permissions_moudule_enum_1 = require("../enums/permissions-moudule.enum");
6
+ exports.PERMISSIONS_DATA = [
7
+ {
8
+ module: permissions_moudule_enum_1.PermissionsModule.ORGANIZATION,
9
+ actions: [
10
+ permission_actions_enum_1.PermissionActions.CREATE_ORGANIZATION,
11
+ permission_actions_enum_1.PermissionActions.READ_ORGANIZATION,
12
+ permission_actions_enum_1.PermissionActions.UPDATE_ORGANIZATION,
13
+ permission_actions_enum_1.PermissionActions.DELETE_ORGANIZATION
14
+ ]
15
+ },
16
+ {
17
+ module: permissions_moudule_enum_1.PermissionsModule.PARTNER,
18
+ actions: [
19
+ permission_actions_enum_1.PermissionActions.CREATE_CONTROL_CENTRE,
20
+ permission_actions_enum_1.PermissionActions.READ_CONTROL_CENTRE,
21
+ permission_actions_enum_1.PermissionActions.UPDATE_CONTROL_CENTRE,
22
+ permission_actions_enum_1.PermissionActions.DELETE_CONTROL_CENTRE
23
+ ]
24
+ },
25
+ {
26
+ module: permissions_moudule_enum_1.PermissionsModule.USER,
27
+ actions: [
28
+ permission_actions_enum_1.PermissionActions.CREATE_USER,
29
+ permission_actions_enum_1.PermissionActions.READ_USER,
30
+ permission_actions_enum_1.PermissionActions.UPDATE_USER,
31
+ permission_actions_enum_1.PermissionActions.DELETE_USER
32
+ ]
33
+ },
34
+ {
35
+ module: permissions_moudule_enum_1.PermissionsModule.ROLE,
36
+ actions: [
37
+ permission_actions_enum_1.PermissionActions.CREATE_ROLE,
38
+ permission_actions_enum_1.PermissionActions.READ_ROLE,
39
+ permission_actions_enum_1.PermissionActions.UPDATE_ROLE,
40
+ permission_actions_enum_1.PermissionActions.DELETE_ROLE
41
+ ]
42
+ },
43
+ {
44
+ module: permissions_moudule_enum_1.PermissionsModule.INCIDENT,
45
+ actions: [
46
+ permission_actions_enum_1.PermissionActions.CREATE_INCIDENT,
47
+ permission_actions_enum_1.PermissionActions.READ_INCIDENT,
48
+ permission_actions_enum_1.PermissionActions.UPDATE_INCIDENT,
49
+ permission_actions_enum_1.PermissionActions.DELETE_INCIDENT
50
+ ]
51
+ }
52
+ ];
@@ -0,0 +1,4 @@
1
+ export declare class CreatePermissionDto {
2
+ module: string;
3
+ actions: string[];
4
+ }
@@ -0,0 +1,27 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.CreatePermissionDto = void 0;
13
+ const class_validator_1 = require("class-validator");
14
+ class CreatePermissionDto {
15
+ }
16
+ exports.CreatePermissionDto = CreatePermissionDto;
17
+ __decorate([
18
+ (0, class_validator_1.IsString)(),
19
+ (0, class_validator_1.IsNotEmpty)(),
20
+ __metadata("design:type", String)
21
+ ], CreatePermissionDto.prototype, "module", void 0);
22
+ __decorate([
23
+ (0, class_validator_1.IsArray)(),
24
+ (0, class_validator_1.IsString)({ each: true }),
25
+ (0, class_validator_1.IsNotEmpty)(),
26
+ __metadata("design:type", Array)
27
+ ], CreatePermissionDto.prototype, "actions", void 0);
@@ -0,0 +1,5 @@
1
+ import { CreatePermissionDto } from "./create-permission.dto";
2
+ declare const UpdatePermissionDto_base: import("@nestjs/mapped-types").MappedType<Partial<CreatePermissionDto>>;
3
+ export declare class UpdatePermissionDto extends UpdatePermissionDto_base {
4
+ }
5
+ export {};
@@ -0,0 +1,8 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.UpdatePermissionDto = void 0;
4
+ const mapped_types_1 = require("@nestjs/mapped-types");
5
+ const create_permission_dto_1 = require("./create-permission.dto");
6
+ class UpdatePermissionDto extends (0, mapped_types_1.PartialType)(create_permission_dto_1.CreatePermissionDto) {
7
+ }
8
+ exports.UpdatePermissionDto = UpdatePermissionDto;
@@ -0,0 +1,22 @@
1
+ export declare enum PermissionActions {
2
+ CREATE_ORGANIZATION = "create:organization",
3
+ READ_ORGANIZATION = "read:organization",
4
+ UPDATE_ORGANIZATION = "update:organization",
5
+ DELETE_ORGANIZATION = "delete:organization",
6
+ CREATE_CONTROL_CENTRE = "create:control-centre",
7
+ READ_CONTROL_CENTRE = "read:control-centre",
8
+ UPDATE_CONTROL_CENTRE = "update:control-centre",
9
+ DELETE_CONTROL_CENTRE = "delete:control-centre",
10
+ CREATE_ROLE = "create:role",
11
+ READ_ROLE = "read:role",
12
+ UPDATE_ROLE = "update:role",
13
+ DELETE_ROLE = "delete:role",
14
+ CREATE_USER = "create:user",
15
+ READ_USER = "read:user",
16
+ UPDATE_USER = "update:user",
17
+ DELETE_USER = "delete:user",
18
+ CREATE_INCIDENT = "create:incident",
19
+ READ_INCIDENT = "read:incident",
20
+ UPDATE_INCIDENT = "update:incident",
21
+ DELETE_INCIDENT = "delete:incident"
22
+ }
@@ -0,0 +1,31 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.PermissionActions = void 0;
4
+ var PermissionActions;
5
+ (function (PermissionActions) {
6
+ // Module: Organization
7
+ PermissionActions["CREATE_ORGANIZATION"] = "create:organization";
8
+ PermissionActions["READ_ORGANIZATION"] = "read:organization";
9
+ PermissionActions["UPDATE_ORGANIZATION"] = "update:organization";
10
+ PermissionActions["DELETE_ORGANIZATION"] = "delete:organization";
11
+ // Module: ControlCentre
12
+ PermissionActions["CREATE_CONTROL_CENTRE"] = "create:control-centre";
13
+ PermissionActions["READ_CONTROL_CENTRE"] = "read:control-centre";
14
+ PermissionActions["UPDATE_CONTROL_CENTRE"] = "update:control-centre";
15
+ PermissionActions["DELETE_CONTROL_CENTRE"] = "delete:control-centre";
16
+ // Module: Role
17
+ PermissionActions["CREATE_ROLE"] = "create:role";
18
+ PermissionActions["READ_ROLE"] = "read:role";
19
+ PermissionActions["UPDATE_ROLE"] = "update:role";
20
+ PermissionActions["DELETE_ROLE"] = "delete:role";
21
+ // Module: User
22
+ PermissionActions["CREATE_USER"] = "create:user";
23
+ PermissionActions["READ_USER"] = "read:user";
24
+ PermissionActions["UPDATE_USER"] = "update:user";
25
+ PermissionActions["DELETE_USER"] = "delete:user";
26
+ // Module: Incident
27
+ PermissionActions["CREATE_INCIDENT"] = "create:incident";
28
+ PermissionActions["READ_INCIDENT"] = "read:incident";
29
+ PermissionActions["UPDATE_INCIDENT"] = "update:incident";
30
+ PermissionActions["DELETE_INCIDENT"] = "delete:incident";
31
+ })(PermissionActions || (exports.PermissionActions = PermissionActions = {}));
@@ -0,0 +1,7 @@
1
+ export declare enum PermissionsModule {
2
+ ORGANIZATION = "Organization",
3
+ PARTNER = "Partner",
4
+ USER = "User",
5
+ ROLE = "Role",
6
+ INCIDENT = "Grievance"
7
+ }
@@ -0,0 +1,11 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.PermissionsModule = void 0;
4
+ var PermissionsModule;
5
+ (function (PermissionsModule) {
6
+ PermissionsModule["ORGANIZATION"] = "Organization";
7
+ PermissionsModule["PARTNER"] = "Partner";
8
+ PermissionsModule["USER"] = "User";
9
+ PermissionsModule["ROLE"] = "Role";
10
+ PermissionsModule["INCIDENT"] = "Grievance";
11
+ })(PermissionsModule || (exports.PermissionsModule = PermissionsModule = {}));
@@ -0,0 +1,6 @@
1
+ export * from './data/permissions.data';
2
+ export * from './dtos/create-permission.dto';
3
+ export * from './dtos/update-permission.dto';
4
+ export * from './enums/permission-actions.enum';
5
+ export * from './enums/permissions-moudule.enum';
6
+ export * from './interfaces/permission';
@@ -0,0 +1,23 @@
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
+ //Permission
18
+ __exportStar(require("./data/permissions.data"), exports);
19
+ __exportStar(require("./dtos/create-permission.dto"), exports);
20
+ __exportStar(require("./dtos/update-permission.dto"), exports);
21
+ __exportStar(require("./enums/permission-actions.enum"), exports);
22
+ __exportStar(require("./enums/permissions-moudule.enum"), exports);
23
+ __exportStar(require("./interfaces/permission"), exports);
@@ -0,0 +1,5 @@
1
+ export interface Permission {
2
+ id?: number;
3
+ module: string;
4
+ actions: string[];
5
+ }
@@ -0,0 +1,2 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
@@ -0,0 +1,2 @@
1
+ import { Role } from "../interfaces/role";
2
+ export declare const ROLES_DATA: Role[];
@@ -0,0 +1,120 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ROLES_DATA = void 0;
4
+ const permission_1 = require("../../permission");
5
+ const role_enum_1 = require("../enums/role.enum");
6
+ exports.ROLES_DATA = [
7
+ {
8
+ name: role_enum_1.Roles.SUPER_ADMIN,
9
+ description: 'Super Admin',
10
+ permissions: ['*']
11
+ },
12
+ {
13
+ name: role_enum_1.Roles.ORGANIZATION_OWNER,
14
+ description: 'Organization Owner: Manages all Organization functions',
15
+ permissions: [
16
+ //organization
17
+ permission_1.PermissionActions.READ_ORGANIZATION,
18
+ permission_1.PermissionActions.UPDATE_ORGANIZATION,
19
+ permission_1.PermissionActions.DELETE_ORGANIZATION,
20
+ //control centre
21
+ permission_1.PermissionActions.CREATE_CONTROL_CENTRE,
22
+ permission_1.PermissionActions.READ_CONTROL_CENTRE,
23
+ permission_1.PermissionActions.UPDATE_CONTROL_CENTRE,
24
+ permission_1.PermissionActions.DELETE_CONTROL_CENTRE,
25
+ //Role
26
+ permission_1.PermissionActions.READ_ROLE,
27
+ //User
28
+ permission_1.PermissionActions.CREATE_USER,
29
+ permission_1.PermissionActions.READ_USER,
30
+ permission_1.PermissionActions.UPDATE_USER,
31
+ permission_1.PermissionActions.DELETE_USER,
32
+ //Incident
33
+ permission_1.PermissionActions.CREATE_INCIDENT,
34
+ permission_1.PermissionActions.READ_INCIDENT,
35
+ permission_1.PermissionActions.UPDATE_INCIDENT,
36
+ permission_1.PermissionActions.DELETE_INCIDENT
37
+ ]
38
+ },
39
+ {
40
+ name: role_enum_1.Roles.ORGANIZATION_ADMIN,
41
+ description: 'Organization Admin: Manage Organization & Set up Control Centres',
42
+ permissions: [
43
+ //organization
44
+ permission_1.PermissionActions.READ_ORGANIZATION,
45
+ permission_1.PermissionActions.UPDATE_ORGANIZATION,
46
+ //control centre
47
+ permission_1.PermissionActions.CREATE_CONTROL_CENTRE,
48
+ permission_1.PermissionActions.READ_CONTROL_CENTRE,
49
+ permission_1.PermissionActions.UPDATE_CONTROL_CENTRE,
50
+ permission_1.PermissionActions.DELETE_CONTROL_CENTRE,
51
+ //Role
52
+ permission_1.PermissionActions.READ_ROLE,
53
+ //User
54
+ permission_1.PermissionActions.CREATE_USER,
55
+ permission_1.PermissionActions.READ_USER,
56
+ permission_1.PermissionActions.UPDATE_USER,
57
+ permission_1.PermissionActions.DELETE_USER,
58
+ //Incident
59
+ permission_1.PermissionActions.CREATE_INCIDENT,
60
+ permission_1.PermissionActions.READ_INCIDENT,
61
+ permission_1.PermissionActions.UPDATE_INCIDENT
62
+ ]
63
+ },
64
+ {
65
+ name: role_enum_1.Roles.ORGANIZATION_USER,
66
+ description: 'Organization User: View organization-wide data',
67
+ permissions: [
68
+ //organization
69
+ permission_1.PermissionActions.READ_ORGANIZATION,
70
+ //control centre
71
+ permission_1.PermissionActions.READ_CONTROL_CENTRE,
72
+ //Role
73
+ permission_1.PermissionActions.READ_ROLE,
74
+ //User
75
+ permission_1.PermissionActions.READ_USER,
76
+ //Incident
77
+ permission_1.PermissionActions.READ_INCIDENT
78
+ ]
79
+ },
80
+ {
81
+ name: role_enum_1.Roles.CONTROL_CENTRE_ADMIN,
82
+ description: 'Control Centre Admin: Manage Control Centre',
83
+ permissions: [
84
+ //Organization
85
+ permission_1.PermissionActions.READ_ORGANIZATION,
86
+ //Control Centre
87
+ permission_1.PermissionActions.READ_CONTROL_CENTRE,
88
+ permission_1.PermissionActions.UPDATE_CONTROL_CENTRE,
89
+ //Role
90
+ permission_1.PermissionActions.READ_ROLE,
91
+ //User
92
+ permission_1.PermissionActions.CREATE_USER,
93
+ permission_1.PermissionActions.READ_USER,
94
+ permission_1.PermissionActions.UPDATE_USER,
95
+ permission_1.PermissionActions.DELETE_USER,
96
+ //Incident
97
+ permission_1.PermissionActions.CREATE_INCIDENT,
98
+ permission_1.PermissionActions.READ_INCIDENT,
99
+ permission_1.PermissionActions.UPDATE_INCIDENT
100
+ ]
101
+ },
102
+ {
103
+ name: role_enum_1.Roles.CONTROL_CENTRE_USER,
104
+ description: 'Control Centre User: View control centre-wide data & Manage Incidents',
105
+ permissions: [
106
+ //Organization
107
+ permission_1.PermissionActions.READ_ORGANIZATION,
108
+ //Control Centre
109
+ permission_1.PermissionActions.READ_CONTROL_CENTRE,
110
+ //Role
111
+ permission_1.PermissionActions.READ_ROLE,
112
+ //User
113
+ permission_1.PermissionActions.READ_USER,
114
+ //Incident
115
+ permission_1.PermissionActions.CREATE_INCIDENT,
116
+ permission_1.PermissionActions.READ_INCIDENT,
117
+ permission_1.PermissionActions.UPDATE_INCIDENT
118
+ ]
119
+ }
120
+ ];
@@ -0,0 +1,5 @@
1
+ export declare class CreateRoleDto {
2
+ name: string;
3
+ description?: string;
4
+ permissions: string[];
5
+ }
@@ -0,0 +1,33 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.CreateRoleDto = void 0;
13
+ const class_validator_1 = require("class-validator");
14
+ const role_enum_1 = require("../enums/role.enum");
15
+ class CreateRoleDto {
16
+ }
17
+ exports.CreateRoleDto = CreateRoleDto;
18
+ __decorate([
19
+ (0, class_validator_1.IsEnum)(role_enum_1.Roles),
20
+ (0, class_validator_1.IsNotEmpty)(),
21
+ __metadata("design:type", String)
22
+ ], CreateRoleDto.prototype, "name", void 0);
23
+ __decorate([
24
+ (0, class_validator_1.IsString)(),
25
+ (0, class_validator_1.IsOptional)(),
26
+ __metadata("design:type", String)
27
+ ], CreateRoleDto.prototype, "description", void 0);
28
+ __decorate([
29
+ (0, class_validator_1.IsArray)(),
30
+ (0, class_validator_1.IsString)({ each: true }),
31
+ (0, class_validator_1.IsNotEmpty)(),
32
+ __metadata("design:type", Array)
33
+ ], CreateRoleDto.prototype, "permissions", void 0);
@@ -0,0 +1,5 @@
1
+ import { CreateRoleDto } from "./create-role.dto";
2
+ declare const UpdateRoleDto_base: import("@nestjs/mapped-types").MappedType<Partial<CreateRoleDto>>;
3
+ export declare class UpdateRoleDto extends UpdateRoleDto_base {
4
+ }
5
+ export {};
@@ -0,0 +1,8 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.UpdateRoleDto = void 0;
4
+ const mapped_types_1 = require("@nestjs/mapped-types");
5
+ const create_role_dto_1 = require("./create-role.dto");
6
+ class UpdateRoleDto extends (0, mapped_types_1.PartialType)(create_role_dto_1.CreateRoleDto) {
7
+ }
8
+ exports.UpdateRoleDto = UpdateRoleDto;
@@ -0,0 +1,8 @@
1
+ export declare enum Roles {
2
+ SUPER_ADMIN = "Super-Admin",
3
+ ORGANIZATION_OWNER = "Org:Owner",
4
+ ORGANIZATION_ADMIN = "Org:Admin",
5
+ ORGANIZATION_USER = "Org:User",
6
+ CONTROL_CENTRE_ADMIN = "Control-Centre:Admin",
7
+ CONTROL_CENTRE_USER = "Control-Centre:User"
8
+ }
@@ -0,0 +1,12 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Roles = void 0;
4
+ var Roles;
5
+ (function (Roles) {
6
+ Roles["SUPER_ADMIN"] = "Super-Admin";
7
+ Roles["ORGANIZATION_OWNER"] = "Org:Owner";
8
+ Roles["ORGANIZATION_ADMIN"] = "Org:Admin";
9
+ Roles["ORGANIZATION_USER"] = "Org:User";
10
+ Roles["CONTROL_CENTRE_ADMIN"] = "Control-Centre:Admin";
11
+ Roles["CONTROL_CENTRE_USER"] = "Control-Centre:User";
12
+ })(Roles || (exports.Roles = Roles = {}));
@@ -0,0 +1,5 @@
1
+ export * from './data/roles.data';
2
+ export * from './dtos/create-role.dto';
3
+ export * from './dtos/update-tole.dto';
4
+ export * from './enums/role.enum';
5
+ export * from './interfaces/role';