Skip to main content

aws_sdk_codecommit/operation/
delete_file.rs

1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2/// Orchestration and serialization glue logic for `DeleteFile`.
3#[derive(::std::clone::Clone, ::std::default::Default, ::std::fmt::Debug)]
4#[non_exhaustive]
5pub struct DeleteFile;
6impl DeleteFile {
7    /// Creates a new `DeleteFile`
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::delete_file::DeleteFileInput,
14    ) -> ::std::result::Result<
15        crate::operation::delete_file::DeleteFileOutput,
16        ::aws_smithy_runtime_api::client::result::SdkError<
17            crate::operation::delete_file::DeleteFileError,
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::delete_file::DeleteFileError>()
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::delete_file::DeleteFileOutput>()
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::delete_file::DeleteFileInput,
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("CodeCommit", "DeleteFile", input, runtime_plugins, stop_point)
55            // Create a parent span for the entire operation. Includes a random, internal-only,
56            // seven-digit ID for the operation orchestration so that it can be correlated in the logs.
57            .instrument(::tracing::debug_span!(
58                "CodeCommit.DeleteFile",
59                "rpc.service" = "CodeCommit",
60                "rpc.method" = "DeleteFile",
61                "sdk_invocation_id" = ::fastrand::u32(1_000_000..10_000_000),
62                "rpc.system" = "aws-api",
63            ))
64            .await
65    }
66
67    pub(crate) fn operation_runtime_plugins(
68        client_runtime_plugins: ::aws_smithy_runtime_api::client::runtime_plugin::RuntimePlugins,
69        client_config: &crate::config::Config,
70        config_override: ::std::option::Option<crate::config::Builder>,
71    ) -> ::aws_smithy_runtime_api::client::runtime_plugin::RuntimePlugins {
72        let mut runtime_plugins = client_runtime_plugins.with_operation_plugin(Self::new());
73
74        if let ::std::option::Option::Some(config_override) = config_override {
75            for plugin in config_override.runtime_plugins.iter().cloned() {
76                runtime_plugins = runtime_plugins.with_operation_plugin(plugin);
77            }
78            runtime_plugins = runtime_plugins.with_operation_plugin(crate::config::ConfigOverrideRuntimePlugin::new(
79                config_override,
80                client_config.config.clone(),
81                &client_config.runtime_components,
82            ));
83        }
84        runtime_plugins
85    }
86}
87impl ::aws_smithy_runtime_api::client::runtime_plugin::RuntimePlugin for DeleteFile {
88    fn config(&self) -> ::std::option::Option<::aws_smithy_types::config_bag::FrozenLayer> {
89        let mut cfg = ::aws_smithy_types::config_bag::Layer::new("DeleteFile");
90
91        cfg.store_put(::aws_smithy_runtime_api::client::ser_de::SharedRequestSerializer::new(
92            DeleteFileRequestSerializer,
93        ));
94        cfg.store_put(::aws_smithy_runtime_api::client::ser_de::SharedResponseDeserializer::new(
95            DeleteFileResponseDeserializer,
96        ));
97
98        cfg.store_put(::aws_smithy_runtime_api::client::auth::AuthSchemeOptionResolverParams::new(
99            crate::config::auth::Params::builder()
100                .operation_name("DeleteFile")
101                .build()
102                .expect("required fields set"),
103        ));
104
105        cfg.store_put(::aws_smithy_runtime_api::client::orchestrator::Metadata::new("DeleteFile", "CodeCommit"));
106        let mut signing_options = ::aws_runtime::auth::SigningOptions::default();
107        signing_options.double_uri_encode = true;
108        signing_options.content_sha256_header = false;
109        signing_options.normalize_uri_path = true;
110        signing_options.payload_override = None;
111
112        cfg.store_put(::aws_runtime::auth::SigV4OperationSigningConfig {
113            signing_options,
114            ..::std::default::Default::default()
115        });
116
117        ::std::option::Option::Some(cfg.freeze())
118    }
119
120    fn runtime_components(
121        &self,
122        _: &::aws_smithy_runtime_api::client::runtime_components::RuntimeComponentsBuilder,
123    ) -> ::std::borrow::Cow<'_, ::aws_smithy_runtime_api::client::runtime_components::RuntimeComponentsBuilder> {
124        #[allow(unused_mut)]
125        let mut rcb = ::aws_smithy_runtime_api::client::runtime_components::RuntimeComponentsBuilder::new("DeleteFile")
126            .with_interceptor(::aws_smithy_runtime_api::client::interceptors::SharedInterceptor::permanent(
127                ::aws_smithy_runtime::client::stalled_stream_protection::StalledStreamProtectionInterceptor::default(),
128            ))
129            .with_interceptor(::aws_smithy_runtime_api::client::interceptors::SharedInterceptor::permanent(
130                DeleteFileEndpointParamsInterceptor,
131            ))
132            .with_retry_classifier(::aws_smithy_runtime::client::retries::classifiers::TransientErrorClassifier::<
133                crate::operation::delete_file::DeleteFileError,
134            >::new())
135            .with_retry_classifier(::aws_smithy_runtime::client::retries::classifiers::ModeledAsRetryableClassifier::<
136                crate::operation::delete_file::DeleteFileError,
137            >::new())
138            .with_retry_classifier(::aws_runtime::retries::classifiers::AwsErrorCodeClassifier::<
139                crate::operation::delete_file::DeleteFileError,
140            >::new());
141
142        ::std::borrow::Cow::Owned(rcb)
143    }
144}
145
146#[derive(Debug)]
147struct DeleteFileResponseDeserializer;
148impl ::aws_smithy_runtime_api::client::ser_de::DeserializeResponse for DeleteFileResponseDeserializer {
149    fn deserialize_nonstreaming_with_config(
150        &self,
151        response: &::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
152        _cfg: &::aws_smithy_types::config_bag::ConfigBag,
153    ) -> ::aws_smithy_runtime_api::client::interceptors::context::OutputOrError {
154        let (success, status) = (response.status().is_success(), response.status().as_u16());
155        let headers = response.headers();
156        let body = response.body().bytes().expect("body loaded");
157        #[allow(unused_mut)]
158        let mut force_error = false;
159        ::tracing::debug!(request_id = ?::aws_types::request_id::RequestId::request_id(response));
160        let parse_result = if !success && status != 200 || force_error {
161            crate::protocol_serde::shape_delete_file::de_delete_file_http_error(status, headers, body)
162        } else {
163            crate::protocol_serde::shape_delete_file::de_delete_file_http_response(status, headers, body)
164        };
165        crate::protocol_serde::type_erase_result(parse_result)
166    }
167}
168#[derive(Debug)]
169struct DeleteFileRequestSerializer;
170impl ::aws_smithy_runtime_api::client::ser_de::SerializeRequest for DeleteFileRequestSerializer {
171    #[allow(unused_mut, clippy::let_and_return, clippy::needless_borrow, clippy::useless_conversion)]
172    fn serialize_input(
173        &self,
174        input: ::aws_smithy_runtime_api::client::interceptors::context::Input,
175        _cfg: &mut ::aws_smithy_types::config_bag::ConfigBag,
176    ) -> ::std::result::Result<::aws_smithy_runtime_api::client::orchestrator::HttpRequest, ::aws_smithy_runtime_api::box_error::BoxError> {
177        let input = input.downcast::<crate::operation::delete_file::DeleteFileInput>().expect("correct type");
178        let _header_serialization_settings = _cfg
179            .load::<crate::serialization_settings::HeaderSerializationSettings>()
180            .cloned()
181            .unwrap_or_default();
182        let mut request_builder = {
183            #[allow(clippy::uninlined_format_args)]
184            fn uri_base(
185                _input: &crate::operation::delete_file::DeleteFileInput,
186                output: &mut ::std::string::String,
187            ) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::BuildError> {
188                use ::std::fmt::Write as _;
189                ::std::write!(output, "/").expect("formatting should succeed");
190                ::std::result::Result::Ok(())
191            }
192            #[allow(clippy::unnecessary_wraps)]
193            fn update_http_builder(
194                input: &crate::operation::delete_file::DeleteFileInput,
195                builder: ::http_1x::request::Builder,
196            ) -> ::std::result::Result<::http_1x::request::Builder, ::aws_smithy_types::error::operation::BuildError> {
197                let mut uri = ::std::string::String::new();
198                uri_base(input, &mut uri)?;
199                ::std::result::Result::Ok(builder.method("POST").uri(uri))
200            }
201            let mut builder = update_http_builder(&input, ::http_1x::request::Builder::new())?;
202            builder = _header_serialization_settings.set_default_header(builder, ::http_1x::header::CONTENT_TYPE, "application/x-amz-json-1.1");
203            builder = _header_serialization_settings.set_default_header(
204                builder,
205                ::http_1x::header::HeaderName::from_static("x-amz-target"),
206                "CodeCommit_20150413.DeleteFile",
207            );
208            builder
209        };
210        let body = ::aws_smithy_types::body::SdkBody::from(crate::protocol_serde::shape_delete_file::ser_delete_file_input(&input)?);
211        if let Some(content_length) = body.content_length() {
212            let content_length = content_length.to_string();
213            request_builder = _header_serialization_settings.set_default_header(request_builder, ::http_1x::header::CONTENT_LENGTH, &content_length);
214        }
215        ::std::result::Result::Ok(request_builder.body(body).expect("valid request").try_into().unwrap())
216    }
217}
218#[derive(Debug)]
219struct DeleteFileEndpointParamsInterceptor;
220
221#[::aws_smithy_runtime_api::client::interceptors::dyn_dispatch_hint]
222impl ::aws_smithy_runtime_api::client::interceptors::Intercept for DeleteFileEndpointParamsInterceptor {
223    fn name(&self) -> &'static str {
224        "DeleteFileEndpointParamsInterceptor"
225    }
226
227    fn read_before_execution(
228        &self,
229        context: &::aws_smithy_runtime_api::client::interceptors::context::BeforeSerializationInterceptorContextRef<
230            '_,
231            ::aws_smithy_runtime_api::client::interceptors::context::Input,
232            ::aws_smithy_runtime_api::client::interceptors::context::Output,
233            ::aws_smithy_runtime_api::client::interceptors::context::Error,
234        >,
235        cfg: &mut ::aws_smithy_types::config_bag::ConfigBag,
236    ) -> ::std::result::Result<(), ::aws_smithy_runtime_api::box_error::BoxError> {
237        let _input = context
238            .input()
239            .downcast_ref::<DeleteFileInput>()
240            .ok_or("failed to downcast to DeleteFileInput")?;
241
242        let params = crate::config::endpoint::Params::builder()
243            .set_region(cfg.load::<::aws_types::region::Region>().map(|r| r.as_ref().to_owned()))
244            .set_use_dual_stack(cfg.load::<::aws_types::endpoint_config::UseDualStack>().map(|ty| ty.0))
245            .set_use_fips(cfg.load::<::aws_types::endpoint_config::UseFips>().map(|ty| ty.0))
246            .set_endpoint(cfg.load::<::aws_types::endpoint_config::EndpointUrl>().map(|ty| ty.0.clone()))
247            .build()
248            .map_err(|err| {
249                ::aws_smithy_runtime_api::client::interceptors::error::ContextAttachedError::new("endpoint params could not be built", err)
250            })?;
251        cfg.interceptor_state()
252            .store_put(::aws_smithy_runtime_api::client::endpoint::EndpointResolverParams::new(params));
253        ::std::result::Result::Ok(())
254    }
255}
256
257// The get_* functions below are generated from JMESPath expressions in the
258// operationContextParams trait. They target the operation's input shape.
259
260/// Error type for the `DeleteFileError` operation.
261#[non_exhaustive]
262#[derive(::std::fmt::Debug)]
263pub enum DeleteFileError {
264    /// <p>The specified branch does not exist.</p>
265    BranchDoesNotExistException(crate::types::error::BranchDoesNotExistException),
266    /// <p>The specified branch name is not valid because it is a tag name. Enter the name of a branch in the repository. For a list of valid branch names, use <code>ListBranches</code>.</p>
267    BranchNameIsTagNameException(crate::types::error::BranchNameIsTagNameException),
268    /// <p>A branch name is required, but was not specified.</p>
269    BranchNameRequiredException(crate::types::error::BranchNameRequiredException),
270    /// <p>The commit message is too long. Provide a shorter string.</p>
271    CommitMessageLengthExceededException(crate::types::error::CommitMessageLengthExceededException),
272    /// <p>An encryption integrity check failed.</p>
273    EncryptionIntegrityChecksFailedException(crate::types::error::EncryptionIntegrityChecksFailedException),
274    /// <p>An encryption key could not be accessed.</p>
275    EncryptionKeyAccessDeniedException(crate::types::error::EncryptionKeyAccessDeniedException),
276    /// <p>The encryption key is disabled.</p>
277    EncryptionKeyDisabledException(crate::types::error::EncryptionKeyDisabledException),
278    /// <p>No encryption key was found.</p>
279    EncryptionKeyNotFoundException(crate::types::error::EncryptionKeyNotFoundException),
280    /// <p>The encryption key is not available.</p>
281    EncryptionKeyUnavailableException(crate::types::error::EncryptionKeyUnavailableException),
282    /// <p>The specified file does not exist. Verify that you have used the correct file name, full path, and extension.</p>
283    FileDoesNotExistException(crate::types::error::FileDoesNotExistException),
284    /// <p>The specified reference name is not valid.</p>
285    InvalidBranchNameException(crate::types::error::InvalidBranchNameException),
286    /// <p>The specified email address either contains one or more characters that are not allowed, or it exceeds the maximum number of characters allowed for an email address.</p>
287    InvalidEmailException(crate::types::error::InvalidEmailException),
288    /// <p>The parent commit ID is not valid. The commit ID cannot be empty, and must match the head commit ID for the branch of the repository where you want to add or update a file.</p>
289    InvalidParentCommitIdException(crate::types::error::InvalidParentCommitIdException),
290    /// <p>The specified path is not valid.</p>
291    InvalidPathException(crate::types::error::InvalidPathException),
292    /// <p>A specified repository name is not valid.</p><note>
293    /// <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>
294    /// </note>
295    InvalidRepositoryNameException(crate::types::error::InvalidRepositoryNameException),
296    /// <p>The user name is not valid because it has exceeded the character limit for author names.</p>
297    NameLengthExceededException(crate::types::error::NameLengthExceededException),
298    /// <p>The parent commit ID is not valid because it does not exist. The specified parent commit ID does not exist in the specified branch of the repository.</p>
299    ParentCommitDoesNotExistException(crate::types::error::ParentCommitDoesNotExistException),
300    /// <p>The file could not be added because the provided parent commit ID is not the current tip of the specified branch. To view the full commit ID of the current head of the branch, use <code>GetBranch</code>.</p>
301    ParentCommitIdOutdatedException(crate::types::error::ParentCommitIdOutdatedException),
302    /// <p>A parent commit ID is required. To view the full commit ID of a branch in a repository, use <code>GetBranch</code> or a Git command (for example, git pull or git log).</p>
303    ParentCommitIdRequiredException(crate::types::error::ParentCommitIdRequiredException),
304    /// <p>The folderPath for a location cannot be null.</p>
305    PathRequiredException(crate::types::error::PathRequiredException),
306    /// <p>The specified repository does not exist.</p>
307    RepositoryDoesNotExistException(crate::types::error::RepositoryDoesNotExistException),
308    /// <p>A repository name is required, but was not specified.</p>
309    RepositoryNameRequiredException(crate::types::error::RepositoryNameRequiredException),
310    /// An unexpected error occurred (e.g., invalid JSON returned by the service or an unknown error code).
311    #[deprecated(note = "Matching `Unhandled` directly is not forwards compatible. Instead, match using a \
312    variable wildcard pattern and check `.code()`:
313     \
314    &nbsp;&nbsp;&nbsp;`err if err.code() == Some(\"SpecificExceptionCode\") => { /* handle the error */ }`
315     \
316    See [`ProvideErrorMetadata`](#impl-ProvideErrorMetadata-for-DeleteFileError) for what information is available for the error.")]
317    Unhandled(crate::error::sealed_unhandled::Unhandled),
318}
319impl DeleteFileError {
320    /// Creates the `DeleteFileError::Unhandled` variant from any error type.
321    pub fn unhandled(
322        err: impl ::std::convert::Into<::std::boxed::Box<dyn ::std::error::Error + ::std::marker::Send + ::std::marker::Sync + 'static>>,
323    ) -> Self {
324        Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
325            source: err.into(),
326            meta: ::std::default::Default::default(),
327        })
328    }
329
330    /// Creates the `DeleteFileError::Unhandled` variant from an [`ErrorMetadata`](::aws_smithy_types::error::ErrorMetadata).
331    pub fn generic(err: ::aws_smithy_types::error::ErrorMetadata) -> Self {
332        Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
333            source: err.clone().into(),
334            meta: err,
335        })
336    }
337    ///
338    /// Returns error metadata, which includes the error code, message,
339    /// request ID, and potentially additional information.
340    ///
341    pub fn meta(&self) -> &::aws_smithy_types::error::ErrorMetadata {
342        match self {
343            Self::BranchDoesNotExistException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
344            Self::BranchNameIsTagNameException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
345            Self::BranchNameRequiredException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
346            Self::CommitMessageLengthExceededException(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::FileDoesNotExistException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
353            Self::InvalidBranchNameException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
354            Self::InvalidEmailException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
355            Self::InvalidParentCommitIdException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
356            Self::InvalidPathException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
357            Self::InvalidRepositoryNameException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
358            Self::NameLengthExceededException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
359            Self::ParentCommitDoesNotExistException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
360            Self::ParentCommitIdOutdatedException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
361            Self::ParentCommitIdRequiredException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
362            Self::PathRequiredException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
363            Self::RepositoryDoesNotExistException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
364            Self::RepositoryNameRequiredException(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 `DeleteFileError::BranchDoesNotExistException`.
369    pub fn is_branch_does_not_exist_exception(&self) -> bool {
370        matches!(self, Self::BranchDoesNotExistException(_))
371    }
372    /// Returns `true` if the error kind is `DeleteFileError::BranchNameIsTagNameException`.
373    pub fn is_branch_name_is_tag_name_exception(&self) -> bool {
374        matches!(self, Self::BranchNameIsTagNameException(_))
375    }
376    /// Returns `true` if the error kind is `DeleteFileError::BranchNameRequiredException`.
377    pub fn is_branch_name_required_exception(&self) -> bool {
378        matches!(self, Self::BranchNameRequiredException(_))
379    }
380    /// Returns `true` if the error kind is `DeleteFileError::CommitMessageLengthExceededException`.
381    pub fn is_commit_message_length_exceeded_exception(&self) -> bool {
382        matches!(self, Self::CommitMessageLengthExceededException(_))
383    }
384    /// Returns `true` if the error kind is `DeleteFileError::EncryptionIntegrityChecksFailedException`.
385    pub fn is_encryption_integrity_checks_failed_exception(&self) -> bool {
386        matches!(self, Self::EncryptionIntegrityChecksFailedException(_))
387    }
388    /// Returns `true` if the error kind is `DeleteFileError::EncryptionKeyAccessDeniedException`.
389    pub fn is_encryption_key_access_denied_exception(&self) -> bool {
390        matches!(self, Self::EncryptionKeyAccessDeniedException(_))
391    }
392    /// Returns `true` if the error kind is `DeleteFileError::EncryptionKeyDisabledException`.
393    pub fn is_encryption_key_disabled_exception(&self) -> bool {
394        matches!(self, Self::EncryptionKeyDisabledException(_))
395    }
396    /// Returns `true` if the error kind is `DeleteFileError::EncryptionKeyNotFoundException`.
397    pub fn is_encryption_key_not_found_exception(&self) -> bool {
398        matches!(self, Self::EncryptionKeyNotFoundException(_))
399    }
400    /// Returns `true` if the error kind is `DeleteFileError::EncryptionKeyUnavailableException`.
401    pub fn is_encryption_key_unavailable_exception(&self) -> bool {
402        matches!(self, Self::EncryptionKeyUnavailableException(_))
403    }
404    /// Returns `true` if the error kind is `DeleteFileError::FileDoesNotExistException`.
405    pub fn is_file_does_not_exist_exception(&self) -> bool {
406        matches!(self, Self::FileDoesNotExistException(_))
407    }
408    /// Returns `true` if the error kind is `DeleteFileError::InvalidBranchNameException`.
409    pub fn is_invalid_branch_name_exception(&self) -> bool {
410        matches!(self, Self::InvalidBranchNameException(_))
411    }
412    /// Returns `true` if the error kind is `DeleteFileError::InvalidEmailException`.
413    pub fn is_invalid_email_exception(&self) -> bool {
414        matches!(self, Self::InvalidEmailException(_))
415    }
416    /// Returns `true` if the error kind is `DeleteFileError::InvalidParentCommitIdException`.
417    pub fn is_invalid_parent_commit_id_exception(&self) -> bool {
418        matches!(self, Self::InvalidParentCommitIdException(_))
419    }
420    /// Returns `true` if the error kind is `DeleteFileError::InvalidPathException`.
421    pub fn is_invalid_path_exception(&self) -> bool {
422        matches!(self, Self::InvalidPathException(_))
423    }
424    /// Returns `true` if the error kind is `DeleteFileError::InvalidRepositoryNameException`.
425    pub fn is_invalid_repository_name_exception(&self) -> bool {
426        matches!(self, Self::InvalidRepositoryNameException(_))
427    }
428    /// Returns `true` if the error kind is `DeleteFileError::NameLengthExceededException`.
429    pub fn is_name_length_exceeded_exception(&self) -> bool {
430        matches!(self, Self::NameLengthExceededException(_))
431    }
432    /// Returns `true` if the error kind is `DeleteFileError::ParentCommitDoesNotExistException`.
433    pub fn is_parent_commit_does_not_exist_exception(&self) -> bool {
434        matches!(self, Self::ParentCommitDoesNotExistException(_))
435    }
436    /// Returns `true` if the error kind is `DeleteFileError::ParentCommitIdOutdatedException`.
437    pub fn is_parent_commit_id_outdated_exception(&self) -> bool {
438        matches!(self, Self::ParentCommitIdOutdatedException(_))
439    }
440    /// Returns `true` if the error kind is `DeleteFileError::ParentCommitIdRequiredException`.
441    pub fn is_parent_commit_id_required_exception(&self) -> bool {
442        matches!(self, Self::ParentCommitIdRequiredException(_))
443    }
444    /// Returns `true` if the error kind is `DeleteFileError::PathRequiredException`.
445    pub fn is_path_required_exception(&self) -> bool {
446        matches!(self, Self::PathRequiredException(_))
447    }
448    /// Returns `true` if the error kind is `DeleteFileError::RepositoryDoesNotExistException`.
449    pub fn is_repository_does_not_exist_exception(&self) -> bool {
450        matches!(self, Self::RepositoryDoesNotExistException(_))
451    }
452    /// Returns `true` if the error kind is `DeleteFileError::RepositoryNameRequiredException`.
453    pub fn is_repository_name_required_exception(&self) -> bool {
454        matches!(self, Self::RepositoryNameRequiredException(_))
455    }
456}
457impl ::std::error::Error for DeleteFileError {
458    fn source(&self) -> ::std::option::Option<&(dyn ::std::error::Error + 'static)> {
459        match self {
460            Self::BranchDoesNotExistException(_inner) => ::std::option::Option::Some(_inner),
461            Self::BranchNameIsTagNameException(_inner) => ::std::option::Option::Some(_inner),
462            Self::BranchNameRequiredException(_inner) => ::std::option::Option::Some(_inner),
463            Self::CommitMessageLengthExceededException(_inner) => ::std::option::Option::Some(_inner),
464            Self::EncryptionIntegrityChecksFailedException(_inner) => ::std::option::Option::Some(_inner),
465            Self::EncryptionKeyAccessDeniedException(_inner) => ::std::option::Option::Some(_inner),
466            Self::EncryptionKeyDisabledException(_inner) => ::std::option::Option::Some(_inner),
467            Self::EncryptionKeyNotFoundException(_inner) => ::std::option::Option::Some(_inner),
468            Self::EncryptionKeyUnavailableException(_inner) => ::std::option::Option::Some(_inner),
469            Self::FileDoesNotExistException(_inner) => ::std::option::Option::Some(_inner),
470            Self::InvalidBranchNameException(_inner) => ::std::option::Option::Some(_inner),
471            Self::InvalidEmailException(_inner) => ::std::option::Option::Some(_inner),
472            Self::InvalidParentCommitIdException(_inner) => ::std::option::Option::Some(_inner),
473            Self::InvalidPathException(_inner) => ::std::option::Option::Some(_inner),
474            Self::InvalidRepositoryNameException(_inner) => ::std::option::Option::Some(_inner),
475            Self::NameLengthExceededException(_inner) => ::std::option::Option::Some(_inner),
476            Self::ParentCommitDoesNotExistException(_inner) => ::std::option::Option::Some(_inner),
477            Self::ParentCommitIdOutdatedException(_inner) => ::std::option::Option::Some(_inner),
478            Self::ParentCommitIdRequiredException(_inner) => ::std::option::Option::Some(_inner),
479            Self::PathRequiredException(_inner) => ::std::option::Option::Some(_inner),
480            Self::RepositoryDoesNotExistException(_inner) => ::std::option::Option::Some(_inner),
481            Self::RepositoryNameRequiredException(_inner) => ::std::option::Option::Some(_inner),
482            Self::Unhandled(_inner) => ::std::option::Option::Some(&*_inner.source),
483        }
484    }
485}
486impl ::std::fmt::Display for DeleteFileError {
487    fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
488        match self {
489            Self::BranchDoesNotExistException(_inner) => _inner.fmt(f),
490            Self::BranchNameIsTagNameException(_inner) => _inner.fmt(f),
491            Self::BranchNameRequiredException(_inner) => _inner.fmt(f),
492            Self::CommitMessageLengthExceededException(_inner) => _inner.fmt(f),
493            Self::EncryptionIntegrityChecksFailedException(_inner) => _inner.fmt(f),
494            Self::EncryptionKeyAccessDeniedException(_inner) => _inner.fmt(f),
495            Self::EncryptionKeyDisabledException(_inner) => _inner.fmt(f),
496            Self::EncryptionKeyNotFoundException(_inner) => _inner.fmt(f),
497            Self::EncryptionKeyUnavailableException(_inner) => _inner.fmt(f),
498            Self::FileDoesNotExistException(_inner) => _inner.fmt(f),
499            Self::InvalidBranchNameException(_inner) => _inner.fmt(f),
500            Self::InvalidEmailException(_inner) => _inner.fmt(f),
501            Self::InvalidParentCommitIdException(_inner) => _inner.fmt(f),
502            Self::InvalidPathException(_inner) => _inner.fmt(f),
503            Self::InvalidRepositoryNameException(_inner) => _inner.fmt(f),
504            Self::NameLengthExceededException(_inner) => _inner.fmt(f),
505            Self::ParentCommitDoesNotExistException(_inner) => _inner.fmt(f),
506            Self::ParentCommitIdOutdatedException(_inner) => _inner.fmt(f),
507            Self::ParentCommitIdRequiredException(_inner) => _inner.fmt(f),
508            Self::PathRequiredException(_inner) => _inner.fmt(f),
509            Self::RepositoryDoesNotExistException(_inner) => _inner.fmt(f),
510            Self::RepositoryNameRequiredException(_inner) => _inner.fmt(f),
511            Self::Unhandled(_inner) => {
512                if let ::std::option::Option::Some(code) = ::aws_smithy_types::error::metadata::ProvideErrorMetadata::code(self) {
513                    write!(f, "unhandled error ({code})")
514                } else {
515                    f.write_str("unhandled error")
516                }
517            }
518        }
519    }
520}
521impl ::aws_smithy_types::retry::ProvideErrorKind for DeleteFileError {
522    fn code(&self) -> ::std::option::Option<&str> {
523        ::aws_smithy_types::error::metadata::ProvideErrorMetadata::code(self)
524    }
525    fn retryable_error_kind(&self) -> ::std::option::Option<::aws_smithy_types::retry::ErrorKind> {
526        ::std::option::Option::None
527    }
528}
529impl ::aws_smithy_types::error::metadata::ProvideErrorMetadata for DeleteFileError {
530    fn meta(&self) -> &::aws_smithy_types::error::ErrorMetadata {
531        match self {
532            Self::BranchDoesNotExistException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
533            Self::BranchNameIsTagNameException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
534            Self::BranchNameRequiredException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
535            Self::CommitMessageLengthExceededException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
536            Self::EncryptionIntegrityChecksFailedException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
537            Self::EncryptionKeyAccessDeniedException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
538            Self::EncryptionKeyDisabledException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
539            Self::EncryptionKeyNotFoundException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
540            Self::EncryptionKeyUnavailableException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
541            Self::FileDoesNotExistException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
542            Self::InvalidBranchNameException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
543            Self::InvalidEmailException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
544            Self::InvalidParentCommitIdException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
545            Self::InvalidPathException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
546            Self::InvalidRepositoryNameException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
547            Self::NameLengthExceededException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
548            Self::ParentCommitDoesNotExistException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
549            Self::ParentCommitIdOutdatedException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
550            Self::ParentCommitIdRequiredException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
551            Self::PathRequiredException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
552            Self::RepositoryDoesNotExistException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
553            Self::RepositoryNameRequiredException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
554            Self::Unhandled(_inner) => &_inner.meta,
555        }
556    }
557}
558impl ::aws_smithy_runtime_api::client::result::CreateUnhandledError for DeleteFileError {
559    fn create_unhandled_error(
560        source: ::std::boxed::Box<dyn ::std::error::Error + ::std::marker::Send + ::std::marker::Sync + 'static>,
561        meta: ::std::option::Option<::aws_smithy_types::error::ErrorMetadata>,
562    ) -> Self {
563        Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
564            source,
565            meta: meta.unwrap_or_default(),
566        })
567    }
568}
569impl ::aws_types::request_id::RequestId for crate::operation::delete_file::DeleteFileError {
570    fn request_id(&self) -> Option<&str> {
571        self.meta().request_id()
572    }
573}
574
575pub use crate::operation::delete_file::_delete_file_input::DeleteFileInput;
576
577pub use crate::operation::delete_file::_delete_file_output::DeleteFileOutput;
578
579mod _delete_file_input;
580
581mod _delete_file_output;
582
583/// Builders
584pub mod builders;