#[non_exhaustive]
#[derive(::std::clone::Clone, ::std::cmp::PartialEq, ::std::fmt::Debug)]
pub struct VpcEndpoint {
pub vpc_endpoint_id: ::std::option::Option<::std::string::String>,
pub vpc_endpoint_type: ::std::option::Option<crate::types::VpcEndpointType>,
pub vpc_id: ::std::option::Option<::std::string::String>,
pub service_name: ::std::option::Option<::std::string::String>,
pub state: ::std::option::Option<crate::types::State>,
pub policy_document: ::std::option::Option<::std::string::String>,
pub route_table_ids: ::std::option::Option<::std::vec::Vec<::std::string::String>>,
pub subnet_ids: ::std::option::Option<::std::vec::Vec<::std::string::String>>,
pub groups: ::std::option::Option<::std::vec::Vec<crate::types::SecurityGroupIdentifier>>,
pub ip_address_type: ::std::option::Option<crate::types::IpAddressType>,
pub dns_options: ::std::option::Option<crate::types::DnsOptions>,
pub private_dns_enabled: ::std::option::Option<bool>,
pub requester_managed: ::std::option::Option<bool>,
pub network_interface_ids: ::std::option::Option<::std::vec::Vec<::std::string::String>>,
pub dns_entries: ::std::option::Option<::std::vec::Vec<crate::types::DnsEntry>>,
pub creation_timestamp: ::std::option::Option<::aws_smithy_types::DateTime>,
pub tags: ::std::option::Option<::std::vec::Vec<crate::types::Tag>>,
pub owner_id: ::std::option::Option<::std::string::String>,
pub last_error: ::std::option::Option<crate::types::LastError>,
}
impl VpcEndpoint {
pub fn vpc_endpoint_id(&self) -> ::std::option::Option<&str> {
self.vpc_endpoint_id.as_deref()
}
pub fn vpc_endpoint_type(&self) -> ::std::option::Option<&crate::types::VpcEndpointType> {
self.vpc_endpoint_type.as_ref()
}
pub fn vpc_id(&self) -> ::std::option::Option<&str> {
self.vpc_id.as_deref()
}
pub fn service_name(&self) -> ::std::option::Option<&str> {
self.service_name.as_deref()
}
pub fn state(&self) -> ::std::option::Option<&crate::types::State> {
self.state.as_ref()
}
pub fn policy_document(&self) -> ::std::option::Option<&str> {
self.policy_document.as_deref()
}
pub fn route_table_ids(&self) -> ::std::option::Option<&[::std::string::String]> {
self.route_table_ids.as_deref()
}
pub fn subnet_ids(&self) -> ::std::option::Option<&[::std::string::String]> {
self.subnet_ids.as_deref()
}
pub fn groups(&self) -> ::std::option::Option<&[crate::types::SecurityGroupIdentifier]> {
self.groups.as_deref()
}
pub fn ip_address_type(&self) -> ::std::option::Option<&crate::types::IpAddressType> {
self.ip_address_type.as_ref()
}
pub fn dns_options(&self) -> ::std::option::Option<&crate::types::DnsOptions> {
self.dns_options.as_ref()
}
pub fn private_dns_enabled(&self) -> ::std::option::Option<bool> {
self.private_dns_enabled
}
pub fn requester_managed(&self) -> ::std::option::Option<bool> {
self.requester_managed
}
pub fn network_interface_ids(&self) -> ::std::option::Option<&[::std::string::String]> {
self.network_interface_ids.as_deref()
}
pub fn dns_entries(&self) -> ::std::option::Option<&[crate::types::DnsEntry]> {
self.dns_entries.as_deref()
}
pub fn creation_timestamp(&self) -> ::std::option::Option<&::aws_smithy_types::DateTime> {
self.creation_timestamp.as_ref()
}
pub fn tags(&self) -> ::std::option::Option<&[crate::types::Tag]> {
self.tags.as_deref()
}
pub fn owner_id(&self) -> ::std::option::Option<&str> {
self.owner_id.as_deref()
}
pub fn last_error(&self) -> ::std::option::Option<&crate::types::LastError> {
self.last_error.as_ref()
}
}
impl VpcEndpoint {
pub fn builder() -> crate::types::builders::VpcEndpointBuilder {
crate::types::builders::VpcEndpointBuilder::default()
}
}
#[non_exhaustive]
#[derive(::std::clone::Clone, ::std::cmp::PartialEq, ::std::default::Default, ::std::fmt::Debug)]
pub struct VpcEndpointBuilder {
pub(crate) vpc_endpoint_id: ::std::option::Option<::std::string::String>,
pub(crate) vpc_endpoint_type: ::std::option::Option<crate::types::VpcEndpointType>,
pub(crate) vpc_id: ::std::option::Option<::std::string::String>,
pub(crate) service_name: ::std::option::Option<::std::string::String>,
pub(crate) state: ::std::option::Option<crate::types::State>,
pub(crate) policy_document: ::std::option::Option<::std::string::String>,
pub(crate) route_table_ids: ::std::option::Option<::std::vec::Vec<::std::string::String>>,
pub(crate) subnet_ids: ::std::option::Option<::std::vec::Vec<::std::string::String>>,
pub(crate) groups: ::std::option::Option<::std::vec::Vec<crate::types::SecurityGroupIdentifier>>,
pub(crate) ip_address_type: ::std::option::Option<crate::types::IpAddressType>,
pub(crate) dns_options: ::std::option::Option<crate::types::DnsOptions>,
pub(crate) private_dns_enabled: ::std::option::Option<bool>,
pub(crate) requester_managed: ::std::option::Option<bool>,
pub(crate) network_interface_ids: ::std::option::Option<::std::vec::Vec<::std::string::String>>,
pub(crate) dns_entries: ::std::option::Option<::std::vec::Vec<crate::types::DnsEntry>>,
pub(crate) creation_timestamp: ::std::option::Option<::aws_smithy_types::DateTime>,
pub(crate) tags: ::std::option::Option<::std::vec::Vec<crate::types::Tag>>,
pub(crate) owner_id: ::std::option::Option<::std::string::String>,
pub(crate) last_error: ::std::option::Option<crate::types::LastError>,
}
impl VpcEndpointBuilder {
pub fn vpc_endpoint_id(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
self.vpc_endpoint_id = ::std::option::Option::Some(input.into());
self
}
pub fn set_vpc_endpoint_id(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
self.vpc_endpoint_id = input;
self
}
pub fn get_vpc_endpoint_id(&self) -> &::std::option::Option<::std::string::String> {
&self.vpc_endpoint_id
}
pub fn vpc_endpoint_type(mut self, input: crate::types::VpcEndpointType) -> Self {
self.vpc_endpoint_type = ::std::option::Option::Some(input);
self
}
pub fn set_vpc_endpoint_type(mut self, input: ::std::option::Option<crate::types::VpcEndpointType>) -> Self {
self.vpc_endpoint_type = input;
self
}
pub fn get_vpc_endpoint_type(&self) -> &::std::option::Option<crate::types::VpcEndpointType> {
&self.vpc_endpoint_type
}
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 service_name(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
self.service_name = ::std::option::Option::Some(input.into());
self
}
pub fn set_service_name(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
self.service_name = input;
self
}
pub fn get_service_name(&self) -> &::std::option::Option<::std::string::String> {
&self.service_name
}
pub fn state(mut self, input: crate::types::State) -> Self {
self.state = ::std::option::Option::Some(input);
self
}
pub fn set_state(mut self, input: ::std::option::Option<crate::types::State>) -> Self {
self.state = input;
self
}
pub fn get_state(&self) -> &::std::option::Option<crate::types::State> {
&self.state
}
pub fn policy_document(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
self.policy_document = ::std::option::Option::Some(input.into());
self
}
pub fn set_policy_document(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
self.policy_document = input;
self
}
pub fn get_policy_document(&self) -> &::std::option::Option<::std::string::String> {
&self.policy_document
}
pub fn route_table_ids(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
let mut v = self.route_table_ids.unwrap_or_default();
v.push(input.into());
self.route_table_ids = ::std::option::Option::Some(v);
self
}
pub fn set_route_table_ids(mut self, input: ::std::option::Option<::std::vec::Vec<::std::string::String>>) -> Self {
self.route_table_ids = input;
self
}
pub fn get_route_table_ids(&self) -> &::std::option::Option<::std::vec::Vec<::std::string::String>> {
&self.route_table_ids
}
pub fn subnet_ids(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
let mut v = self.subnet_ids.unwrap_or_default();
v.push(input.into());
self.subnet_ids = ::std::option::Option::Some(v);
self
}
pub fn set_subnet_ids(mut self, input: ::std::option::Option<::std::vec::Vec<::std::string::String>>) -> Self {
self.subnet_ids = input;
self
}
pub fn get_subnet_ids(&self) -> &::std::option::Option<::std::vec::Vec<::std::string::String>> {
&self.subnet_ids
}
pub fn groups(mut self, input: crate::types::SecurityGroupIdentifier) -> Self {
let mut v = self.groups.unwrap_or_default();
v.push(input);
self.groups = ::std::option::Option::Some(v);
self
}
pub fn set_groups(mut self, input: ::std::option::Option<::std::vec::Vec<crate::types::SecurityGroupIdentifier>>) -> Self {
self.groups = input;
self
}
pub fn get_groups(&self) -> &::std::option::Option<::std::vec::Vec<crate::types::SecurityGroupIdentifier>> {
&self.groups
}
pub fn ip_address_type(mut self, input: crate::types::IpAddressType) -> Self {
self.ip_address_type = ::std::option::Option::Some(input);
self
}
pub fn set_ip_address_type(mut self, input: ::std::option::Option<crate::types::IpAddressType>) -> Self {
self.ip_address_type = input;
self
}
pub fn get_ip_address_type(&self) -> &::std::option::Option<crate::types::IpAddressType> {
&self.ip_address_type
}
pub fn dns_options(mut self, input: crate::types::DnsOptions) -> Self {
self.dns_options = ::std::option::Option::Some(input);
self
}
pub fn set_dns_options(mut self, input: ::std::option::Option<crate::types::DnsOptions>) -> Self {
self.dns_options = input;
self
}
pub fn get_dns_options(&self) -> &::std::option::Option<crate::types::DnsOptions> {
&self.dns_options
}
pub fn private_dns_enabled(mut self, input: bool) -> Self {
self.private_dns_enabled = ::std::option::Option::Some(input);
self
}
pub fn set_private_dns_enabled(mut self, input: ::std::option::Option<bool>) -> Self {
self.private_dns_enabled = input;
self
}
pub fn get_private_dns_enabled(&self) -> &::std::option::Option<bool> {
&self.private_dns_enabled
}
pub fn requester_managed(mut self, input: bool) -> Self {
self.requester_managed = ::std::option::Option::Some(input);
self
}
pub fn set_requester_managed(mut self, input: ::std::option::Option<bool>) -> Self {
self.requester_managed = input;
self
}
pub fn get_requester_managed(&self) -> &::std::option::Option<bool> {
&self.requester_managed
}
pub fn network_interface_ids(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
let mut v = self.network_interface_ids.unwrap_or_default();
v.push(input.into());
self.network_interface_ids = ::std::option::Option::Some(v);
self
}
pub fn set_network_interface_ids(mut self, input: ::std::option::Option<::std::vec::Vec<::std::string::String>>) -> Self {
self.network_interface_ids = input;
self
}
pub fn get_network_interface_ids(&self) -> &::std::option::Option<::std::vec::Vec<::std::string::String>> {
&self.network_interface_ids
}
pub fn dns_entries(mut self, input: crate::types::DnsEntry) -> Self {
let mut v = self.dns_entries.unwrap_or_default();
v.push(input);
self.dns_entries = ::std::option::Option::Some(v);
self
}
pub fn set_dns_entries(mut self, input: ::std::option::Option<::std::vec::Vec<crate::types::DnsEntry>>) -> Self {
self.dns_entries = input;
self
}
pub fn get_dns_entries(&self) -> &::std::option::Option<::std::vec::Vec<crate::types::DnsEntry>> {
&self.dns_entries
}
pub fn creation_timestamp(mut self, input: ::aws_smithy_types::DateTime) -> Self {
self.creation_timestamp = ::std::option::Option::Some(input);
self
}
pub fn set_creation_timestamp(mut self, input: ::std::option::Option<::aws_smithy_types::DateTime>) -> Self {
self.creation_timestamp = input;
self
}
pub fn get_creation_timestamp(&self) -> &::std::option::Option<::aws_smithy_types::DateTime> {
&self.creation_timestamp
}
pub fn tags(mut self, input: crate::types::Tag) -> Self {
let mut v = self.tags.unwrap_or_default();
v.push(input);
self.tags = ::std::option::Option::Some(v);
self
}
pub fn set_tags(mut self, input: ::std::option::Option<::std::vec::Vec<crate::types::Tag>>) -> Self {
self.tags = input;
self
}
pub fn get_tags(&self) -> &::std::option::Option<::std::vec::Vec<crate::types::Tag>> {
&self.tags
}
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 last_error(mut self, input: crate::types::LastError) -> Self {
self.last_error = ::std::option::Option::Some(input);
self
}
pub fn set_last_error(mut self, input: ::std::option::Option<crate::types::LastError>) -> Self {
self.last_error = input;
self
}
pub fn get_last_error(&self) -> &::std::option::Option<crate::types::LastError> {
&self.last_error
}
pub fn build(self) -> crate::types::VpcEndpoint {
crate::types::VpcEndpoint {
vpc_endpoint_id: self.vpc_endpoint_id,
vpc_endpoint_type: self.vpc_endpoint_type,
vpc_id: self.vpc_id,
service_name: self.service_name,
state: self.state,
policy_document: self.policy_document,
route_table_ids: self.route_table_ids,
subnet_ids: self.subnet_ids,
groups: self.groups,
ip_address_type: self.ip_address_type,
dns_options: self.dns_options,
private_dns_enabled: self.private_dns_enabled,
requester_managed: self.requester_managed,
network_interface_ids: self.network_interface_ids,
dns_entries: self.dns_entries,
creation_timestamp: self.creation_timestamp,
tags: self.tags,
owner_id: self.owner_id,
last_error: self.last_error,
}
}
}