aws_sdk_opensearch/operation/upgrade_domain/
builders.rs

1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2pub use crate::operation::upgrade_domain::_upgrade_domain_output::UpgradeDomainOutputBuilder;
3
4pub use crate::operation::upgrade_domain::_upgrade_domain_input::UpgradeDomainInputBuilder;
5
6impl crate::operation::upgrade_domain::builders::UpgradeDomainInputBuilder {
7    /// Sends a request with this input using the given client.
8    pub async fn send_with(
9        self,
10        client: &crate::Client,
11    ) -> ::std::result::Result<
12        crate::operation::upgrade_domain::UpgradeDomainOutput,
13        ::aws_smithy_runtime_api::client::result::SdkError<
14            crate::operation::upgrade_domain::UpgradeDomainError,
15            ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
16        >,
17    > {
18        let mut fluent_builder = client.upgrade_domain();
19        fluent_builder.inner = self;
20        fluent_builder.send().await
21    }
22}
23/// Fluent builder constructing a request to `UpgradeDomain`.
24///
25/// <p>Allows you to either upgrade your Amazon OpenSearch Service domain or perform an upgrade eligibility check to a compatible version of OpenSearch or Elasticsearch.</p>
26#[derive(::std::clone::Clone, ::std::fmt::Debug)]
27pub struct UpgradeDomainFluentBuilder {
28    handle: ::std::sync::Arc<crate::client::Handle>,
29    inner: crate::operation::upgrade_domain::builders::UpgradeDomainInputBuilder,
30    config_override: ::std::option::Option<crate::config::Builder>,
31}
32impl
33    crate::client::customize::internal::CustomizableSend<
34        crate::operation::upgrade_domain::UpgradeDomainOutput,
35        crate::operation::upgrade_domain::UpgradeDomainError,
36    > for UpgradeDomainFluentBuilder
37{
38    fn send(
39        self,
40        config_override: crate::config::Builder,
41    ) -> crate::client::customize::internal::BoxFuture<
42        crate::client::customize::internal::SendResult<
43            crate::operation::upgrade_domain::UpgradeDomainOutput,
44            crate::operation::upgrade_domain::UpgradeDomainError,
45        >,
46    > {
47        ::std::boxed::Box::pin(async move { self.config_override(config_override).send().await })
48    }
49}
50impl UpgradeDomainFluentBuilder {
51    /// Creates a new `UpgradeDomainFluentBuilder`.
52    pub(crate) fn new(handle: ::std::sync::Arc<crate::client::Handle>) -> Self {
53        Self {
54            handle,
55            inner: ::std::default::Default::default(),
56            config_override: ::std::option::Option::None,
57        }
58    }
59    /// Access the UpgradeDomain as a reference.
60    pub fn as_input(&self) -> &crate::operation::upgrade_domain::builders::UpgradeDomainInputBuilder {
61        &self.inner
62    }
63    /// Sends the request and returns the response.
64    ///
65    /// If an error occurs, an `SdkError` will be returned with additional details that
66    /// can be matched against.
67    ///
68    /// By default, any retryable failures will be retried twice. Retry behavior
69    /// is configurable with the [RetryConfig](aws_smithy_types::retry::RetryConfig), which can be
70    /// set when configuring the client.
71    pub async fn send(
72        self,
73    ) -> ::std::result::Result<
74        crate::operation::upgrade_domain::UpgradeDomainOutput,
75        ::aws_smithy_runtime_api::client::result::SdkError<
76            crate::operation::upgrade_domain::UpgradeDomainError,
77            ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
78        >,
79    > {
80        let input = self
81            .inner
82            .build()
83            .map_err(::aws_smithy_runtime_api::client::result::SdkError::construction_failure)?;
84        let runtime_plugins = crate::operation::upgrade_domain::UpgradeDomain::operation_runtime_plugins(
85            self.handle.runtime_plugins.clone(),
86            &self.handle.conf,
87            self.config_override,
88        );
89        crate::operation::upgrade_domain::UpgradeDomain::orchestrate(&runtime_plugins, input).await
90    }
91
92    /// Consumes this builder, creating a customizable operation that can be modified before being sent.
93    pub fn customize(
94        self,
95    ) -> crate::client::customize::CustomizableOperation<
96        crate::operation::upgrade_domain::UpgradeDomainOutput,
97        crate::operation::upgrade_domain::UpgradeDomainError,
98        Self,
99    > {
100        crate::client::customize::CustomizableOperation::new(self)
101    }
102    pub(crate) fn config_override(mut self, config_override: impl ::std::convert::Into<crate::config::Builder>) -> Self {
103        self.set_config_override(::std::option::Option::Some(config_override.into()));
104        self
105    }
106
107    pub(crate) fn set_config_override(&mut self, config_override: ::std::option::Option<crate::config::Builder>) -> &mut Self {
108        self.config_override = config_override;
109        self
110    }
111    /// <p>Name of the OpenSearch Service domain that you want to upgrade.</p>
112    pub fn domain_name(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
113        self.inner = self.inner.domain_name(input.into());
114        self
115    }
116    /// <p>Name of the OpenSearch Service domain that you want to upgrade.</p>
117    pub fn set_domain_name(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
118        self.inner = self.inner.set_domain_name(input);
119        self
120    }
121    /// <p>Name of the OpenSearch Service domain that you want to upgrade.</p>
122    pub fn get_domain_name(&self) -> &::std::option::Option<::std::string::String> {
123        self.inner.get_domain_name()
124    }
125    /// <p>OpenSearch or Elasticsearch version to which you want to upgrade, in the format Opensearch_X.Y or Elasticsearch_X.Y.</p>
126    pub fn target_version(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
127        self.inner = self.inner.target_version(input.into());
128        self
129    }
130    /// <p>OpenSearch or Elasticsearch version to which you want to upgrade, in the format Opensearch_X.Y or Elasticsearch_X.Y.</p>
131    pub fn set_target_version(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
132        self.inner = self.inner.set_target_version(input);
133        self
134    }
135    /// <p>OpenSearch or Elasticsearch version to which you want to upgrade, in the format Opensearch_X.Y or Elasticsearch_X.Y.</p>
136    pub fn get_target_version(&self) -> &::std::option::Option<::std::string::String> {
137        self.inner.get_target_version()
138    }
139    /// <p>When true, indicates that an upgrade eligibility check needs to be performed. Does not actually perform the upgrade.</p>
140    pub fn perform_check_only(mut self, input: bool) -> Self {
141        self.inner = self.inner.perform_check_only(input);
142        self
143    }
144    /// <p>When true, indicates that an upgrade eligibility check needs to be performed. Does not actually perform the upgrade.</p>
145    pub fn set_perform_check_only(mut self, input: ::std::option::Option<bool>) -> Self {
146        self.inner = self.inner.set_perform_check_only(input);
147        self
148    }
149    /// <p>When true, indicates that an upgrade eligibility check needs to be performed. Does not actually perform the upgrade.</p>
150    pub fn get_perform_check_only(&self) -> &::std::option::Option<bool> {
151        self.inner.get_perform_check_only()
152    }
153    ///
154    /// Adds a key-value pair to `AdvancedOptions`.
155    ///
156    /// To override the contents of this collection use [`set_advanced_options`](Self::set_advanced_options).
157    ///
158    /// <p>Only supports the <code>override_main_response_version</code> parameter and not other advanced options. You can only include this option when upgrading to an OpenSearch version. Specifies whether the domain reports its version as 7.10 so that it continues to work with Elasticsearch OSS clients and plugins.</p>
159    pub fn advanced_options(
160        mut self,
161        k: impl ::std::convert::Into<::std::string::String>,
162        v: impl ::std::convert::Into<::std::string::String>,
163    ) -> Self {
164        self.inner = self.inner.advanced_options(k.into(), v.into());
165        self
166    }
167    /// <p>Only supports the <code>override_main_response_version</code> parameter and not other advanced options. You can only include this option when upgrading to an OpenSearch version. Specifies whether the domain reports its version as 7.10 so that it continues to work with Elasticsearch OSS clients and plugins.</p>
168    pub fn set_advanced_options(
169        mut self,
170        input: ::std::option::Option<::std::collections::HashMap<::std::string::String, ::std::string::String>>,
171    ) -> Self {
172        self.inner = self.inner.set_advanced_options(input);
173        self
174    }
175    /// <p>Only supports the <code>override_main_response_version</code> parameter and not other advanced options. You can only include this option when upgrading to an OpenSearch version. Specifies whether the domain reports its version as 7.10 so that it continues to work with Elasticsearch OSS clients and plugins.</p>
176    pub fn get_advanced_options(&self) -> &::std::option::Option<::std::collections::HashMap<::std::string::String, ::std::string::String>> {
177        self.inner.get_advanced_options()
178    }
179}