@platform-modules/civil-aviation-authority 2.3.250 → 2.3.256

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 (96) hide show
  1. package/.env +22 -7
  2. package/dist/data-source.js +8 -0
  3. package/dist/index.d.ts +1 -0
  4. package/dist/index.js +1 -0
  5. package/dist/models/DocumentMetadataModel.d.ts +45 -0
  6. package/dist/models/DocumentMetadataModel.js +171 -0
  7. package/dist/models/DocumentationDepartmentsModel.d.ts +13 -0
  8. package/dist/models/DocumentationDepartmentsModel.js +53 -0
  9. package/dist/models/FolderModel.d.ts +16 -0
  10. package/dist/models/FolderModel.js +85 -0
  11. package/dist/models/ImportExportMaterialModels.d.ts +92 -0
  12. package/dist/models/ImportExportMaterialModels.js +307 -0
  13. package/dist/models/PermissionModel.d.ts +18 -0
  14. package/dist/models/PermissionModel.js +68 -0
  15. package/dist/models/SecurityAccessApprovalModel.d.ts +23 -0
  16. package/dist/models/SecurityAccessApprovalModel.js +82 -0
  17. package/dist/models/SecurityAccessAttachmentModel.d.ts +12 -0
  18. package/dist/models/SecurityAccessAttachmentModel.js +56 -0
  19. package/dist/models/SecurityAccessChatModel.d.ts +12 -0
  20. package/dist/models/SecurityAccessChatModel.js +56 -0
  21. package/dist/models/SecurityAccessRequestModel.d.ts +25 -0
  22. package/dist/models/SecurityAccessRequestModel.js +80 -0
  23. package/dist/models/SecurityAccessWorkflowModel.d.ts +24 -0
  24. package/dist/models/SecurityAccessWorkflowModel.js +84 -0
  25. package/dist/models/ServiceExtensionAfterAge60Models.d.ts +93 -0
  26. package/dist/models/ServiceExtensionAfterAge60Models.js +312 -0
  27. package/dist/models/SlaMyRequestsViewModel.d.ts +25 -0
  28. package/dist/models/SlaMyRequestsViewModel.js +148 -0
  29. package/dist/models/UUIDBaseModel.d.ts +14 -0
  30. package/dist/models/UUIDBaseModel.js +66 -0
  31. package/dist/models/WorkingHoursExtensionModels.d.ts +88 -0
  32. package/dist/models/WorkingHoursExtensionModels.js +295 -0
  33. package/package.json +1 -2
  34. package/src/data-source.ts +8 -0
  35. package/src/index.ts +1 -0
  36. package/src/models/AccessCardRequestModel.ts +135 -135
  37. package/src/models/AccommodationApprovalModel.ts +8 -8
  38. package/src/models/AccommodationRequestModel.ts +8 -8
  39. package/src/models/AirportEntryPermitModel.ts +276 -276
  40. package/src/models/AnnualIncrementRequestEmployeeModel.ts +65 -65
  41. package/src/models/AnnualIncrementRequestModel.ts +25 -25
  42. package/src/models/AnnualTrainingPlanRequestModel.ts +153 -153
  43. package/src/models/AppealAgainstAdministrativeDecisionRequestModel.ts +23 -23
  44. package/src/models/CAAServices.ts +33 -33
  45. package/src/models/CAASubServices.ts +33 -33
  46. package/src/models/CAIRatingMasterModel.ts +39 -39
  47. package/src/models/CSRMBusinessImpactRatingMasterModel.ts +25 -25
  48. package/src/models/CSRMLikelihoodMasterModel.ts +25 -25
  49. package/src/models/CashAllowanceLeaveRequestModel.ts +11 -11
  50. package/src/models/DepartmentsModel.ts +25 -25
  51. package/src/models/DocumentDriveModel.ts +28 -28
  52. package/src/models/DocumentFolderModel.ts +45 -45
  53. package/src/models/HotelApprovalModel.ts +83 -83
  54. package/src/models/HousingContractCancelApprovalModel.ts +64 -64
  55. package/src/models/HousingContractCancelChatModel.ts +56 -56
  56. package/src/models/HousingContractRenewalApprovalModel.ts +64 -64
  57. package/src/models/HousingContractRenewalChatModel.ts +59 -59
  58. package/src/models/HrServiceRequestModel.ts +193 -193
  59. package/src/models/ITRequestAttachmentModel.ts +73 -73
  60. package/src/models/ITRequestChatModel.ts +74 -74
  61. package/src/models/ItApprovalsModel.ts +84 -84
  62. package/src/models/ItWorkflowModel.ts +55 -55
  63. package/src/models/LegalConsultationApprovalModel.ts +65 -65
  64. package/src/models/MissionTravelPassportExpiryNotificationConfigModel.ts +36 -36
  65. package/src/models/NotificationModel.ts +89 -89
  66. package/src/models/PerformanceCyclePeriodModel.ts +26 -26
  67. package/src/models/PerformanceGoalMasterModel.ts +27 -27
  68. package/src/models/PerformanceManagementRequestGoalModel.ts +46 -46
  69. package/src/models/PerformanceManagementRequestModel.ts +14 -14
  70. package/src/models/PromotionRequestModel.ts +11 -11
  71. package/src/models/ResidentialUnitRentalApprovalModel.ts +143 -143
  72. package/src/models/ResidentialUnitRentalChatModel.ts +56 -56
  73. package/src/models/ResidentialUnitRentalRequestModel.ts +218 -218
  74. package/src/models/RespondToEnquiriesRequestModel.ts +31 -31
  75. package/src/models/ServiceExtensionAfter60ApprovalModel.ts +87 -87
  76. package/src/models/ServiceSlaApprovalModel.ts +64 -64
  77. package/src/models/ServicesNotificationConfigModel.ts +55 -55
  78. package/src/models/SkillsEnhancementRequestModel.ts +17 -17
  79. package/src/models/SlaMyRequestsViewModel.ts +142 -0
  80. package/src/models/SlaRequestModel.ts +65 -65
  81. package/src/models/StudyLeaveRequestModel.ts +144 -144
  82. package/src/models/TrainingRequestModel.ts +164 -164
  83. package/src/models/TrainingRoomBookingRequestModel.ts +142 -142
  84. package/src/models/TrainingRoomNotificationConfigModel.ts +30 -30
  85. package/src/models/UserSkillModel.ts +56 -56
  86. package/src/models/role.ts +34 -34
  87. package/src/models/user.ts +233 -233
  88. package/src/sla/sla-table-sync.service.ts +90 -90
  89. package/dist/models/ITApprovalSettings.d.ts +0 -7
  90. package/dist/models/ITApprovalSettings.js +0 -40
  91. package/dist/models/ITServicesTypesMuscatModel.d.ts +0 -6
  92. package/dist/models/ITServicesTypesMuscatModel.js +0 -34
  93. package/dist/models/ITServicesTypesSalalahModel.d.ts +0 -6
  94. package/dist/models/ITServicesTypesSalalahModel.js +0 -34
  95. package/dist/models/Workflows.d.ts +0 -9
  96. package/dist/models/Workflows.js +0 -31
