1use crate::models;
12use serde::{Deserialize, Serialize};
13
14#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
15pub struct Schedule {
16 #[serde(rename = "path")]
17 pub path: String,
18 #[serde(rename = "edited_by")]
19 pub edited_by: String,
20 #[serde(rename = "edited_at")]
21 pub edited_at: String,
22 #[serde(rename = "schedule")]
23 pub schedule: String,
24 #[serde(rename = "timezone")]
25 pub timezone: String,
26 #[serde(rename = "enabled")]
27 pub enabled: bool,
28 #[serde(rename = "script_path")]
29 pub script_path: String,
30 #[serde(rename = "is_flow")]
31 pub is_flow: bool,
32 #[serde(rename = "args", skip_serializing_if = "Option::is_none")]
34 pub args: Option<std::collections::HashMap<String, serde_json::Value>>,
35 #[serde(rename = "extra_perms")]
36 pub extra_perms: std::collections::HashMap<String, bool>,
37 #[serde(rename = "email")]
38 pub email: String,
39 #[serde(rename = "error", skip_serializing_if = "Option::is_none")]
40 pub error: Option<String>,
41 #[serde(rename = "on_failure", skip_serializing_if = "Option::is_none")]
42 pub on_failure: Option<String>,
43 #[serde(rename = "on_failure_times", skip_serializing_if = "Option::is_none")]
44 pub on_failure_times: Option<f64>,
45 #[serde(rename = "on_failure_exact", skip_serializing_if = "Option::is_none")]
46 pub on_failure_exact: Option<bool>,
47 #[serde(rename = "on_failure_extra_args", skip_serializing_if = "Option::is_none")]
49 pub on_failure_extra_args: Option<std::collections::HashMap<String, serde_json::Value>>,
50 #[serde(rename = "on_recovery", skip_serializing_if = "Option::is_none")]
51 pub on_recovery: Option<String>,
52 #[serde(rename = "on_recovery_times", skip_serializing_if = "Option::is_none")]
53 pub on_recovery_times: Option<f64>,
54 #[serde(rename = "on_recovery_extra_args", skip_serializing_if = "Option::is_none")]
56 pub on_recovery_extra_args: Option<std::collections::HashMap<String, serde_json::Value>>,
57 #[serde(rename = "on_success", skip_serializing_if = "Option::is_none")]
58 pub on_success: Option<String>,
59 #[serde(rename = "on_success_extra_args", skip_serializing_if = "Option::is_none")]
61 pub on_success_extra_args: Option<std::collections::HashMap<String, serde_json::Value>>,
62 #[serde(rename = "ws_error_handler_muted", skip_serializing_if = "Option::is_none")]
63 pub ws_error_handler_muted: Option<bool>,
64 #[serde(rename = "retry", skip_serializing_if = "Option::is_none")]
65 pub retry: Option<Box<models::Retry>>,
66 #[serde(rename = "summary", skip_serializing_if = "Option::is_none")]
67 pub summary: Option<String>,
68 #[serde(rename = "description", skip_serializing_if = "Option::is_none")]
69 pub description: Option<String>,
70 #[serde(rename = "no_flow_overlap", skip_serializing_if = "Option::is_none")]
71 pub no_flow_overlap: Option<bool>,
72 #[serde(rename = "tag", skip_serializing_if = "Option::is_none")]
73 pub tag: Option<String>,
74 #[serde(rename = "paused_until", skip_serializing_if = "Option::is_none")]
75 pub paused_until: Option<String>,
76 #[serde(rename = "cron_version", skip_serializing_if = "Option::is_none")]
77 pub cron_version: Option<String>,
78}
79
80impl Schedule {
81 pub fn new(path: String, edited_by: String, edited_at: String, schedule: String, timezone: String, enabled: bool, script_path: String, is_flow: bool, extra_perms: std::collections::HashMap<String, bool>, email: String) -> Schedule {
82 Schedule {
83 path,
84 edited_by,
85 edited_at,
86 schedule,
87 timezone,
88 enabled,
89 script_path,
90 is_flow,
91 args: None,
92 extra_perms,
93 email,
94 error: None,
95 on_failure: None,
96 on_failure_times: None,
97 on_failure_exact: None,
98 on_failure_extra_args: None,
99 on_recovery: None,
100 on_recovery_times: None,
101 on_recovery_extra_args: None,
102 on_success: None,
103 on_success_extra_args: None,
104 ws_error_handler_muted: None,
105 retry: None,
106 summary: None,
107 description: None,
108 no_flow_overlap: None,
109 tag: None,
110 paused_until: None,
111 cron_version: None,
112 }
113 }
114}
115