Skip to main content

windmill_api/models/
azure_trigger_data.rs

1/*
2 * Windmill API
3 *
4 * No description provided (generated by Openapi Generator https://github.com/openapitools/openapi-generator)
5 *
6 * The version of the OpenAPI document: 1.693.2
7 * Contact: contact@windmill.dev
8 * Generated by: https://openapi-generator.tech
9 */
10
11use crate::models;
12use serde::{Deserialize, Serialize};
13
14/// AzureTriggerData : Data for creating or updating an Azure Event Grid trigger.
15#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
16pub struct AzureTriggerData {
17    #[serde(rename = "azure_resource_path")]
18    pub azure_resource_path: String,
19    #[serde(rename = "azure_mode")]
20    pub azure_mode: models::AzureMode,
21    #[serde(rename = "scope_resource_id")]
22    pub scope_resource_id: String,
23    #[serde(rename = "topic_name", default, with = "::serde_with::rust::double_option", skip_serializing_if = "Option::is_none")]
24    pub topic_name: Option<Option<String>>,
25    #[serde(rename = "subscription_name")]
26    pub subscription_name: String,
27    /// Base URL for push delivery endpoints (push modes only).
28    #[serde(rename = "base_endpoint", skip_serializing_if = "Option::is_none")]
29    pub base_endpoint: Option<String>,
30    #[serde(rename = "event_type_filters", skip_serializing_if = "Option::is_none")]
31    pub event_type_filters: Option<Vec<String>>,
32    /// The unique Windmill path for this trigger. Must be of the form `u/<user>/<path>` or `f/<folder>/<path>`. This is the trigger object path, not the HTTP route path.
33    #[serde(rename = "path")]
34    pub path: String,
35    #[serde(rename = "script_path")]
36    pub script_path: String,
37    #[serde(rename = "is_flow")]
38    pub is_flow: bool,
39    #[serde(rename = "mode", skip_serializing_if = "Option::is_none")]
40    pub mode: Option<models::TriggerMode>,
41    #[serde(rename = "error_handler_path", skip_serializing_if = "Option::is_none")]
42    pub error_handler_path: Option<String>,
43    /// The arguments to pass to the script or flow
44    #[serde(rename = "error_handler_args", skip_serializing_if = "Option::is_none")]
45    pub error_handler_args: Option<std::collections::HashMap<String, serde_json::Value>>,
46    #[serde(rename = "retry", skip_serializing_if = "Option::is_none")]
47    pub retry: Option<Box<models::Retry>>,
48    #[serde(rename = "permissioned_as", skip_serializing_if = "Option::is_none")]
49    pub permissioned_as: Option<String>,
50    #[serde(rename = "preserve_permissioned_as", skip_serializing_if = "Option::is_none")]
51    pub preserve_permissioned_as: Option<bool>,
52    #[serde(rename = "labels", skip_serializing_if = "Option::is_none")]
53    pub labels: Option<Vec<String>>,
54}
55
56impl AzureTriggerData {
57    /// Data for creating or updating an Azure Event Grid trigger.
58    pub fn new(azure_resource_path: String, azure_mode: models::AzureMode, scope_resource_id: String, subscription_name: String, path: String, script_path: String, is_flow: bool) -> AzureTriggerData {
59        AzureTriggerData {
60            azure_resource_path,
61            azure_mode,
62            scope_resource_id,
63            topic_name: None,
64            subscription_name,
65            base_endpoint: None,
66            event_type_filters: None,
67            path,
68            script_path,
69            is_flow,
70            mode: None,
71            error_handler_path: None,
72            error_handler_args: None,
73            retry: None,
74            permissioned_as: None,
75            preserve_permissioned_as: None,
76            labels: None,
77        }
78    }
79}
80