use crate::models;
use serde::{Deserialize, Serialize};
#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
pub struct FlowValue {
#[serde(rename = "modules")]
pub modules: Vec<models::FlowModule>,
#[serde(rename = "failure_module", skip_serializing_if = "Option::is_none")]
pub failure_module: Option<Box<models::FlowModule>>,
#[serde(rename = "preprocessor_module", skip_serializing_if = "Option::is_none")]
pub preprocessor_module: Option<Box<models::FlowModule>>,
#[serde(rename = "same_worker", skip_serializing_if = "Option::is_none")]
pub same_worker: Option<bool>,
#[serde(rename = "concurrent_limit", skip_serializing_if = "Option::is_none")]
pub concurrent_limit: Option<f64>,
#[serde(rename = "concurrency_key", skip_serializing_if = "Option::is_none")]
pub concurrency_key: Option<String>,
#[serde(rename = "concurrency_time_window_s", skip_serializing_if = "Option::is_none")]
pub concurrency_time_window_s: Option<f64>,
#[serde(rename = "debounce_delay_s", skip_serializing_if = "Option::is_none")]
pub debounce_delay_s: Option<i32>,
#[serde(rename = "debounce_key", skip_serializing_if = "Option::is_none")]
pub debounce_key: Option<String>,
#[serde(rename = "debounce_args_to_accumulate", skip_serializing_if = "Option::is_none")]
pub debounce_args_to_accumulate: Option<Vec<String>>,
#[serde(rename = "max_total_debouncing_time", skip_serializing_if = "Option::is_none")]
pub max_total_debouncing_time: Option<i32>,
#[serde(rename = "max_total_debounces_amount", skip_serializing_if = "Option::is_none")]
pub max_total_debounces_amount: Option<i32>,
#[serde(rename = "skip_expr", skip_serializing_if = "Option::is_none")]
pub skip_expr: Option<String>,
#[serde(rename = "cache_ttl", skip_serializing_if = "Option::is_none")]
pub cache_ttl: Option<f64>,
#[serde(rename = "cache_ignore_s3_path", skip_serializing_if = "Option::is_none")]
pub cache_ignore_s3_path: Option<bool>,
#[serde(rename = "delete_after_secs", skip_serializing_if = "Option::is_none")]
pub delete_after_secs: Option<i32>,
#[serde(rename = "flow_env", skip_serializing_if = "Option::is_none")]
pub flow_env: Option<std::collections::HashMap<String, serde_json::Value>>,
#[serde(rename = "priority", skip_serializing_if = "Option::is_none")]
pub priority: Option<f64>,
#[serde(rename = "early_return", skip_serializing_if = "Option::is_none")]
pub early_return: Option<String>,
#[serde(rename = "chat_input_enabled", skip_serializing_if = "Option::is_none")]
pub chat_input_enabled: Option<bool>,
#[serde(rename = "notes", skip_serializing_if = "Option::is_none")]
pub notes: Option<Vec<models::FlowNote>>,
#[serde(rename = "groups", skip_serializing_if = "Option::is_none")]
pub groups: Option<Vec<models::FlowGroup>>,
}
impl FlowValue {
pub fn new(modules: Vec<models::FlowModule>) -> FlowValue {
FlowValue {
modules,
failure_module: None,
preprocessor_module: None,
same_worker: None,
concurrent_limit: None,
concurrency_key: None,
concurrency_time_window_s: None,
debounce_delay_s: None,
debounce_key: None,
debounce_args_to_accumulate: None,
max_total_debouncing_time: None,
max_total_debounces_amount: None,
skip_expr: None,
cache_ttl: None,
cache_ignore_s3_path: None,
delete_after_secs: None,
flow_env: None,
priority: None,
early_return: None,
chat_input_enabled: None,
notes: None,
groups: None,
}
}
}