Skip to main content

clientapi_pve/models/
nodes_firewall_set_options_request.rs

1/*
2 * Proxmox Virtual Environment API
3 *
4 * Generated from apidoc.js. NOT an official Proxmox specification. See https://pve.proxmox.com/pve-docs/api-viewer/ for the upstream documentation.
5 *
6 * The version of the OpenAPI document: 9.x
7 * 
8 * Generated by: https://openapi-generator.tech
9 */
10
11use crate::models;
12use serde::{Deserialize, Serialize};
13
14#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
15pub struct NodesFirewallSetOptionsRequest {
16
17    /// A list of settings you want to delete.
18    #[serde(rename = "delete", skip_serializing_if = "Option::is_none")]
19    pub delete: Option<String>,
20
21    /// Prevent changes if current configuration file has a different digest. This can be used to prevent concurrent modifications.
22    #[serde(rename = "digest", skip_serializing_if = "Option::is_none")]
23    pub digest: Option<String>,
24
25    /// Enable host firewall rules.
26    #[serde(rename = "enable", skip_serializing_if = "Option::is_none")]
27    pub enable: Option<models::PveBoolean>,
28
29    /// Log level for forwarded traffic.
30    #[serde(rename = "log_level_forward", skip_serializing_if = "Option::is_none")]
31    pub log_level_forward: Option<models::PveLogEnum>,
32
33    /// Log level for incoming traffic.
34    #[serde(rename = "log_level_in", skip_serializing_if = "Option::is_none")]
35    pub log_level_in: Option<models::PveLogEnum>,
36
37    /// Log level for outgoing traffic.
38    #[serde(rename = "log_level_out", skip_serializing_if = "Option::is_none")]
39    pub log_level_out: Option<models::PveLogEnum>,
40
41    /// Enable logging of conntrack information.
42    #[serde(rename = "log_nf_conntrack", skip_serializing_if = "Option::is_none")]
43    pub log_nf_conntrack: Option<models::PveBoolean>,
44
45    /// Enable NDP (Neighbor Discovery Protocol).
46    #[serde(rename = "ndp", skip_serializing_if = "Option::is_none")]
47    pub ndp: Option<models::PveBoolean>,
48
49    /// Allow invalid packets on connection tracking.
50    #[serde(rename = "nf_conntrack_allow_invalid", skip_serializing_if = "Option::is_none")]
51    pub nf_conntrack_allow_invalid: Option<models::PveBoolean>,
52
53    /// Enable conntrack helpers for specific protocols. Supported protocols: amanda, ftp, irc, netbios-ns, pptp, sane, sip, snmp, tftp
54    #[serde(rename = "nf_conntrack_helpers", skip_serializing_if = "Option::is_none")]
55    pub nf_conntrack_helpers: Option<String>,
56
57    /// Maximum number of tracked connections.
58    #[serde(rename = "nf_conntrack_max", skip_serializing_if = "Option::is_none")]
59    pub nf_conntrack_max: Option<i64>,
60
61    /// Conntrack established timeout.
62    #[serde(rename = "nf_conntrack_tcp_timeout_established", skip_serializing_if = "Option::is_none")]
63    pub nf_conntrack_tcp_timeout_established: Option<i64>,
64
65    /// Conntrack syn recv timeout.
66    #[serde(rename = "nf_conntrack_tcp_timeout_syn_recv", skip_serializing_if = "Option::is_none")]
67    pub nf_conntrack_tcp_timeout_syn_recv: Option<i32>,
68
69    /// Enable nftables based firewall (tech preview)
70    #[serde(rename = "nftables", skip_serializing_if = "Option::is_none")]
71    pub nftables: Option<models::PveBoolean>,
72
73    /// Enable SMURFS filter.
74    #[serde(rename = "nosmurfs", skip_serializing_if = "Option::is_none")]
75    pub nosmurfs: Option<models::PveBoolean>,
76
77    /// Enable synflood protection
78    #[serde(rename = "protection_synflood", skip_serializing_if = "Option::is_none")]
79    pub protection_synflood: Option<models::PveBoolean>,
80
81    /// Synflood protection rate burst by ip src.
82    #[serde(rename = "protection_synflood_burst", skip_serializing_if = "Option::is_none")]
83    pub protection_synflood_burst: Option<i64>,
84
85    /// Synflood protection rate syn/sec by ip src.
86    #[serde(rename = "protection_synflood_rate", skip_serializing_if = "Option::is_none")]
87    pub protection_synflood_rate: Option<i64>,
88
89    /// Log level for SMURFS filter.
90    #[serde(rename = "smurf_log_level", skip_serializing_if = "Option::is_none")]
91    pub smurf_log_level: Option<models::PveLogEnum>,
92
93    /// Log level for illegal tcp flags filter.
94    #[serde(rename = "tcp_flags_log_level", skip_serializing_if = "Option::is_none")]
95    pub tcp_flags_log_level: Option<models::PveLogEnum>,
96
97    /// Filter illegal combinations of TCP flags.
98    #[serde(rename = "tcpflags", skip_serializing_if = "Option::is_none")]
99    pub tcpflags: Option<models::PveBoolean>,
100
101
102}
103
104impl NodesFirewallSetOptionsRequest {
105    pub fn new() -> NodesFirewallSetOptionsRequest {
106        NodesFirewallSetOptionsRequest {
107            
108            delete: None,
109            
110            digest: None,
111            
112            enable: None,
113            
114            log_level_forward: None,
115            
116            log_level_in: None,
117            
118            log_level_out: None,
119            
120            log_nf_conntrack: None,
121            
122            ndp: None,
123            
124            nf_conntrack_allow_invalid: None,
125            
126            nf_conntrack_helpers: None,
127            
128            nf_conntrack_max: None,
129            
130            nf_conntrack_tcp_timeout_established: None,
131            
132            nf_conntrack_tcp_timeout_syn_recv: None,
133            
134            nftables: None,
135            
136            nosmurfs: None,
137            
138            protection_synflood: None,
139            
140            protection_synflood_burst: None,
141            
142            protection_synflood_rate: None,
143            
144            smurf_log_level: None,
145            
146            tcp_flags_log_level: None,
147            
148            tcpflags: None,
149            
150        }
151    }
152}
153
154