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