#[allow(missing_docs)] #[non_exhaustive]
#[derive(::std::clone::Clone, ::std::cmp::PartialEq, ::std::fmt::Debug)]
pub struct CreateProbeOutput {
pub probe_id: ::std::option::Option<::std::string::String>,
pub probe_arn: ::std::option::Option<::std::string::String>,
pub source_arn: ::std::string::String,
pub destination: ::std::string::String,
pub destination_port: ::std::option::Option<i32>,
pub protocol: crate::types::Protocol,
pub packet_size: ::std::option::Option<i32>,
pub address_family: ::std::option::Option<crate::types::AddressFamily>,
pub vpc_id: ::std::option::Option<::std::string::String>,
pub state: ::std::option::Option<crate::types::ProbeState>,
pub created_at: ::std::option::Option<::aws_smithy_types::DateTime>,
pub modified_at: ::std::option::Option<::aws_smithy_types::DateTime>,
pub tags: ::std::option::Option<::std::collections::HashMap<::std::string::String, ::std::string::String>>,
_request_id: Option<String>,
}
impl CreateProbeOutput {
pub fn probe_id(&self) -> ::std::option::Option<&str> {
self.probe_id.as_deref()
}
pub fn probe_arn(&self) -> ::std::option::Option<&str> {
self.probe_arn.as_deref()
}
pub fn source_arn(&self) -> &str {
use std::ops::Deref;
self.source_arn.deref()
}
pub fn destination(&self) -> &str {
use std::ops::Deref;
self.destination.deref()
}
pub fn destination_port(&self) -> ::std::option::Option<i32> {
self.destination_port
}
pub fn protocol(&self) -> &crate::types::Protocol {
&self.protocol
}
pub fn packet_size(&self) -> ::std::option::Option<i32> {
self.packet_size
}
pub fn address_family(&self) -> ::std::option::Option<&crate::types::AddressFamily> {
self.address_family.as_ref()
}
pub fn vpc_id(&self) -> ::std::option::Option<&str> {
self.vpc_id.as_deref()
}
pub fn state(&self) -> ::std::option::Option<&crate::types::ProbeState> {
self.state.as_ref()
}
pub fn created_at(&self) -> ::std::option::Option<&::aws_smithy_types::DateTime> {
self.created_at.as_ref()
}
pub fn modified_at(&self) -> ::std::option::Option<&::aws_smithy_types::DateTime> {
self.modified_at.as_ref()
}
pub fn tags(&self) -> ::std::option::Option<&::std::collections::HashMap<::std::string::String, ::std::string::String>> {
self.tags.as_ref()
}
}
impl ::aws_types::request_id::RequestId for CreateProbeOutput {
fn request_id(&self) -> Option<&str> {
self._request_id.as_deref()
}
}
impl CreateProbeOutput {
pub fn builder() -> crate::operation::create_probe::builders::CreateProbeOutputBuilder {
crate::operation::create_probe::builders::CreateProbeOutputBuilder::default()
}
}
#[derive(::std::clone::Clone, ::std::cmp::PartialEq, ::std::default::Default, ::std::fmt::Debug)]
#[non_exhaustive]
pub struct CreateProbeOutputBuilder {
pub(crate) probe_id: ::std::option::Option<::std::string::String>,
pub(crate) probe_arn: ::std::option::Option<::std::string::String>,
pub(crate) source_arn: ::std::option::Option<::std::string::String>,
pub(crate) destination: ::std::option::Option<::std::string::String>,
pub(crate) destination_port: ::std::option::Option<i32>,
pub(crate) protocol: ::std::option::Option<crate::types::Protocol>,
pub(crate) packet_size: ::std::option::Option<i32>,
pub(crate) address_family: ::std::option::Option<crate::types::AddressFamily>,
pub(crate) vpc_id: ::std::option::Option<::std::string::String>,
pub(crate) state: ::std::option::Option<crate::types::ProbeState>,
pub(crate) created_at: ::std::option::Option<::aws_smithy_types::DateTime>,
pub(crate) modified_at: ::std::option::Option<::aws_smithy_types::DateTime>,
pub(crate) tags: ::std::option::Option<::std::collections::HashMap<::std::string::String, ::std::string::String>>,
_request_id: Option<String>,
}
impl CreateProbeOutputBuilder {
pub fn probe_id(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
self.probe_id = ::std::option::Option::Some(input.into());
self
}
pub fn set_probe_id(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
self.probe_id = input;
self
}
pub fn get_probe_id(&self) -> &::std::option::Option<::std::string::String> {
&self.probe_id
}
pub fn probe_arn(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
self.probe_arn = ::std::option::Option::Some(input.into());
self
}
pub fn set_probe_arn(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
self.probe_arn = input;
self
}
pub fn get_probe_arn(&self) -> &::std::option::Option<::std::string::String> {
&self.probe_arn
}
pub fn source_arn(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
self.source_arn = ::std::option::Option::Some(input.into());
self
}
pub fn set_source_arn(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
self.source_arn = input;
self
}
pub fn get_source_arn(&self) -> &::std::option::Option<::std::string::String> {
&self.source_arn
}
pub fn destination(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
self.destination = ::std::option::Option::Some(input.into());
self
}
pub fn set_destination(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
self.destination = input;
self
}
pub fn get_destination(&self) -> &::std::option::Option<::std::string::String> {
&self.destination
}
pub fn destination_port(mut self, input: i32) -> Self {
self.destination_port = ::std::option::Option::Some(input);
self
}
pub fn set_destination_port(mut self, input: ::std::option::Option<i32>) -> Self {
self.destination_port = input;
self
}
pub fn get_destination_port(&self) -> &::std::option::Option<i32> {
&self.destination_port
}
pub fn protocol(mut self, input: crate::types::Protocol) -> Self {
self.protocol = ::std::option::Option::Some(input);
self
}
pub fn set_protocol(mut self, input: ::std::option::Option<crate::types::Protocol>) -> Self {
self.protocol = input;
self
}
pub fn get_protocol(&self) -> &::std::option::Option<crate::types::Protocol> {
&self.protocol
}
pub fn packet_size(mut self, input: i32) -> Self {
self.packet_size = ::std::option::Option::Some(input);
self
}
pub fn set_packet_size(mut self, input: ::std::option::Option<i32>) -> Self {
self.packet_size = input;
self
}
pub fn get_packet_size(&self) -> &::std::option::Option<i32> {
&self.packet_size
}
pub fn address_family(mut self, input: crate::types::AddressFamily) -> Self {
self.address_family = ::std::option::Option::Some(input);
self
}
pub fn set_address_family(mut self, input: ::std::option::Option<crate::types::AddressFamily>) -> Self {
self.address_family = input;
self
}
pub fn get_address_family(&self) -> &::std::option::Option<crate::types::AddressFamily> {
&self.address_family
}
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 state(mut self, input: crate::types::ProbeState) -> Self {
self.state = ::std::option::Option::Some(input);
self
}
pub fn set_state(mut self, input: ::std::option::Option<crate::types::ProbeState>) -> Self {
self.state = input;
self
}
pub fn get_state(&self) -> &::std::option::Option<crate::types::ProbeState> {
&self.state
}
pub fn created_at(mut self, input: ::aws_smithy_types::DateTime) -> Self {
self.created_at = ::std::option::Option::Some(input);
self
}
pub fn set_created_at(mut self, input: ::std::option::Option<::aws_smithy_types::DateTime>) -> Self {
self.created_at = input;
self
}
pub fn get_created_at(&self) -> &::std::option::Option<::aws_smithy_types::DateTime> {
&self.created_at
}
pub fn modified_at(mut self, input: ::aws_smithy_types::DateTime) -> Self {
self.modified_at = ::std::option::Option::Some(input);
self
}
pub fn set_modified_at(mut self, input: ::std::option::Option<::aws_smithy_types::DateTime>) -> Self {
self.modified_at = input;
self
}
pub fn get_modified_at(&self) -> &::std::option::Option<::aws_smithy_types::DateTime> {
&self.modified_at
}
pub fn tags(mut self, k: impl ::std::convert::Into<::std::string::String>, v: impl ::std::convert::Into<::std::string::String>) -> Self {
let mut hash_map = self.tags.unwrap_or_default();
hash_map.insert(k.into(), v.into());
self.tags = ::std::option::Option::Some(hash_map);
self
}
pub fn set_tags(mut self, input: ::std::option::Option<::std::collections::HashMap<::std::string::String, ::std::string::String>>) -> Self {
self.tags = input;
self
}
pub fn get_tags(&self) -> &::std::option::Option<::std::collections::HashMap<::std::string::String, ::std::string::String>> {
&self.tags
}
pub(crate) fn _request_id(mut self, request_id: impl Into<String>) -> Self {
self._request_id = Some(request_id.into());
self
}
pub(crate) fn _set_request_id(&mut self, request_id: Option<String>) -> &mut Self {
self._request_id = request_id;
self
}
pub fn build(self) -> ::std::result::Result<crate::operation::create_probe::CreateProbeOutput, ::aws_smithy_types::error::operation::BuildError> {
::std::result::Result::Ok(crate::operation::create_probe::CreateProbeOutput {
probe_id: self.probe_id,
probe_arn: self.probe_arn,
source_arn: self.source_arn.ok_or_else(|| {
::aws_smithy_types::error::operation::BuildError::missing_field(
"source_arn",
"source_arn was not specified but it is required when building CreateProbeOutput",
)
})?,
destination: self.destination.ok_or_else(|| {
::aws_smithy_types::error::operation::BuildError::missing_field(
"destination",
"destination was not specified but it is required when building CreateProbeOutput",
)
})?,
destination_port: self.destination_port,
protocol: self.protocol.ok_or_else(|| {
::aws_smithy_types::error::operation::BuildError::missing_field(
"protocol",
"protocol was not specified but it is required when building CreateProbeOutput",
)
})?,
packet_size: self.packet_size,
address_family: self.address_family,
vpc_id: self.vpc_id,
state: self.state,
created_at: self.created_at,
modified_at: self.modified_at,
tags: self.tags,
_request_id: self._request_id,
})
}
}