#[non_exhaustive]
#[derive(::std::clone::Clone, ::std::cmp::PartialEq, ::std::fmt::Debug)]
pub struct DbSecurityGroup {
pub owner_id: ::std::option::Option<::std::string::String>,
pub db_security_group_name: ::std::option::Option<::std::string::String>,
pub db_security_group_description: ::std::option::Option<::std::string::String>,
pub vpc_id: ::std::option::Option<::std::string::String>,
pub ec2_security_groups: ::std::option::Option<::std::vec::Vec<crate::types::Ec2SecurityGroup>>,
pub ip_ranges: ::std::option::Option<::std::vec::Vec<crate::types::IpRange>>,
pub db_security_group_arn: ::std::option::Option<::std::string::String>,
}
impl DbSecurityGroup {
pub fn owner_id(&self) -> ::std::option::Option<&str> {
self.owner_id.as_deref()
}
pub fn db_security_group_name(&self) -> ::std::option::Option<&str> {
self.db_security_group_name.as_deref()
}
pub fn db_security_group_description(&self) -> ::std::option::Option<&str> {
self.db_security_group_description.as_deref()
}
pub fn vpc_id(&self) -> ::std::option::Option<&str> {
self.vpc_id.as_deref()
}
pub fn ec2_security_groups(&self) -> &[crate::types::Ec2SecurityGroup] {
self.ec2_security_groups.as_deref().unwrap_or_default()
}
pub fn ip_ranges(&self) -> &[crate::types::IpRange] {
self.ip_ranges.as_deref().unwrap_or_default()
}
pub fn db_security_group_arn(&self) -> ::std::option::Option<&str> {
self.db_security_group_arn.as_deref()
}
}
impl DbSecurityGroup {
pub fn builder() -> crate::types::builders::DbSecurityGroupBuilder {
crate::types::builders::DbSecurityGroupBuilder::default()
}
}
#[non_exhaustive]
#[derive(::std::clone::Clone, ::std::cmp::PartialEq, ::std::default::Default, ::std::fmt::Debug)]
pub struct DbSecurityGroupBuilder {
pub(crate) owner_id: ::std::option::Option<::std::string::String>,
pub(crate) db_security_group_name: ::std::option::Option<::std::string::String>,
pub(crate) db_security_group_description: ::std::option::Option<::std::string::String>,
pub(crate) vpc_id: ::std::option::Option<::std::string::String>,
pub(crate) ec2_security_groups: ::std::option::Option<::std::vec::Vec<crate::types::Ec2SecurityGroup>>,
pub(crate) ip_ranges: ::std::option::Option<::std::vec::Vec<crate::types::IpRange>>,
pub(crate) db_security_group_arn: ::std::option::Option<::std::string::String>,
}
impl DbSecurityGroupBuilder {
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 db_security_group_name(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
self.db_security_group_name = ::std::option::Option::Some(input.into());
self
}
pub fn set_db_security_group_name(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
self.db_security_group_name = input;
self
}
pub fn get_db_security_group_name(&self) -> &::std::option::Option<::std::string::String> {
&self.db_security_group_name
}
pub fn db_security_group_description(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
self.db_security_group_description = ::std::option::Option::Some(input.into());
self
}
pub fn set_db_security_group_description(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
self.db_security_group_description = input;
self
}
pub fn get_db_security_group_description(&self) -> &::std::option::Option<::std::string::String> {
&self.db_security_group_description
}
pub fn vpc_id(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
self.vpc_id = ::std::option::Option::Some(input.into());
self
}
pub fn set_vpc_id(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
self.vpc_id = input;
self
}
pub fn get_vpc_id(&self) -> &::std::option::Option<::std::string::String> {
&self.vpc_id
}
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 ip_ranges(mut self, input: crate::types::IpRange) -> Self {
let mut v = self.ip_ranges.unwrap_or_default();
v.push(input);
self.ip_ranges = ::std::option::Option::Some(v);
self
}
pub fn set_ip_ranges(mut self, input: ::std::option::Option<::std::vec::Vec<crate::types::IpRange>>) -> Self {
self.ip_ranges = input;
self
}
pub fn get_ip_ranges(&self) -> &::std::option::Option<::std::vec::Vec<crate::types::IpRange>> {
&self.ip_ranges
}
pub fn db_security_group_arn(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
self.db_security_group_arn = ::std::option::Option::Some(input.into());
self
}
pub fn set_db_security_group_arn(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
self.db_security_group_arn = input;
self
}
pub fn get_db_security_group_arn(&self) -> &::std::option::Option<::std::string::String> {
&self.db_security_group_arn
}
pub fn build(self) -> crate::types::DbSecurityGroup {
crate::types::DbSecurityGroup {
owner_id: self.owner_id,
db_security_group_name: self.db_security_group_name,
db_security_group_description: self.db_security_group_description,
vpc_id: self.vpc_id,
ec2_security_groups: self.ec2_security_groups,
ip_ranges: self.ip_ranges,
db_security_group_arn: self.db_security_group_arn,
}
}
}