aws-sdk-directconnect 1.106.0

AWS SDK for AWS Direct Connect
Documentation
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
pub use crate::operation::update_virtual_interface_attributes::_update_virtual_interface_attributes_input::UpdateVirtualInterfaceAttributesInputBuilder;

pub use crate::operation::update_virtual_interface_attributes::_update_virtual_interface_attributes_output::UpdateVirtualInterfaceAttributesOutputBuilder;

impl crate::operation::update_virtual_interface_attributes::builders::UpdateVirtualInterfaceAttributesInputBuilder {
    /// Sends a request with this input using the given client.
    pub async fn send_with(
        self,
        client: &crate::Client,
    ) -> ::std::result::Result<
        crate::operation::update_virtual_interface_attributes::UpdateVirtualInterfaceAttributesOutput,
        ::aws_smithy_runtime_api::client::result::SdkError<
            crate::operation::update_virtual_interface_attributes::UpdateVirtualInterfaceAttributesError,
            ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
        >,
    > {
        let mut fluent_builder = client.update_virtual_interface_attributes();
        fluent_builder.inner = self;
        fluent_builder.send().await
    }
}
/// Fluent builder constructing a request to `UpdateVirtualInterfaceAttributes`.
///
/// <p>Updates the specified attributes of the specified virtual private interface.</p>
/// <p>Setting the MTU of a virtual interface to 8500 (jumbo frames) can cause an update to the underlying physical connection if it wasn't updated to support jumbo frames. Updating the connection disrupts network connectivity for all virtual interfaces associated with the connection for up to 30 seconds. To check whether your connection supports jumbo frames, call <code>DescribeConnections</code>. To check whether your virtual interface supports jumbo frames, call <code>DescribeVirtualInterfaces</code>.</p>
#[derive(::std::clone::Clone, ::std::fmt::Debug)]
pub struct UpdateVirtualInterfaceAttributesFluentBuilder {
    handle: ::std::sync::Arc<crate::client::Handle>,
    inner: crate::operation::update_virtual_interface_attributes::builders::UpdateVirtualInterfaceAttributesInputBuilder,
    config_override: ::std::option::Option<crate::config::Builder>,
}
impl
    crate::client::customize::internal::CustomizableSend<
        crate::operation::update_virtual_interface_attributes::UpdateVirtualInterfaceAttributesOutput,
        crate::operation::update_virtual_interface_attributes::UpdateVirtualInterfaceAttributesError,
    > for UpdateVirtualInterfaceAttributesFluentBuilder
{
    fn send(
        self,
        config_override: crate::config::Builder,
    ) -> crate::client::customize::internal::BoxFuture<
        crate::client::customize::internal::SendResult<
            crate::operation::update_virtual_interface_attributes::UpdateVirtualInterfaceAttributesOutput,
            crate::operation::update_virtual_interface_attributes::UpdateVirtualInterfaceAttributesError,
        >,
    > {
        ::std::boxed::Box::pin(async move { self.config_override(config_override).send().await })
    }
}
impl UpdateVirtualInterfaceAttributesFluentBuilder {
    /// Creates a new `UpdateVirtualInterfaceAttributesFluentBuilder`.
    pub(crate) fn new(handle: ::std::sync::Arc<crate::client::Handle>) -> Self {
        Self {
            handle,
            inner: ::std::default::Default::default(),
            config_override: ::std::option::Option::None,
        }
    }
    /// Access the UpdateVirtualInterfaceAttributes as a reference.
    pub fn as_input(&self) -> &crate::operation::update_virtual_interface_attributes::builders::UpdateVirtualInterfaceAttributesInputBuilder {
        &self.inner
    }
    /// Sends the request and returns the response.
    ///
    /// If an error occurs, an `SdkError` will be returned with additional details that
    /// can be matched against.
    ///
    /// By default, any retryable failures will be retried twice. Retry behavior
    /// is configurable with the [RetryConfig](aws_smithy_types::retry::RetryConfig), which can be
    /// set when configuring the client.
    pub async fn send(
        self,
    ) -> ::std::result::Result<
        crate::operation::update_virtual_interface_attributes::UpdateVirtualInterfaceAttributesOutput,
        ::aws_smithy_runtime_api::client::result::SdkError<
            crate::operation::update_virtual_interface_attributes::UpdateVirtualInterfaceAttributesError,
            ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
        >,
    > {
        let input = self
            .inner
            .build()
            .map_err(::aws_smithy_runtime_api::client::result::SdkError::construction_failure)?;
        let runtime_plugins = crate::operation::update_virtual_interface_attributes::UpdateVirtualInterfaceAttributes::operation_runtime_plugins(
            self.handle.runtime_plugins.clone(),
            &self.handle.conf,
            self.config_override,
        );
        crate::operation::update_virtual_interface_attributes::UpdateVirtualInterfaceAttributes::orchestrate(&runtime_plugins, input).await
    }

