@platform-modules/civil-aviation-authority 2.3.265 → 2.3.267
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.
- package/.env +7 -22
- package/dist/index.d.ts +1 -0
- package/dist/index.js +1 -0
- package/dist/models/AnnualIncrementRequestEmployeeModel.d.ts +2 -1
- package/dist/models/AnnualIncrementRequestEmployeeModel.js +7 -2
- package/dist/models/AnnualIncrementRequestModel.d.ts +2 -1
- package/dist/models/AnnualIncrementRequestModel.js +7 -2
- package/dist/models/EmployeeSecurityDriveOwnerModel.d.ts +13 -0
- package/dist/models/EmployeeSecurityDriveOwnerModel.js +54 -0
- package/dist/models/ITApprovalSettings.d.ts +7 -0
- package/dist/models/ITApprovalSettings.js +40 -0
- package/dist/models/ITServicesTypesMuscatModel.d.ts +6 -0
- package/dist/models/ITServicesTypesMuscatModel.js +34 -0
- package/dist/models/ITServicesTypesSalalahModel.d.ts +6 -0
- package/dist/models/ITServicesTypesSalalahModel.js +34 -0
- package/dist/models/SlaApprovalsViewModel.js +47 -47
- package/dist/models/SlaMyRequestsViewModel.js +50 -50
- package/dist/models/Workflows.d.ts +9 -0
- package/dist/models/Workflows.js +31 -0
- package/package.json +1 -1
- package/scripts/sync-sla-reports-sql.js +98 -94
- package/sql/README.md +21 -25
- package/sql/sla-reports-sync.manifest.json +7 -7
- package/sql/sla_reports_admin_procedures.sql +283 -283
- package/sql/sla_reports_approvals_workbook.sql +383 -383
- package/sql/sla_reports_procedures.sql +874 -874
- package/sql/vw_sla_approvals.sql +108 -108
- package/sql/vw_sla_my_requests.sql +53 -53
- package/src/data-source.ts +517 -517
- package/src/index.ts +496 -495
- package/src/models/AccessCardRequestModel.ts +135 -135
- package/src/models/AccommodationApprovalModel.ts +8 -8
- package/src/models/AccommodationRequestModel.ts +8 -8
- package/src/models/AirportEntryPermitModel.ts +276 -276
- package/src/models/AnnualIncrementRequestEmployeeModel.ts +6 -1
- package/src/models/AnnualIncrementRequestModel.ts +6 -1
- package/src/models/AnnualTrainingPlanRequestModel.ts +153 -153
- package/src/models/AppealAgainstAdministrativeDecisionRequestModel.ts +23 -23
- package/src/models/CAAServices.ts +33 -33
- package/src/models/CAASubServices.ts +33 -33
- package/src/models/CAIRatingMasterModel.ts +39 -39
- package/src/models/CSRMBusinessImpactRatingMasterModel.ts +25 -25
- package/src/models/CSRMLikelihoodMasterModel.ts +25 -25
- package/src/models/CashAllowanceLeaveRequestModel.ts +11 -11
- package/src/models/DepartmentsModel.ts +25 -25
- package/src/models/DocumentDriveModel.ts +28 -28
- package/src/models/DocumentFolderModel.ts +45 -45
- package/src/models/EmployeeSecurityDriveOwnerModel.ts +32 -0
- package/src/models/HotelApprovalModel.ts +83 -83
- package/src/models/HousingContractCancelApprovalModel.ts +64 -64
- package/src/models/HousingContractCancelChatModel.ts +56 -56
- package/src/models/HousingContractRenewalApprovalModel.ts +64 -64
- package/src/models/HousingContractRenewalChatModel.ts +59 -59
- package/src/models/HrServiceRequestModel.ts +193 -193
- package/src/models/ITRequestAttachmentModel.ts +73 -73
- package/src/models/ITRequestChatModel.ts +74 -74
- package/src/models/ItApprovalsModel.ts +84 -84
- package/src/models/ItWorkflowModel.ts +55 -55
- package/src/models/LegalConsultationApprovalModel.ts +65 -65
- package/src/models/MissionTravelPassportExpiryNotificationConfigModel.ts +36 -36
- package/src/models/NotificationModel.ts +89 -89
- package/src/models/PerformanceCyclePeriodModel.ts +26 -26
- package/src/models/PerformanceGoalMasterModel.ts +27 -27
- package/src/models/PerformanceManagementRequestGoalModel.ts +46 -46
- package/src/models/PerformanceManagementRequestModel.ts +14 -14
- package/src/models/PromotionRequestModel.ts +11 -11
- package/src/models/ResidentialUnitRentalApprovalModel.ts +143 -143
- package/src/models/ResidentialUnitRentalChatModel.ts +56 -56
- package/src/models/ResidentialUnitRentalRequestModel.ts +218 -218
- package/src/models/RespondToEnquiriesRequestModel.ts +31 -31
- package/src/models/ServiceExtensionAfter60ApprovalModel.ts +87 -87
- package/src/models/ServiceSlaApprovalModel.ts +64 -64
- package/src/models/ServicesNotificationConfigModel.ts +55 -55
- package/src/models/SkillsEnhancementRequestModel.ts +17 -17
- package/src/models/SlaApprovalsViewModel.ts +135 -135
- package/src/models/SlaMyRequestsViewModel.ts +170 -170
- package/src/models/SlaRequestModel.ts +65 -65
- package/src/models/StudyLeaveRequestModel.ts +144 -144
- package/src/models/TrainingRequestModel.ts +164 -164
- package/src/models/TrainingRoomBookingRequestModel.ts +142 -142
- package/src/models/TrainingRoomNotificationConfigModel.ts +30 -30
- package/src/models/UserSkillModel.ts +56 -56
- package/src/models/role.ts +34 -34
- package/src/models/user.ts +233 -233
- package/src/sla/sla-table-sync.service.ts +90 -90
- package/dist/models/DocumentMetadataModel.d.ts +0 -45
- package/dist/models/DocumentMetadataModel.js +0 -171
- package/dist/models/DocumentationDepartmentsModel.d.ts +0 -13
- package/dist/models/DocumentationDepartmentsModel.js +0 -53
- package/dist/models/FolderModel.d.ts +0 -16
- package/dist/models/FolderModel.js +0 -85
- package/dist/models/ImportExportMaterialModels.d.ts +0 -92
- package/dist/models/ImportExportMaterialModels.js +0 -307
- package/dist/models/PermissionModel.d.ts +0 -18
- package/dist/models/PermissionModel.js +0 -68
- package/dist/models/SecurityAccessApprovalModel.d.ts +0 -23
- package/dist/models/SecurityAccessApprovalModel.js +0 -82
- package/dist/models/SecurityAccessAttachmentModel.d.ts +0 -12
- package/dist/models/SecurityAccessAttachmentModel.js +0 -56
- package/dist/models/SecurityAccessChatModel.d.ts +0 -12
- package/dist/models/SecurityAccessChatModel.js +0 -56
- package/dist/models/SecurityAccessRequestModel.d.ts +0 -25
- package/dist/models/SecurityAccessRequestModel.js +0 -80
- package/dist/models/SecurityAccessWorkflowModel.d.ts +0 -24
- package/dist/models/SecurityAccessWorkflowModel.js +0 -84
- package/dist/models/ServiceExtensionAfterAge60Models.d.ts +0 -93
- package/dist/models/ServiceExtensionAfterAge60Models.js +0 -312
- package/dist/models/UUIDBaseModel.d.ts +0 -14
- package/dist/models/UUIDBaseModel.js +0 -66
- package/dist/models/WorkingHoursExtensionModels.d.ts +0 -88
- package/dist/models/WorkingHoursExtensionModels.js +0 -295
|
@@ -1,94 +1,98 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Applies SLA report views + stored procedures to PostgreSQL (idempotent CREATE OR REPLACE).
|
|
3
|
-
*
|
|
4
|
-
* Env (shared_models/.env or Reports_Service/.env):
|
|
5
|
-
* DB_HOST / TYPEORM_HOST
|
|
6
|
-
* DB_PORT / TYPEORM_PORT
|
|
7
|
-
* DB_USER / TYPEORM_USERNAME
|
|
8
|
-
* DB_PASS / TYPEORM_PASSWORD
|
|
9
|
-
* DB_NAME / TYPEORM_DATABASE
|
|
10
|
-
*
|
|
11
|
-
* Usage:
|
|
12
|
-
* node scripts/sync-sla-reports-sql.js
|
|
13
|
-
* npm run sync:sla-sql (from shared_models)
|
|
14
|
-
*/
|
|
15
|
-
|
|
16
|
-
const fs = require('fs');
|
|
17
|
-
const path = require('path');
|
|
18
|
-
const { Client } = require('pg');
|
|
19
|
-
|
|
20
|
-
function loadEnvFiles() {
|
|
21
|
-
const dotenv = require('dotenv');
|
|
22
|
-
const
|
|
23
|
-
const
|
|
24
|
-
const
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
const
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
const
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
1
|
+
/**
|
|
2
|
+
* Applies SLA report views + stored procedures to PostgreSQL (idempotent CREATE OR REPLACE).
|
|
3
|
+
*
|
|
4
|
+
* Env (shared_models/.env or Reports_Service/.env):
|
|
5
|
+
* DB_HOST / TYPEORM_HOST
|
|
6
|
+
* DB_PORT / TYPEORM_PORT
|
|
7
|
+
* DB_USER / TYPEORM_USERNAME
|
|
8
|
+
* DB_PASS / TYPEORM_PASSWORD
|
|
9
|
+
* DB_NAME / TYPEORM_DATABASE
|
|
10
|
+
*
|
|
11
|
+
* Usage:
|
|
12
|
+
* node scripts/sync-sla-reports-sql.js
|
|
13
|
+
* npm run sync:sla-sql (from shared_models)
|
|
14
|
+
*/
|
|
15
|
+
|
|
16
|
+
const fs = require('fs');
|
|
17
|
+
const path = require('path');
|
|
18
|
+
const { Client } = require('pg');
|
|
19
|
+
|
|
20
|
+
function loadEnvFiles() {
|
|
21
|
+
const dotenv = require('dotenv');
|
|
22
|
+
const packageRoot = path.resolve(__dirname, '..');
|
|
23
|
+
const cwdEnv = path.join(process.cwd(), '.env');
|
|
24
|
+
const packageEnv = path.join(packageRoot, '.env');
|
|
25
|
+
const reportsEnv = path.resolve(packageRoot, '..', 'Reports_Service', '.env');
|
|
26
|
+
|
|
27
|
+
if (fs.existsSync(cwdEnv)) {
|
|
28
|
+
dotenv.config({ path: cwdEnv });
|
|
29
|
+
}
|
|
30
|
+
if (fs.existsSync(packageEnv)) {
|
|
31
|
+
dotenv.config({ path: packageEnv, override: true });
|
|
32
|
+
}
|
|
33
|
+
if (fs.existsSync(reportsEnv)) {
|
|
34
|
+
dotenv.config({ path: reportsEnv, override: true });
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
function getDbConfig() {
|
|
39
|
+
const host = (process.env.TYPEORM_HOST || process.env.DB_HOST || '').trim();
|
|
40
|
+
const port = parseInt(process.env.TYPEORM_PORT || process.env.DB_PORT || '5432', 10);
|
|
41
|
+
const user = (process.env.TYPEORM_USERNAME || process.env.DB_USER || '').trim();
|
|
42
|
+
const password = process.env.TYPEORM_PASSWORD || process.env.DB_PASS || '';
|
|
43
|
+
const database = (process.env.TYPEORM_DATABASE || process.env.DB_NAME || '').trim();
|
|
44
|
+
|
|
45
|
+
if (!host || !user || !database) {
|
|
46
|
+
throw new Error(
|
|
47
|
+
'Missing DB config. Set TYPEORM_* in Reports_Service/.env or DB_* in shared_models/.env'
|
|
48
|
+
);
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
return { host, port, user, password, database };
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
async function main() {
|
|
55
|
+
const skipSync = process.argv.includes('--skip');
|
|
56
|
+
if (skipSync || process.env.SKIP_SLA_SQL_SYNC === 'true') {
|
|
57
|
+
console.log('[sync-sla-reports-sql] skipped (SKIP_SLA_SQL_SYNC or --skip)');
|
|
58
|
+
return;
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
loadEnvFiles();
|
|
62
|
+
const config = getDbConfig();
|
|
63
|
+
const sqlDir = path.join(__dirname, '..', 'sql');
|
|
64
|
+
const manifestPath = path.join(sqlDir, 'sla-reports-sync.manifest.json');
|
|
65
|
+
|
|
66
|
+
if (!fs.existsSync(manifestPath)) {
|
|
67
|
+
throw new Error(`Manifest not found: ${manifestPath}`);
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
const files = JSON.parse(fs.readFileSync(manifestPath, 'utf8'));
|
|
71
|
+
if (!Array.isArray(files) || files.length === 0) {
|
|
72
|
+
throw new Error('sla-reports-sync.manifest.json must be a non-empty array');
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
const client = new Client(config);
|
|
76
|
+
await client.connect();
|
|
77
|
+
console.log(`[sync-sla-reports-sql] connected to ${config.host}/${config.database}`);
|
|
78
|
+
|
|
79
|
+
try {
|
|
80
|
+
for (const file of files) {
|
|
81
|
+
const filePath = path.join(sqlDir, file);
|
|
82
|
+
if (!fs.existsSync(filePath)) {
|
|
83
|
+
throw new Error(`SQL file missing: ${filePath}`);
|
|
84
|
+
}
|
|
85
|
+
const sql = fs.readFileSync(filePath, 'utf8');
|
|
86
|
+
await client.query(sql);
|
|
87
|
+
console.log(`[sync-sla-reports-sql] applied ${file}`);
|
|
88
|
+
}
|
|
89
|
+
console.log('[sync-sla-reports-sql] done');
|
|
90
|
+
} finally {
|
|
91
|
+
await client.end();
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
main().catch((err) => {
|
|
96
|
+
console.error('[sync-sla-reports-sql] failed:', err.message);
|
|
97
|
+
process.exit(1);
|
|
98
|
+
});
|
package/sql/README.md
CHANGED
|
@@ -1,25 +1,21 @@
|
|
|
1
|
-
# SLA reports — database objects
|
|
2
|
-
|
|
3
|
-
Applied in order by `npm run sync:sla-sql` (see `sla-reports-sync.manifest.json`).
|
|
4
|
-
|
|
5
|
-
| File | Description |
|
|
6
|
-
|------|-------------|
|
|
7
|
-
| `vw_sla_my_requests.sql` | My-requests view |
|
|
8
|
-
| `vw_sla_approvals.sql` | Approvals view |
|
|
9
|
-
| `sla_reports_procedures.sql` | User SLA report functions + Excel helpers |
|
|
10
|
-
| `sla_reports_approvals_workbook.sql` | Approvals Excel workbook (Requests + Approvals per sub-service) |
|
|
11
|
-
| `sla_reports_admin_procedures.sql` | Admin SLA report functions (requires procedures file) |
|
|
12
|
-
|
|
13
|
-
From **shared_models
|
|
14
|
-
|
|
15
|
-
```bash
|
|
16
|
-
npm run sync:sla-sql
|
|
17
|
-
```
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
npm run sync:sla-sql
|
|
23
|
-
```
|
|
24
|
-
|
|
25
|
-
`npm run dev` in Reports_Service runs sync automatically before nodemon.
|
|
1
|
+
# SLA reports — database objects
|
|
2
|
+
|
|
3
|
+
Applied in order by `npm run sync:sla-sql` (see `sla-reports-sync.manifest.json`).
|
|
4
|
+
|
|
5
|
+
| File | Description |
|
|
6
|
+
|------|-------------|
|
|
7
|
+
| `vw_sla_my_requests.sql` | My-requests view |
|
|
8
|
+
| `vw_sla_approvals.sql` | Approvals view |
|
|
9
|
+
| `sla_reports_procedures.sql` | User SLA report functions + Excel helpers |
|
|
10
|
+
| `sla_reports_approvals_workbook.sql` | Approvals Excel workbook (Requests + Approvals per sub-service) |
|
|
11
|
+
| `sla_reports_admin_procedures.sql` | Admin SLA report functions (requires procedures file) |
|
|
12
|
+
|
|
13
|
+
From **shared_models** (uses `shared_models/.env`, or `Reports_Service/.env` when present in monorepo):
|
|
14
|
+
|
|
15
|
+
```bash
|
|
16
|
+
cd shared_models && npm run sync:sla-sql
|
|
17
|
+
```
|
|
18
|
+
|
|
19
|
+
Skip sync: `SKIP_SLA_SQL_SYNC=true` or pass `--skip`.
|
|
20
|
+
|
|
21
|
+
Reports_Service does not run SQL sync — apply these objects before using the reports API (local dev, CI, or deployment pipeline).
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
[
|
|
2
|
-
"vw_sla_my_requests.sql",
|
|
3
|
-
"vw_sla_approvals.sql",
|
|
4
|
-
"sla_reports_procedures.sql",
|
|
5
|
-
"sla_reports_approvals_workbook.sql",
|
|
6
|
-
"sla_reports_admin_procedures.sql"
|
|
7
|
-
]
|
|
1
|
+
[
|
|
2
|
+
"vw_sla_my_requests.sql",
|
|
3
|
+
"vw_sla_approvals.sql",
|
|
4
|
+
"sla_reports_procedures.sql",
|
|
5
|
+
"sla_reports_approvals_workbook.sql",
|
|
6
|
+
"sla_reports_admin_procedures.sql"
|
|
7
|
+
]
|