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")]
33 pub args: Option<std::collections::HashMap<String, serde_json::Value>>,
34 #[serde(rename = "extra_perms")]
35 pub extra_perms: std::collections::HashMap<String, bool>,
36 #[serde(rename = "email")]
37 pub email: String,
38 #[serde(rename = "error", skip_serializing_if = "Option::is_none")]
39 pub error: Option<String>,
40 #[serde(rename = "on_failure", skip_serializing_if = "Option::is_none")]
41 pub on_failure: Option<String>,
42 #[serde(rename = "on_failure_times", skip_serializing_if = "Option::is_none")]
43 pub on_failure_times: Option<f64>,
44 #[serde(rename = "on_failure_exact", skip_serializing_if = "Option::is_none")]
45 pub on_failure_exact: Option<bool>,
46 #[serde(rename = "on_failure_extra_args", skip_serializing_if = "Option::is_none")]
47 pub on_failure_extra_args: Option<std::collections::HashMap<String, serde_json::Value>>,
48 #[serde(rename = "on_recovery", skip_serializing_if = "Option::is_none")]
49 pub on_recovery: Option<String>,
50 #[serde(rename = "on_recovery_times", skip_serializing_if = "Option::is_none")]
51 pub on_recovery_times: Option<f64>,
52 #[serde(rename = "on_recovery_extra_args", skip_serializing_if = "Option::is_none")]
53 pub on_recovery_extra_args: Option<std::collections::HashMap<String, serde_json::Value>>,
54 #[serde(rename = "on_success", skip_serializing_if = "Option::is_none")]
55 pub on_success: Option<String>,
56 #[serde(rename = "on_success_extra_args", skip_serializing_if = "Option::is_none")]
57 pub on_success_extra_args: Option<std::collections::HashMap<String, serde_json::Value>>,
58 #[serde(rename = "ws_error_handler_muted", skip_serializing_if = "Option::is_none")]
59 pub ws_error_handler_muted: Option<bool>,
60 #[serde(rename = "retry", skip_serializing_if = "Option::is_none")]
61 pub retry: Option<Box<models::Retry>>,
62 #[serde(rename = "summary", skip_serializing_if = "Option::is_none")]
63 pub summary: Option<String>,
64 #[serde(rename = "description", skip_serializing_if = "Option::is_none")]
65 pub description: Option<String>,
66 #[serde(rename = "no_flow_overlap", skip_serializing_if = "Option::is_none")]
67 pub no_flow_overlap: Option<bool>,
68 #[serde(rename = "tag", skip_serializing_if = "Option::is_none")]
69 pub tag: Option<String>,
70 #[serde(rename = "paused_until", skip_serializing_if = "Option::is_none")]
71 pub paused_until: Option<String>,
72 #[serde(rename = "cron_version", skip_serializing_if = "Option::is_none")]
73 pub cron_version: Option<String>,
74}
75
76impl Schedule {
77 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 {
78 Schedule {
79 path,
80 edited_by,
81 edited_at,
82 schedule,
83 timezone,
84 enabled,
85 script_path,
86 is_flow,
87 args: None,
88 extra_perms,
89 email,
90 error: None,
91 on_failure: None,
92 on_failure_times: None,
93 on_failure_exact: None,
94 on_failure_extra_args: None,
95 on_recovery: None,
96 on_recovery_times: None,
97 on_recovery_extra_args: None,
98 on_success: None,
99 on_success_extra_args: None,
100 ws_error_handler_muted: None,
101 retry: None,
102 summary: None,
103 description: None,
104 no_flow_overlap: None,
105 tag: None,
106 paused_until: None,
107 cron_version: None,
108 }
109 }
110}
111