use crate::models;
use serde::{Deserialize, Serialize};
#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
pub struct ScheduleWJobs {
#[serde(rename = "path")]
pub path: String,
#[serde(rename = "edited_by")]
pub edited_by: String,
#[serde(rename = "edited_at")]
pub edited_at: String,
#[serde(rename = "schedule")]
pub schedule: String,
#[serde(rename = "timezone")]
pub timezone: String,
#[serde(rename = "enabled")]
pub enabled: bool,
#[serde(rename = "script_path")]
pub script_path: String,
#[serde(rename = "is_flow")]
pub is_flow: bool,
#[serde(rename = "args", skip_serializing_if = "Option::is_none")]
pub args: Option<std::collections::HashMap<String, serde_json::Value>>,
#[serde(rename = "extra_perms")]
pub extra_perms: std::collections::HashMap<String, bool>,
#[serde(rename = "email")]
pub email: String,
#[serde(rename = "permissioned_as")]
pub permissioned_as: String,
#[serde(rename = "error", default, with = "::serde_with::rust::double_option", skip_serializing_if = "Option::is_none")]
pub error: Option<Option<String>>,
#[serde(rename = "on_failure", default, with = "::serde_with::rust::double_option", skip_serializing_if = "Option::is_none")]
pub on_failure: Option<Option<String>>,
#[serde(rename = "on_failure_times", default, with = "::serde_with::rust::double_option", skip_serializing_if = "Option::is_none")]
pub on_failure_times: Option<Option<f64>>,
#[serde(rename = "on_failure_exact", default, with = "::serde_with::rust::double_option", skip_serializing_if = "Option::is_none")]
pub on_failure_exact: Option<Option<bool>>,
#[serde(rename = "on_failure_extra_args", skip_serializing_if = "Option::is_none")]
pub on_failure_extra_args: Option<std::collections::HashMap<String, serde_json::Value>>,
#[serde(rename = "on_recovery", default, with = "::serde_with::rust::double_option", skip_serializing_if = "Option::is_none")]
pub on_recovery: Option<Option<String>>,
#[serde(rename = "on_recovery_times", default, with = "::serde_with::rust::double_option", skip_serializing_if = "Option::is_none")]
pub on_recovery_times: Option<Option<f64>>,
#[serde(rename = "on_recovery_extra_args", skip_serializing_if = "Option::is_none")]
pub on_recovery_extra_args: Option<std::collections::HashMap<String, serde_json::Value>>,
#[serde(rename = "on_success", default, with = "::serde_with::rust::double_option", skip_serializing_if = "Option::is_none")]
pub on_success: Option<Option<String>>,
#[serde(rename = "on_success_extra_args", skip_serializing_if = "Option::is_none")]
pub on_success_extra_args: Option<std::collections::HashMap<String, serde_json::Value>>,
#[serde(rename = "ws_error_handler_muted", skip_serializing_if = "Option::is_none")]
pub ws_error_handler_muted: Option<bool>,
#[serde(rename = "retry", skip_serializing_if = "Option::is_none")]
pub retry: Option<Box<models::Retry>>,
#[serde(rename = "summary", default, with = "::serde_with::rust::double_option", skip_serializing_if = "Option::is_none")]
pub summary: Option<Option<String>>,
#[serde(rename = "description", default, with = "::serde_with::rust::double_option", skip_serializing_if = "Option::is_none")]
pub description: Option<Option<String>>,
#[serde(rename = "no_flow_overlap", skip_serializing_if = "Option::is_none")]
pub no_flow_overlap: Option<bool>,
#[serde(rename = "tag", default, with = "::serde_with::rust::double_option", skip_serializing_if = "Option::is_none")]
pub tag: Option<Option<String>>,
#[serde(rename = "paused_until", default, with = "::serde_with::rust::double_option", skip_serializing_if = "Option::is_none")]
pub paused_until: Option<Option<String>>,
#[serde(rename = "cron_version", default, with = "::serde_with::rust::double_option", skip_serializing_if = "Option::is_none")]
pub cron_version: Option<Option<String>>,
#[serde(rename = "dynamic_skip", default, with = "::serde_with::rust::double_option", skip_serializing_if = "Option::is_none")]
pub dynamic_skip: Option<Option<String>>,
#[serde(rename = "labels", skip_serializing_if = "Option::is_none")]
pub labels: Option<Vec<String>>,
#[serde(rename = "jobs", skip_serializing_if = "Option::is_none")]
pub jobs: Option<Vec<models::ScheduleWJobsAllOfJobs>>,
}
impl ScheduleWJobs {
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, permissioned_as: String) -> ScheduleWJobs {
ScheduleWJobs {
path,
edited_by,
edited_at,
schedule,
timezone,
enabled,
script_path,
is_flow,
args: None,
extra_perms,
email,
permissioned_as,
error: None,
on_failure: None,
on_failure_times: None,
on_failure_exact: None,
on_failure_extra_args: None,
on_recovery: None,
on_recovery_times: None,
on_recovery_extra_args: None,
on_success: None,
on_success_extra_args: None,
ws_error_handler_muted: None,
retry: None,
summary: None,
description: None,
no_flow_overlap: None,
tag: None,
paused_until: None,
cron_version: None,
dynamic_skip: None,
labels: None,
jobs: None,
}
}
}