#[non_exhaustive]
#[derive(::std::clone::Clone, ::std::cmp::PartialEq)]
pub struct CreateTrustInput {
pub directory_id: ::std::option::Option<::std::string::String>,
pub remote_domain_name: ::std::option::Option<::std::string::String>,
pub trust_password: ::std::option::Option<::std::string::String>,
pub trust_direction: ::std::option::Option<crate::types::TrustDirection>,
pub trust_type: ::std::option::Option<crate::types::TrustType>,
pub conditional_forwarder_ip_addrs: ::std::option::Option<::std::vec::Vec<::std::string::String>>,
pub conditional_forwarder_ipv6_addrs: ::std::option::Option<::std::vec::Vec<::std::string::String>>,
pub selective_auth: ::std::option::Option<crate::types::SelectiveAuth>,
}
impl CreateTrustInput {
pub fn directory_id(&self) -> ::std::option::Option<&str> {
self.directory_id.as_deref()
}
pub fn remote_domain_name(&self) -> ::std::option::Option<&str> {
self.remote_domain_name.as_deref()
}
pub fn trust_password(&self) -> ::std::option::Option<&str> {
self.trust_password.as_deref()
}
pub fn trust_direction(&self) -> ::std::option::Option<&crate::types::TrustDirection> {
self.trust_direction.as_ref()
}
pub fn trust_type(&self) -> ::std::option::Option<&crate::types::TrustType> {
self.trust_type.as_ref()
}
pub fn conditional_forwarder_ip_addrs(&self) -> &[::std::string::String] {
self.conditional_forwarder_ip_addrs.as_deref().unwrap_or_default()
}
pub fn conditional_forwarder_ipv6_addrs(&self) -> &[::std::string::String] {
self.conditional_forwarder_ipv6_addrs.as_deref().unwrap_or_default()
}
pub fn selective_auth(&self) -> ::std::option::Option<&crate::types::SelectiveAuth> {
self.selective_auth.as_ref()
}
}
impl ::std::fmt::Debug for CreateTrustInput {
fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
let mut formatter = f.debug_struct("CreateTrustInput");
formatter.field("directory_id", &self.directory_id);
formatter.field("remote_domain_name", &self.remote_domain_name);
formatter.field("trust_password", &"*** Sensitive Data Redacted ***");
formatter.field("trust_direction", &self.trust_direction);
formatter.field("trust_type", &self.trust_type);
formatter.field("conditional_forwarder_ip_addrs", &self.conditional_forwarder_ip_addrs);
formatter.field("conditional_forwarder_ipv6_addrs", &self.conditional_forwarder_ipv6_addrs);
formatter.field("selective_auth", &self.selective_auth);
formatter.finish()
}
}
impl CreateTrustInput {
pub fn builder() -> crate::operation::create_trust::builders::CreateTrustInputBuilder {
crate::operation::create_trust::builders::CreateTrustInputBuilder::default()
}
}
#[derive(::std::clone::Clone, ::std::cmp::PartialEq, ::std::default::Default)]
#[non_exhaustive]
pub struct CreateTrustInputBuilder {
pub(crate) directory_id: ::std::option::Option<::std::string::String>,
pub(crate) remote_domain_name: ::std::option::Option<::std::string::String>,
pub(crate) trust_password: ::std::option::Option<::std::string::String>,
pub(crate) trust_direction: ::std::option::Option<crate::types::TrustDirection>,
pub(crate) trust_type: ::std::option::Option<crate::types::TrustType>,
pub(crate) conditional_forwarder_ip_addrs: ::std::option::Option<::std::vec::Vec<::std::string::String>>,
pub(crate) conditional_forwarder_ipv6_addrs: ::std::option::Option<::std::vec::Vec<::std::string::String>>,
pub(crate) selective_auth: ::std::option::Option<crate::types::SelectiveAuth>,
}
impl CreateTrustInputBuilder {
pub fn directory_id(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
self.directory_id = ::std::option::Option::Some(input.into());
self
}
pub fn set_directory_id(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
self.directory_id = input;
self
}
pub fn get_directory_id(&self) -> &::std::option::Option<::std::string::String> {
&self.directory_id
}
pub fn remote_domain_name(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
self.remote_domain_name = ::std::option::Option::Some(input.into());
self
}
pub fn set_remote_domain_name(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
self.remote_domain_name = input;
self
}
pub fn get_remote_domain_name(&self) -> &::std::option::Option<::std::string::String> {
&self.remote_domain_name
}
pub fn trust_password(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
self.trust_password = ::std::option::Option::Some(input.into());
self
}
pub fn set_trust_password(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
self.trust_password = input;
self
}
pub fn get_trust_password(&self) -> &::std::option::Option<::std::string::String> {
&self.trust_password
}
pub fn trust_direction(mut self, input: crate::types::TrustDirection) -> Self {
self.trust_direction = ::std::option::Option::Some(input);
self
}
pub fn set_trust_direction(mut self, input: ::std::option::Option<crate::types::TrustDirection>) -> Self {
self.trust_direction = input;
self
}
pub fn get_trust_direction(&self) -> &::std::option::Option<crate::types::TrustDirection> {
&self.trust_direction
}
pub fn trust_type(mut self, input: crate::types::TrustType) -> Self {
self.trust_type = ::std::option::Option::Some(input);
self
}
pub fn set_trust_type(mut self, input: ::std::option::Option<crate::types::TrustType>) -> Self {
self.trust_type = input;
self
}
pub fn get_trust_type(&self) -> &::std::option::Option<crate::types::TrustType> {
&self.trust_type
}
pub fn conditional_forwarder_ip_addrs(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
let mut v = self.conditional_forwarder_ip_addrs.unwrap_or_default();
v.push(input.into());
self.conditional_forwarder_ip_addrs = ::std::option::Option::Some(v);
self
}
pub fn set_conditional_forwarder_ip_addrs(mut self, input: ::std::option::Option<::std::vec::Vec<::std::string::String>>) -> Self {
self.conditional_forwarder_ip_addrs = input;
self
}
pub fn get_conditional_forwarder_ip_addrs(&self) -> &::std::option::Option<::std::vec::Vec<::std::string::String>> {
&self.conditional_forwarder_ip_addrs
}
pub fn conditional_forwarder_ipv6_addrs(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
let mut v = self.conditional_forwarder_ipv6_addrs.unwrap_or_default();
v.push(input.into());
self.conditional_forwarder_ipv6_addrs = ::std::option::Option::Some(v);
self
}
pub fn set_conditional_forwarder_ipv6_addrs(mut self, input: ::std::option::Option<::std::vec::Vec<::std::string::String>>) -> Self {
self.conditional_forwarder_ipv6_addrs = input;
self
}
pub fn get_conditional_forwarder_ipv6_addrs(&self) -> &::std::option::Option<::std::vec::Vec<::std::string::String>> {
&self.conditional_forwarder_ipv6_addrs
}
pub fn selective_auth(mut self, input: crate::types::SelectiveAuth) -> Self {
self.selective_auth = ::std::option::Option::Some(input);
self
}
pub fn set_selective_auth(mut self, input: ::std::option::Option<crate::types::SelectiveAuth>) -> Self {
self.selective_auth = input;
self
}
pub fn get_selective_auth(&self) -> &::std::option::Option<crate::types::SelectiveAuth> {
&self.selective_auth
}
pub fn build(self) -> ::std::result::Result<crate::operation::create_trust::CreateTrustInput, ::aws_smithy_types::error::operation::BuildError> {
::std::result::Result::Ok(crate::operation::create_trust::CreateTrustInput {
directory_id: self.directory_id,
remote_domain_name: self.remote_domain_name,
trust_password: self.trust_password,
trust_direction: self.trust_direction,
trust_type: self.trust_type,
conditional_forwarder_ip_addrs: self.conditional_forwarder_ip_addrs,
conditional_forwarder_ipv6_addrs: self.conditional_forwarder_ipv6_addrs,
selective_auth: self.selective_auth,
})
}
}
impl ::std::fmt::Debug for CreateTrustInputBuilder {
fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
let mut formatter = f.debug_struct("CreateTrustInputBuilder");
formatter.field("directory_id", &self.directory_id);
formatter.field("remote_domain_name", &self.remote_domain_name);
formatter.field("trust_password", &"*** Sensitive Data Redacted ***");
formatter.field("trust_direction", &self.trust_direction);
formatter.field("trust_type", &self.trust_type);
formatter.field("conditional_forwarder_ip_addrs", &self.conditional_forwarder_ip_addrs);
formatter.field("conditional_forwarder_ipv6_addrs", &self.conditional_forwarder_ipv6_addrs);
formatter.field("selective_auth", &self.selective_auth);
formatter.finish()
}
}