@platform-modules/civil-aviation-authority 2.3.264 → 2.3.266

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 (80) hide show
  1. package/.env +0 -15
  2. package/dist/models/AnnualIncrementRequestEmployeeModel.d.ts +2 -1
  3. package/dist/models/AnnualIncrementRequestEmployeeModel.js +7 -2
  4. package/dist/models/AnnualIncrementRequestModel.d.ts +2 -1
  5. package/dist/models/AnnualIncrementRequestModel.js +7 -2
  6. package/dist/models/SlaApprovalsViewModel.js +47 -47
  7. package/dist/models/SlaMyRequestsViewModel.js +50 -50
  8. package/package.json +3 -2
  9. package/scripts/sync-sla-reports-sql.js +98 -0
  10. package/sql/README.md +21 -0
  11. package/sql/sla-reports-sync.manifest.json +7 -0
  12. package/sql/sla_reports_admin_procedures.sql +283 -0
  13. package/sql/sla_reports_approvals_workbook.sql +383 -0
  14. package/sql/sla_reports_procedures.sql +874 -0
  15. package/sql/vw_sla_approvals.sql +108 -108
  16. package/sql/vw_sla_my_requests.sql +53 -54
  17. package/src/data-source.ts +517 -517
  18. package/src/index.ts +495 -495
  19. package/src/models/AccessCardRequestModel.ts +135 -135
  20. package/src/models/AirportEntryPermitModel.ts +276 -276
  21. package/src/models/AnnualIncrementRequestEmployeeModel.ts +6 -1
  22. package/src/models/AnnualIncrementRequestModel.ts +6 -1
  23. package/src/models/AnnualTrainingPlanRequestModel.ts +153 -153
  24. package/src/models/DepartmentsModel.ts +25 -25
  25. package/src/models/DocumentDriveModel.ts +28 -28
  26. package/src/models/DocumentFolderModel.ts +45 -45
  27. package/src/models/HotelApprovalModel.ts +83 -83
  28. package/src/models/HousingContractCancelApprovalModel.ts +64 -64
  29. package/src/models/HousingContractCancelChatModel.ts +56 -56
  30. package/src/models/HousingContractRenewalApprovalModel.ts +64 -64
  31. package/src/models/HousingContractRenewalChatModel.ts +59 -59
  32. package/src/models/ITRequestAttachmentModel.ts +73 -73
  33. package/src/models/ITRequestChatModel.ts +74 -74
  34. package/src/models/ItApprovalsModel.ts +84 -84
  35. package/src/models/ItWorkflowModel.ts +55 -55
  36. package/src/models/LegalConsultationApprovalModel.ts +65 -65
  37. package/src/models/MissionTravelPassportExpiryNotificationConfigModel.ts +36 -36
  38. package/src/models/NotificationModel.ts +89 -89
  39. package/src/models/ResidentialUnitRentalApprovalModel.ts +143 -143
  40. package/src/models/ResidentialUnitRentalChatModel.ts +56 -56
  41. package/src/models/ResidentialUnitRentalRequestModel.ts +218 -218
  42. package/src/models/ServiceExtensionAfter60ApprovalModel.ts +87 -87
  43. package/src/models/ServiceSlaApprovalModel.ts +64 -64
  44. package/src/models/ServicesNotificationConfigModel.ts +55 -55
  45. package/src/models/SlaApprovalsViewModel.ts +135 -135
  46. package/src/models/SlaMyRequestsViewModel.ts +170 -170
  47. package/src/models/SlaRequestModel.ts +65 -65
  48. package/src/models/StudyLeaveRequestModel.ts +144 -144
  49. package/src/models/TrainingRequestModel.ts +164 -164
  50. package/src/models/TrainingRoomBookingRequestModel.ts +142 -142
  51. package/src/models/TrainingRoomNotificationConfigModel.ts +30 -30
  52. package/src/models/role.ts +34 -34
  53. package/src/models/user.ts +233 -233
  54. package/src/sla/sla-table-sync.service.ts +90 -90
  55. package/dist/models/DocumentMetadataModel.d.ts +0 -45
  56. package/dist/models/DocumentMetadataModel.js +0 -171
  57. package/dist/models/DocumentationDepartmentsModel.d.ts +0 -13
  58. package/dist/models/DocumentationDepartmentsModel.js +0 -53
  59. package/dist/models/FolderModel.d.ts +0 -16
  60. package/dist/models/FolderModel.js +0 -85
  61. package/dist/models/ImportExportMaterialModels.d.ts +0 -92
  62. package/dist/models/ImportExportMaterialModels.js +0 -307
  63. package/dist/models/PermissionModel.d.ts +0 -18
  64. package/dist/models/PermissionModel.js +0 -68
  65. package/dist/models/SecurityAccessApprovalModel.d.ts +0 -23
  66. package/dist/models/SecurityAccessApprovalModel.js +0 -82
  67. package/dist/models/SecurityAccessAttachmentModel.d.ts +0 -12
  68. package/dist/models/SecurityAccessAttachmentModel.js +0 -56
  69. package/dist/models/SecurityAccessChatModel.d.ts +0 -12
  70. package/dist/models/SecurityAccessChatModel.js +0 -56
  71. package/dist/models/SecurityAccessRequestModel.d.ts +0 -25
  72. package/dist/models/SecurityAccessRequestModel.js +0 -80
  73. package/dist/models/SecurityAccessWorkflowModel.d.ts +0 -24
  74. package/dist/models/SecurityAccessWorkflowModel.js +0 -84
  75. package/dist/models/ServiceExtensionAfterAge60Models.d.ts +0 -93
  76. package/dist/models/ServiceExtensionAfterAge60Models.js +0 -312
  77. package/dist/models/UUIDBaseModel.d.ts +0 -14
  78. package/dist/models/UUIDBaseModel.js +0 -66
  79. package/dist/models/WorkingHoursExtensionModels.d.ts +0 -88
  80. package/dist/models/WorkingHoursExtensionModels.js +0 -295
