use crate::models;
#[derive(Clone, Debug, serde::Deserialize, serde::Serialize)]
#[derive(derivative::Derivative)]
#[derivative(Default)]
pub struct AllowDeny {
#[serde(rename = "@odata.context")]
#[serde(skip_deserializing)]
#[serde(default, skip_serializing_if = "Option::is_none")]
pub odata_context: Option<models::odata_v4::Context>,
#[serde(rename = "@odata.etag")]
#[serde(skip_deserializing)]
#[serde(default, skip_serializing_if = "Option::is_none")]
pub odata_etag: Option<models::odata_v4::Etag>,
#[serde(rename = "@odata.id")]
#[serde(skip_deserializing)]
pub odata_id: models::odata_v4::Id,
#[serde(rename = "@odata.type")]
#[serde(skip_deserializing)]
#[derivative(Default(value = "models::odata_v4::Type(\"#AllowDeny.v1_0_0.AllowDeny\".to_string())"))]
pub odata_type: models::odata_v4::Type,
#[serde(rename = "Actions")]
#[serde(default, skip_serializing_if = "Option::is_none")]
pub actions: Option<models::allow_deny::v1_0_0::Actions>,
#[serde(rename = "AllowType")]
#[serde(default, skip_serializing_if = "Option::is_none")]
pub allow_type: Option<models::allow_deny::v1_0_0::AllowType>,
#[serde(rename = "Description")]
#[serde(default, skip_serializing_if = "Option::is_none")]
pub description: Option<models::resource::Description>,
#[serde(rename = "DestinationPortLower")]
#[serde(default, skip_serializing_if = "Option::is_none")]
pub destination_port_lower: Option<i64>,
#[serde(rename = "DestinationPortUpper")]
#[serde(default, skip_serializing_if = "Option::is_none")]
pub destination_port_upper: Option<i64>,
#[serde(rename = "Direction")]
#[serde(default, skip_serializing_if = "Option::is_none")]
pub direction: Option<models::allow_deny::v1_0_0::DataDirection>,
#[serde(rename = "IANAProtocolNumber")]
#[serde(default, skip_serializing_if = "Option::is_none")]
pub iana_protocol_number: Option<i64>,
#[serde(rename = "IPAddressLower")]
#[serde(default, skip_serializing_if = "Option::is_none")]
pub ip_address_lower: Option<String>,
#[serde(rename = "IPAddressType")]
#[serde(default, skip_serializing_if = "Option::is_none")]
pub ip_address_type: Option<models::allow_deny::v1_0_0::IPAddressType>,
#[serde(rename = "IPAddressUpper")]
#[serde(default, skip_serializing_if = "Option::is_none")]
pub ip_address_upper: Option<String>,
#[serde(rename = "Id")]
#[serde(skip_deserializing)]
pub id: models::resource::Id,
#[serde(rename = "Name")]
#[serde(skip_deserializing)]
pub name: models::resource::Name,
#[serde(rename = "Oem")]
#[serde(default, skip_serializing_if = "Option::is_none")]
pub oem: Option<models::resource::Oem>,
#[serde(rename = "SourcePortLower")]
#[serde(default, skip_serializing_if = "Option::is_none")]
pub source_port_lower: Option<i64>,
#[serde(rename = "SourcePortUpper")]
#[serde(default, skip_serializing_if = "Option::is_none")]
pub source_port_upper: Option<i64>,
#[serde(rename = "StatefulSession")]
#[serde(default, skip_serializing_if = "Option::is_none")]
pub stateful_session: Option<bool>,
}
impl crate::Metadata<'static> for AllowDeny {
const JSON_SCHEMA: &'static str = "AllowDeny.v1_0_0.json";
}