#[non_exhaustive]
#[derive(::std::clone::Clone, ::std::cmp::PartialEq, ::std::fmt::Debug)]
pub struct CacheSecurityGroup {
pub owner_id: ::std::option::Option<::std::string::String>,
pub cache_security_group_name: ::std::option::Option<::std::string::String>,
pub description: ::std::option::Option<::std::string::String>,
pub ec2_security_groups: ::std::option::Option<::std::vec::Vec<crate::types::Ec2SecurityGroup>>,
pub arn: ::std::option::Option<::std::string::String>,
}
impl CacheSecurityGroup {
pub fn owner_id(&self) -> ::std::option::Option<&str> {
self.owner_id.as_deref()
}
pub fn cache_security_group_name(&self) -> ::std::option::Option<&str> {
self.cache_security_group_name.as_deref()
}
pub fn description(&self) -> ::std::option::Option<&str> {
self.description.as_deref()
}
pub fn ec2_security_groups(&self) -> &[crate::types::Ec2SecurityGroup] {
self.ec2_security_groups.as_deref().unwrap_or_default()
}
pub fn arn(&self) -> ::std::option::Option<&str> {
self.arn.as_deref()
}
}
impl CacheSecurityGroup {
pub fn builder() -> crate::types::builders::CacheSecurityGroupBuilder {
crate::types::builders::CacheSecurityGroupBuilder::default()
}
}
#[non_exhaustive]
#[derive(::std::clone::Clone, ::std::cmp::PartialEq, ::std::default::Default, ::std::fmt::Debug)]
pub struct CacheSecurityGroupBuilder {
pub(crate) owner_id: ::std::option::Option<::std::string::String>,
pub(crate) cache_security_group_name: ::std::option::Option<::std::string::String>,
pub(crate) description: ::std::option::Option<::std::string::String>,
pub(crate) ec2_security_groups: ::std::option::Option<::std::vec::Vec<crate::types::Ec2SecurityGroup>>,
pub(crate) arn: ::std::option::Option<::std::string::String>,
}
impl CacheSecurityGroupBuilder {
pub fn owner_id(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
self.owner_id = ::std::option::Option::Some(input.into());
self
}
pub fn set_owner_id(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
self.owner_id = input;
self
}
pub fn get_owner_id(&self) -> &::std::option::Option<::std::string::String> {
&self.owner_id
}
pub fn cache_security_group_name(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
self.cache_security_group_name = ::std::option::Option::Some(input.into());
self
}
pub fn set_cache_security_group_name(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
self.cache_security_group_name = input;
self
}
pub fn get_cache_security_group_name(&self) -> &::std::option::Option<::std::string::String> {
&self.cache_security_group_name
}
pub fn description(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
self.description = ::std::option::Option::Some(input.into());
self
}
pub fn set_description(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
self.description = input;
self
}
pub fn get_description(&self) -> &::std::option::Option<::std::string::String> {
&self.description
}
pub fn ec2_security_groups(mut self, input: crate::types::Ec2SecurityGroup) -> Self {
let mut v = self.ec2_security_groups.unwrap_or_default();
v.push(input);
self.ec2_security_groups = ::std::option::Option::Some(v);
self
}
pub fn set_ec2_security_groups(mut self, input: ::std::option::Option<::std::vec::Vec<crate::types::Ec2SecurityGroup>>) -> Self {
self.ec2_security_groups = input;
self
}
pub fn get_ec2_security_groups(&self) -> &::std::option::Option<::std::vec::Vec<crate::types::Ec2SecurityGroup>> {
&self.ec2_security_groups
}
pub fn arn(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
self.arn = ::std::option::Option::Some(input.into());
self
}
pub fn set_arn(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
self.arn = input;
self
}
pub fn get_arn(&self) -> &::std::option::Option<::std::string::String> {
&self.arn
}
pub fn build(self) -> crate::types::CacheSecurityGroup {
crate::types::CacheSecurityGroup {
owner_id: self.owner_id,
cache_security_group_name: self.cache_security_group_name,
description: self.description,
ec2_security_groups: self.ec2_security_groups,
arn: self.arn,
}
}
}