aws_sdk_codecommit/operation/merge_pull_request_by_three_way/
builders.rs

1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2pub use crate::operation::merge_pull_request_by_three_way::_merge_pull_request_by_three_way_output::MergePullRequestByThreeWayOutputBuilder;
3
4pub use crate::operation::merge_pull_request_by_three_way::_merge_pull_request_by_three_way_input::MergePullRequestByThreeWayInputBuilder;
5
6impl crate::operation::merge_pull_request_by_three_way::builders::MergePullRequestByThreeWayInputBuilder {
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::merge_pull_request_by_three_way::MergePullRequestByThreeWayOutput,
13        ::aws_smithy_runtime_api::client::result::SdkError<
14            crate::operation::merge_pull_request_by_three_way::MergePullRequestByThreeWayError,
15            ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
16        >,
17    > {
18        let mut fluent_builder = client.merge_pull_request_by_three_way();
19        fluent_builder.inner = self;
20        fluent_builder.send().await
21    }
22}
23/// Fluent builder constructing a request to `MergePullRequestByThreeWay`.
24///
25/// <p>Attempts to merge the source commit of a pull request into the specified destination branch for that pull request at the specified commit using the three-way merge strategy. If the merge is successful, it closes the pull request.</p>
26#[derive(::std::clone::Clone, ::std::fmt::Debug)]
27pub struct MergePullRequestByThreeWayFluentBuilder {
28    handle: ::std::sync::Arc<crate::client::Handle>,
29    inner: crate::operation::merge_pull_request_by_three_way::builders::MergePullRequestByThreeWayInputBuilder,
30    config_override: ::std::option::Option<crate::config::Builder>,
31}
32impl
33    crate::client::customize::internal::CustomizableSend<
34        crate::operation::merge_pull_request_by_three_way::MergePullRequestByThreeWayOutput,
35        crate::operation::merge_pull_request_by_three_way::MergePullRequestByThreeWayError,
36    > for MergePullRequestByThreeWayFluentBuilder
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::merge_pull_request_by_three_way::MergePullRequestByThreeWayOutput,
44            crate::operation::merge_pull_request_by_three_way::MergePullRequestByThreeWayError,
45        >,
46    > {
47        ::std::boxed::Box::pin(async move { self.config_override(config_override).send().await })
48    }
49}
50impl MergePullRequestByThreeWayFluentBuilder {
51    /// Creates a new `MergePullRequestByThreeWayFluentBuilder`.
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 MergePullRequestByThreeWay as a reference.
60    pub fn as_input(&self) -> &crate::operation::merge_pull_request_by_three_way::builders::MergePullRequestByThreeWayInputBuilder {
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::merge_pull_request_by_three_way::MergePullRequestByThreeWayOutput,
75        ::aws_smithy_runtime_api::client::result::SdkError<
76            crate::operation::merge_pull_request_by_three_way::MergePullRequestByThreeWayError,
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::merge_pull_request_by_three_way::MergePullRequestByThreeWay::operation_runtime_plugins(
85            self.handle.runtime_plugins.clone(),
86            &self.handle.conf,
87            self.config_override,
88        );
89        crate::operation::merge_pull_request_by_three_way::MergePullRequestByThreeWay::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::merge_pull_request_by_three_way::MergePullRequestByThreeWayOutput,
97        crate::operation::merge_pull_request_by_three_way::MergePullRequestByThreeWayError,
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>The system-generated ID of the pull request. To get this ID, use <code>ListPullRequests</code>.</p>
112    pub fn pull_request_id(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
113        self.inner = self.inner.pull_request_id(input.into());
114        self
115    }
116    /// <p>The system-generated ID of the pull request. To get this ID, use <code>ListPullRequests</code>.</p>
117    pub fn set_pull_request_id(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
118        self.inner = self.inner.set_pull_request_id(input);
119        self
120    }
121    /// <p>The system-generated ID of the pull request. To get this ID, use <code>ListPullRequests</code>.</p>
122    pub fn get_pull_request_id(&self) -> &::std::option::Option<::std::string::String> {
123        self.inner.get_pull_request_id()
124    }
125    /// <p>The name of the repository where the pull request was created.</p>
126    pub fn repository_name(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
127        self.inner = self.inner.repository_name(input.into());
128        self
129    }
130    /// <p>The name of the repository where the pull request was created.</p>
131    pub fn set_repository_name(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
132        self.inner = self.inner.set_repository_name(input);
133        self
134    }
135    /// <p>The name of the repository where the pull request was created.</p>
136    pub fn get_repository_name(&self) -> &::std::option::Option<::std::string::String> {
137        self.inner.get_repository_name()
138    }
139    /// <p>The full commit ID of the original or updated commit in the pull request source branch. Pass this value if you want an exception thrown if the current commit ID of the tip of the source branch does not match this commit ID.</p>
140    pub fn source_commit_id(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
141        self.inner = self.inner.source_commit_id(input.into());
142        self
143    }
144    /// <p>The full commit ID of the original or updated commit in the pull request source branch. Pass this value if you want an exception thrown if the current commit ID of the tip of the source branch does not match this commit ID.</p>
145    pub fn set_source_commit_id(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
146        self.inner = self.inner.set_source_commit_id(input);
147        self
148    }
149    /// <p>The full commit ID of the original or updated commit in the pull request source branch. Pass this value if you want an exception thrown if the current commit ID of the tip of the source branch does not match this commit ID.</p>
150    pub fn get_source_commit_id(&self) -> &::std::option::Option<::std::string::String> {
151        self.inner.get_source_commit_id()
152    }
153    /// <p>The level of conflict detail to use. If unspecified, the default FILE_LEVEL is used, which returns a not-mergeable result if the same file has differences in both branches. If LINE_LEVEL is specified, a conflict is considered not mergeable if the same file in both branches has differences on the same line.</p>
154    pub fn conflict_detail_level(mut self, input: crate::types::ConflictDetailLevelTypeEnum) -> Self {
155        self.inner = self.inner.conflict_detail_level(input);
156        self
157    }
158    /// <p>The level of conflict detail to use. If unspecified, the default FILE_LEVEL is used, which returns a not-mergeable result if the same file has differences in both branches. If LINE_LEVEL is specified, a conflict is considered not mergeable if the same file in both branches has differences on the same line.</p>
159    pub fn set_conflict_detail_level(mut self, input: ::std::option::Option<crate::types::ConflictDetailLevelTypeEnum>) -> Self {
160        self.inner = self.inner.set_conflict_detail_level(input);
161        self
162    }
163    /// <p>The level of conflict detail to use. If unspecified, the default FILE_LEVEL is used, which returns a not-mergeable result if the same file has differences in both branches. If LINE_LEVEL is specified, a conflict is considered not mergeable if the same file in both branches has differences on the same line.</p>
164    pub fn get_conflict_detail_level(&self) -> &::std::option::Option<crate::types::ConflictDetailLevelTypeEnum> {
165        self.inner.get_conflict_detail_level()
166    }
167    /// <p>Specifies which branch to use when resolving conflicts, or whether to attempt automatically merging two versions of a file. The default is NONE, which requires any conflicts to be resolved manually before the merge operation is successful.</p>
168    pub fn conflict_resolution_strategy(mut self, input: crate::types::ConflictResolutionStrategyTypeEnum) -> Self {
169        self.inner = self.inner.conflict_resolution_strategy(input);
170        self
171    }
172    /// <p>Specifies which branch to use when resolving conflicts, or whether to attempt automatically merging two versions of a file. The default is NONE, which requires any conflicts to be resolved manually before the merge operation is successful.</p>
173    pub fn set_conflict_resolution_strategy(mut self, input: ::std::option::Option<crate::types::ConflictResolutionStrategyTypeEnum>) -> Self {
174        self.inner = self.inner.set_conflict_resolution_strategy(input);
175        self
176    }
177    /// <p>Specifies which branch to use when resolving conflicts, or whether to attempt automatically merging two versions of a file. The default is NONE, which requires any conflicts to be resolved manually before the merge operation is successful.</p>
178    pub fn get_conflict_resolution_strategy(&self) -> &::std::option::Option<crate::types::ConflictResolutionStrategyTypeEnum> {
179        self.inner.get_conflict_resolution_strategy()
180    }
181    /// <p>The commit message to include in the commit information for the merge.</p>
182    pub fn commit_message(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
183        self.inner = self.inner.commit_message(input.into());
184        self
185    }
186    /// <p>The commit message to include in the commit information for the merge.</p>
187    pub fn set_commit_message(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
188        self.inner = self.inner.set_commit_message(input);
189        self
190    }
191    /// <p>The commit message to include in the commit information for the merge.</p>
192    pub fn get_commit_message(&self) -> &::std::option::Option<::std::string::String> {
193        self.inner.get_commit_message()
194    }
195    /// <p>The name of the author who created the commit. This information is used as both the author and committer for the commit.</p>
196    pub fn author_name(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
197        self.inner = self.inner.author_name(input.into());
198        self
199    }
200    /// <p>The name of the author who created the commit. This information is used as both the author and committer for the commit.</p>
201    pub fn set_author_name(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
202        self.inner = self.inner.set_author_name(input);
203        self
204    }
205    /// <p>The name of the author who created the commit. This information is used as both the author and committer for the commit.</p>
206    pub fn get_author_name(&self) -> &::std::option::Option<::std::string::String> {
207        self.inner.get_author_name()
208    }
209    /// <p>The email address of the person merging the branches. This information is used in the commit information for the merge.</p>
210    pub fn email(mut self, input: impl ::std::convert::Into<::std::string::String>) -> Self {
211        self.inner = self.inner.email(input.into());
212        self
213    }
214    /// <p>The email address of the person merging the branches. This information is used in the commit information for the merge.</p>
215    pub fn set_email(mut self, input: ::std::option::Option<::std::string::String>) -> Self {
216        self.inner = self.inner.set_email(input);
217        self
218    }
219    /// <p>The email address of the person merging the branches. This information is used in the commit information for the merge.</p>
220    pub fn get_email(&self) -> &::std::option::Option<::std::string::String> {
221        self.inner.get_email()
222    }
223    /// <p>If the commit contains deletions, whether to keep a folder or folder structure if the changes leave the folders empty. If true, a .gitkeep file is created for empty folders. The default is false.</p>
224    pub fn keep_empty_folders(mut self, input: bool) -> Self {
225        self.inner = self.inner.keep_empty_folders(input);
226        self
227    }
228    /// <p>If the commit contains deletions, whether to keep a folder or folder structure if the changes leave the folders empty. If true, a .gitkeep file is created for empty folders. The default is false.</p>
229    pub fn set_keep_empty_folders(mut self, input: ::std::option::Option<bool>) -> Self {
230        self.inner = self.inner.set_keep_empty_folders(input);
231        self
232    }
233    /// <p>If the commit contains deletions, whether to keep a folder or folder structure if the changes leave the folders empty. If true, a .gitkeep file is created for empty folders. The default is false.</p>
234    pub fn get_keep_empty_folders(&self) -> &::std::option::Option<bool> {
235        self.inner.get_keep_empty_folders()
236    }
237    /// <p>If AUTOMERGE is the conflict resolution strategy, a list of inputs to use when resolving conflicts during a merge.</p>
238    pub fn conflict_resolution(mut self, input: crate::types::ConflictResolution) -> Self {
239        self.inner = self.inner.conflict_resolution(input);
240        self
241    }
242    /// <p>If AUTOMERGE is the conflict resolution strategy, a list of inputs to use when resolving conflicts during a merge.</p>
243    pub fn set_conflict_resolution(mut self, input: ::std::option::Option<crate::types::ConflictResolution>) -> Self {
244        self.inner = self.inner.set_conflict_resolution(input);
245        self
246    }
247    /// <p>If AUTOMERGE is the conflict resolution strategy, a list of inputs to use when resolving conflicts during a merge.</p>
248    pub fn get_conflict_resolution(&self) -> &::std::option::Option<crate::types::ConflictResolution> {
249        self.inner.get_conflict_resolution()
250    }
251}