    /// Consumes this builder, creating a customizable operation that can be modified before being sent.
    pub fn customize(
        self,
    ) -> crate::client::customize::CustomizableOperation<
        crate::operation::update_virtual_interface_attributes::UpdateVirtualInterfaceAttributesOutput,
        crate::operation::update_virtual_interface_attributes::UpdateVirtualInterfaceAttributesError,
        Self,
    > {
        crate::client::customize::CustomizableOperation::new(self)
    }
    pub(crate) fn config_override(mut self, config_override: impl ::std::convert::Into<crate::config::Builder>) -> Self {
        self.set_config_override(::std::option::Option::Some(config_override.into()));
        self
    }

    pub(crate) fn set_config_override(&mut self, config_override: ::std::option::Option<crate::config::Builder>) -> &mut Self {
        self.config_override = config_override;
        self
    }
    /// <p>The ID of the virtual private interface.</p>
    pub fn virtual_interface_id(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
        self.inner = self.inner.virtual_interface_id(input.into());
        self
    }
    /// <p>The ID of the virtual private interface.</p>
    pub fn set_virtual_interface_id(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
        self.inner = self.inner.set_virtual_interface_id(input);
        self
    }
    /// <p>The ID of the virtual private interface.</p>
    pub fn get_virtual_interface_id(&self) -> &::std::option::Option<::std::string::String> {
        self.inner.get_virtual_interface_id()
    }
    /// <p>The maximum transmission unit (MTU), in bytes. The supported values are 1500 and 8500. The default value is 1500.</p>
    pub fn mtu(mut self, input: i32) -> Self {
        self.inner = self.inner.mtu(input);
        self
    }
    /// <p>The maximum transmission unit (MTU), in bytes. The supported values are 1500 and 8500. The default value is 1500.</p>
    pub fn set_mtu(mut self, input: ::std::option::Option<i32>) -> Self {
        self.inner = self.inner.set_mtu(input);
        self
    }
    /// <p>The maximum transmission unit (MTU), in bytes. The supported values are 1500 and 8500. The default value is 1500.</p>
    pub fn get_mtu(&self) -> &::std::option::Option<i32> {
        self.inner.get_mtu()
    }
    /// <p>Indicates whether to enable or disable SiteLink.</p>
    pub fn enable_site_link(mut self, input: bool) -> Self {
        self.inner = self.inner.enable_site_link(input);
        self
    }
    /// <p>Indicates whether to enable or disable SiteLink.</p>
    pub fn set_enable_site_link(mut self, input: ::std::option::Option<bool>) -> Self {
        self.inner = self.inner.set_enable_site_link(input);
        self
    }
    /// <p>Indicates whether to enable or disable SiteLink.</p>
    pub fn get_enable_site_link(&self) -> &::std::option::Option<bool> {
        self.inner.get_enable_site_link()
    }
    /// <p>The name of the virtual private interface.</p>
    pub fn virtual_interface_name(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
        self.inner = self.inner.virtual_interface_name(input.into());
        self
    }
    /// <p>The name of the virtual private interface.</p>
    pub fn set_virtual_interface_name(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
        self.inner = self.inner.set_virtual_interface_name(input);
        self
    }
    /// <p>The name of the virtual private interface.</p>
    pub fn get_virtual_interface_name(&self) -> &::std::option::Option<::std::string::String> {
        self.inner.get_virtual_interface_name()
    }
}