@@ -1,87 +1,87 @@
1
- import { Column, Entity } from "typeorm";
2
- import { BaseModel } from "./BaseModel";
3
-
4
- export enum ServiceExtensionAfter60ApprovalStatus {
5
- PENDING = "Pending",
6
- IN_PROGRESS = "In Progress",
7
- APPROVED = "Approved",
8
- REJECTED = "Rejected"
9
- }
10
-
11
- @Entity({ name: "service_extension_after_60_approvals" })
12
- export class ServiceExtensionAfter60Approval extends BaseModel {
13
- @Column({ type: "integer", nullable: false })
14
- request_id: number;
15
-
16
- @Column({ type: "integer", nullable: true })
17
- service_id: number | null;
18
-
19
- @Column({ type: "integer", nullable: true })
20
- sub_service_id: number | null;
21
-
22
- @Column({ type: "integer", nullable: false })
23
- level: number;
24
-
25
- @Column({ type: "integer", nullable: true })
26
- approver_role_id: number;
27
-
28
- @Column({ type: "integer", nullable: true })
29
- department_id: number | null;
30
-
31
- @Column({ type: "integer", nullable: true })
32
- section_id: number | null;
33
-
34
- @Column({ type: "integer", nullable: true })
35
- approver_user_id: number | null;
36
-
37
- @Column({ type: "integer", nullable: true })
38
- delegate_user_id: number | null;
39
-
40
- @Column({ type: "integer", nullable: true })
41
- approved_by: number | null;
42
-
43
- @Column({ type: "varchar", length: 500, nullable: true, default: "" })
44
- comment: string;
45
-
46
- @Column({
47
- type: "enum",
48
- enum: ServiceExtensionAfter60ApprovalStatus,
49
- default: ServiceExtensionAfter60ApprovalStatus.PENDING,
50
- nullable: false
51
- })
52
- approval_status: ServiceExtensionAfter60ApprovalStatus;
53
-
54
- @Column({ type: "boolean", default: true, nullable: false })
55
- is_allowed: boolean;
56
-
57
- constructor(
58
- request_id: number,
59
- approver_role_id: number,
60
- level: number,
61
- comment: string,
62
- approval_status: ServiceExtensionAfter60ApprovalStatus,
63
- service_id?: number,
64
- sub_service_id?: number,
65
- department_id?: number | null,
66
- section_id?: number | null,
67
- approver_user_id?: number | null,
68
- delegate_user_id?: number | null,
69
- approved_by?: number | null,
70
- is_allowed?: boolean
71
- ) {
72
- super();
73
- this.request_id = request_id;
74
- this.service_id = service_id ?? null;
75
- this.sub_service_id = sub_service_id ?? null;
76
- this.level = level;
77
- this.approver_role_id = approver_role_id;
78
- this.department_id = department_id ?? null;
79
- this.section_id = section_id ?? null;
80
- this.approver_user_id = approver_user_id ?? null;
81
- this.delegate_user_id = delegate_user_id ?? null;
82
- this.approved_by = approved_by ?? null;
83
- this.comment = comment;
84
- this.approval_status = approval_status;
85
- this.is_allowed = is_allowed !== undefined ? is_allowed : true;
86
- }
87
- }
1
+ import { Column, Entity } from "typeorm";
2
+ import { BaseModel } from "./BaseModel";
3
+
4
+ export enum ServiceExtensionAfter60ApprovalStatus {
5
+ PENDING = "Pending",
6
+ IN_PROGRESS = "In Progress",
7
+ APPROVED = "Approved",
8
+ REJECTED = "Rejected"
9
+ }
10
+
11
+ @Entity({ name: "service_extension_after_60_approvals" })
12
+ export class ServiceExtensionAfter60Approval extends BaseModel {
13
+ @Column({ type: "integer", nullable: false })
14
+ request_id: number;
15
+
16
+ @Column({ type: "integer", nullable: true })
17
+ service_id: number | null;
18
+
19
+ @Column({ type: "integer", nullable: true })
20
+ sub_service_id: number | null;
21
+
22
+ @Column({ type: "integer", nullable: false })
23
+ level: number;
24
+
25
+ @Column({ type: "integer", nullable: true })
26
+ approver_role_id: number;
27
+
28
+ @Column({ type: "integer", nullable: true })
29
+ department_id: number | null;
30
+
31
+ @Column({ type: "integer", nullable: true })
32
+ section_id: number | null;
33
+
34
+ @Column({ type: "integer", nullable: true })
35
+ approver_user_id: number | null;
36
+
37
+ @Column({ type: "integer", nullable: true })
38
+ delegate_user_id: number | null;
39
+
40
+ @Column({ type: "integer", nullable: true })
41
+ approved_by: number | null;
42
+
43
+ @Column({ type: "varchar", length: 500, nullable: true, default: "" })
44
+ comment: string;
45
+
46
+ @Column({
47
+ type: "enum",
48
+ enum: ServiceExtensionAfter60ApprovalStatus,
49
+ default: ServiceExtensionAfter60ApprovalStatus.PENDING,
50
+ nullable: false
51
+ })
52
+ approval_status: ServiceExtensionAfter60ApprovalStatus;
53
+
54
+ @Column({ type: "boolean", default: true, nullable: false })
55
+ is_allowed: boolean;
56
+
57
+ constructor(
58
+ request_id: number,
59
+ approver_role_id: number,
60
+ level: number,
61
+ comment: string,
62
+ approval_status: ServiceExtensionAfter60ApprovalStatus,
63
+ service_id?: number,
64
+ sub_service_id?: number,
65
+ department_id?: number | null,
66
+ section_id?: number | null,
67
+ approver_user_id?: number | null,
68
+ delegate_user_id?: number | null,
69
+ approved_by?: number | null,
70
+ is_allowed?: boolean
71
+ ) {
72
+ super();
73
+ this.request_id = request_id;
74
+ this.service_id = service_id ?? null;
75
+ this.sub_service_id = sub_service_id ?? null;
76
+ this.level = level;
77
+ this.approver_role_id = approver_role_id;
78
+ this.department_id = department_id ?? null;
79
+ this.section_id = section_id ?? null;
80
+ this.approver_user_id = approver_user_id ?? null;
81
+ this.delegate_user_id = delegate_user_id ?? null;
82
+ this.approved_by = approved_by ?? null;
83
+ this.comment = comment;
84
+ this.approval_status = approval_status;
85
+ this.is_allowed = is_allowed !== undefined ? is_allowed : true;
86
+ }
87
+ }
@@ -1,64 +1,64 @@
1
- import { Column, Entity, Index } from "typeorm";
2
- import { BaseModel } from "./BaseModel";
3
-
4
- /**
5
- * Cross-service SLA tracking row for any microservice (HR, IT, Tender, …).
6
- * Segregated by service_id, sub_service_id, request_id.
7
- * source_approval_id = native approval row PK in the owning service (e.g. hr_service_approvals.id, vpn_approvals.id); not a DB FK.
8
- */
9
- @Entity({ name: "sla_approval" })
10
- @Index("idx_sla_approval_request_id", ["request_id"])
11
- @Index("idx_sla_approval_source_approval_id", ["source_approval_id"])
12
- @Index("idx_sla_approval_service_subservice", ["service_id", "sub_service_id"])
13
- @Index("idx_sla_approval_approval_status", ["approval_status"])
14
- @Index("idx_sla_approval_level", ["level"])
15
- @Index("idx_sla_approval_approver_user_id", ["approver_user_id"])
16
- @Index("idx_sla_approval_request_level", ["request_id", "level"])
17
- @Index("idx_sla_approval_svc_sub_status", ["service_id", "sub_service_id", "approval_status"])
18
- export class ServiceSlaApproval extends BaseModel {
19
- @Column({ type: "int" })
20
- request_id: number;
21
-
22
- @Column({ type: "int" })
23
- source_approval_id: number;
24
-
25
- @Column({ type: "int", nullable: true })
26
- service_id: number | null;
27
-
28
- @Column({ type: "int", nullable: true })
29
- sub_service_id: number | null;
30
-
31
- @Column({ type: "varchar", length: 64 })
32
- approval_status: string;
33
-
34
- @Column({ type: "int" })
35
- level: number;
36
-
37
- @Column({ type: "int", nullable: true })
38
- approver_user_id: number | null;
39
-
40
- @Column({ type: "int", nullable: true })
41
- approver_role_id: number | null;
42
-
43
- @Column({ type: "int", nullable: true })
44
- department_id: number | null;
45
-
46
- @Column({ type: "int", nullable: true })
47
- section_id: number | null;
48
-
49
- /** Mirrors native approval `delegate_user_id` (IT master tables may use `delegation_user_id`). */
50
- @Column({ type: "int", nullable: true })
51
- delegate_user_id: number | null;
52
-
53
- /** Mirrors native approval `approved_by` (acting user when status was last resolved). */
54
- @Column({ type: "int", nullable: true })
55
- approved_by: number | null;
56
-
57
- /** Mirrors native approval comment / rejection reason. */
58
- @Column({ type: "varchar", length: 255, nullable: true })
59
- comment: string | null;
60
-
61
- constructor() {
62
- super();
63
- }
64
- }
1
+ import { Column, Entity, Index } from "typeorm";
2
+ import { BaseModel } from "./BaseModel";
3
+
4
+ /**
5
+ * Cross-service SLA tracking row for any microservice (HR, IT, Tender, …).
6
+ * Segregated by service_id, sub_service_id, request_id.
7
+ * source_approval_id = native approval row PK in the owning service (e.g. hr_service_approvals.id, vpn_approvals.id); not a DB FK.
8
+ */
9
+ @Entity({ name: "sla_approval" })
10
+ @Index("idx_sla_approval_request_id", ["request_id"])
11
+ @Index("idx_sla_approval_source_approval_id", ["source_approval_id"])
12
+ @Index("idx_sla_approval_service_subservice", ["service_id", "sub_service_id"])
13
+ @Index("idx_sla_approval_approval_status", ["approval_status"])
14
+ @Index("idx_sla_approval_level", ["level"])
15
+ @Index("idx_sla_approval_approver_user_id", ["approver_user_id"])
16
+ @Index("idx_sla_approval_request_level", ["request_id", "level"])
17
+ @Index("idx_sla_approval_svc_sub_status", ["service_id", "sub_service_id", "approval_status"])
18
+ export class ServiceSlaApproval extends BaseModel {
19
+ @Column({ type: "int" })
20
+ request_id: number;
21
+
22
+ @Column({ type: "int" })
23
+ source_approval_id: number;
24
+
25
+ @Column({ type: "int", nullable: true })
26
+ service_id: number | null;
27
+
28
+ @Column({ type: "int", nullable: true })
29
+ sub_service_id: number | null;
30
+
31
+ @Column({ type: "varchar", length: 64 })
32
+ approval_status: string;
33
+
34
+ @Column({ type: "int" })
35
+ level: number;
36
+
37
+ @Column({ type: "int", nullable: true })
38
+ approver_user_id: number | null;
39
+
40
+ @Column({ type: "int", nullable: true })
41
+ approver_role_id: number | null;
42
+
43
+ @Column({ type: "int", nullable: true })
44
+ department_id: number | null;
45
+
46
+ @Column({ type: "int", nullable: true })
47
+ section_id: number | null;
48
+
49
+ /** Mirrors native approval `delegate_user_id` (IT master tables may use `delegation_user_id`). */
50
+ @Column({ type: "int", nullable: true })
51
+ delegate_user_id: number | null;
52
+
53
+ /** Mirrors native approval `approved_by` (acting user when status was last resolved). */
54
+ @Column({ type: "int", nullable: true })
55
+ approved_by: number | null;
56
+
57
+ /** Mirrors native approval comment / rejection reason. */
58
+ @Column({ type: "varchar", length: 255, nullable: true })
59
+ comment: string | null;
60
+
61
+ constructor() {
62
+ super();
63
+ }
64
+ }
@@ -1,55 +1,55 @@
1
- import { Column, Entity } from "typeorm";
2
- import { BaseModel } from "./BaseModel";
3
-
4
- export enum ServicesNotificationTriggerType {
5
- FINAL_APPROVAL = "final_approval",
6
- EVERY_APPROVAL = "every_approval"
7
- }
8
-
9
- @Entity({ name: "services_notification_configs" })
10
- export class ServicesNotificationConfigs extends BaseModel {
11
- @Column({ type: "integer", nullable: false })
12
- service_id: number;
13
-
14
- @Column({ type: "integer", nullable: false })
15
- sub_service_id: number;
16
-
17
- @Column({ type: "integer", nullable: false })
18
- department_id: number;
19
-
20
- @Column({ type: "integer", nullable: true })
21
- section_id: number | null;
22
-
23
- @Column({ type: "integer", nullable: true })
24
- role_id: number | null;
25
-
26
- @Column({
27
- type: "enum",
28
- enum: ServicesNotificationTriggerType,
29
- nullable: false,
30
- default: ServicesNotificationTriggerType.FINAL_APPROVAL
31
- })
32
- trigger: ServicesNotificationTriggerType;
33
-
34
- @Column({ type: "boolean", nullable: false, default: true })
35
- is_active: boolean;
36
-
37
- constructor(
38
- service_id: number,
39
- sub_service_id: number,
40
- department_id: number,
41
- section_id: number | null = null,
42
- role_id: number | null = null,
43
- trigger: ServicesNotificationTriggerType = ServicesNotificationTriggerType.FINAL_APPROVAL,
44
- is_active: boolean = true
45
- ) {
46
- super();
47
- this.service_id = service_id;
48
- this.sub_service_id = sub_service_id;
49
- this.department_id = department_id;
50
- this.section_id = section_id;
51
- this.role_id = role_id;
52
- this.trigger = trigger;
53
- this.is_active = is_active;
54
- }
55
- }
1
+ import { Column, Entity } from "typeorm";
2
+ import { BaseModel } from "./BaseModel";
3
+
4
+ export enum ServicesNotificationTriggerType {
5
+ FINAL_APPROVAL = "final_approval",
6
+ EVERY_APPROVAL = "every_approval"
7
+ }
8
+
9
+ @Entity({ name: "services_notification_configs" })
10
+ export class ServicesNotificationConfigs extends BaseModel {
11
+ @Column({ type: "integer", nullable: false })
12
+ service_id: number;
13
+
14
+ @Column({ type: "integer", nullable: false })
15
+ sub_service_id: number;
16
+
17
+ @Column({ type: "integer", nullable: false })
18
+ department_id: number;
19
+
20
+ @Column({ type: "integer", nullable: true })
21
+ section_id: number | null;
22
+
23
+ @Column({ type: "integer", nullable: true })
24
+ role_id: number | null;
25
+
26
+ @Column({
27
+ type: "enum",
28
+ enum: ServicesNotificationTriggerType,
29
+ nullable: false,
30
+ default: ServicesNotificationTriggerType.FINAL_APPROVAL
31
+ })
32
+ trigger: ServicesNotificationTriggerType;
33
+
34
+ @Column({ type: "boolean", nullable: false, default: true })
35
+ is_active: boolean;
36
+
37
+ constructor(
38
+ service_id: number,
39
+ sub_service_id: number,
40
+ department_id: number,
41
+ section_id: number | null = null,
42
+ role_id: number | null = null,
43
+ trigger: ServicesNotificationTriggerType = ServicesNotificationTriggerType.FINAL_APPROVAL,
44
+ is_active: boolean = true
45
+ ) {
46
+ super();
47
+ this.service_id = service_id;
48
+ this.sub_service_id = sub_service_id;
49
+ this.department_id = department_id;
50
+ this.section_id = section_id;
51
+ this.role_id = role_id;
52
+ this.trigger = trigger;
53
+ this.is_active = is_active;
54
+ }
55
+ }
@@ -68,8 +68,8 @@ export class SkillsEnhancementRequest extends BaseModel {
68
68
  @Column({ type: "varchar", length: 255, nullable: false })
69
69
  issuing_authority: string;
70
70
 
71
- @Column({ type: "text", nullable: true })
72
- skill_summary: string | null;
71
+ @Column({ type: "text", nullable: true })
72
+ skill_summary: string | null;
73
73
 
74
74
  @Column({ type: "text", nullable: true })
75
75
  additional_info_requested: string | null;
@@ -86,13 +86,13 @@ export class SkillsEnhancementRequest extends BaseModel {
86
86
  reviewer_user_id?: number | null,
87
87
  assigned_to_user_id?: number | null,
88
88
  assigned_at?: Date | null,
89
- workflow_execution_id?: string | null,
90
- certification_title?: string,
91
- skill_category?: SkillCategory,
92
- issuing_authority?: string,
93
- skill_summary?: string | null,
94
- additional_info_requested?: string | null
95
- ) {
89
+ workflow_execution_id?: string | null,
90
+ certification_title?: string,
91
+ skill_category?: SkillCategory,
92
+ issuing_authority?: string,
93
+ skill_summary?: string | null,
94
+ additional_info_requested?: string | null
95
+ ) {
96
96
  super();
97
97
  this.user_id = user_id;
98
98
  this.status = status;
@@ -105,11 +105,11 @@ export class SkillsEnhancementRequest extends BaseModel {
105
105
  this.reviewer_user_id = reviewer_user_id || null;
106
106
  this.assigned_to_user_id = assigned_to_user_id || null;
107
107
  this.assigned_at = assigned_at || null;
108
- this.workflow_execution_id = workflow_execution_id || null;
109
- this.certification_title = certification_title || "";
110
- this.skill_category = skill_category || SkillCategory.TECHNICAL;
111
- this.issuing_authority = issuing_authority || "";
112
- this.skill_summary = skill_summary || null;
113
- this.additional_info_requested = additional_info_requested || null;
114
- }
115
- }
108
+ this.workflow_execution_id = workflow_execution_id || null;
109
+ this.certification_title = certification_title || "";
110
+ this.skill_category = skill_category || SkillCategory.TECHNICAL;
111
+ this.issuing_authority = issuing_authority || "";
112
+ this.skill_summary = skill_summary || null;
113
+ this.additional_info_requested = additional_info_requested || null;
114
+ }
115
+ }
@@ -0,0 +1,142 @@
1
+ import { ViewColumn, ViewEntity } from "typeorm";
2
+ import { SlaRequestStatus } from "./SlaRequestModel";
3
+
4
+ /** Top-level `request_obj` keys omitted from `request_fields` (see sql/vw_sla_my_requests.sql). */
5
+ export const SLA_MY_REQUESTS_REQUEST_OBJ_EXCLUDED_KEYS = [
6
+ "id",
7
+ "status",
8
+ "role_id",
9
+ "user_id",
10
+ "createdBy",
11
+ "created_at",
12
+ "updated_by",
13
+ "updated_at",
14
+ "req_user_department_id",
15
+ "workflow_execution_id",
16
+ "department_id",
17
+ "req_user_section_id",
18
+ "service_type_id",
19
+ "service_type",
20
+ ] as const;
21
+
22
+ const VW_SLA_MY_REQUESTS_SQL = `
23
+ SELECT
24
+ sr.id AS sla_request_id,
25
+ sr.user_id,
26
+ TRIM(COALESCE(creator.employee_name, ''))::TEXT AS created_by,
27
+ sr.created_at,
28
+ TRIM(COALESCE(dept.department_name, ''))::TEXT AS req_user_department_id,
29
+ TRIM(COALESCE(sec.section_name, ''))::TEXT AS req_user_section_id,
30
+ TRIM(COALESCE(svc.name, ''))::TEXT AS service_id,
31
+ TRIM(COALESCE(subsvc.sub_service_name, ''))::TEXT AS sub_service_id,
32
+ sr.status::TEXT AS status,
33
+ sr.request_id,
34
+ (
35
+ COALESCE(sr.request_obj, '{}'::jsonb)
36
+ - 'id'
37
+ - 'status'
38
+ - 'role_id'
39
+ - 'user_id'
40
+ - 'createdBy'
41
+ - 'created_at'
42
+ - 'updated_by'
43
+ - 'updated_at'
44
+ - 'req_user_department_id'
45
+ - 'workflow_execution_id'
46
+ - 'department_id'
47
+ - 'req_user_section_id'
48
+ - 'service_type_id'
49
+ - 'service_type'
50
+ ) AS request_fields
51
+ FROM sla_requests sr
52
+ LEFT JOIN users creator
53
+ ON creator.id = sr.created_by AND COALESCE(creator.is_deleted, false) = false
54
+ LEFT JOIN departments dept
55
+ ON dept.id = sr.req_user_department_id AND COALESCE(dept.is_deleted, false) = false
56
+ LEFT JOIN sections sec
57
+ ON sec.id = sr.req_user_section_id AND COALESCE(sec.is_deleted, false) = false
58
+ LEFT JOIN caa_services svc
59
+ ON svc.id = sr.service_id AND COALESCE(svc.is_deleted, false) = false
60
+ LEFT JOIN caa_sub_services subsvc
61
+ ON subsvc.id = sr.sub_service_id AND COALESCE(subsvc.is_deleted, false) = false
62
+ WHERE COALESCE(sr.is_deleted, false) = false
63
+ `;
64
+
65
+ /**
66
+ * Read-only view for SLA "my requests" listings.
67
+ * Display-name columns reuse sla_requests field names; values come from joined lookup tables.
68
+ * Service-specific payload keys live in `request_fields` (filtered `request_obj`).
69
+ */
70
+ @ViewEntity({
71
+ name: "vw_sla_my_requests",
72
+ expression: VW_SLA_MY_REQUESTS_SQL,
73
+ })
74
+ export class SlaMyRequestsView {
75
+ @ViewColumn()
76
+ sla_request_id: number;
77
+
78
+ /** Request owner (`sla_requests.user_id`) — filter with WHERE user_id = :userId for "my requests". */
79
+ @ViewColumn()
80
+ user_id: number;
81
+
82
+ @ViewColumn()
83
+ created_by: string;
84
+
85
+ @ViewColumn()
86
+ created_at: Date;
87
+
88
+ @ViewColumn()
89
+ req_user_department_id: string;
90
+
91
+ @ViewColumn()
92
+ req_user_section_id: string;
93
+
94
+ @ViewColumn()
95
+ service_id: string;
96
+
97
+ @ViewColumn()
98
+ sub_service_id: string;
99
+
100
+ @ViewColumn()
101
+ status: SlaRequestStatus | string;
102
+
103
+ @ViewColumn()
104
+ request_id: number;
105
+
106
+ /** Remaining `request_obj` keys after excluding workflow/common duplicates. */
107
+ @ViewColumn()
108
+ request_fields: Record<string, unknown>;
109
+ }
110
+
111
+ /** Flatten view row: fixed columns plus each entry in `request_fields`. */
112
+ export function flattenSlaMyRequestsViewRow(
113
+ row: SlaMyRequestsView
114
+ ): Record<string, unknown> {
115
+ const {
116
+ sla_request_id,
117
+ user_id,
118
+ created_by,
119
+ created_at,
120
+ req_user_department_id,
121
+ req_user_section_id,
122
+ service_id,
123
+ sub_service_id,
124
+ status,
125
+ request_id,
126
+ request_fields,
127
+ } = row;
128
+
129
+ return {
130
+ sla_request_id,
131
+ user_id,
132
+ created_by,
133
+ created_at,
134
+ req_user_department_id,
135
+ req_user_section_id,
136
+ service_id,
137
+ sub_service_id,
138
+ status,
139
+ request_id,
140
+ ...(request_fields ?? {}),
141
+ };
142
+ }