@platform-modules/foreign-ministry 1.1.106 → 1.1.108

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 (39) hide show
  1. package/dist/data-source.js +22 -0
  2. package/dist/index.d.ts +11 -0
  3. package/dist/index.js +11 -0
  4. package/dist/models/DependentsPassportDetailsModel.d.ts +17 -0
  5. package/dist/models/DependentsPassportDetailsModel.js +73 -0
  6. package/dist/models/RequestParcelApprovalModel.d.ts +22 -0
  7. package/dist/models/RequestParcelApprovalModel.js +79 -0
  8. package/dist/models/RequestParcelAttachmentModel.d.ts +11 -0
  9. package/dist/models/RequestParcelAttachmentModel.js +52 -0
  10. package/dist/models/RequestParcelChatModel.d.ts +19 -0
  11. package/dist/models/RequestParcelChatModel.js +78 -0
  12. package/dist/models/RequestParcelRequestModel.d.ts +35 -0
  13. package/dist/models/RequestParcelRequestModel.js +106 -0
  14. package/dist/models/RequestParcelWorkflowModel.d.ts +17 -0
  15. package/dist/models/RequestParcelWorkflowModel.js +62 -0
  16. package/dist/models/RequestPassportApprovalModel.d.ts +22 -0
  17. package/dist/models/RequestPassportApprovalModel.js +79 -0
  18. package/dist/models/RequestPassportAttachmentModel.d.ts +11 -0
  19. package/dist/models/RequestPassportAttachmentModel.js +52 -0
  20. package/dist/models/RequestPassportChatModel.d.ts +19 -0
  21. package/dist/models/RequestPassportChatModel.js +78 -0
  22. package/dist/models/RequestPassportRequestModel.d.ts +47 -0
  23. package/dist/models/RequestPassportRequestModel.js +151 -0
  24. package/dist/models/RequestPassportWorkflowModel.d.ts +17 -0
  25. package/dist/models/RequestPassportWorkflowModel.js +62 -0
  26. package/package.json +1 -1
  27. package/src/data-source.ts +22 -0
  28. package/src/index.ts +11 -0
  29. package/src/models/DependentsPassportDetailsModel.ts +46 -0
  30. package/src/models/RequestParcelApprovalModel.ts +51 -0
  31. package/src/models/RequestParcelAttachmentModel.ts +30 -0
  32. package/src/models/RequestParcelChatModel.ts +65 -0
  33. package/src/models/RequestParcelRequestModel.ts +78 -0
  34. package/src/models/RequestParcelWorkflowModel.ts +38 -0
  35. package/src/models/RequestPassportApprovalModel.ts +51 -0
  36. package/src/models/RequestPassportAttachmentModel.ts +30 -0
  37. package/src/models/RequestPassportChatModel.ts +65 -0
  38. package/src/models/RequestPassportRequestModel.ts +112 -0
  39. package/src/models/RequestPassportWorkflowModel.ts +38 -0
package/src/index.ts CHANGED
@@ -106,6 +106,17 @@ export * from './models/RegisterCandidateApprovalModel';
106
106
  export * from './models/RegisterCandidateAttachmentModel';
107
107
  export * from './models/RegisterCandidateChatModel';
108
108
  export * from './models/RegisterCandidateWorkflowModel';
109
+ export * from './models/RequestParcelRequestModel';
110
+ export * from './models/RequestParcelApprovalModel';
111
+ export * from './models/RequestParcelAttachmentModel';
112
+ export * from './models/RequestParcelChatModel';
113
+ export * from './models/RequestParcelWorkflowModel';
114
+ export * from './models/RequestPassportRequestModel';
115
+ export * from './models/RequestPassportApprovalModel';
116
+ export * from './models/RequestPassportAttachmentModel';
117
+ export * from './models/RequestPassportChatModel';
118
+ export * from './models/RequestPassportWorkflowModel';
119
+ export * from './models/DependentsPassportDetailsModel';
109
120
  export * from './models/GroupNamesModel';
110
121
  export * from './models/GroupModel';
111
122
  export * from './models/WorkScheduleModel';
