@platform-modules/civil-aviation-authority 2.3.85 → 2.3.87
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/dist/models/DutyMissionRequestModel.d.ts +3 -1
- package/dist/models/DutyMissionRequestModel.js +12 -2
- package/dist/models/RequestForCoverageRequestModel.d.ts +4 -2
- package/dist/models/RequestForCoverageRequestModel.js +11 -5
- package/dist/models/SecurityThreatRequestModel.d.ts +9 -0
- package/dist/models/SecurityThreatRequestModel.js +36 -0
- package/package.json +1 -1
- package/src/models/DutyMissionRequestModel.ts +10 -0
- package/src/models/RequestForCoverageRequestModel.ts +11 -4
- package/src/models/SecurityThreatRequestModel.ts +28 -0
|
@@ -57,10 +57,12 @@ export declare class DutyMissionRequests extends BaseModel {
|
|
|
57
57
|
travel_start_date: Date;
|
|
58
58
|
travel_return_date: Date;
|
|
59
59
|
allowance_percentage: string | null;
|
|
60
|
+
sponsored_company_allowance_amount: string | null;
|
|
61
|
+
sponsored_total_company_amount: number | null;
|
|
60
62
|
air_ticket_required: AirTicketRequired | null;
|
|
61
63
|
vehicle_required: VehicleRequired | null;
|
|
62
64
|
remarks: string | null;
|
|
63
65
|
decision_number: string | null;
|
|
64
66
|
decision_date: Date | null;
|
|
65
|
-
constructor(req_user_department_id: number | null, req_user_section_id: number | null, service_id: number, sub_service_id: number, user_id: number, trip_type: TripType, choose_type: ChooseType, mission_sponsored_by: MissionSponsoredBy, mission_purpose: string, mission_number: string, mission_start_date: Date, mission_end_date: Date, travelling_area_from: string, travelling_area_to: string, from_country: string, to_country: string, travel_place: string, travel_start_date: Date, travel_return_date: Date, status: DutyMissionStatus, request_id?: string | null, mission_id?: string | null, mission_days?: number | null, distance?: string | null, if_sponsored?: string | null, allowance_percentage?: string | null, air_ticket_required?: AirTicketRequired | null, vehicle_required?: VehicleRequired | null, remarks?: string | null, decision_number?: string | null, decision_date?: Date | null, workflow_execution_id?: string | null);
|
|
67
|
+
constructor(req_user_department_id: number | null, req_user_section_id: number | null, service_id: number, sub_service_id: number, user_id: number, trip_type: TripType, choose_type: ChooseType, mission_sponsored_by: MissionSponsoredBy, mission_purpose: string, mission_number: string, mission_start_date: Date, mission_end_date: Date, travelling_area_from: string, travelling_area_to: string, from_country: string, to_country: string, travel_place: string, travel_start_date: Date, travel_return_date: Date, status: DutyMissionStatus, request_id?: string | null, mission_id?: string | null, mission_days?: number | null, distance?: string | null, if_sponsored?: string | null, allowance_percentage?: string | null, air_ticket_required?: AirTicketRequired | null, vehicle_required?: VehicleRequired | null, remarks?: string | null, decision_number?: string | null, decision_date?: Date | null, workflow_execution_id?: string | null, sponsored_company_allowance_amount?: string | null, sponsored_total_company_amount?: number | null);
|
|
66
68
|
}
|
|
@@ -49,7 +49,7 @@ var DutyMissionStatus;
|
|
|
49
49
|
DutyMissionStatus["REJECTED"] = "Rejected";
|
|
50
50
|
})(DutyMissionStatus || (exports.DutyMissionStatus = DutyMissionStatus = {}));
|
|
51
51
|
let DutyMissionRequests = class DutyMissionRequests extends BaseModel_1.BaseModel {
|
|
52
|
-
constructor(req_user_department_id, req_user_section_id, service_id, sub_service_id, user_id, trip_type, choose_type, mission_sponsored_by, mission_purpose, mission_number, mission_start_date, mission_end_date, travelling_area_from, travelling_area_to, from_country, to_country, travel_place, travel_start_date, travel_return_date, status, request_id, mission_id, mission_days, distance, if_sponsored, allowance_percentage, air_ticket_required, vehicle_required, remarks, decision_number, decision_date, workflow_execution_id) {
|
|
52
|
+
constructor(req_user_department_id, req_user_section_id, service_id, sub_service_id, user_id, trip_type, choose_type, mission_sponsored_by, mission_purpose, mission_number, mission_start_date, mission_end_date, travelling_area_from, travelling_area_to, from_country, to_country, travel_place, travel_start_date, travel_return_date, status, request_id, mission_id, mission_days, distance, if_sponsored, allowance_percentage, air_ticket_required, vehicle_required, remarks, decision_number, decision_date, workflow_execution_id, sponsored_company_allowance_amount, sponsored_total_company_amount) {
|
|
53
53
|
super();
|
|
54
54
|
this.req_user_department_id = req_user_department_id ?? null;
|
|
55
55
|
this.req_user_section_id = req_user_section_id ?? null;
|
|
@@ -83,6 +83,8 @@ let DutyMissionRequests = class DutyMissionRequests extends BaseModel_1.BaseMode
|
|
|
83
83
|
this.decision_number = decision_number ?? null;
|
|
84
84
|
this.decision_date = decision_date ?? null;
|
|
85
85
|
this.workflow_execution_id = workflow_execution_id ?? null;
|
|
86
|
+
this.sponsored_company_allowance_amount = sponsored_company_allowance_amount ?? null;
|
|
87
|
+
this.sponsored_total_company_amount = sponsored_total_company_amount ?? null;
|
|
86
88
|
}
|
|
87
89
|
};
|
|
88
90
|
exports.DutyMissionRequests = DutyMissionRequests;
|
|
@@ -211,6 +213,14 @@ __decorate([
|
|
|
211
213
|
(0, typeorm_1.Column)({ type: 'varchar', length: 50, nullable: true }),
|
|
212
214
|
__metadata("design:type", Object)
|
|
213
215
|
], DutyMissionRequests.prototype, "allowance_percentage", void 0);
|
|
216
|
+
__decorate([
|
|
217
|
+
(0, typeorm_1.Column)({ type: 'varchar', length: 50, nullable: true }),
|
|
218
|
+
__metadata("design:type", Object)
|
|
219
|
+
], DutyMissionRequests.prototype, "sponsored_company_allowance_amount", void 0);
|
|
220
|
+
__decorate([
|
|
221
|
+
(0, typeorm_1.Column)({ type: 'decimal', precision: 18, scale: 2, nullable: true }),
|
|
222
|
+
__metadata("design:type", Object)
|
|
223
|
+
], DutyMissionRequests.prototype, "sponsored_total_company_amount", void 0);
|
|
214
224
|
__decorate([
|
|
215
225
|
(0, typeorm_1.Column)({
|
|
216
226
|
type: "enum",
|
|
@@ -243,5 +253,5 @@ exports.DutyMissionRequests = DutyMissionRequests = __decorate([
|
|
|
243
253
|
(0, typeorm_1.Entity)({ name: 'duty_mission_requests' }),
|
|
244
254
|
__metadata("design:paramtypes", [Object, Object, Number, Number, Number, String, String, String, String, String, Date,
|
|
245
255
|
Date, String, String, String, String, String, Date,
|
|
246
|
-
Date, String, Object, Object, Object, Object, Object, Object, Object, Object, Object, Object, Object, Object])
|
|
256
|
+
Date, String, Object, Object, Object, Object, Object, Object, Object, Object, Object, Object, Object, Object, Object, Object])
|
|
247
257
|
], DutyMissionRequests);
|
|
@@ -24,7 +24,9 @@ export declare class RequestForCoverageRequest extends BaseModel {
|
|
|
24
24
|
extension_number: string | null;
|
|
25
25
|
suggested_photography: string | null;
|
|
26
26
|
event_name: string | null;
|
|
27
|
-
event_from_date
|
|
27
|
+
/** Use event_from_date for new data; kept for backward compatibility with existing rows */
|
|
28
|
+
event_date: Date | null;
|
|
29
|
+
event_from_date: Date | null;
|
|
28
30
|
event_to_date: Date | null;
|
|
29
31
|
tags: string | null;
|
|
30
32
|
event_time: string;
|
|
@@ -43,5 +45,5 @@ export declare class RequestForCoverageRequest extends BaseModel {
|
|
|
43
45
|
assigned_at: Date | null;
|
|
44
46
|
workflow_execution_id: string | null;
|
|
45
47
|
rejection_reason: string | null;
|
|
46
|
-
constructor(user_id: number, event_from_date: Date, event_time: string, event_location: string, event_details: string, importance_of_publishing: string, directorate_name: string, required_for_president?: boolean, status?: RequestForCoverageRequestStatus, service_id?: number | null, sub_service_id?: number | null, req_user_department_id?: number | null, req_user_section_id?: number | null, req_user_position_id?: number | null, department_id?: number | null, extension_number?: string | null, suggested_photography?: string | null, news_size?: RequestForCoverageNewsSize | null, event_objective?: string | null, organizing_entity?: string | null, hosted_person?: string | null, audience?: string | null, document_event?: string | null, reviewer_user_id?: number | null, assigned_to_user_id?: number | null, assigned_at?: Date | null, workflow_execution_id?: string | null, rejection_reason?: string | null, event_name?: string | null, event_to_date?: Date | null, tags?: string | null);
|
|
48
|
+
constructor(user_id: number, event_from_date: Date, event_time: string, event_location: string, event_details: string, importance_of_publishing: string, directorate_name: string, required_for_president?: boolean, status?: RequestForCoverageRequestStatus, service_id?: number | null, sub_service_id?: number | null, req_user_department_id?: number | null, req_user_section_id?: number | null, req_user_position_id?: number | null, department_id?: number | null, extension_number?: string | null, suggested_photography?: string | null, news_size?: RequestForCoverageNewsSize | null, event_objective?: string | null, organizing_entity?: string | null, hosted_person?: string | null, audience?: string | null, document_event?: string | null, reviewer_user_id?: number | null, assigned_to_user_id?: number | null, assigned_at?: Date | null, workflow_execution_id?: string | null, rejection_reason?: string | null, event_name?: string | null, event_to_date?: Date | null, tags?: string | null, event_date?: Date | null);
|
|
47
49
|
}
|
|
@@ -27,10 +27,11 @@ var RequestForCoverageNewsSize;
|
|
|
27
27
|
RequestForCoverageNewsSize["LARGE"] = "Large";
|
|
28
28
|
})(RequestForCoverageNewsSize || (exports.RequestForCoverageNewsSize = RequestForCoverageNewsSize = {}));
|
|
29
29
|
let RequestForCoverageRequest = class RequestForCoverageRequest extends BaseModel_1.BaseModel {
|
|
30
|
-
constructor(user_id, event_from_date, event_time, event_location, event_details, importance_of_publishing, directorate_name, required_for_president = false, status = RequestForCoverageRequestStatus.PENDING, service_id, sub_service_id, req_user_department_id, req_user_section_id, req_user_position_id, department_id, extension_number, suggested_photography, news_size, event_objective, organizing_entity, hosted_person, audience, document_event, reviewer_user_id, assigned_to_user_id, assigned_at, workflow_execution_id, rejection_reason, event_name, event_to_date, tags) {
|
|
30
|
+
constructor(user_id, event_from_date, event_time, event_location, event_details, importance_of_publishing, directorate_name, required_for_president = false, status = RequestForCoverageRequestStatus.PENDING, service_id, sub_service_id, req_user_department_id, req_user_section_id, req_user_position_id, department_id, extension_number, suggested_photography, news_size, event_objective, organizing_entity, hosted_person, audience, document_event, reviewer_user_id, assigned_to_user_id, assigned_at, workflow_execution_id, rejection_reason, event_name, event_to_date, tags, event_date) {
|
|
31
31
|
super();
|
|
32
32
|
this.user_id = user_id;
|
|
33
|
-
this.event_from_date = event_from_date;
|
|
33
|
+
this.event_from_date = event_from_date ?? event_date ?? null;
|
|
34
|
+
this.event_date = event_date ?? event_from_date ?? null;
|
|
34
35
|
this.event_time = event_time;
|
|
35
36
|
this.event_location = event_location;
|
|
36
37
|
this.event_details = event_details;
|
|
@@ -60,6 +61,7 @@ let RequestForCoverageRequest = class RequestForCoverageRequest extends BaseMode
|
|
|
60
61
|
this.event_name = event_name || null;
|
|
61
62
|
this.event_to_date = event_to_date || null;
|
|
62
63
|
this.tags = tags || null;
|
|
64
|
+
this.event_date = event_date ?? null;
|
|
63
65
|
}
|
|
64
66
|
};
|
|
65
67
|
exports.RequestForCoverageRequest = RequestForCoverageRequest;
|
|
@@ -112,8 +114,12 @@ __decorate([
|
|
|
112
114
|
__metadata("design:type", Object)
|
|
113
115
|
], RequestForCoverageRequest.prototype, "event_name", void 0);
|
|
114
116
|
__decorate([
|
|
115
|
-
(0, typeorm_1.Column)({ type: "date", nullable:
|
|
116
|
-
__metadata("design:type",
|
|
117
|
+
(0, typeorm_1.Column)({ type: "date", nullable: true }),
|
|
118
|
+
__metadata("design:type", Object)
|
|
119
|
+
], RequestForCoverageRequest.prototype, "event_date", void 0);
|
|
120
|
+
__decorate([
|
|
121
|
+
(0, typeorm_1.Column)({ type: "date", nullable: true }),
|
|
122
|
+
__metadata("design:type", Object)
|
|
117
123
|
], RequestForCoverageRequest.prototype, "event_from_date", void 0);
|
|
118
124
|
__decorate([
|
|
119
125
|
(0, typeorm_1.Column)({ type: "date", nullable: true }),
|
|
@@ -198,5 +204,5 @@ __decorate([
|
|
|
198
204
|
], RequestForCoverageRequest.prototype, "rejection_reason", void 0);
|
|
199
205
|
exports.RequestForCoverageRequest = RequestForCoverageRequest = __decorate([
|
|
200
206
|
(0, typeorm_1.Entity)({ name: "request_for_coverage_requests" }),
|
|
201
|
-
__metadata("design:paramtypes", [Number, Date, String, String, String, String, String, Boolean, String, Object, Object, Object, Object, Object, Object, Object, Object, Object, Object, Object, Object, Object, Object, Object, Object, Object, Object, Object, Object, Object, Object])
|
|
207
|
+
__metadata("design:paramtypes", [Number, Date, String, String, String, String, String, Boolean, String, Object, Object, Object, Object, Object, Object, Object, Object, Object, Object, Object, Object, Object, Object, Object, Object, Object, Object, Object, Object, Object, Object, Object])
|
|
202
208
|
], RequestForCoverageRequest);
|
|
@@ -20,10 +20,19 @@ export declare class SecurityThreatRequest extends BaseModel {
|
|
|
20
20
|
sub_service_id: number;
|
|
21
21
|
user_id: number;
|
|
22
22
|
type_of_threat: number;
|
|
23
|
+
ticket_name: string | null;
|
|
24
|
+
source_of_incident: string | null;
|
|
25
|
+
type_of_incident_detected: string[] | null;
|
|
23
26
|
description: string;
|
|
24
27
|
contact_number: string;
|
|
25
28
|
priority: SecurityThreatPriority;
|
|
26
29
|
status: SecurityThreatRequestStatus;
|
|
27
30
|
workflow_execution_id: string | null;
|
|
31
|
+
incident_notification_in_caa: string[] | null;
|
|
32
|
+
identification_measures: string | null;
|
|
33
|
+
evidence_collected: string | null;
|
|
34
|
+
eradication_mitigation_measures: string | null;
|
|
35
|
+
recovery_measures: string | null;
|
|
36
|
+
other_mitigation_measures: string | null;
|
|
28
37
|
constructor(req_user_department_id: number | null, req_user_section_id: number | null, service_id: number, sub_service_id: number, user_id: number, type_of_threat: number, description: string, contact_number: string, priority: SecurityThreatPriority, status: SecurityThreatRequestStatus, workflow_execution_id?: string | null);
|
|
29
38
|
}
|
|
@@ -69,6 +69,18 @@ __decorate([
|
|
|
69
69
|
(0, typeorm_1.Column)({ type: 'int', nullable: false }),
|
|
70
70
|
__metadata("design:type", Number)
|
|
71
71
|
], SecurityThreatRequest.prototype, "type_of_threat", void 0);
|
|
72
|
+
__decorate([
|
|
73
|
+
(0, typeorm_1.Column)({ type: 'varchar', length: 255, nullable: true }),
|
|
74
|
+
__metadata("design:type", Object)
|
|
75
|
+
], SecurityThreatRequest.prototype, "ticket_name", void 0);
|
|
76
|
+
__decorate([
|
|
77
|
+
(0, typeorm_1.Column)({ type: 'text', nullable: true }),
|
|
78
|
+
__metadata("design:type", Object)
|
|
79
|
+
], SecurityThreatRequest.prototype, "source_of_incident", void 0);
|
|
80
|
+
__decorate([
|
|
81
|
+
(0, typeorm_1.Column)({ type: 'jsonb', nullable: true }),
|
|
82
|
+
__metadata("design:type", Object)
|
|
83
|
+
], SecurityThreatRequest.prototype, "type_of_incident_detected", void 0);
|
|
72
84
|
__decorate([
|
|
73
85
|
(0, typeorm_1.Column)({ type: 'text', nullable: true }),
|
|
74
86
|
__metadata("design:type", String)
|
|
@@ -98,6 +110,30 @@ __decorate([
|
|
|
98
110
|
(0, typeorm_1.Column)({ type: "varchar", nullable: true }),
|
|
99
111
|
__metadata("design:type", Object)
|
|
100
112
|
], SecurityThreatRequest.prototype, "workflow_execution_id", void 0);
|
|
113
|
+
__decorate([
|
|
114
|
+
(0, typeorm_1.Column)({ type: 'jsonb', nullable: true }),
|
|
115
|
+
__metadata("design:type", Object)
|
|
116
|
+
], SecurityThreatRequest.prototype, "incident_notification_in_caa", void 0);
|
|
117
|
+
__decorate([
|
|
118
|
+
(0, typeorm_1.Column)({ type: 'text', nullable: true }),
|
|
119
|
+
__metadata("design:type", Object)
|
|
120
|
+
], SecurityThreatRequest.prototype, "identification_measures", void 0);
|
|
121
|
+
__decorate([
|
|
122
|
+
(0, typeorm_1.Column)({ type: 'text', nullable: true }),
|
|
123
|
+
__metadata("design:type", Object)
|
|
124
|
+
], SecurityThreatRequest.prototype, "evidence_collected", void 0);
|
|
125
|
+
__decorate([
|
|
126
|
+
(0, typeorm_1.Column)({ type: 'text', nullable: true }),
|
|
127
|
+
__metadata("design:type", Object)
|
|
128
|
+
], SecurityThreatRequest.prototype, "eradication_mitigation_measures", void 0);
|
|
129
|
+
__decorate([
|
|
130
|
+
(0, typeorm_1.Column)({ type: 'text', nullable: true }),
|
|
131
|
+
__metadata("design:type", Object)
|
|
132
|
+
], SecurityThreatRequest.prototype, "recovery_measures", void 0);
|
|
133
|
+
__decorate([
|
|
134
|
+
(0, typeorm_1.Column)({ type: 'text', nullable: true }),
|
|
135
|
+
__metadata("design:type", Object)
|
|
136
|
+
], SecurityThreatRequest.prototype, "other_mitigation_measures", void 0);
|
|
101
137
|
exports.SecurityThreatRequest = SecurityThreatRequest = __decorate([
|
|
102
138
|
(0, typeorm_1.Entity)({ name: 'security_threat_requests' }),
|
|
103
139
|
__metadata("design:paramtypes", [Object, Object, Number, Number, Number, Number, String, String, String, String, Object])
|
package/package.json
CHANGED
|
@@ -140,6 +140,12 @@ export class DutyMissionRequests extends BaseModel {
|
|
|
140
140
|
@Column({ type: 'varchar', length: 50, nullable: true })
|
|
141
141
|
allowance_percentage: string | null; // Inside: 0%, 50%, 100%; Outside: 0%, 75%, 100%
|
|
142
142
|
|
|
143
|
+
@Column({ type: 'varchar', length: 50, nullable: true })
|
|
144
|
+
sponsored_company_allowance_amount: string | null; // e.g. "50%"
|
|
145
|
+
|
|
146
|
+
@Column({ type: 'decimal', precision: 18, scale: 2, nullable: true })
|
|
147
|
+
sponsored_total_company_amount: number | null; // e.g. 1000000
|
|
148
|
+
|
|
143
149
|
@Column({
|
|
144
150
|
type: "enum",
|
|
145
151
|
enum: AirTicketRequired,
|
|
@@ -196,6 +202,8 @@ export class DutyMissionRequests extends BaseModel {
|
|
|
196
202
|
decision_number?: string | null,
|
|
197
203
|
decision_date?: Date | null,
|
|
198
204
|
workflow_execution_id?: string | null,
|
|
205
|
+
sponsored_company_allowance_amount?: string | null,
|
|
206
|
+
sponsored_total_company_amount?: number | null,
|
|
199
207
|
) {
|
|
200
208
|
super();
|
|
201
209
|
this.req_user_department_id = req_user_department_id ?? null;
|
|
@@ -230,5 +238,7 @@ export class DutyMissionRequests extends BaseModel {
|
|
|
230
238
|
this.decision_number = decision_number ?? null;
|
|
231
239
|
this.decision_date = decision_date ?? null;
|
|
232
240
|
this.workflow_execution_id = workflow_execution_id ?? null;
|
|
241
|
+
this.sponsored_company_allowance_amount = sponsored_company_allowance_amount ?? null;
|
|
242
|
+
this.sponsored_total_company_amount = sponsored_total_company_amount ?? null;
|
|
233
243
|
}
|
|
234
244
|
}
|
|
@@ -53,8 +53,12 @@ export class RequestForCoverageRequest extends BaseModel {
|
|
|
53
53
|
@Column({ type: "varchar", length: 255, nullable: true })
|
|
54
54
|
event_name: string | null;
|
|
55
55
|
|
|
56
|
-
|
|
57
|
-
|
|
56
|
+
/** Use event_from_date for new data; kept for backward compatibility with existing rows */
|
|
57
|
+
@Column({ type: "date", nullable: true })
|
|
58
|
+
event_date: Date | null;
|
|
59
|
+
|
|
60
|
+
@Column({ type: "date", nullable: true })
|
|
61
|
+
event_from_date: Date | null;
|
|
58
62
|
|
|
59
63
|
@Column({ type: "date", nullable: true })
|
|
60
64
|
event_to_date: Date | null;
|
|
@@ -150,11 +154,13 @@ export class RequestForCoverageRequest extends BaseModel {
|
|
|
150
154
|
rejection_reason?: string | null,
|
|
151
155
|
event_name?: string | null,
|
|
152
156
|
event_to_date?: Date | null,
|
|
153
|
-
tags?: string | null
|
|
157
|
+
tags?: string | null,
|
|
158
|
+
event_date?: Date | null
|
|
154
159
|
) {
|
|
155
160
|
super();
|
|
156
161
|
this.user_id = user_id;
|
|
157
|
-
this.event_from_date = event_from_date;
|
|
162
|
+
this.event_from_date = event_from_date ?? event_date ?? null;
|
|
163
|
+
this.event_date = event_date ?? event_from_date ?? null;
|
|
158
164
|
this.event_time = event_time;
|
|
159
165
|
this.event_location = event_location;
|
|
160
166
|
this.event_details = event_details;
|
|
@@ -184,6 +190,7 @@ export class RequestForCoverageRequest extends BaseModel {
|
|
|
184
190
|
this.event_name = event_name || null;
|
|
185
191
|
this.event_to_date = event_to_date || null;
|
|
186
192
|
this.tags = tags || null;
|
|
193
|
+
this.event_date = event_date ?? null;
|
|
187
194
|
}
|
|
188
195
|
}
|
|
189
196
|
|
|
@@ -37,6 +37,15 @@ export class SecurityThreatRequest extends BaseModel {
|
|
|
37
37
|
@Column({ type: 'int', nullable: false })
|
|
38
38
|
type_of_threat: number;
|
|
39
39
|
|
|
40
|
+
@Column({ type: 'varchar', length: 255, nullable: true })
|
|
41
|
+
ticket_name: string | null;
|
|
42
|
+
|
|
43
|
+
@Column({ type: 'text', nullable: true })
|
|
44
|
+
source_of_incident: string | null;
|
|
45
|
+
|
|
46
|
+
@Column({ type: 'jsonb', nullable: true })
|
|
47
|
+
type_of_incident_detected: string[] | null;
|
|
48
|
+
|
|
40
49
|
@Column({ type: 'text', nullable: true })
|
|
41
50
|
description: string;
|
|
42
51
|
|
|
@@ -61,6 +70,25 @@ export class SecurityThreatRequest extends BaseModel {
|
|
|
61
70
|
@Column({ type: "varchar", nullable: true })
|
|
62
71
|
workflow_execution_id: string | null;
|
|
63
72
|
|
|
73
|
+
// Final-approval fields (updated when request is closed/approved at final level)
|
|
74
|
+
@Column({ type: 'jsonb', nullable: true })
|
|
75
|
+
incident_notification_in_caa: string[] | null;
|
|
76
|
+
|
|
77
|
+
@Column({ type: 'text', nullable: true })
|
|
78
|
+
identification_measures: string | null;
|
|
79
|
+
|
|
80
|
+
@Column({ type: 'text', nullable: true })
|
|
81
|
+
evidence_collected: string | null;
|
|
82
|
+
|
|
83
|
+
@Column({ type: 'text', nullable: true })
|
|
84
|
+
eradication_mitigation_measures: string | null;
|
|
85
|
+
|
|
86
|
+
@Column({ type: 'text', nullable: true })
|
|
87
|
+
recovery_measures: string | null;
|
|
88
|
+
|
|
89
|
+
@Column({ type: 'text', nullable: true })
|
|
90
|
+
other_mitigation_measures: string | null;
|
|
91
|
+
|
|
64
92
|
constructor(
|
|
65
93
|
req_user_department_id: number | null,
|
|
66
94
|
req_user_section_id: number | null,
|