1use crate::models;
12use serde::{Deserialize, Serialize};
13
14#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
15pub struct CompletedJob {
16 #[serde(rename = "workspace_id", skip_serializing_if = "Option::is_none")]
17 pub workspace_id: Option<String>,
18 #[serde(rename = "id")]
19 pub id: uuid::Uuid,
20 #[serde(rename = "parent_job", skip_serializing_if = "Option::is_none")]
21 pub parent_job: Option<uuid::Uuid>,
22 #[serde(rename = "created_by")]
23 pub created_by: String,
24 #[serde(rename = "created_at")]
25 pub created_at: String,
26 #[serde(rename = "started_at")]
27 pub started_at: String,
28 #[serde(rename = "duration_ms")]
29 pub duration_ms: i32,
30 #[serde(rename = "success")]
31 pub success: bool,
32 #[serde(rename = "script_path", skip_serializing_if = "Option::is_none")]
33 pub script_path: Option<String>,
34 #[serde(rename = "script_hash", skip_serializing_if = "Option::is_none")]
35 pub script_hash: Option<String>,
36 #[serde(rename = "args", skip_serializing_if = "Option::is_none")]
38 pub args: Option<std::collections::HashMap<String, serde_json::Value>>,
39 #[serde(rename = "result", default, with = "::serde_with::rust::double_option", skip_serializing_if = "Option::is_none")]
40 pub result: Option<Option<serde_json::Value>>,
41 #[serde(rename = "logs", skip_serializing_if = "Option::is_none")]
42 pub logs: Option<String>,
43 #[serde(rename = "deleted", skip_serializing_if = "Option::is_none")]
44 pub deleted: Option<bool>,
45 #[serde(rename = "raw_code", skip_serializing_if = "Option::is_none")]
46 pub raw_code: Option<String>,
47 #[serde(rename = "canceled")]
48 pub canceled: bool,
49 #[serde(rename = "canceled_by", skip_serializing_if = "Option::is_none")]
50 pub canceled_by: Option<String>,
51 #[serde(rename = "canceled_reason", skip_serializing_if = "Option::is_none")]
52 pub canceled_reason: Option<String>,
53 #[serde(rename = "job_kind")]
54 pub job_kind: JobKind,
55 #[serde(rename = "schedule_path", skip_serializing_if = "Option::is_none")]
56 pub schedule_path: Option<String>,
57 #[serde(rename = "permissioned_as")]
59 pub permissioned_as: String,
60 #[serde(rename = "flow_status", skip_serializing_if = "Option::is_none")]
61 pub flow_status: Option<Box<models::FlowStatus>>,
62 #[serde(rename = "workflow_as_code_status", skip_serializing_if = "Option::is_none")]
63 pub workflow_as_code_status: Option<Box<models::WorkflowStatus>>,
64 #[serde(rename = "raw_flow", skip_serializing_if = "Option::is_none")]
65 pub raw_flow: Option<Box<models::FlowValue>>,
66 #[serde(rename = "is_flow_step")]
67 pub is_flow_step: bool,
68 #[serde(rename = "language", skip_serializing_if = "Option::is_none")]
69 pub language: Option<models::ScriptLang>,
70 #[serde(rename = "is_skipped")]
71 pub is_skipped: bool,
72 #[serde(rename = "email")]
73 pub email: String,
74 #[serde(rename = "visible_to_owner")]
75 pub visible_to_owner: bool,
76 #[serde(rename = "mem_peak", skip_serializing_if = "Option::is_none")]
77 pub mem_peak: Option<i32>,
78 #[serde(rename = "tag")]
79 pub tag: String,
80 #[serde(rename = "priority", skip_serializing_if = "Option::is_none")]
81 pub priority: Option<i32>,
82 #[serde(rename = "labels", skip_serializing_if = "Option::is_none")]
83 pub labels: Option<Vec<String>>,
84 #[serde(rename = "self_wait_time_ms", skip_serializing_if = "Option::is_none")]
85 pub self_wait_time_ms: Option<f64>,
86 #[serde(rename = "aggregate_wait_time_ms", skip_serializing_if = "Option::is_none")]
87 pub aggregate_wait_time_ms: Option<f64>,
88 #[serde(rename = "preprocessed", skip_serializing_if = "Option::is_none")]
89 pub preprocessed: Option<bool>,
90 #[serde(rename = "worker", skip_serializing_if = "Option::is_none")]
91 pub worker: Option<String>,
92}
93
94impl CompletedJob {
95 pub fn new(id: uuid::Uuid, created_by: String, created_at: String, started_at: String, duration_ms: i32, success: bool, canceled: bool, job_kind: JobKind, permissioned_as: String, is_flow_step: bool, is_skipped: bool, email: String, visible_to_owner: bool, tag: String) -> CompletedJob {
96 CompletedJob {
97 workspace_id: None,
98 id,
99 parent_job: None,
100 created_by,
101 created_at,
102 started_at,
103 duration_ms,
104 success,
105 script_path: None,
106 script_hash: None,
107 args: None,
108 result: None,
109 logs: None,
110 deleted: None,
111 raw_code: None,
112 canceled,
113 canceled_by: None,
114 canceled_reason: None,
115 job_kind,
116 schedule_path: None,
117 permissioned_as,
118 flow_status: None,
119 workflow_as_code_status: None,
120 raw_flow: None,
121 is_flow_step,
122 language: None,
123 is_skipped,
124 email,
125 visible_to_owner,
126 mem_peak: None,
127 tag,
128 priority: None,
129 labels: None,
130 self_wait_time_ms: None,
131 aggregate_wait_time_ms: None,
132 preprocessed: None,
133 worker: None,
134 }
135 }
136}
137#[derive(Clone, Copy, Debug, Eq, PartialEq, Ord, PartialOrd, Hash, Serialize, Deserialize)]
139pub enum JobKind {
140 #[serde(rename = "script")]
141 Script,
142 #[serde(rename = "preview")]
143 Preview,
144 #[serde(rename = "dependencies")]
145 Dependencies,
146 #[serde(rename = "flow")]
147 Flow,
148 #[serde(rename = "flowdependencies")]
149 Flowdependencies,
150 #[serde(rename = "appdependencies")]
151 Appdependencies,
152 #[serde(rename = "flowpreview")]
153 Flowpreview,
154 #[serde(rename = "script_hub")]
155 ScriptHub,
156 #[serde(rename = "identity")]
157 Identity,
158 #[serde(rename = "deploymentcallback")]
159 Deploymentcallback,
160 #[serde(rename = "singlestepflow")]
161 Singlestepflow,
162 #[serde(rename = "flowscript")]
163 Flowscript,
164 #[serde(rename = "flownode")]
165 Flownode,
166 #[serde(rename = "appscript")]
167 Appscript,
168 #[serde(rename = "aiagent")]
169 Aiagent,
170}
171
172impl Default for JobKind {
173 fn default() -> JobKind {
174 Self::Script
175 }
176}
177