#[non_exhaustive]
#[derive(::std::clone::Clone, ::std::cmp::PartialEq, ::std::fmt::Debug)]
pub struct FirewallStatelessRule {
pub rule_group_arn: ::std::option::Option<::std::string::String>,
pub sources: ::std::option::Option<::std::vec::Vec<::std::string::String>>,
pub destinations: ::std::option::Option<::std::vec::Vec<::std::string::String>>,
pub source_ports: ::std::option::Option<::std::vec::Vec<crate::types::PortRange>>,
pub destination_ports: ::std::option::Option<::std::vec::Vec<crate::types::PortRange>>,
pub protocols: ::std::option::Option<::std::vec::Vec<i32>>,
pub rule_action: ::std::option::Option<::std::string::String>,
pub priority: ::std::option::Option<i32>,
}
impl FirewallStatelessRule {
pub fn rule_group_arn(&self) -> ::std::option::Option<&str> {
self.rule_group_arn.as_deref()
}
pub fn sources(&self) -> &[::std::string::String] {
self.sources.as_deref().unwrap_or_default()
}
pub fn destinations(&self) -> &[::std::string::String] {
self.destinations.as_deref().unwrap_or_default()
}
pub fn source_ports(&self) -> &[crate::types::PortRange] {
self.source_ports.as_deref().unwrap_or_default()
}
pub fn destination_ports(&self) -> &[crate::types::PortRange] {
self.destination_ports.as_deref().unwrap_or_default()
}
pub fn protocols(&self) -> &[i32] {
self.protocols.as_deref().unwrap_or_default()
}
pub fn rule_action(&self) -> ::std::option::Option<&str> {
self.rule_action.as_deref()
}
pub fn priority(&self) -> ::std::option::Option<i32> {
self.priority
}
}
impl FirewallStatelessRule {
pub fn builder() -> crate::types::builders::FirewallStatelessRuleBuilder {
crate::types::builders::FirewallStatelessRuleBuilder::default()
}
}
#[non_exhaustive]
#[derive(::std::clone::Clone, ::std::cmp::PartialEq, ::std::default::Default, ::std::fmt::Debug)]
pub struct FirewallStatelessRuleBuilder {
pub(crate) rule_group_arn: ::std::option::Option<::std::string::String>,
pub(crate) sources: ::std::option::Option<::std::vec::Vec<::std::string::String>>,
pub(crate) destinations: ::std::option::Option<::std::vec::Vec<::std::string::String>>,
pub(crate) source_ports: ::std::option::Option<::std::vec::Vec<crate::types::PortRange>>,
pub(crate) destination_ports: ::std::option::Option<::std::vec::Vec<crate::types::PortRange>>,
pub(crate) protocols: ::std::option::Option<::std::vec::Vec<i32>>,
pub(crate) rule_action: ::std::option::Option<::std::string::String>,
pub(crate) priority: ::std::option::Option<i32>,
}
impl FirewallStatelessRuleBuilder {
pub fn rule_group_arn(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
self.rule_group_arn = ::std::option::Option::Some(input.into());
self
}
pub fn set_rule_group_arn(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
self.rule_group_arn = input;
self
}
pub fn get_rule_group_arn(&self) -> &::std::option::Option<::std::string::String> {
&self.rule_group_arn
}
pub fn sources(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
let mut v = self.sources.unwrap_or_default();
v.push(input.into());
self.sources = ::std::option::Option::Some(v);
self
}
pub fn set_sources(mut self, input: ::std::option::Option<::std::vec::Vec<::std::string::String>>) -> Self {
self.sources = input;
self
}
pub fn get_sources(&self) -> &::std::option::Option<::std::vec::Vec<::std::string::String>> {
&self.sources
}
pub fn destinations(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
let mut v = self.destinations.unwrap_or_default();
v.push(input.into());
self.destinations = ::std::option::Option::Some(v);
self
}
pub fn set_destinations(mut self, input: ::std::option::Option<::std::vec::Vec<::std::string::String>>) -> Self {
self.destinations = input;
self
}
pub fn get_destinations(&self) -> &::std::option::Option<::std::vec::Vec<::std::string::String>> {
&self.destinations
}
pub fn source_ports(mut self, input: crate::types::PortRange) -> Self {
let mut v = self.source_ports.unwrap_or_default();
v.push(input);
self.source_ports = ::std::option::Option::Some(v);
self
}
pub fn set_source_ports(mut self, input: ::std::option::Option<::std::vec::Vec<crate::types::PortRange>>) -> Self {
self.source_ports = input;
self
}
pub fn get_source_ports(&self) -> &::std::option::Option<::std::vec::Vec<crate::types::PortRange>> {
&self.source_ports
}
pub fn destination_ports(mut self, input: crate::types::PortRange) -> Self {
let mut v = self.destination_ports.unwrap_or_default();
v.push(input);
self.destination_ports = ::std::option::Option::Some(v);
self
}
pub fn set_destination_ports(mut self, input: ::std::option::Option<::std::vec::Vec<crate::types::PortRange>>) -> Self {
self.destination_ports = input;
self
}
pub fn get_destination_ports(&self) -> &::std::option::Option<::std::vec::Vec<crate::types::PortRange>> {
&self.destination_ports
}
pub fn protocols(mut self, input: i32) -> Self {
let mut v = self.protocols.unwrap_or_default();
v.push(input);
self.protocols = ::std::option::Option::Some(v);
self
}
pub fn set_protocols(mut self, input: ::std::option::Option<::std::vec::Vec<i32>>) -> Self {
self.protocols = input;
self
}
pub fn get_protocols(&self) -> &::std::option::Option<::std::vec::Vec<i32>> {
&self.protocols
}
pub fn rule_action(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
self.rule_action = ::std::option::Option::Some(input.into());
self
}
pub fn set_rule_action(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
self.rule_action = input;
self
}
pub fn get_rule_action(&self) -> &::std::option::Option<::std::string::String> {
&self.rule_action
}
pub fn priority(mut self, input: i32) -> Self {
self.priority = ::std::option::Option::Some(input);
self
}
pub fn set_priority(mut self, input: ::std::option::Option<i32>) -> Self {
self.priority = input;
self
}
pub fn get_priority(&self) -> &::std::option::Option<i32> {
&self.priority
}
pub fn build(self) -> crate::types::FirewallStatelessRule {
crate::types::FirewallStatelessRule {
rule_group_arn: self.rule_group_arn,
sources: self.sources,
destinations: self.destinations,
source_ports: self.source_ports,
destination_ports: self.destination_ports,
protocols: self.protocols,
rule_action: self.rule_action,
priority: self.priority,
}
}
}