@@ -1,170 +1,170 @@
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
- "created_by",
21
- "service_id",
22
- "sub_service_id",
23
- "attachments",
24
- "is_deleted",
25
- "sla_request",
26
- "sla_request_id",
27
- ] as const;
28
-
29
- const VW_SLA_MY_REQUESTS_SQL = `
30
- SELECT
31
- sr.id AS sla_request_id,
32
- sr.user_id,
33
- sr.service_id AS service_id,
34
- sr.sub_service_id AS sub_service_id,
35
- TRIM(COALESCE(creator.employee_name, ''))::TEXT AS created_by,
36
- sr.created_at,
37
- TRIM(COALESCE(dept.department_name, ''))::TEXT AS req_user_department_id,
38
- TRIM(COALESCE(sec.section_name, ''))::TEXT AS req_user_section_id,
39
- TRIM(COALESCE(svc.name, ''))::TEXT AS service_name,
40
- TRIM(COALESCE(subsvc.sub_service_name, ''))::TEXT AS sub_service_name,
41
- sr.status::TEXT AS status,
42
- sr.request_id,
43
- (
44
- COALESCE(sr.request_obj, '{}'::jsonb)
45
- - 'id'
46
- - 'status'
47
- - 'role_id'
48
- - 'user_id'
49
- - 'createdBy'
50
- - 'created_at'
51
- - 'updated_by'
52
- - 'updated_at'
53
- - 'req_user_department_id'
54
- - 'workflow_execution_id'
55
- - 'department_id'
56
- - 'req_user_section_id'
57
- - 'service_type_id'
58
- - 'service_type'
59
- - 'created_by'
60
- - 'service_id'
61
- - 'sub_service_id'
62
- - 'attachments'
63
- - 'is_deleted'
64
- - 'sla_request'
65
- - 'sla_request_id'
66
- ) AS request_fields
67
- FROM sla_requests sr
68
- LEFT JOIN users creator
69
- ON creator.id = sr.created_by AND COALESCE(creator.is_deleted, false) = false
70
- LEFT JOIN departments dept
71
- ON dept.id = sr.req_user_department_id AND COALESCE(dept.is_deleted, false) = false
72
- LEFT JOIN sections sec
73
- ON sec.id = sr.req_user_section_id AND COALESCE(sec.is_deleted, false) = false
74
- LEFT JOIN caa_services svc
75
- ON svc.id = sr.service_id AND COALESCE(svc.is_deleted, false) = false
76
- LEFT JOIN caa_sub_services subsvc
77
- ON subsvc.id = sr.sub_service_id AND COALESCE(subsvc.is_deleted, false) = false
78
- WHERE COALESCE(sr.is_deleted, false) = false
79
- `;
80
-
81
- /**
82
- * Read-only view for SLA "my requests" listings.
83
- * Display-name columns reuse sla_requests field names; values come from joined lookup tables.
84
- * Service-specific payload keys live in `request_fields` (filtered `request_obj`).
85
- */
86
- @ViewEntity({
87
- name: "vw_sla_my_requests",
88
- expression: VW_SLA_MY_REQUESTS_SQL,
89
- })
90
- export class SlaMyRequestsView {
91
- @ViewColumn()
92
- sla_request_id: number;
93
-
94
- /** Request owner (`sla_requests.user_id`) — filter with WHERE user_id = :userId for "my requests". */
95
- @ViewColumn()
96
- user_id: number;
97
-
98
- /** Numeric caa_services.id used for filtering. */
99
- @ViewColumn()
100
- service_id: number;
101
-
102
- /** Numeric caa_sub_services.id used for filtering. */
103
- @ViewColumn()
104
- sub_service_id: number;
105
-
106
- @ViewColumn()
107
- created_by: string;
108
-
109
- @ViewColumn()
110
- created_at: Date;
111
-
112
- @ViewColumn()
113
- req_user_department_id: string;
114
-
115
- @ViewColumn()
116
- req_user_section_id: string;
117
-
118
- @ViewColumn()
119
- service_name: string;
120
-
121
- @ViewColumn()
122
- sub_service_name: string;
123
-
124
- @ViewColumn()
125
- status: SlaRequestStatus | string;
126
-
127
- @ViewColumn()
128
- request_id: number;
129
-
130
- /** Remaining `request_obj` keys after excluding workflow/common duplicates. */
131
- @ViewColumn()
132
- request_fields: Record<string, unknown>;
133
- }
134
-
135
- /** Flatten view row: fixed columns plus each entry in `request_fields`. */
136
- export function flattenSlaMyRequestsViewRow(
137
- row: SlaMyRequestsView
138
- ): Record<string, unknown> {
139
- const {
140
- sla_request_id,
141
- user_id,
142
- service_id,
143
- sub_service_id,
144
- created_by,
145
- created_at,
146
- req_user_department_id,
147
- req_user_section_id,
148
- service_name,
149
- sub_service_name,
150
- status,
151
- request_id,
152
- request_fields,
153
- } = row;
154
-
155
- return {
156
- sla_request_id,
157
- user_id,
158
- service_id,
159
- sub_service_id,
160
- created_by,
161
- created_at,
162
- req_user_department_id,
163
- req_user_section_id,
164
- service_name,
165
- sub_service_name,
166
- status,
167
- request_id,
168
- ...(request_fields ?? {}),
169
- };
170
- }
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
+ "created_by",
21
+ "service_id",
22
+ "sub_service_id",
23
+ "attachments",
24
+ "is_deleted",
25
+ "sla_request",
26
+ "sla_request_id",
27
+ ] as const;
28
+
29
+ const VW_SLA_MY_REQUESTS_SQL = `
30
+ SELECT
31
+ sr.id AS sla_request_id,
32
+ sr.user_id,
33
+ sr.service_id AS service_id,
34
+ sr.sub_service_id AS sub_service_id,
35
+ TRIM(COALESCE(creator.employee_name, ''))::TEXT AS created_by,
36
+ sr.created_at,
37
+ TRIM(COALESCE(dept.department_name, ''))::TEXT AS req_user_department_id,
38
+ TRIM(COALESCE(sec.section_name, ''))::TEXT AS req_user_section_id,
39
+ TRIM(COALESCE(svc.name, ''))::TEXT AS service_name,
40
+ TRIM(COALESCE(subsvc.sub_service_name, ''))::TEXT AS sub_service_name,
41
+ sr.status::TEXT AS status,
42
+ sr.request_id,
43
+ (
44
+ COALESCE(sr.request_obj, '{}'::jsonb)
45
+ - 'id'
46
+ - 'status'
47
+ - 'role_id'
48
+ - 'user_id'
49
+ - 'createdBy'
50
+ - 'created_at'
51
+ - 'updated_by'
52
+ - 'updated_at'
53
+ - 'req_user_department_id'
54
+ - 'workflow_execution_id'
55
+ - 'department_id'
56
+ - 'req_user_section_id'
57
+ - 'service_type_id'
58
+ - 'service_type'
59
+ - 'created_by'
60
+ - 'service_id'
61
+ - 'sub_service_id'
62
+ - 'attachments'
63
+ - 'is_deleted'
64
+ - 'sla_request'
65
+ - 'sla_request_id'
66
+ ) AS request_fields
67
+ FROM sla_requests sr
68
+ LEFT JOIN users creator
69
+ ON creator.id = sr.created_by AND COALESCE(creator.is_deleted, false) = false
70
+ LEFT JOIN departments dept
71
+ ON dept.id = sr.req_user_department_id AND COALESCE(dept.is_deleted, false) = false
72
+ LEFT JOIN sections sec
73
+ ON sec.id = sr.req_user_section_id AND COALESCE(sec.is_deleted, false) = false
74
+ LEFT JOIN caa_services svc
75
+ ON svc.id = sr.service_id AND COALESCE(svc.is_deleted, false) = false
76
+ LEFT JOIN caa_sub_services subsvc
77
+ ON subsvc.id = sr.sub_service_id AND COALESCE(subsvc.is_deleted, false) = false
78
+ WHERE COALESCE(sr.is_deleted, false) = false
79
+ `;
80
+
81
+ /**
82
+ * Read-only view for SLA "my requests" listings.
83
+ * Display-name columns reuse sla_requests field names; values come from joined lookup tables.
84
+ * Service-specific payload keys live in `request_fields` (filtered `request_obj`).
85
+ */
86
+ @ViewEntity({
87
+ name: "vw_sla_my_requests",
88
+ expression: VW_SLA_MY_REQUESTS_SQL,
89
+ })
90
+ export class SlaMyRequestsView {
91
+ @ViewColumn()
92
+ sla_request_id: number;
93
+
94
+ /** Request owner (`sla_requests.user_id`) — filter with WHERE user_id = :userId for "my requests". */
95
+ @ViewColumn()
96
+ user_id: number;
97
+
98
+ /** Numeric caa_services.id used for filtering. */
99
+ @ViewColumn()
100
+ service_id: number;
101
+
102
+ /** Numeric caa_sub_services.id used for filtering. */
103
+ @ViewColumn()
104
+ sub_service_id: number;
105
+
106
+ @ViewColumn()
107
+ created_by: string;
108
+
109
+ @ViewColumn()
110
+ created_at: Date;
111
+
112
+ @ViewColumn()
113
+ req_user_department_id: string;
114
+
115
+ @ViewColumn()
116
+ req_user_section_id: string;
117
+
118
+ @ViewColumn()
119
+ service_name: string;
120
+
121
+ @ViewColumn()
122
+ sub_service_name: string;
123
+
124
+ @ViewColumn()
125
+ status: SlaRequestStatus | string;
126
+
127
+ @ViewColumn()
128
+ request_id: number;
129
+
130
+ /** Remaining `request_obj` keys after excluding workflow/common duplicates. */
131
+ @ViewColumn()
132
+ request_fields: Record<string, unknown>;
133
+ }
134
+
135
+ /** Flatten view row: fixed columns plus each entry in `request_fields`. */
136
+ export function flattenSlaMyRequestsViewRow(
137
+ row: SlaMyRequestsView
138
+ ): Record<string, unknown> {
139
+ const {
140
+ sla_request_id,
141
+ user_id,
142
+ service_id,
143
+ sub_service_id,
144
+ created_by,
145
+ created_at,
146
+ req_user_department_id,
147
+ req_user_section_id,
148
+ service_name,
149
+ sub_service_name,
150
+ status,
151
+ request_id,
152
+ request_fields,
153
+ } = row;
154
+
155
+ return {
156
+ sla_request_id,
157
+ user_id,
158
+ service_id,
159
+ sub_service_id,
160
+ created_by,
161
+ created_at,
162
+ req_user_department_id,
163
+ req_user_section_id,
164
+ service_name,
165
+ sub_service_name,
166
+ status,
167
+ request_id,
168
+ ...(request_fields ?? {}),
169
+ };
170
+ }
@@ -1,65 +1,65 @@
1
- import { Column, Entity, Index } from "typeorm";
2
- import { BaseModel } from "./BaseModel";
3
-
4
- /** Workflow status for generic SLA-tracked service requests. */
5
- export enum SlaRequestStatus {
6
- PENDING = "Pending",
7
- IN_PROGRESS = "In Progress",
8
- APPROVED = "Approved",
9
- REJECTED = "Rejected"
10
- }
11
-
12
- /**
13
- * Cross-service SLA request: common routing/workflow fields plus `request_obj`
14
- * for service-specific payload (same common columns as `ServiceExtensionAfter60Request` lines 13–37).
15
- */
16
- @Entity({ name: "sla_requests" })
17
- /** Non-unique: same native `request_id` may be inserted more than once (e.g. workflow retries); scope in queries with service_id / workflow_execution_id as needed. */
18
- @Index("idx_sla_requests_request_id", ["request_id"])
19
- @Index("idx_sla_requests_user_id", ["user_id"])
20
- @Index("idx_sla_requests_service_subservice", ["service_id", "sub_service_id"])
21
- @Index("idx_sla_requests_workflow_execution_id", ["workflow_execution_id"])
22
- @Index("idx_sla_requests_status", ["status"])
23
- export class SlaRequest extends BaseModel {
24
- @Column({ type: "int", nullable: true })
25
- req_user_department_id: number | null;
26
-
27
- @Column({ type: "int", nullable: true })
28
- req_user_section_id: number | null;
29
-
30
- @Column({ type: "int", nullable: true })
31
- service_id: number | null;
32
-
33
- @Column({ type: "int", nullable: true })
34
- sub_service_id: number | null;
35
-
36
- @Column({ type: "int", nullable: false })
37
- user_id: number;
38
-
39
- @Column({
40
- type: "enum",
41
- enum: SlaRequestStatus,
42
- default: SlaRequestStatus.PENDING,
43
- nullable: false
44
- })
45
- status: SlaRequestStatus;
46
-
47
- @Column({ type: "varchar", length: 255, nullable: true })
48
- workflow_execution_id: string | null;
49
-
50
- /**
51
- * Native service request PK this SLA row tracks (non-unique index; scope with service_id/sub_service_id in queries).
52
- */
53
- @Column({ type: "int", nullable: false })
54
- request_id: number;
55
-
56
- /** Service-specific fields as JSON (shape defined per service / sub_service). */
57
- @Column({ type: "jsonb", nullable: false, default: () => "'{}'::jsonb" })
58
- request_obj: Record<string, unknown>;
59
-
60
- constructor() {
61
- super();
62
- this.request_id = 0;
63
- this.request_obj = {};
64
- }
65
- }
1
+ import { Column, Entity, Index } from "typeorm";
2
+ import { BaseModel } from "./BaseModel";
3
+
4
+ /** Workflow status for generic SLA-tracked service requests. */
5
+ export enum SlaRequestStatus {
6
+ PENDING = "Pending",
7
+ IN_PROGRESS = "In Progress",
8
+ APPROVED = "Approved",
9
+ REJECTED = "Rejected"
10
+ }
11
+
12
+ /**
13
+ * Cross-service SLA request: common routing/workflow fields plus `request_obj`
14
+ * for service-specific payload (same common columns as `ServiceExtensionAfter60Request` lines 13–37).
15
+ */
16
+ @Entity({ name: "sla_requests" })
17
+ /** Non-unique: same native `request_id` may be inserted more than once (e.g. workflow retries); scope in queries with service_id / workflow_execution_id as needed. */
18
+ @Index("idx_sla_requests_request_id", ["request_id"])
19
+ @Index("idx_sla_requests_user_id", ["user_id"])
20
+ @Index("idx_sla_requests_service_subservice", ["service_id", "sub_service_id"])
21
+ @Index("idx_sla_requests_workflow_execution_id", ["workflow_execution_id"])
22
+ @Index("idx_sla_requests_status", ["status"])
23
+ export class SlaRequest extends BaseModel {
24
+ @Column({ type: "int", nullable: true })
25
+ req_user_department_id: number | null;
26
+
27
+ @Column({ type: "int", nullable: true })
28
+ req_user_section_id: number | null;
29
+
30
+ @Column({ type: "int", nullable: true })
31
+ service_id: number | null;
32
+
33
+ @Column({ type: "int", nullable: true })
34
+ sub_service_id: number | null;
35
+
36
+ @Column({ type: "int", nullable: false })
37
+ user_id: number;
38
+
39
+ @Column({
40
+ type: "enum",
41
+ enum: SlaRequestStatus,
42
+ default: SlaRequestStatus.PENDING,
43
+ nullable: false
44
+ })
45
+ status: SlaRequestStatus;
46
+
47
+ @Column({ type: "varchar", length: 255, nullable: true })
48
+ workflow_execution_id: string | null;
49
+
50
+ /**
51
+ * Native service request PK this SLA row tracks (non-unique index; scope with service_id/sub_service_id in queries).
52
+ */
53
+ @Column({ type: "int", nullable: false })
54
+ request_id: number;
55
+
56
+ /** Service-specific fields as JSON (shape defined per service / sub_service). */
57
+ @Column({ type: "jsonb", nullable: false, default: () => "'{}'::jsonb" })
58
+ request_obj: Record<string, unknown>;
59
+
60
+ constructor() {
61
+ super();
62
+ this.request_id = 0;
63
+ this.request_obj = {};
64
+ }
65
+ }