#[non_exhaustive]
#[derive(::std::clone::Clone, ::std::cmp::PartialEq, ::std::fmt::Debug)]
pub struct ClientVpnEndpoint {
pub client_vpn_endpoint_id: ::std::option::Option<::std::string::String>,
pub description: ::std::option::Option<::std::string::String>,
pub status: ::std::option::Option<crate::types::ClientVpnEndpointStatus>,
pub creation_time: ::std::option::Option<::std::string::String>,
pub deletion_time: ::std::option::Option<::std::string::String>,
pub dns_name: ::std::option::Option<::std::string::String>,
pub client_cidr_block: ::std::option::Option<::std::string::String>,
pub dns_servers: ::std::option::Option<::std::vec::Vec<::std::string::String>>,
pub split_tunnel: ::std::option::Option<bool>,
pub vpn_protocol: ::std::option::Option<crate::types::VpnProtocol>,
pub transport_protocol: ::std::option::Option<crate::types::TransportProtocol>,
pub vpn_port: ::std::option::Option<i32>,
#[deprecated(
note = "This property is deprecated. To view the target networks associated with a Client VPN endpoint, call DescribeClientVpnTargetNetworks and inspect the clientVpnTargetNetworks response element."
)]
pub associated_target_networks: ::std::option::Option<::std::vec::Vec<crate::types::AssociatedTargetNetwork>>,
pub server_certificate_arn: ::std::option::Option<::std::string::String>,
pub authentication_options: ::std::option::Option<::std::vec::Vec<crate::types::ClientVpnAuthentication>>,
pub connection_log_options: ::std::option::Option<crate::types::ConnectionLogResponseOptions>,
pub tags: ::std::option::Option<::std::vec::Vec<crate::types::Tag>>,
pub security_group_ids: ::std::option::Option<::std::vec::Vec<::std::string::String>>,
pub vpc_id: ::std::option::Option<::std::string::String>,
pub self_service_portal_url: ::std::option::Option<::std::string::String>,
pub client_connect_options: ::std::option::Option<crate::types::ClientConnectResponseOptions>,
pub session_timeout_hours: ::std::option::Option<i32>,
pub client_login_banner_options: ::std::option::Option<crate::types::ClientLoginBannerResponseOptions>,
}
impl ClientVpnEndpoint {
pub fn client_vpn_endpoint_id(&self) -> ::std::option::Option<&str> {
self.client_vpn_endpoint_id.as_deref()
}
pub fn description(&self) -> ::std::option::Option<&str> {
self.description.as_deref()
}
pub fn status(&self) -> ::std::option::Option<&crate::types::ClientVpnEndpointStatus> {
self.status.as_ref()
}
pub fn creation_time(&self) -> ::std::option::Option<&str> {
self.creation_time.as_deref()
}
pub fn deletion_time(&self) -> ::std::option::Option<&str> {
self.deletion_time.as_deref()
}
pub fn dns_name(&self) -> ::std::option::Option<&str> {
self.dns_name.as_deref()
}
pub fn client_cidr_block(&self) -> ::std::option::Option<&str> {
self.client_cidr_block.as_deref()
}
pub fn dns_servers(&self) -> &[::std::string::String] {
self.dns_servers.as_deref().unwrap_or_default()
}
pub fn split_tunnel(&self) -> ::std::option::Option<bool> {
self.split_tunnel
}
pub fn vpn_protocol(&self) -> ::std::option::Option<&crate::types::VpnProtocol> {
self.vpn_protocol.as_ref()
}
pub fn transport_protocol(&self) -> ::std::option::Option<&crate::types::TransportProtocol> {
self.transport_protocol.as_ref()
}
pub fn vpn_port(&self) -> ::std::option::Option<i32> {
self.vpn_port
}
#[deprecated(
note = "This property is deprecated. To view the target networks associated with a Client VPN endpoint, call DescribeClientVpnTargetNetworks and inspect the clientVpnTargetNetworks response element."
)]
pub fn associated_target_networks(&self) -> &[crate::types::AssociatedTargetNetwork] {
self.associated_target_networks.as_deref().unwrap_or_default()
}
pub fn server_certificate_arn(&self) -> ::std::option::Option<&str> {
self.server_certificate_arn.as_deref()
}
pub fn authentication_options(&self) -> &[crate::types::ClientVpnAuthentication] {
self.authentication_options.as_deref().unwrap_or_default()
}
pub fn connection_log_options(&self) -> ::std::option::Option<&crate::types::ConnectionLogResponseOptions> {
self.connection_log_options.as_ref()
}
pub fn tags(&self) -> &[crate::types::Tag] {
self.tags.as_deref().unwrap_or_default()
}
pub fn security_group_ids(&self) -> &[::std::string::String] {
self.security_group_ids.as_deref().unwrap_or_default()
}
pub fn vpc_id(&self) -> ::std::option::Option<&str> {
self.vpc_id.as_deref()
}
pub fn self_service_portal_url(&self) -> ::std::option::Option<&str> {
self.self_service_portal_url.as_deref()
}
pub fn client_connect_options(&self) -> ::std::option::Option<&crate::types::ClientConnectResponseOptions> {
self.client_connect_options.as_ref()
}
pub fn session_timeout_hours(&self) -> ::std::option::Option<i32> {
self.session_timeout_hours
}
pub fn client_login_banner_options(&self) -> ::std::option::Option<&crate::types::ClientLoginBannerResponseOptions> {
self.client_login_banner_options.as_ref()
}
}
impl ClientVpnEndpoint {
pub fn builder() -> crate::types::builders::ClientVpnEndpointBuilder {
crate::types::builders::ClientVpnEndpointBuilder::default()
}
}
#[non_exhaustive]
#[derive(::std::clone::Clone, ::std::cmp::PartialEq, ::std::default::Default, ::std::fmt::Debug)]
pub struct ClientVpnEndpointBuilder {
pub(crate) client_vpn_endpoint_id: ::std::option::Option<::std::string::String>,
pub(crate) description: ::std::option::Option<::std::string::String>,
pub(crate) status: ::std::option::Option<crate::types::ClientVpnEndpointStatus>,
pub(crate) creation_time: ::std::option::Option<::std::string::String>,
pub(crate) deletion_time: ::std::option::Option<::std::string::String>,
pub(crate) dns_name: ::std::option::Option<::std::string::String>,
pub(crate) client_cidr_block: ::std::option::Option<::std::string::String>,
pub(crate) dns_servers: ::std::option::Option<::std::vec::Vec<::std::string::String>>,
pub(crate) split_tunnel: ::std::option::Option<bool>,
pub(crate) vpn_protocol: ::std::option::Option<crate::types::VpnProtocol>,
pub(crate) transport_protocol: ::std::option::Option<crate::types::TransportProtocol>,
pub(crate) vpn_port: ::std::option::Option<i32>,
pub(crate) associated_target_networks: ::std::option::Option<::std::vec::Vec<crate::types::AssociatedTargetNetwork>>,
pub(crate) server_certificate_arn: ::std::option::Option<::std::string::String>,
pub(crate) authentication_options: ::std::option::Option<::std::vec::Vec<crate::types::ClientVpnAuthentication>>,
pub(crate) connection_log_options: ::std::option::Option<crate::types::ConnectionLogResponseOptions>,
pub(crate) tags: ::std::option::Option<::std::vec::Vec<crate::types::Tag>>,
pub(crate) security_group_ids: ::std::option::Option<::std::vec::Vec<::std::string::String>>,
pub(crate) vpc_id: ::std::option::Option<::std::string::String>,
pub(crate) self_service_portal_url: ::std::option::Option<::std::string::String>,
pub(crate) client_connect_options: ::std::option::Option<crate::types::ClientConnectResponseOptions>,
pub(crate) session_timeout_hours: ::std::option::Option<i32>,
pub(crate) client_login_banner_options: ::std::option::Option<crate::types::ClientLoginBannerResponseOptions>,
}
impl ClientVpnEndpointBuilder {
pub fn client_vpn_endpoint_id(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
self.client_vpn_endpoint_id = ::std::option::Option::Some(input.into());
self
}
pub fn set_client_vpn_endpoint_id(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
self.client_vpn_endpoint_id = input;
self
}
pub fn get_client_vpn_endpoint_id(&self) -> &::std::option::Option<::std::string::String> {
&self.client_vpn_endpoint_id
}
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 status(mut self, input: crate::types::ClientVpnEndpointStatus) -> Self {
self.status = ::std::option::Option::Some(input);
self
}
pub fn set_status(mut self, input: ::std::option::Option<crate::types::ClientVpnEndpointStatus>) -> Self {
self.status = input;
self
}
pub fn get_status(&self) -> &::std::option::Option<crate::types::ClientVpnEndpointStatus> {
&self.status
}
pub fn creation_time(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
self.creation_time = ::std::option::Option::Some(input.into());
self
}
pub fn set_creation_time(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
self.creation_time = input;
self
}
pub fn get_creation_time(&self) -> &::std::option::Option<::std::string::String> {
&self.creation_time
}
pub fn deletion_time(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
self.deletion_time = ::std::option::Option::Some(input.into());
self
}
pub fn set_deletion_time(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
self.deletion_time = input;
self
}
pub fn get_deletion_time(&self) -> &::std::option::Option<::std::string::String> {
&self.deletion_time
}
pub fn dns_name(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
self.dns_name = ::std::option::Option::Some(input.into());
self
}
pub fn set_dns_name(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
self.dns_name = input;
self
}
pub fn get_dns_name(&self) -> &::std::option::Option<::std::string::String> {
&self.dns_name
}
pub fn client_cidr_block(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
self.client_cidr_block = ::std::option::Option::Some(input.into());
self
}
pub fn set_client_cidr_block(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
self.client_cidr_block = input;
self
}
pub fn get_client_cidr_block(&self) -> &::std::option::Option<::std::string::String> {
&self.client_cidr_block
}
pub fn dns_servers(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
let mut v = self.dns_servers.unwrap_or_default();
v.push(input.into());
self.dns_servers = ::std::option::Option::Some(v);
self
}
pub fn set_dns_servers(mut self, input: ::std::option::Option<::std::vec::Vec<::std::string::String>>) -> Self {
self.dns_servers = input;
self
}
pub fn get_dns_servers(&self) -> &::std::option::Option<::std::vec::Vec<::std::string::String>> {
&self.dns_servers
}
pub fn split_tunnel(mut self, input: bool) -> Self {
self.split_tunnel = ::std::option::Option::Some(input);
self
}
pub fn set_split_tunnel(mut self, input: ::std::option::Option<bool>) -> Self {
self.split_tunnel = input;
self
}
pub fn get_split_tunnel(&self) -> &::std::option::Option<bool> {
&self.split_tunnel
}
pub fn vpn_protocol(mut self, input: crate::types::VpnProtocol) -> Self {
self.vpn_protocol = ::std::option::Option::Some(input);
self
}
pub fn set_vpn_protocol(mut self, input: ::std::option::Option<crate::types::VpnProtocol>) -> Self {
self.vpn_protocol = input;
self
}
pub fn get_vpn_protocol(&self) -> &::std::option::Option<crate::types::VpnProtocol> {
&self.vpn_protocol
}
pub fn transport_protocol(mut self, input: crate::types::TransportProtocol) -> Self {
self.transport_protocol = ::std::option::Option::Some(input);
self
}
pub fn set_transport_protocol(mut self, input: ::std::option::Option<crate::types::TransportProtocol>) -> Self {
self.transport_protocol = input;
self
}
pub fn get_transport_protocol(&self) -> &::std::option::Option<crate::types::TransportProtocol> {
&self.transport_protocol
}
pub fn vpn_port(mut self, input: i32) -> Self {
self.vpn_port = ::std::option::Option::Some(input);
self
}
pub fn set_vpn_port(mut self, input: ::std::option::Option<i32>) -> Self {
self.vpn_port = input;
self
}
pub fn get_vpn_port(&self) -> &::std::option::Option<i32> {
&self.vpn_port
}
#[deprecated(
note = "This property is deprecated. To view the target networks associated with a Client VPN endpoint, call DescribeClientVpnTargetNetworks and inspect the clientVpnTargetNetworks response element."
)]
pub fn associated_target_networks(mut self, input: crate::types::AssociatedTargetNetwork) -> Self {
let mut v = self.associated_target_networks.unwrap_or_default();
v.push(input);
self.associated_target_networks = ::std::option::Option::Some(v);
self
}
#[deprecated(
note = "This property is deprecated. To view the target networks associated with a Client VPN endpoint, call DescribeClientVpnTargetNetworks and inspect the clientVpnTargetNetworks response element."
)]
pub fn set_associated_target_networks(mut self, input: ::std::option::Option<::std::vec::Vec<crate::types::AssociatedTargetNetwork>>) -> Self {
self.associated_target_networks = input;
self
}
#[deprecated(
note = "This property is deprecated. To view the target networks associated with a Client VPN endpoint, call DescribeClientVpnTargetNetworks and inspect the clientVpnTargetNetworks response element."
)]
pub fn get_associated_target_networks(&self) -> &::std::option::Option<::std::vec::Vec<crate::types::AssociatedTargetNetwork>> {
&self.associated_target_networks
}
pub fn server_certificate_arn(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
self.server_certificate_arn = ::std::option::Option::Some(input.into());
self
}
pub fn set_server_certificate_arn(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
self.server_certificate_arn = input;
self
}
pub fn get_server_certificate_arn(&self) -> &::std::option::Option<::std::string::String> {
&self.server_certificate_arn
}
pub fn authentication_options(mut self, input: crate::types::ClientVpnAuthentication) -> Self {
let mut v = self.authentication_options.unwrap_or_default();
v.push(input);
self.authentication_options = ::std::option::Option::Some(v);
self
}
pub fn set_authentication_options(mut self, input: ::std::option::Option<::std::vec::Vec<crate::types::ClientVpnAuthentication>>) -> Self {
self.authentication_options = input;
self
}
pub fn get_authentication_options(&self) -> &::std::option::Option<::std::vec::Vec<crate::types::ClientVpnAuthentication>> {
&self.authentication_options
}
pub fn connection_log_options(mut self, input: crate::types::ConnectionLogResponseOptions) -> Self {
self.connection_log_options = ::std::option::Option::Some(input);
self
}
pub fn set_connection_log_options(mut self, input: ::std::option::Option<crate::types::ConnectionLogResponseOptions>) -> Self {
self.connection_log_options = input;
self
}
pub fn get_connection_log_options(&self) -> &::std::option::Option<crate::types::ConnectionLogResponseOptions> {
&self.connection_log_options
}
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 security_group_ids(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
let mut v = self.security_group_ids.unwrap_or_default();
v.push(input.into());
self.security_group_ids = ::std::option::Option::Some(v);
self
}
pub fn set_security_group_ids(mut self, input: ::std::option::Option<::std::vec::Vec<::std::string::String>>) -> Self {
self.security_group_ids = input;
self
}
pub fn get_security_group_ids(&self) -> &::std::option::Option<::std::vec::Vec<::std::string::String>> {
&self.security_group_ids
}
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 self_service_portal_url(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
self.self_service_portal_url = ::std::option::Option::Some(input.into());
self
}
pub fn set_self_service_portal_url(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
self.self_service_portal_url = input;
self
}
pub fn get_self_service_portal_url(&self) -> &::std::option::Option<::std::string::String> {
&self.self_service_portal_url
}
pub fn client_connect_options(mut self, input: crate::types::ClientConnectResponseOptions) -> Self {
self.client_connect_options = ::std::option::Option::Some(input);
self
}
pub fn set_client_connect_options(mut self, input: ::std::option::Option<crate::types::ClientConnectResponseOptions>) -> Self {
self.client_connect_options = input;
self
}
pub fn get_client_connect_options(&self) -> &::std::option::Option<crate::types::ClientConnectResponseOptions> {
&self.client_connect_options
}
pub fn session_timeout_hours(mut self, input: i32) -> Self {
self.session_timeout_hours = ::std::option::Option::Some(input);
self
}
pub fn set_session_timeout_hours(mut self, input: ::std::option::Option<i32>) -> Self {
self.session_timeout_hours = input;
self
}
pub fn get_session_timeout_hours(&self) -> &::std::option::Option<i32> {
&self.session_timeout_hours
}
pub fn client_login_banner_options(mut self, input: crate::types::ClientLoginBannerResponseOptions) -> Self {
self.client_login_banner_options = ::std::option::Option::Some(input);
self
}
pub fn set_client_login_banner_options(mut self, input: ::std::option::Option<crate::types::ClientLoginBannerResponseOptions>) -> Self {
self.client_login_banner_options = input;
self
}
pub fn get_client_login_banner_options(&self) -> &::std::option::Option<crate::types::ClientLoginBannerResponseOptions> {
&self.client_login_banner_options
}
pub fn build(self) -> crate::types::ClientVpnEndpoint {
crate::types::ClientVpnEndpoint {
client_vpn_endpoint_id: self.client_vpn_endpoint_id,
description: self.description,
status: self.status,
creation_time: self.creation_time,
deletion_time: self.deletion_time,
dns_name: self.dns_name,
client_cidr_block: self.client_cidr_block,
dns_servers: self.dns_servers,
split_tunnel: self.split_tunnel,
vpn_protocol: self.vpn_protocol,
transport_protocol: self.transport_protocol,
vpn_port: self.vpn_port,
associated_target_networks: self.associated_target_networks,
server_certificate_arn: self.server_certificate_arn,
authentication_options: self.authentication_options,
connection_log_options: self.connection_log_options,
tags: self.tags,
security_group_ids: self.security_group_ids,
vpc_id: self.vpc_id,
self_service_portal_url: self.self_service_portal_url,
client_connect_options: self.client_connect_options,
session_timeout_hours: self.session_timeout_hours,
client_login_banner_options: self.client_login_banner_options,
}
}
}