@@ -0,0 +1,46 @@
1
+ import { Column, Entity } from "typeorm";
2
+ import { BaseModel } from './BaseModel';
3
+ import { RelationType } from './RequestPassportRequestModel';
4
+
5
+ @Entity({ name: 'dependents_passport_details' })
6
+ export class DependentsPassportDetails extends BaseModel {
7
+
8
+ @Column({ type: 'integer', nullable: false })
9
+ request_id: number;
10
+
11
+ @Column({ type: 'varchar', length: 255, nullable: false })
12
+ first_name: string;
13
+
14
+ @Column({ type: 'varchar', length: 255, nullable: false })
15
+ family_name: string;
16
+
17
+ @Column({ type: 'varchar', length: 255, nullable: false })
18
+ last_name: string;
19
+
20
+ @Column({ type: 'varchar', length: 50, nullable: false })
21
+ gender: string;
22
+
23
+ @Column({ type: 'varchar', length: 255, nullable: false })
24
+ nationality: string;
25
+
26
+ @Column({ type: 'varchar', length: 255, nullable: false })
27
+ place_of_birth: string;
28
+
29
+ @Column({ type: 'date', nullable: true })
30
+ date_of_birth: Date | null;
31
+
32
+ @Column({ type: 'varchar', length: 255, nullable: false })
33
+ job_occupation: string;
34
+
35
+ @Column({ type: 'enum', enum: RelationType, nullable: true })
36
+ relation_type: RelationType | null;
37
+
38
+ @Column({ type: 'int', nullable: false })
39
+ age: number;
40
+
41
+ @Column({ type: 'varchar', length: 255, nullable: true })
42
+ passport_request_type: string;
43
+
44
+ @Column({ type: 'varchar', length: 255, nullable: true })
45
+ dependent_passport_number: string | null;
46
+ }
@@ -0,0 +1,51 @@
1
+ import { Column, Entity } from "typeorm";
2
+ import { BaseModel } from './BaseModel';
3
+
4
+ export enum RequestParcelApprovalStatus {
5
+ PENDING = "Pending",
6
+ IN_PROGRESS = "In Progress",
7
+ APPROVED = "Approved",
8
+ REJECTED = "Rejected"
9
+ }
10
+
11
+ @Entity({ name: 'request_parcel_approvals' })
12
+ export class RequestParcelApprovalDetails 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({ type: 'enum', enum: RequestParcelApprovalStatus, default: RequestParcelApprovalStatus.PENDING, nullable: false })
47
+ approval_status: RequestParcelApprovalStatus;
48
+
49
+ @Column({ type: 'boolean', default: true, nullable: false })
50
+ is_allowed: boolean;
51
+ }
@@ -0,0 +1,30 @@
1
+ import { Column, Entity } from "typeorm";
2
+ import { BaseModel } from './BaseModel';
3
+
4
+ @Entity({ name: 'request_parcel_attachments' })
5
+ export class RequestParcelRequestAttachment extends BaseModel {
6
+
7
+ @Column({ type: 'integer', nullable: false })
8
+ request_id: number;
9
+
10
+ @Column({ type: 'integer', nullable: true })
11
+ service_id: number | null;
12
+
13
+ @Column({ type: 'integer', nullable: true })
14
+ sub_service_id: number | null;
15
+
16
+ @Column({ type: 'varchar', length: 500, nullable: false })
17
+ file_url: string;
18
+
19
+ @Column({ type: 'varchar', length: 255, nullable: true })
20
+ file_name: string;
21
+
22
+ @Column({ type: 'varchar', length: 100, nullable: true })
23
+ file_type: string;
24
+
25
+ @Column({ type: 'bigint', nullable: true })
26
+ file_size: number | null;
27
+
28
+ @Column({ type: 'integer', nullable: true })
29
+ chat_id: number | null;
30
+ }
@@ -0,0 +1,65 @@
1
+ import { Column, Entity } from "typeorm";
2
+ import { BaseModel } from './BaseModel';
3
+ import { RequestParcelApprovalStatus } from './RequestParcelApprovalModel';
4
+
5
+ export enum RequestParcelMessageType {
6
+ TEXT = "text",
7
+ IMAGE = "image",
8
+ VIDEO = "video",
9
+ FILE = "file",
10
+ LINK = "link"
11
+ }
12
+
13
+ @Entity({ name: 'request_parcel_chats' })
14
+ export class RequestParcelRequestChat extends BaseModel {
15
+
16
+ @Column({ type: 'integer', nullable: false })
17
+ request_id: number;
18
+
19
+ @Column({ type: 'integer', nullable: true })
20
+ service_id: number | null;
21
+
22
+ @Column({ type: 'integer', nullable: true })
23
+ sub_service_id: number | null;
24
+
25
+ @Column({ type: 'integer', nullable: false })
26
+ user_id: number;
27
+
28
+ @Column({ type: 'integer', nullable: true })
29
+ role_id: number;
30
+
31
+ @Column({ type: 'text', nullable: false })
32
+ message: string;
33
+
34
+ @Column({
35
+ type: 'enum',
36
+ enum: RequestParcelMessageType,
37
+ default: RequestParcelMessageType.TEXT,
38
+ nullable: false
39
+ })
40
+ messageType: RequestParcelMessageType;
41
+
42
+ @Column({ type: 'text', nullable: true })
43
+ status: string;
44
+
45
+ constructor(
46
+ request_id: number,
47
+ user_id: number,
48
+ role_id: number,
49
+ message: string,
50
+ service_id?: number,
51
+ sub_service_id?: number,
52
+ messageType?: RequestParcelMessageType,
53
+ status?: string
54
+ ) {
55
+ super();
56
+ this.request_id = request_id;
57
+ this.service_id = service_id || null;
58
+ this.sub_service_id = sub_service_id || null;
59
+ this.user_id = user_id;
60
+ this.role_id = role_id;
61
+ this.message = message;
62
+ this.messageType = messageType || RequestParcelMessageType.TEXT;
63
+ this.status = status || RequestParcelApprovalStatus.PENDING;
64
+ }
65
+ }
@@ -0,0 +1,78 @@
1
+ import { Column, Entity } from "typeorm";
2
+ import { BaseModel } from './BaseModel';
3
+
4
+ export enum RequestParcelStatus {
5
+ SUBMITTED = "Submitted",
6
+ IN_TRANSIT = "In Transit",
7
+ RECEIVED = "Received",
8
+ }
9
+
10
+ export enum ImportanceOfPouchType {
11
+ NORMAL = "Normal",
12
+ URGENT = "Urgent",
13
+ CONFIDENTIAL = "Confidential"
14
+ }
15
+
16
+ export enum PriorityType {
17
+ LOW = "Low",
18
+ MEDIUM = "Medium",
19
+ HIGH = "High"
20
+ }
21
+
22
+ @Entity({ name: 'request_parcel_requests' })
23
+ export class RequestParcelRequests extends BaseModel {
24
+
25
+ // Common columns from register_vacancy_requests
26
+ @Column({ type: 'int', nullable: true })
27
+ req_user_department_id: number | null;
28
+
29
+ @Column({ type: 'int', nullable: true })
30
+ req_user_section_id: number | null;
31
+
32
+ @Column({ type: 'int', nullable: true })
33
+ service_id: number | null;
34
+
35
+ @Column({ type: 'int', nullable: true })
36
+ sub_service_id: number | null;
37
+
38
+ @Column({ type: 'int', nullable: false })
39
+ user_id: number;
40
+
41
+ // New columns
42
+ @Column({ type: 'enum', enum: ImportanceOfPouchType, nullable: true })
43
+ importance_of_pouch: ImportanceOfPouchType | null;
44
+
45
+ @Column({ type: 'text', nullable: false })
46
+ contents: string;
47
+
48
+ @Column({ type: 'decimal', precision: 10, scale: 2, nullable: true })
49
+ price: number | null;
50
+
51
+ @Column({ type: 'varchar', length: 255, nullable: true })
52
+ shipment_courier_number: string | null;
53
+
54
+ @Column({ type: 'date', nullable: true })
55
+ max_delivery_date: Date | null;
56
+
57
+ @Column({ type: 'varchar', nullable: true })
58
+ mission_selection: string | null;
59
+
60
+ @Column({ type: 'enum', enum: PriorityType, nullable: true })
61
+ priority: PriorityType | null;
62
+
63
+ @Column({ type: 'int', nullable: true })
64
+ receiving_department: number | null;
65
+
66
+ @Column({ type: 'int', nullable: true })
67
+ receiving_section: number | null;
68
+
69
+ @Column({ type: 'varchar', length: 255, nullable: true })
70
+ mc_ministry: string | null;
71
+
72
+ @Column({ type: 'enum', enum: RequestParcelStatus, default: RequestParcelStatus.SUBMITTED, nullable: false })
73
+ status: RequestParcelStatus;
74
+
75
+ @Column({ type: 'varchar', nullable: true })
76
+ workflow_execution_id: string | null;
77
+
78
+ }
@@ -0,0 +1,38 @@
1
+ import { Column, Entity } from "typeorm";
2
+ import { BaseModel } from './BaseModel';
3
+
4
+ export enum RequestParcelWorkFlowStatus {
5
+ COMPLETED = "Completed",
6
+ NOT_YET_STARTED = "Not Yet Started",
7
+ PENDING = "Pending"
8
+ }
9
+
10
+ @Entity({ name: 'request_parcel_workflows' })
11
+ export class RequestParcelWorkFlow extends BaseModel {
12
+ @Column({ type: 'integer', nullable: false })
13
+ request_id: number;
14
+
15
+ @Column({ type: 'integer', nullable: true })
16
+ service_id: number | null;
17
+
18
+ @Column({ type: 'integer', nullable: true })
19
+ sub_service_id: number | null;
20
+
21
+ @Column({ type: 'varchar', length: 500, nullable: false })
22
+ content: string;
23
+
24
+ @Column({ type: 'enum', enum: RequestParcelWorkFlowStatus, default: RequestParcelWorkFlowStatus.NOT_YET_STARTED, nullable: false })
25
+ status: RequestParcelWorkFlowStatus;
26
+
27
+ @Column({ type: 'integer', nullable: true })
28
+ user_id: number | null;
29
+
30
+ @Column({ type: 'integer', nullable: true })
31
+ role_id: number | null;
32
+
33
+ @Column({ type: 'integer', nullable: true })
34
+ department_id: number | null;
35
+
36
+ @Column({ type: 'integer', nullable: true })
37
+ section_id: number | null;
38
+ }
@@ -0,0 +1,51 @@
1
+ import { Column, Entity } from "typeorm";
2
+ import { BaseModel } from './BaseModel';
3
+
4
+ export enum RequestPassportApprovalStatus {
5
+ PENDING = "Pending",
6
+ IN_PROGRESS = "In Progress",
7
+ APPROVED = "Approved",
8
+ REJECTED = "Rejected"
9
+ }
10
+
11
+ @Entity({ name: 'request_passport_approvals' })
12
+ export class RequestPassportApprovalDetails 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({ type: 'enum', enum: RequestPassportApprovalStatus, default: RequestPassportApprovalStatus.PENDING, nullable: false })
47
+ approval_status: RequestPassportApprovalStatus;
48
+
49
+ @Column({ type: 'boolean', default: true, nullable: false })
50
+ is_allowed: boolean;
51
+ }
@@ -0,0 +1,30 @@
1
+ import { Column, Entity } from "typeorm";
2
+ import { BaseModel } from './BaseModel';
3
+
4
+ @Entity({ name: 'request_passport_attachments' })
5
+ export class RequestPassportRequestAttachment extends BaseModel {
6
+
7
+ @Column({ type: 'integer', nullable: false })
8
+ request_id: number;
9
+
10
+ @Column({ type: 'integer', nullable: true })
11
+ service_id: number | null;
12
+
13
+ @Column({ type: 'integer', nullable: true })
14
+ sub_service_id: number | null;
15
+
16
+ @Column({ type: 'varchar', length: 500, nullable: false })
17
+ file_url: string;
18
+
19
+ @Column({ type: 'varchar', length: 255, nullable: true })
20
+ file_name: string;
21
+
22
+ @Column({ type: 'varchar', length: 100, nullable: true })
23
+ file_type: string;
24
+
25
+ @Column({ type: 'bigint', nullable: true })
26
+ file_size: number | null;
27
+
28
+ @Column({ type: 'integer', nullable: true })
29
+ chat_id: number | null;
30
+ }
@@ -0,0 +1,65 @@
1
+ import { Column, Entity } from "typeorm";
2
+ import { BaseModel } from './BaseModel';
3
+ import { RequestPassportApprovalStatus } from './RequestPassportApprovalModel';
4
+
5
+ export enum RequestPassportMessageType {
6
+ TEXT = "text",
7
+ IMAGE = "image",
8
+ VIDEO = "video",
9
+ FILE = "file",
10
+ LINK = "link"
11
+ }
12
+
13
+ @Entity({ name: 'request_passport_chats' })
14
+ export class RequestPassportRequestChat extends BaseModel {
15
+
16
+ @Column({ type: 'integer', nullable: false })
17
+ request_id: number;
18
+
19
+ @Column({ type: 'integer', nullable: true })
20
+ service_id: number | null;
21
+
22
+ @Column({ type: 'integer', nullable: true })
23
+ sub_service_id: number | null;
24
+
25
+ @Column({ type: 'integer', nullable: false })
26
+ user_id: number;
27
+
28
+ @Column({ type: 'integer', nullable: true })
29
+ role_id: number;
30
+
31
+ @Column({ type: 'text', nullable: false })
32
+ message: string;
33
+
34
+ @Column({
35
+ type: 'enum',
36
+ enum: RequestPassportMessageType,
37
+ default: RequestPassportMessageType.TEXT,
38
+ nullable: false
39
+ })
40
+ messageType: RequestPassportMessageType;
41
+
42
+ @Column({ type: 'text', nullable: true })
43
+ status: string;
44
+
45
+ constructor(
46
+ request_id: number,
47
+ user_id: number,
48
+ role_id: number,
49
+ message: string,
50
+ service_id?: number,
51
+ sub_service_id?: number,
52
+ messageType?: RequestPassportMessageType,
53
+ status?: string
54
+ ) {
55
+ super();
56
+ this.request_id = request_id;
57
+ this.service_id = service_id || null;
58
+ this.sub_service_id = sub_service_id || null;
59
+ this.user_id = user_id;
60
+ this.role_id = role_id;
61
+ this.message = message;
62
+ this.messageType = messageType || RequestPassportMessageType.TEXT;
63
+ this.status = status || RequestPassportApprovalStatus.PENDING;
64
+ }
65
+ }
@@ -0,0 +1,112 @@
1
+ import { Column, Entity } from "typeorm";
2
+ import { BaseModel } from './BaseModel';
3
+
4
+ export enum RequestPassportStatus {
5
+ PENDING = "Pending",
6
+ SUBMITTED = "Submitted",
7
+ APPROVED = "Approved",
8
+ REJECTED = "Rejected"
9
+ }
10
+
11
+ export enum ApplicationForType {
12
+ SELF = "Self",
13
+ DEPENDENTS = "Dependents",
14
+ BOTH = "Both"
15
+ }
16
+
17
+ export enum RelationType {
18
+ SELF = "Self",
19
+ SPOUSE = "Spouse",
20
+ CHILD = "Child"
21
+ }
22
+
23
+ @Entity({ name: 'request_passport_requests' })
24
+ export class RequestPassportRequests extends BaseModel {
25
+
26
+ // Common columns from register_vacancy_requests
27
+ @Column({ type: 'int', nullable: true })
28
+ req_user_department_id: number | null;
29
+
30
+ @Column({ type: 'int', nullable: true })
31
+ req_user_section_id: number | null;
32
+
33
+ @Column({ type: 'int', nullable: true })
34
+ service_id: number | null;
35
+
36
+ @Column({ type: 'int', nullable: true })
37
+ sub_service_id: number | null;
38
+
39
+ @Column({ type: 'int', nullable: false })
40
+ user_id: number;
41
+
42
+ // New columns
43
+ @Column({ type: 'varchar', length: 255, nullable: true })
44
+ request_number_for_official_use: string | null;
45
+
46
+ @Column({ type: 'varchar', length: 255, nullable: true })
47
+ passport_type: string | null;
48
+
49
+ @Column({ type: 'varchar', length: 255, nullable: true })
50
+ applicant_civil_id: string | null;
51
+
52
+ @Column({ type: 'varchar', length: 255, nullable: true })
53
+ applicant_name: string | null;
54
+
55
+ @Column({ type: 'varchar', length: 255, nullable: true })
56
+ applicant_passport_number: string | null;
57
+
58
+ @Column({ type: 'enum', enum: ApplicationForType, nullable: true })
59
+ application_for_type: ApplicationForType | null;
60
+
61
+ @Column({ type: 'varchar', length: 255, nullable: true })
62
+ application_type: string | null;
63
+
64
+ @Column({ type: 'varchar', length: 255, nullable: true })
65
+ applicant_job_occupation: string | null;
66
+
67
+ @Column({ type: 'text', nullable: true })
68
+ purpose_of_application: string | null;
69
+
70
+ @Column({ type: 'int', nullable: false })
71
+ approved_mission_travel_id: number;
72
+
73
+ @Column({ type: 'varchar', length: 255, nullable: false })
74
+ first_name: string;
75
+
76
+ @Column({ type: 'varchar', length: 255, nullable: false })
77
+ family_name: string;
78
+
79
+ @Column({ type: 'varchar', length: 255, nullable: false })
80
+ last_name: string;
81
+
82
+ @Column({ type: 'varchar', length: 50, nullable: false })
83
+ gender: string;
84
+
85
+ @Column({ type: 'varchar', length: 255, nullable: false })
86
+ nationality: string;
87
+
88
+ @Column({ type: 'varchar', length: 255, nullable: false })
89
+ place_of_birth: string;
90
+
91
+ @Column({ type: 'date', nullable: true })
92
+ date_of_birth: Date | null;
93
+
94
+ @Column({ type: 'varchar', length: 255, nullable: false })
95
+ job_occupation: string;
96
+
97
+ @Column({ type: 'enum', enum: RelationType, nullable: true })
98
+ relation_type: RelationType | null;
99
+
100
+ @Column({ type: 'int', nullable: false })
101
+ age: number;
102
+
103
+ @Column({ type: 'varchar', length: 255, nullable: false })
104
+ passport_request_type: string;
105
+
106
+ @Column({ type: 'enum', enum: RequestPassportStatus, default: RequestPassportStatus.PENDING, nullable: false })
107
+ status: RequestPassportStatus;
108
+
109
+ @Column({ type: 'varchar', nullable: true })
110
+ workflow_execution_id: string | null;
111
+
112
+ }
@@ -0,0 +1,38 @@
1
+ import { Column, Entity } from "typeorm";
2
+ import { BaseModel } from './BaseModel';
3
+
4
+ export enum RequestPassportWorkFlowStatus {
5
+ COMPLETED = "Completed",
6
+ NOT_YET_STARTED = "Not Yet Started",
7
+ PENDING = "Pending"
8
+ }
9
+
10
+ @Entity({ name: 'request_passport_workflows' })
11
+ export class RequestPassportWorkFlow extends BaseModel {
12
+ @Column({ type: 'integer', nullable: false })
13
+ request_id: number;
14
+
15
+ @Column({ type: 'integer', nullable: true })
16
+ service_id: number | null;
17
+
18
+ @Column({ type: 'integer', nullable: true })
19
+ sub_service_id: number | null;
20
+
21
+ @Column({ type: 'varchar', length: 500, nullable: false })
22
+ content: string;
23
+
24
+ @Column({ type: 'enum', enum: RequestPassportWorkFlowStatus, default: RequestPassportWorkFlowStatus.NOT_YET_STARTED, nullable: false })
25
+ status: RequestPassportWorkFlowStatus;
26
+
27
+ @Column({ type: 'integer', nullable: true })
28
+ user_id: number | null;
29
+
30
+ @Column({ type: 'integer', nullable: true })
31
+ role_id: number | null;
32
+
33
+ @Column({ type: 'integer', nullable: true })
34
+ department_id: number | null;
35
+
36
+ @Column({ type: 'integer', nullable: true })
37
+ section_id: number | null;
38
+ }