aws-sdk-lightsail 1.109.0

AWS SDK for Amazon Lightsail
Documentation
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
pub use crate::operation::create_container_service_registry_login::_create_container_service_registry_login_input::CreateContainerServiceRegistryLoginInputBuilder;

pub use crate::operation::create_container_service_registry_login::_create_container_service_registry_login_output::CreateContainerServiceRegistryLoginOutputBuilder;

impl crate::operation::create_container_service_registry_login::builders::CreateContainerServiceRegistryLoginInputBuilder {
    /// Sends a request with this input using the given client.
    pub async fn send_with(
        self,
        client: &crate::Client,
    ) -> ::std::result::Result<
        crate::operation::create_container_service_registry_login::CreateContainerServiceRegistryLoginOutput,
        ::aws_smithy_runtime_api::client::result::SdkError<
            crate::operation::create_container_service_registry_login::CreateContainerServiceRegistryLoginError,
            ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
        >,
    > {
        let mut fluent_builder = client.create_container_service_registry_login();
        fluent_builder.inner = self;
        fluent_builder.send().await
    }
}
/// Fluent builder constructing a request to `CreateContainerServiceRegistryLogin`.
///
/// <p>Creates a temporary set of log in credentials that you can use to log in to the Docker process on your local machine. After you're logged in, you can use the native Docker commands to push your local container images to the container image registry of your Amazon Lightsail account so that you can use them with your Lightsail container service. The log in credentials expire 12 hours after they are created, at which point you will need to create a new set of log in credentials.</p><note>
/// <p>You can only push container images to the container service registry of your Lightsail account. You cannot pull container images or perform any other container image management actions on the container service registry.</p>
/// </note>
/// <p>After you push your container images to the container image registry of your Lightsail account, use the <code>RegisterContainerImage</code> action to register the pushed images to a specific Lightsail container service.</p><note>
/// <p>This action is not required if you install and use the Lightsail Control (lightsailctl) plugin to push container images to your Lightsail container service. For more information, see <a href="https://docs.aws.amazon.com/lightsail/latest/userguide/amazon-lightsail-pushing-container-images">Pushing and managing container images on your Amazon Lightsail container services</a> in the <i>Amazon Lightsail Developer Guide</i>.</p>
/// </note>
#[derive(::std::clone::Clone, ::std::fmt::Debug)]
pub struct CreateContainerServiceRegistryLoginFluentBuilder {
    handle: ::std::sync::Arc<crate::client::Handle>,
    inner: crate::operation::create_container_service_registry_login::builders::CreateContainerServiceRegistryLoginInputBuilder,
    config_override: ::std::option::Option<crate::config::Builder>,
}
impl
    crate::client::customize::internal::CustomizableSend<
        crate::operation::create_container_service_registry_login::CreateContainerServiceRegistryLoginOutput,
        crate::operation::create_container_service_registry_login::CreateContainerServiceRegistryLoginError,
    > for CreateContainerServiceRegistryLoginFluentBuilder
{
    fn send(
        self,
        config_override: crate::config::Builder,
    ) -> crate::client::customize::internal::BoxFuture<
        crate::client::customize::internal::SendResult<
            crate::operation::create_container_service_registry_login::CreateContainerServiceRegistryLoginOutput,
            crate::operation::create_container_service_registry_login::CreateContainerServiceRegistryLoginError,
        >,
    > {
        ::std::boxed::Box::pin(async move { self.config_override(config_override).send().await })
    }
}
impl CreateContainerServiceRegistryLoginFluentBuilder {
    /// Creates a new `CreateContainerServiceRegistryLoginFluentBuilder`.
    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 CreateContainerServiceRegistryLogin as a reference.
    pub fn as_input(&self) -> &crate::operation::create_container_service_registry_login::builders::CreateContainerServiceRegistryLoginInputBuilder {
        &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::create_container_service_registry_login::CreateContainerServiceRegistryLoginOutput,
        ::aws_smithy_runtime_api::client::result::SdkError<
            crate::operation::create_container_service_registry_login::CreateContainerServiceRegistryLoginError,
            ::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::create_container_service_registry_login::CreateContainerServiceRegistryLogin::operation_runtime_plugins(
                self.handle.runtime_plugins.clone(),
                &self.handle.conf,
                self.config_override,
            );
        crate::operation::create_container_service_registry_login::CreateContainerServiceRegistryLogin::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::create_container_service_registry_login::CreateContainerServiceRegistryLoginOutput,
        crate::operation::create_container_service_registry_login::CreateContainerServiceRegistryLoginError,
        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
    }
}