aws_sdk_codecommit/operation/
merge_pull_request_by_fast_forward.rs

1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2/// Orchestration and serialization glue logic for `MergePullRequestByFastForward`.
3#[derive(::std::clone::Clone, ::std::default::Default, ::std::fmt::Debug)]
4#[non_exhaustive]
5pub struct MergePullRequestByFastForward;
6impl MergePullRequestByFastForward {
7    /// Creates a new `MergePullRequestByFastForward`
8    pub fn new() -> Self {
9        Self
10    }
11    pub(crate) async fn orchestrate(
12        runtime_plugins: &::aws_smithy_runtime_api::client::runtime_plugin::RuntimePlugins,
13        input: crate::operation::merge_pull_request_by_fast_forward::MergePullRequestByFastForwardInput,
14    ) -> ::std::result::Result<
15        crate::operation::merge_pull_request_by_fast_forward::MergePullRequestByFastForwardOutput,
16        ::aws_smithy_runtime_api::client::result::SdkError<
17            crate::operation::merge_pull_request_by_fast_forward::MergePullRequestByFastForwardError,
18            ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
19        >,
20    > {
21        let map_err = |err: ::aws_smithy_runtime_api::client::result::SdkError<
22            ::aws_smithy_runtime_api::client::interceptors::context::Error,
23            ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
24        >| {
25            err.map_service_error(|err| {
26                err.downcast::<crate::operation::merge_pull_request_by_fast_forward::MergePullRequestByFastForwardError>()
27                    .expect("correct error type")
28            })
29        };
30        let context = Self::orchestrate_with_stop_point(runtime_plugins, input, ::aws_smithy_runtime::client::orchestrator::StopPoint::None)
31            .await
32            .map_err(map_err)?;
33        let output = context.finalize().map_err(map_err)?;
34        ::std::result::Result::Ok(
35            output
36                .downcast::<crate::operation::merge_pull_request_by_fast_forward::MergePullRequestByFastForwardOutput>()
37                .expect("correct output type"),
38        )
39    }
40
41    pub(crate) async fn orchestrate_with_stop_point(
42        runtime_plugins: &::aws_smithy_runtime_api::client::runtime_plugin::RuntimePlugins,
43        input: crate::operation::merge_pull_request_by_fast_forward::MergePullRequestByFastForwardInput,
44        stop_point: ::aws_smithy_runtime::client::orchestrator::StopPoint,
45    ) -> ::std::result::Result<
46        ::aws_smithy_runtime_api::client::interceptors::context::InterceptorContext,
47        ::aws_smithy_runtime_api::client::result::SdkError<
48            ::aws_smithy_runtime_api::client::interceptors::context::Error,
49            ::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
50        >,
51    > {
52        let input = ::aws_smithy_runtime_api::client::interceptors::context::Input::erase(input);
53        use ::tracing::Instrument;
54        ::aws_smithy_runtime::client::orchestrator::invoke_with_stop_point(
55            "CodeCommit",
56            "MergePullRequestByFastForward",
57            input,
58            runtime_plugins,
59            stop_point,
60        )
61        // Create a parent span for the entire operation. Includes a random, internal-only,
62        // seven-digit ID for the operation orchestration so that it can be correlated in the logs.
63        .instrument(::tracing::debug_span!(
64            "CodeCommit.MergePullRequestByFastForward",
65            "rpc.service" = "CodeCommit",
66            "rpc.method" = "MergePullRequestByFastForward",
67            "sdk_invocation_id" = ::fastrand::u32(1_000_000..10_000_000),
68            "rpc.system" = "aws-api",
69        ))
70        .await
71    }
72
73    pub(crate) fn operation_runtime_plugins(
74        client_runtime_plugins: ::aws_smithy_runtime_api::client::runtime_plugin::RuntimePlugins,
75        client_config: &crate::config::Config,
76        config_override: ::std::option::Option<crate::config::Builder>,
77    ) -> ::aws_smithy_runtime_api::client::runtime_plugin::RuntimePlugins {
78        let mut runtime_plugins = client_runtime_plugins.with_operation_plugin(Self::new());
79
80        if let ::std::option::Option::Some(config_override) = config_override {
81            for plugin in config_override.runtime_plugins.iter().cloned() {
82                runtime_plugins = runtime_plugins.with_operation_plugin(plugin);
83            }
84            runtime_plugins = runtime_plugins.with_operation_plugin(crate::config::ConfigOverrideRuntimePlugin::new(
85                config_override,
86                client_config.config.clone(),
87                &client_config.runtime_components,
88            ));
89        }
90        runtime_plugins
91    }
92}
93impl ::aws_smithy_runtime_api::client::runtime_plugin::RuntimePlugin for MergePullRequestByFastForward {
94    fn config(&self) -> ::std::option::Option<::aws_smithy_types::config_bag::FrozenLayer> {
95        let mut cfg = ::aws_smithy_types::config_bag::Layer::new("MergePullRequestByFastForward");
96
97        cfg.store_put(::aws_smithy_runtime_api::client::ser_de::SharedRequestSerializer::new(
98            MergePullRequestByFastForwardRequestSerializer,
99        ));
100        cfg.store_put(::aws_smithy_runtime_api::client::ser_de::SharedResponseDeserializer::new(
101            MergePullRequestByFastForwardResponseDeserializer,
102        ));
103
104        cfg.store_put(::aws_smithy_runtime_api::client::auth::AuthSchemeOptionResolverParams::new(
105            crate::config::auth::Params::builder()
106                .operation_name("MergePullRequestByFastForward")
107                .build()
108                .expect("required fields set"),
109        ));
110
111        cfg.store_put(::aws_smithy_runtime_api::client::orchestrator::Metadata::new(
112            "MergePullRequestByFastForward",
113            "CodeCommit",
114        ));
115        let mut signing_options = ::aws_runtime::auth::SigningOptions::default();
116        signing_options.double_uri_encode = true;
117        signing_options.content_sha256_header = false;
118        signing_options.normalize_uri_path = true;
119        signing_options.payload_override = None;
120
121        cfg.store_put(::aws_runtime::auth::SigV4OperationSigningConfig {
122            signing_options,
123            ..::std::default::Default::default()
124        });
125
126        ::std::option::Option::Some(cfg.freeze())
127    }
128
129    fn runtime_components(
130        &self,
131        _: &::aws_smithy_runtime_api::client::runtime_components::RuntimeComponentsBuilder,
132    ) -> ::std::borrow::Cow<'_, ::aws_smithy_runtime_api::client::runtime_components::RuntimeComponentsBuilder> {
133        #[allow(unused_mut)]
134        let mut rcb = ::aws_smithy_runtime_api::client::runtime_components::RuntimeComponentsBuilder::new("MergePullRequestByFastForward")
135            .with_interceptor(::aws_smithy_runtime::client::stalled_stream_protection::StalledStreamProtectionInterceptor::default())
136            .with_interceptor(MergePullRequestByFastForwardEndpointParamsInterceptor)
137            .with_retry_classifier(::aws_smithy_runtime::client::retries::classifiers::TransientErrorClassifier::<
138                crate::operation::merge_pull_request_by_fast_forward::MergePullRequestByFastForwardError,
139            >::new())
140            .with_retry_classifier(::aws_smithy_runtime::client::retries::classifiers::ModeledAsRetryableClassifier::<
141                crate::operation::merge_pull_request_by_fast_forward::MergePullRequestByFastForwardError,
142            >::new())
143            .with_retry_classifier(::aws_runtime::retries::classifiers::AwsErrorCodeClassifier::<
144                crate::operation::merge_pull_request_by_fast_forward::MergePullRequestByFastForwardError,
145            >::new());
146
147        ::std::borrow::Cow::Owned(rcb)
148    }
149}
150
151#[derive(Debug)]
152struct MergePullRequestByFastForwardResponseDeserializer;
153impl ::aws_smithy_runtime_api::client::ser_de::DeserializeResponse for MergePullRequestByFastForwardResponseDeserializer {
154    fn deserialize_nonstreaming(
155        &self,
156        response: &::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
157    ) -> ::aws_smithy_runtime_api::client::interceptors::context::OutputOrError {
158        let (success, status) = (response.status().is_success(), response.status().as_u16());
159        let headers = response.headers();
160        let body = response.body().bytes().expect("body loaded");
161        #[allow(unused_mut)]
162        let mut force_error = false;
163        ::tracing::debug!(request_id = ?::aws_types::request_id::RequestId::request_id(response));
164        let parse_result = if !success && status != 200 || force_error {
165            crate::protocol_serde::shape_merge_pull_request_by_fast_forward::de_merge_pull_request_by_fast_forward_http_error(status, headers, body)
166        } else {
167            crate::protocol_serde::shape_merge_pull_request_by_fast_forward::de_merge_pull_request_by_fast_forward_http_response(
168                status, headers, body,
169            )
170        };
171        crate::protocol_serde::type_erase_result(parse_result)
172    }
173}
174#[derive(Debug)]
175struct MergePullRequestByFastForwardRequestSerializer;
176impl ::aws_smithy_runtime_api::client::ser_de::SerializeRequest for MergePullRequestByFastForwardRequestSerializer {
177    #[allow(unused_mut, clippy::let_and_return, clippy::needless_borrow, clippy::useless_conversion)]
178    fn serialize_input(
179        &self,
180        input: ::aws_smithy_runtime_api::client::interceptors::context::Input,
181        _cfg: &mut ::aws_smithy_types::config_bag::ConfigBag,
182    ) -> ::std::result::Result<::aws_smithy_runtime_api::client::orchestrator::HttpRequest, ::aws_smithy_runtime_api::box_error::BoxError> {
183        let input = input
184            .downcast::<crate::operation::merge_pull_request_by_fast_forward::MergePullRequestByFastForwardInput>()
185            .expect("correct type");
186        let _header_serialization_settings = _cfg
187            .load::<crate::serialization_settings::HeaderSerializationSettings>()
188            .cloned()
189            .unwrap_or_default();
190        let mut request_builder = {
191            #[allow(clippy::uninlined_format_args)]
192            fn uri_base(
193                _input: &crate::operation::merge_pull_request_by_fast_forward::MergePullRequestByFastForwardInput,
194                output: &mut ::std::string::String,
195            ) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::BuildError> {
196                use ::std::fmt::Write as _;
197                ::std::write!(output, "/").expect("formatting should succeed");
198                ::std::result::Result::Ok(())
199            }
200            #[allow(clippy::unnecessary_wraps)]
201            fn update_http_builder(
202                input: &crate::operation::merge_pull_request_by_fast_forward::MergePullRequestByFastForwardInput,
203                builder: ::http::request::Builder,
204            ) -> ::std::result::Result<::http::request::Builder, ::aws_smithy_types::error::operation::BuildError> {
205                let mut uri = ::std::string::String::new();
206                uri_base(input, &mut uri)?;
207                ::std::result::Result::Ok(builder.method("POST").uri(uri))
208            }
209            let mut builder = update_http_builder(&input, ::http::request::Builder::new())?;
210            builder = _header_serialization_settings.set_default_header(builder, ::http::header::CONTENT_TYPE, "application/x-amz-json-1.1");
211            builder = _header_serialization_settings.set_default_header(
212                builder,
213                ::http::header::HeaderName::from_static("x-amz-target"),
214                "CodeCommit_20150413.MergePullRequestByFastForward",
215            );
216            builder
217        };
218        let body = ::aws_smithy_types::body::SdkBody::from(
219            crate::protocol_serde::shape_merge_pull_request_by_fast_forward::ser_merge_pull_request_by_fast_forward_input(&input)?,
220        );
221        if let Some(content_length) = body.content_length() {
222            let content_length = content_length.to_string();
223            request_builder = _header_serialization_settings.set_default_header(request_builder, ::http::header::CONTENT_LENGTH, &content_length);
224        }
225        ::std::result::Result::Ok(request_builder.body(body).expect("valid request").try_into().unwrap())
226    }
227}
228#[derive(Debug)]
229struct MergePullRequestByFastForwardEndpointParamsInterceptor;
230
231impl ::aws_smithy_runtime_api::client::interceptors::Intercept for MergePullRequestByFastForwardEndpointParamsInterceptor {
232    fn name(&self) -> &'static str {
233        "MergePullRequestByFastForwardEndpointParamsInterceptor"
234    }
235
236    fn read_before_execution(
237        &self,
238        context: &::aws_smithy_runtime_api::client::interceptors::context::BeforeSerializationInterceptorContextRef<
239            '_,
240            ::aws_smithy_runtime_api::client::interceptors::context::Input,
241            ::aws_smithy_runtime_api::client::interceptors::context::Output,
242            ::aws_smithy_runtime_api::client::interceptors::context::Error,
243        >,
244        cfg: &mut ::aws_smithy_types::config_bag::ConfigBag,
245    ) -> ::std::result::Result<(), ::aws_smithy_runtime_api::box_error::BoxError> {
246        let _input = context
247            .input()
248            .downcast_ref::<MergePullRequestByFastForwardInput>()
249            .ok_or("failed to downcast to MergePullRequestByFastForwardInput")?;
250
251        let params = crate::config::endpoint::Params::builder()
252            .set_region(cfg.load::<::aws_types::region::Region>().map(|r| r.as_ref().to_owned()))
253            .set_use_dual_stack(cfg.load::<::aws_types::endpoint_config::UseDualStack>().map(|ty| ty.0))
254            .set_use_fips(cfg.load::<::aws_types::endpoint_config::UseFips>().map(|ty| ty.0))
255            .set_endpoint(cfg.load::<::aws_types::endpoint_config::EndpointUrl>().map(|ty| ty.0.clone()))
256            .build()
257            .map_err(|err| {
258                ::aws_smithy_runtime_api::client::interceptors::error::ContextAttachedError::new("endpoint params could not be built", err)
259            })?;
260        cfg.interceptor_state()
261            .store_put(::aws_smithy_runtime_api::client::endpoint::EndpointResolverParams::new(params));
262        ::std::result::Result::Ok(())
263    }
264}
265
266// The get_* functions below are generated from JMESPath expressions in the
267// operationContextParams trait. They target the operation's input shape.
268
269/// Error type for the `MergePullRequestByFastForwardError` operation.
270#[non_exhaustive]
271#[derive(::std::fmt::Debug)]
272pub enum MergePullRequestByFastForwardError {
273    /// <p>The merge cannot be completed because the target branch has been modified. Another user might have modified the target branch while the merge was in progress. Wait a few minutes, and then try again.</p>
274    ConcurrentReferenceUpdateException(crate::types::error::ConcurrentReferenceUpdateException),
275    /// <p>An encryption integrity check failed.</p>
276    EncryptionIntegrityChecksFailedException(crate::types::error::EncryptionIntegrityChecksFailedException),
277    /// <p>An encryption key could not be accessed.</p>
278    EncryptionKeyAccessDeniedException(crate::types::error::EncryptionKeyAccessDeniedException),
279    /// <p>The encryption key is disabled.</p>
280    EncryptionKeyDisabledException(crate::types::error::EncryptionKeyDisabledException),
281    /// <p>No encryption key was found.</p>
282    EncryptionKeyNotFoundException(crate::types::error::EncryptionKeyNotFoundException),
283    /// <p>The encryption key is not available.</p>
284    EncryptionKeyUnavailableException(crate::types::error::EncryptionKeyUnavailableException),
285    /// <p>The specified commit ID is not valid.</p>
286    InvalidCommitIdException(crate::types::error::InvalidCommitIdException),
287    /// <p>The pull request ID is not valid. Make sure that you have provided the full ID and that the pull request is in the specified repository, and then try again.</p>
288    InvalidPullRequestIdException(crate::types::error::InvalidPullRequestIdException),
289    /// <p>A specified repository name is not valid.</p><note>
290    /// <p>This exception occurs only when a specified repository name is not valid. Other exceptions occur when a required repository parameter is missing, or when a specified repository does not exist.</p>
291    /// </note>
292    InvalidRepositoryNameException(crate::types::error::InvalidRepositoryNameException),
293    /// <p>The pull request cannot be merged automatically into the destination branch. You must manually merge the branches and resolve any conflicts.</p>
294    ManualMergeRequiredException(crate::types::error::ManualMergeRequiredException),
295    /// <p>The pull request status cannot be updated because it is already closed.</p>
296    PullRequestAlreadyClosedException(crate::types::error::PullRequestAlreadyClosedException),
297    /// <p>The pull request cannot be merged because one or more approval rules applied to the pull request have conditions that have not been met.</p>
298    PullRequestApprovalRulesNotSatisfiedException(crate::types::error::PullRequestApprovalRulesNotSatisfiedException),
299    /// <p>The pull request ID could not be found. Make sure that you have specified the correct repository name and pull request ID, and then try again.</p>
300    PullRequestDoesNotExistException(crate::types::error::PullRequestDoesNotExistException),
301    /// <p>A pull request ID is required, but none was provided.</p>
302    PullRequestIdRequiredException(crate::types::error::PullRequestIdRequiredException),
303    /// <p>The specified reference does not exist. You must provide a full commit ID.</p>
304    ReferenceDoesNotExistException(crate::types::error::ReferenceDoesNotExistException),
305    /// <p>The specified repository does not exist.</p>
306    RepositoryDoesNotExistException(crate::types::error::RepositoryDoesNotExistException),
307    /// <p>A repository name is required, but was not specified.</p>
308    RepositoryNameRequiredException(crate::types::error::RepositoryNameRequiredException),
309    /// <p>The repository does not contain any pull requests with that pull request ID. Use GetPullRequest to verify the correct repository name for the pull request ID.</p>
310    RepositoryNotAssociatedWithPullRequestException(crate::types::error::RepositoryNotAssociatedWithPullRequestException),
311    /// <p>The tip of the source branch in the destination repository does not match the tip of the source branch specified in your request. The pull request might have been updated. Make sure that you have the latest changes.</p>
312    TipOfSourceReferenceIsDifferentException(crate::types::error::TipOfSourceReferenceIsDifferentException),
313    /// An unexpected error occurred (e.g., invalid JSON returned by the service or an unknown error code).
314    #[deprecated(note = "Matching `Unhandled` directly is not forwards compatible. Instead, match using a \
315    variable wildcard pattern and check `.code()`:
316     \
317    &nbsp;&nbsp;&nbsp;`err if err.code() == Some(\"SpecificExceptionCode\") => { /* handle the error */ }`
318     \
319    See [`ProvideErrorMetadata`](#impl-ProvideErrorMetadata-for-MergePullRequestByFastForwardError) for what information is available for the error.")]
320    Unhandled(crate::error::sealed_unhandled::Unhandled),
321}
322impl MergePullRequestByFastForwardError {
323    /// Creates the `MergePullRequestByFastForwardError::Unhandled` variant from any error type.
324    pub fn unhandled(
325        err: impl ::std::convert::Into<::std::boxed::Box<dyn ::std::error::Error + ::std::marker::Send + ::std::marker::Sync + 'static>>,
326    ) -> Self {
327        Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
328            source: err.into(),
329            meta: ::std::default::Default::default(),
330        })
331    }
332
333    /// Creates the `MergePullRequestByFastForwardError::Unhandled` variant from an [`ErrorMetadata`](::aws_smithy_types::error::ErrorMetadata).
334    pub fn generic(err: ::aws_smithy_types::error::ErrorMetadata) -> Self {
335        Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
336            source: err.clone().into(),
337            meta: err,
338        })
339    }
340    ///
341    /// Returns error metadata, which includes the error code, message,
342    /// request ID, and potentially additional information.
343    ///
344    pub fn meta(&self) -> &::aws_smithy_types::error::ErrorMetadata {
345        match self {
346            Self::ConcurrentReferenceUpdateException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
347            Self::EncryptionIntegrityChecksFailedException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
348            Self::EncryptionKeyAccessDeniedException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
349            Self::EncryptionKeyDisabledException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
350            Self::EncryptionKeyNotFoundException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
351            Self::EncryptionKeyUnavailableException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
352            Self::InvalidCommitIdException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
353            Self::InvalidPullRequestIdException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
354            Self::InvalidRepositoryNameException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
355            Self::ManualMergeRequiredException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
356            Self::PullRequestAlreadyClosedException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
357            Self::PullRequestApprovalRulesNotSatisfiedException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
358            Self::PullRequestDoesNotExistException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
359            Self::PullRequestIdRequiredException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
360            Self::ReferenceDoesNotExistException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
361            Self::RepositoryDoesNotExistException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
362            Self::RepositoryNameRequiredException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
363            Self::RepositoryNotAssociatedWithPullRequestException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
364            Self::TipOfSourceReferenceIsDifferentException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
365            Self::Unhandled(e) => &e.meta,
366        }
367    }
368    /// Returns `true` if the error kind is `MergePullRequestByFastForwardError::ConcurrentReferenceUpdateException`.
369    pub fn is_concurrent_reference_update_exception(&self) -> bool {
370        matches!(self, Self::ConcurrentReferenceUpdateException(_))
371    }
372    /// Returns `true` if the error kind is `MergePullRequestByFastForwardError::EncryptionIntegrityChecksFailedException`.
373    pub fn is_encryption_integrity_checks_failed_exception(&self) -> bool {
374        matches!(self, Self::EncryptionIntegrityChecksFailedException(_))
375    }
376    /// Returns `true` if the error kind is `MergePullRequestByFastForwardError::EncryptionKeyAccessDeniedException`.
377    pub fn is_encryption_key_access_denied_exception(&self) -> bool {
378        matches!(self, Self::EncryptionKeyAccessDeniedException(_))
379    }
380    /// Returns `true` if the error kind is `MergePullRequestByFastForwardError::EncryptionKeyDisabledException`.
381    pub fn is_encryption_key_disabled_exception(&self) -> bool {
382        matches!(self, Self::EncryptionKeyDisabledException(_))
383    }
384    /// Returns `true` if the error kind is `MergePullRequestByFastForwardError::EncryptionKeyNotFoundException`.
385    pub fn is_encryption_key_not_found_exception(&self) -> bool {
386        matches!(self, Self::EncryptionKeyNotFoundException(_))
387    }
388    /// Returns `true` if the error kind is `MergePullRequestByFastForwardError::EncryptionKeyUnavailableException`.
389    pub fn is_encryption_key_unavailable_exception(&self) -> bool {
390        matches!(self, Self::EncryptionKeyUnavailableException(_))
391    }
392    /// Returns `true` if the error kind is `MergePullRequestByFastForwardError::InvalidCommitIdException`.
393    pub fn is_invalid_commit_id_exception(&self) -> bool {
394        matches!(self, Self::InvalidCommitIdException(_))
395    }
396    /// Returns `true` if the error kind is `MergePullRequestByFastForwardError::InvalidPullRequestIdException`.
397    pub fn is_invalid_pull_request_id_exception(&self) -> bool {
398        matches!(self, Self::InvalidPullRequestIdException(_))
399    }
400    /// Returns `true` if the error kind is `MergePullRequestByFastForwardError::InvalidRepositoryNameException`.
401    pub fn is_invalid_repository_name_exception(&self) -> bool {
402        matches!(self, Self::InvalidRepositoryNameException(_))
403    }
404    /// Returns `true` if the error kind is `MergePullRequestByFastForwardError::ManualMergeRequiredException`.
405    pub fn is_manual_merge_required_exception(&self) -> bool {
406        matches!(self, Self::ManualMergeRequiredException(_))
407    }
408    /// Returns `true` if the error kind is `MergePullRequestByFastForwardError::PullRequestAlreadyClosedException`.
409    pub fn is_pull_request_already_closed_exception(&self) -> bool {
410        matches!(self, Self::PullRequestAlreadyClosedException(_))
411    }
412    /// Returns `true` if the error kind is `MergePullRequestByFastForwardError::PullRequestApprovalRulesNotSatisfiedException`.
413    pub fn is_pull_request_approval_rules_not_satisfied_exception(&self) -> bool {
414        matches!(self, Self::PullRequestApprovalRulesNotSatisfiedException(_))
415    }
416    /// Returns `true` if the error kind is `MergePullRequestByFastForwardError::PullRequestDoesNotExistException`.
417    pub fn is_pull_request_does_not_exist_exception(&self) -> bool {
418        matches!(self, Self::PullRequestDoesNotExistException(_))
419    }
420    /// Returns `true` if the error kind is `MergePullRequestByFastForwardError::PullRequestIdRequiredException`.
421    pub fn is_pull_request_id_required_exception(&self) -> bool {
422        matches!(self, Self::PullRequestIdRequiredException(_))
423    }
424    /// Returns `true` if the error kind is `MergePullRequestByFastForwardError::ReferenceDoesNotExistException`.
425    pub fn is_reference_does_not_exist_exception(&self) -> bool {
426        matches!(self, Self::ReferenceDoesNotExistException(_))
427    }
428    /// Returns `true` if the error kind is `MergePullRequestByFastForwardError::RepositoryDoesNotExistException`.
429    pub fn is_repository_does_not_exist_exception(&self) -> bool {
430        matches!(self, Self::RepositoryDoesNotExistException(_))
431    }
432    /// Returns `true` if the error kind is `MergePullRequestByFastForwardError::RepositoryNameRequiredException`.
433    pub fn is_repository_name_required_exception(&self) -> bool {
434        matches!(self, Self::RepositoryNameRequiredException(_))
435    }
436    /// Returns `true` if the error kind is `MergePullRequestByFastForwardError::RepositoryNotAssociatedWithPullRequestException`.
437    pub fn is_repository_not_associated_with_pull_request_exception(&self) -> bool {
438        matches!(self, Self::RepositoryNotAssociatedWithPullRequestException(_))
439    }
440    /// Returns `true` if the error kind is `MergePullRequestByFastForwardError::TipOfSourceReferenceIsDifferentException`.
441    pub fn is_tip_of_source_reference_is_different_exception(&self) -> bool {
442        matches!(self, Self::TipOfSourceReferenceIsDifferentException(_))
443    }
444}
445impl ::std::error::Error for MergePullRequestByFastForwardError {
446    fn source(&self) -> ::std::option::Option<&(dyn ::std::error::Error + 'static)> {
447        match self {
448            Self::ConcurrentReferenceUpdateException(_inner) => ::std::option::Option::Some(_inner),
449            Self::EncryptionIntegrityChecksFailedException(_inner) => ::std::option::Option::Some(_inner),
450            Self::EncryptionKeyAccessDeniedException(_inner) => ::std::option::Option::Some(_inner),
451            Self::EncryptionKeyDisabledException(_inner) => ::std::option::Option::Some(_inner),
452            Self::EncryptionKeyNotFoundException(_inner) => ::std::option::Option::Some(_inner),
453            Self::EncryptionKeyUnavailableException(_inner) => ::std::option::Option::Some(_inner),
454            Self::InvalidCommitIdException(_inner) => ::std::option::Option::Some(_inner),
455            Self::InvalidPullRequestIdException(_inner) => ::std::option::Option::Some(_inner),
456            Self::InvalidRepositoryNameException(_inner) => ::std::option::Option::Some(_inner),
457            Self::ManualMergeRequiredException(_inner) => ::std::option::Option::Some(_inner),
458            Self::PullRequestAlreadyClosedException(_inner) => ::std::option::Option::Some(_inner),
459            Self::PullRequestApprovalRulesNotSatisfiedException(_inner) => ::std::option::Option::Some(_inner),
460            Self::PullRequestDoesNotExistException(_inner) => ::std::option::Option::Some(_inner),
461            Self::PullRequestIdRequiredException(_inner) => ::std::option::Option::Some(_inner),
462            Self::ReferenceDoesNotExistException(_inner) => ::std::option::Option::Some(_inner),
463            Self::RepositoryDoesNotExistException(_inner) => ::std::option::Option::Some(_inner),
464            Self::RepositoryNameRequiredException(_inner) => ::std::option::Option::Some(_inner),
465            Self::RepositoryNotAssociatedWithPullRequestException(_inner) => ::std::option::Option::Some(_inner),
466            Self::TipOfSourceReferenceIsDifferentException(_inner) => ::std::option::Option::Some(_inner),
467            Self::Unhandled(_inner) => ::std::option::Option::Some(&*_inner.source),
468        }
469    }
470}
471impl ::std::fmt::Display for MergePullRequestByFastForwardError {
472    fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
473        match self {
474            Self::ConcurrentReferenceUpdateException(_inner) => _inner.fmt(f),
475            Self::EncryptionIntegrityChecksFailedException(_inner) => _inner.fmt(f),
476            Self::EncryptionKeyAccessDeniedException(_inner) => _inner.fmt(f),
477            Self::EncryptionKeyDisabledException(_inner) => _inner.fmt(f),
478            Self::EncryptionKeyNotFoundException(_inner) => _inner.fmt(f),
479            Self::EncryptionKeyUnavailableException(_inner) => _inner.fmt(f),
480            Self::InvalidCommitIdException(_inner) => _inner.fmt(f),
481            Self::InvalidPullRequestIdException(_inner) => _inner.fmt(f),
482            Self::InvalidRepositoryNameException(_inner) => _inner.fmt(f),
483            Self::ManualMergeRequiredException(_inner) => _inner.fmt(f),
484            Self::PullRequestAlreadyClosedException(_inner) => _inner.fmt(f),
485            Self::PullRequestApprovalRulesNotSatisfiedException(_inner) => _inner.fmt(f),
486            Self::PullRequestDoesNotExistException(_inner) => _inner.fmt(f),
487            Self::PullRequestIdRequiredException(_inner) => _inner.fmt(f),
488            Self::ReferenceDoesNotExistException(_inner) => _inner.fmt(f),
489            Self::RepositoryDoesNotExistException(_inner) => _inner.fmt(f),
490            Self::RepositoryNameRequiredException(_inner) => _inner.fmt(f),
491            Self::RepositoryNotAssociatedWithPullRequestException(_inner) => _inner.fmt(f),
492            Self::TipOfSourceReferenceIsDifferentException(_inner) => _inner.fmt(f),
493            Self::Unhandled(_inner) => {
494                if let ::std::option::Option::Some(code) = ::aws_smithy_types::error::metadata::ProvideErrorMetadata::code(self) {
495                    write!(f, "unhandled error ({code})")
496                } else {
497                    f.write_str("unhandled error")
498                }
499            }
500        }
501    }
502}
503impl ::aws_smithy_types::retry::ProvideErrorKind for MergePullRequestByFastForwardError {
504    fn code(&self) -> ::std::option::Option<&str> {
505        ::aws_smithy_types::error::metadata::ProvideErrorMetadata::code(self)
506    }
507    fn retryable_error_kind(&self) -> ::std::option::Option<::aws_smithy_types::retry::ErrorKind> {
508        ::std::option::Option::None
509    }
510}
511impl ::aws_smithy_types::error::metadata::ProvideErrorMetadata for MergePullRequestByFastForwardError {
512    fn meta(&self) -> &::aws_smithy_types::error::ErrorMetadata {
513        match self {
514            Self::ConcurrentReferenceUpdateException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
515            Self::EncryptionIntegrityChecksFailedException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
516            Self::EncryptionKeyAccessDeniedException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
517            Self::EncryptionKeyDisabledException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
518            Self::EncryptionKeyNotFoundException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
519            Self::EncryptionKeyUnavailableException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
520            Self::InvalidCommitIdException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
521            Self::InvalidPullRequestIdException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
522            Self::InvalidRepositoryNameException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
523            Self::ManualMergeRequiredException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
524            Self::PullRequestAlreadyClosedException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
525            Self::PullRequestApprovalRulesNotSatisfiedException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
526            Self::PullRequestDoesNotExistException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
527            Self::PullRequestIdRequiredException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
528            Self::ReferenceDoesNotExistException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
529            Self::RepositoryDoesNotExistException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
530            Self::RepositoryNameRequiredException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
531            Self::RepositoryNotAssociatedWithPullRequestException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
532            Self::TipOfSourceReferenceIsDifferentException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
533            Self::Unhandled(_inner) => &_inner.meta,
534        }
535    }
536}
537impl ::aws_smithy_runtime_api::client::result::CreateUnhandledError for MergePullRequestByFastForwardError {
538    fn create_unhandled_error(
539        source: ::std::boxed::Box<dyn ::std::error::Error + ::std::marker::Send + ::std::marker::Sync + 'static>,
540        meta: ::std::option::Option<::aws_smithy_types::error::ErrorMetadata>,
541    ) -> Self {
542        Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
543            source,
544            meta: meta.unwrap_or_default(),
545        })
546    }
547}
548impl ::aws_types::request_id::RequestId for crate::operation::merge_pull_request_by_fast_forward::MergePullRequestByFastForwardError {
549    fn request_id(&self) -> Option<&str> {
550        self.meta().request_id()
551    }
552}
553
554pub use crate::operation::merge_pull_request_by_fast_forward::_merge_pull_request_by_fast_forward_output::MergePullRequestByFastForwardOutput;
555
556pub use crate::operation::merge_pull_request_by_fast_forward::_merge_pull_request_by_fast_forward_input::MergePullRequestByFastForwardInput;
557
558mod _merge_pull_request_by_fast_forward_input;
559
560mod _merge_pull_request_by_fast_forward_output;
561
562/// Builders
563pub mod builders;