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(
150        &self,
151        response: &::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
152    ) -> ::aws_smithy_runtime_api::client::interceptors::context::OutputOrError {
153        let (success, status) = (response.status().is_success(), response.status().as_u16());
154        let headers = response.headers();
155        let body = response.body().bytes().expect("body loaded");
156        #[allow(unused_mut)]
157        let mut force_error = false;
158        ::tracing::debug!(request_id = ?::aws_types::request_id::RequestId::request_id(response));
159        let parse_result = if !success && status != 200 || force_error {
160            crate::protocol_serde::shape_delete_file::de_delete_file_http_error(status, headers, body)
161        } else {
162            crate::protocol_serde::shape_delete_file::de_delete_file_http_response(status, headers, body)
163        };
164        crate::protocol_serde::type_erase_result(parse_result)
165    }
166}
167#[derive(Debug)]
168struct DeleteFileRequestSerializer;
169impl ::aws_smithy_runtime_api::client::ser_de::SerializeRequest for DeleteFileRequestSerializer {
170    #[allow(unused_mut, clippy::let_and_return, clippy::needless_borrow, clippy::useless_conversion)]
171    fn serialize_input(
172        &self,
173        input: ::aws_smithy_runtime_api::client::interceptors::context::Input,
174        _cfg: &mut ::aws_smithy_types::config_bag::ConfigBag,
175    ) -> ::std::result::Result<::aws_smithy_runtime_api::client::orchestrator::HttpRequest, ::aws_smithy_runtime_api::box_error::BoxError> {
176        let input = input.downcast::<crate::operation::delete_file::DeleteFileInput>().expect("correct type");
177        let _header_serialization_settings = _cfg
178            .load::<crate::serialization_settings::HeaderSerializationSettings>()
179            .cloned()
180            .unwrap_or_default();
181        let mut request_builder = {
182            #[allow(clippy::uninlined_format_args)]
183            fn uri_base(
184                _input: &crate::operation::delete_file::DeleteFileInput,
185                output: &mut ::std::string::String,
186            ) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::BuildError> {
187                use ::std::fmt::Write as _;
188                ::std::write!(output, "/").expect("formatting should succeed");
189                ::std::result::Result::Ok(())
190            }
191            #[allow(clippy::unnecessary_wraps)]
192            fn update_http_builder(
193                input: &crate::operation::delete_file::DeleteFileInput,
194                builder: ::http_1x::request::Builder,
195            ) -> ::std::result::Result<::http_1x::request::Builder, ::aws_smithy_types::error::operation::BuildError> {
196                let mut uri = ::std::string::String::new();
197                uri_base(input, &mut uri)?;
198                ::std::result::Result::Ok(builder.method("POST").uri(uri))
199            }
200            let mut builder = update_http_builder(&input, ::http_1x::request::Builder::new())?;
201            builder = _header_serialization_settings.set_default_header(builder, ::http_1x::header::CONTENT_TYPE, "application/x-amz-json-1.1");
202            builder = _header_serialization_settings.set_default_header(
203                builder,
204                ::http_1x::header::HeaderName::from_static("x-amz-target"),
205                "CodeCommit_20150413.DeleteFile",
206            );
207            builder
208        };
209        let body = ::aws_smithy_types::body::SdkBody::from(crate::protocol_serde::shape_delete_file::ser_delete_file_input(&input)?);
210        if let Some(content_length) = body.content_length() {
211            let content_length = content_length.to_string();
212            request_builder = _header_serialization_settings.set_default_header(request_builder, ::http_1x::header::CONTENT_LENGTH, &content_length);
213        }
214        ::std::result::Result::Ok(request_builder.body(body).expect("valid request").try_into().unwrap())
215    }
216}
217#[derive(Debug)]
218struct DeleteFileEndpointParamsInterceptor;
219
220#[::aws_smithy_runtime_api::client::interceptors::dyn_dispatch_hint]
221impl ::aws_smithy_runtime_api::client::interceptors::Intercept for DeleteFileEndpointParamsInterceptor {
222    fn name(&self) -> &'static str {
223        "DeleteFileEndpointParamsInterceptor"
224    }
225
226    fn read_before_execution(
227        &self,
228        context: &::aws_smithy_runtime_api::client::interceptors::context::BeforeSerializationInterceptorContextRef<
229            '_,
230            ::aws_smithy_runtime_api::client::interceptors::context::Input,
231            ::aws_smithy_runtime_api::client::interceptors::context::Output,
232            ::aws_smithy_runtime_api::client::interceptors::context::Error,
233        >,
234        cfg: &mut ::aws_smithy_types::config_bag::ConfigBag,
235    ) -> ::std::result::Result<(), ::aws_smithy_runtime_api::box_error::BoxError> {
236        let _input = context
237            .input()
238            .downcast_ref::<DeleteFileInput>()
239            .ok_or("failed to downcast to DeleteFileInput")?;
240
241        let params = crate::config::endpoint::Params::builder()
242            .set_region(cfg.load::<::aws_types::region::Region>().map(|r| r.as_ref().to_owned()))
243            .set_use_dual_stack(cfg.load::<::aws_types::endpoint_config::UseDualStack>().map(|ty| ty.0))
244            .set_use_fips(cfg.load::<::aws_types::endpoint_config::UseFips>().map(|ty| ty.0))
245            .set_endpoint(cfg.load::<::aws_types::endpoint_config::EndpointUrl>().map(|ty| ty.0.clone()))
246            .build()
247            .map_err(|err| {
248                ::aws_smithy_runtime_api::client::interceptors::error::ContextAttachedError::new("endpoint params could not be built", err)
249            })?;
250        cfg.interceptor_state()
251            .store_put(::aws_smithy_runtime_api::client::endpoint::EndpointResolverParams::new(params));
252        ::std::result::Result::Ok(())
253    }
254}
255
256// The get_* functions below are generated from JMESPath expressions in the
257// operationContextParams trait. They target the operation's input shape.
258
259/// Error type for the `DeleteFileError` operation.
260#[non_exhaustive]
261#[derive(::std::fmt::Debug)]
262pub enum DeleteFileError {
263    /// <p>The specified branch does not exist.</p>
264    BranchDoesNotExistException(crate::types::error::BranchDoesNotExistException),
265    /// <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>
266    BranchNameIsTagNameException(crate::types::error::BranchNameIsTagNameException),
267    /// <p>A branch name is required, but was not specified.</p>
268    BranchNameRequiredException(crate::types::error::BranchNameRequiredException),
269    /// <p>The commit message is too long. Provide a shorter string.</p>
270    CommitMessageLengthExceededException(crate::types::error::CommitMessageLengthExceededException),
271    /// <p>An encryption integrity check failed.</p>
272    EncryptionIntegrityChecksFailedException(crate::types::error::EncryptionIntegrityChecksFailedException),
273    /// <p>An encryption key could not be accessed.</p>
274    EncryptionKeyAccessDeniedException(crate::types::error::EncryptionKeyAccessDeniedException),
275    /// <p>The encryption key is disabled.</p>
276    EncryptionKeyDisabledException(crate::types::error::EncryptionKeyDisabledException),
277    /// <p>No encryption key was found.</p>
278    EncryptionKeyNotFoundException(crate::types::error::EncryptionKeyNotFoundException),
279    /// <p>The encryption key is not available.</p>
280    EncryptionKeyUnavailableException(crate::types::error::EncryptionKeyUnavailableException),
281    /// <p>The specified file does not exist. Verify that you have used the correct file name, full path, and extension.</p>
282    FileDoesNotExistException(crate::types::error::FileDoesNotExistException),
283    /// <p>The specified reference name is not valid.</p>
284    InvalidBranchNameException(crate::types::error::InvalidBranchNameException),
285    /// <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>
286    InvalidEmailException(crate::types::error::InvalidEmailException),
287    /// <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>
288    InvalidParentCommitIdException(crate::types::error::InvalidParentCommitIdException),
289    /// <p>The specified path is not valid.</p>
290    InvalidPathException(crate::types::error::InvalidPathException),
291    /// <p>A specified repository name is not valid.</p><note>
292    /// <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>
293    /// </note>
294    InvalidRepositoryNameException(crate::types::error::InvalidRepositoryNameException),
295    /// <p>The user name is not valid because it has exceeded the character limit for author names.</p>
296    NameLengthExceededException(crate::types::error::NameLengthExceededException),
297    /// <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>
298    ParentCommitDoesNotExistException(crate::types::error::ParentCommitDoesNotExistException),
299    /// <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>
300    ParentCommitIdOutdatedException(crate::types::error::ParentCommitIdOutdatedException),
301    /// <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>
302    ParentCommitIdRequiredException(crate::types::error::ParentCommitIdRequiredException),
303    /// <p>The folderPath for a location cannot be null.</p>
304    PathRequiredException(crate::types::error::PathRequiredException),
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    /// An unexpected error occurred (e.g., invalid JSON returned by the service or an unknown error code).
310    #[deprecated(note = "Matching `Unhandled` directly is not forwards compatible. Instead, match using a \
311    variable wildcard pattern and check `.code()`:
312     \
313    &nbsp;&nbsp;&nbsp;`err if err.code() == Some(\"SpecificExceptionCode\") => { /* handle the error */ }`
314     \
315    See [`ProvideErrorMetadata`](#impl-ProvideErrorMetadata-for-DeleteFileError) for what information is available for the error.")]
316    Unhandled(crate::error::sealed_unhandled::Unhandled),
317}
318impl DeleteFileError {
319    /// Creates the `DeleteFileError::Unhandled` variant from any error type.
320    pub fn unhandled(
321        err: impl ::std::convert::Into<::std::boxed::Box<dyn ::std::error::Error + ::std::marker::Send + ::std::marker::Sync + 'static>>,
322    ) -> Self {
323        Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
324            source: err.into(),
325            meta: ::std::default::Default::default(),
326        })
327    }
328
329    /// Creates the `DeleteFileError::Unhandled` variant from an [`ErrorMetadata`](::aws_smithy_types::error::ErrorMetadata).
330    pub fn generic(err: ::aws_smithy_types::error::ErrorMetadata) -> Self {
331        Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
332            source: err.clone().into(),
333            meta: err,
334        })
335    }
336    ///
337    /// Returns error metadata, which includes the error code, message,
338    /// request ID, and potentially additional information.
339    ///
340    pub fn meta(&self) -> &::aws_smithy_types::error::ErrorMetadata {
341        match self {
342            Self::BranchDoesNotExistException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
343            Self::BranchNameIsTagNameException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
344            Self::BranchNameRequiredException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
345            Self::CommitMessageLengthExceededException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
346            Self::EncryptionIntegrityChecksFailedException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
347            Self::EncryptionKeyAccessDeniedException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
348            Self::EncryptionKeyDisabledException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
349            Self::EncryptionKeyNotFoundException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
350            Self::EncryptionKeyUnavailableException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
351            Self::FileDoesNotExistException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
352            Self::InvalidBranchNameException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
353            Self::InvalidEmailException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
354            Self::InvalidParentCommitIdException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
355            Self::InvalidPathException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
356            Self::InvalidRepositoryNameException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
357            Self::NameLengthExceededException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
358            Self::ParentCommitDoesNotExistException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
359            Self::ParentCommitIdOutdatedException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
360            Self::ParentCommitIdRequiredException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
361            Self::PathRequiredException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
362            Self::RepositoryDoesNotExistException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
363            Self::RepositoryNameRequiredException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
364            Self::Unhandled(e) => &e.meta,
365        }
366    }
367    /// Returns `true` if the error kind is `DeleteFileError::BranchDoesNotExistException`.
368    pub fn is_branch_does_not_exist_exception(&self) -> bool {
369        matches!(self, Self::BranchDoesNotExistException(_))
370    }
371    /// Returns `true` if the error kind is `DeleteFileError::BranchNameIsTagNameException`.
372    pub fn is_branch_name_is_tag_name_exception(&self) -> bool {
373        matches!(self, Self::BranchNameIsTagNameException(_))
374    }
375    /// Returns `true` if the error kind is `DeleteFileError::BranchNameRequiredException`.
376    pub fn is_branch_name_required_exception(&self) -> bool {
377        matches!(self, Self::BranchNameRequiredException(_))
378    }
379    /// Returns `true` if the error kind is `DeleteFileError::CommitMessageLengthExceededException`.
380    pub fn is_commit_message_length_exceeded_exception(&self) -> bool {
381        matches!(self, Self::CommitMessageLengthExceededException(_))
382    }
383    /// Returns `true` if the error kind is `DeleteFileError::EncryptionIntegrityChecksFailedException`.
384    pub fn is_encryption_integrity_checks_failed_exception(&self) -> bool {
385        matches!(self, Self::EncryptionIntegrityChecksFailedException(_))
386    }
387    /// Returns `true` if the error kind is `DeleteFileError::EncryptionKeyAccessDeniedException`.
388    pub fn is_encryption_key_access_denied_exception(&self) -> bool {
389        matches!(self, Self::EncryptionKeyAccessDeniedException(_))
390    }
391    /// Returns `true` if the error kind is `DeleteFileError::EncryptionKeyDisabledException`.
392    pub fn is_encryption_key_disabled_exception(&self) -> bool {
393        matches!(self, Self::EncryptionKeyDisabledException(_))
394    }
395    /// Returns `true` if the error kind is `DeleteFileError::EncryptionKeyNotFoundException`.
396    pub fn is_encryption_key_not_found_exception(&self) -> bool {
397        matches!(self, Self::EncryptionKeyNotFoundException(_))
398    }
399    /// Returns `true` if the error kind is `DeleteFileError::EncryptionKeyUnavailableException`.
400    pub fn is_encryption_key_unavailable_exception(&self) -> bool {
401        matches!(self, Self::EncryptionKeyUnavailableException(_))
402    }
403    /// Returns `true` if the error kind is `DeleteFileError::FileDoesNotExistException`.
404    pub fn is_file_does_not_exist_exception(&self) -> bool {
405        matches!(self, Self::FileDoesNotExistException(_))
406    }
407    /// Returns `true` if the error kind is `DeleteFileError::InvalidBranchNameException`.
408    pub fn is_invalid_branch_name_exception(&self) -> bool {
409        matches!(self, Self::InvalidBranchNameException(_))
410    }
411    /// Returns `true` if the error kind is `DeleteFileError::InvalidEmailException`.
412    pub fn is_invalid_email_exception(&self) -> bool {
413        matches!(self, Self::InvalidEmailException(_))
414    }
415    /// Returns `true` if the error kind is `DeleteFileError::InvalidParentCommitIdException`.
416    pub fn is_invalid_parent_commit_id_exception(&self) -> bool {
417        matches!(self, Self::InvalidParentCommitIdException(_))
418    }
419    /// Returns `true` if the error kind is `DeleteFileError::InvalidPathException`.
420    pub fn is_invalid_path_exception(&self) -> bool {
421        matches!(self, Self::InvalidPathException(_))
422    }
423    /// Returns `true` if the error kind is `DeleteFileError::InvalidRepositoryNameException`.
424    pub fn is_invalid_repository_name_exception(&self) -> bool {
425        matches!(self, Self::InvalidRepositoryNameException(_))
426    }
427    /// Returns `true` if the error kind is `DeleteFileError::NameLengthExceededException`.
428    pub fn is_name_length_exceeded_exception(&self) -> bool {
429        matches!(self, Self::NameLengthExceededException(_))
430    }
431    /// Returns `true` if the error kind is `DeleteFileError::ParentCommitDoesNotExistException`.
432    pub fn is_parent_commit_does_not_exist_exception(&self) -> bool {
433        matches!(self, Self::ParentCommitDoesNotExistException(_))
434    }
435    /// Returns `true` if the error kind is `DeleteFileError::ParentCommitIdOutdatedException`.
436    pub fn is_parent_commit_id_outdated_exception(&self) -> bool {
437        matches!(self, Self::ParentCommitIdOutdatedException(_))
438    }
439    /// Returns `true` if the error kind is `DeleteFileError::ParentCommitIdRequiredException`.
440    pub fn is_parent_commit_id_required_exception(&self) -> bool {
441        matches!(self, Self::ParentCommitIdRequiredException(_))
442    }
443    /// Returns `true` if the error kind is `DeleteFileError::PathRequiredException`.
444    pub fn is_path_required_exception(&self) -> bool {
445        matches!(self, Self::PathRequiredException(_))
446    }
447    /// Returns `true` if the error kind is `DeleteFileError::RepositoryDoesNotExistException`.
448    pub fn is_repository_does_not_exist_exception(&self) -> bool {
449        matches!(self, Self::RepositoryDoesNotExistException(_))
450    }
451    /// Returns `true` if the error kind is `DeleteFileError::RepositoryNameRequiredException`.
452    pub fn is_repository_name_required_exception(&self) -> bool {
453        matches!(self, Self::RepositoryNameRequiredException(_))
454    }
455}
456impl ::std::error::Error for DeleteFileError {
457    fn source(&self) -> ::std::option::Option<&(dyn ::std::error::Error + 'static)> {
458        match self {
459            Self::BranchDoesNotExistException(_inner) => ::std::option::Option::Some(_inner),
460            Self::BranchNameIsTagNameException(_inner) => ::std::option::Option::Some(_inner),
461            Self::BranchNameRequiredException(_inner) => ::std::option::Option::Some(_inner),
462            Self::CommitMessageLengthExceededException(_inner) => ::std::option::Option::Some(_inner),
463            Self::EncryptionIntegrityChecksFailedException(_inner) => ::std::option::Option::Some(_inner),
464            Self::EncryptionKeyAccessDeniedException(_inner) => ::std::option::Option::Some(_inner),
465            Self::EncryptionKeyDisabledException(_inner) => ::std::option::Option::Some(_inner),
466            Self::EncryptionKeyNotFoundException(_inner) => ::std::option::Option::Some(_inner),
467            Self::EncryptionKeyUnavailableException(_inner) => ::std::option::Option::Some(_inner),
468            Self::FileDoesNotExistException(_inner) => ::std::option::Option::Some(_inner),
469            Self::InvalidBranchNameException(_inner) => ::std::option::Option::Some(_inner),
470            Self::InvalidEmailException(_inner) => ::std::option::Option::Some(_inner),
471            Self::InvalidParentCommitIdException(_inner) => ::std::option::Option::Some(_inner),
472            Self::InvalidPathException(_inner) => ::std::option::Option::Some(_inner),
473            Self::InvalidRepositoryNameException(_inner) => ::std::option::Option::Some(_inner),
474            Self::NameLengthExceededException(_inner) => ::std::option::Option::Some(_inner),
475            Self::ParentCommitDoesNotExistException(_inner) => ::std::option::Option::Some(_inner),
476            Self::ParentCommitIdOutdatedException(_inner) => ::std::option::Option::Some(_inner),
477            Self::ParentCommitIdRequiredException(_inner) => ::std::option::Option::Some(_inner),
478            Self::PathRequiredException(_inner) => ::std::option::Option::Some(_inner),
479            Self::RepositoryDoesNotExistException(_inner) => ::std::option::Option::Some(_inner),
480            Self::RepositoryNameRequiredException(_inner) => ::std::option::Option::Some(_inner),
481            Self::Unhandled(_inner) => ::std::option::Option::Some(&*_inner.source),
482        }
483    }
484}
485impl ::std::fmt::Display for DeleteFileError {
486    fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
487        match self {
488            Self::BranchDoesNotExistException(_inner) => _inner.fmt(f),
489            Self::BranchNameIsTagNameException(_inner) => _inner.fmt(f),
490            Self::BranchNameRequiredException(_inner) => _inner.fmt(f),
491            Self::CommitMessageLengthExceededException(_inner) => _inner.fmt(f),
492            Self::EncryptionIntegrityChecksFailedException(_inner) => _inner.fmt(f),
493            Self::EncryptionKeyAccessDeniedException(_inner) => _inner.fmt(f),
494            Self::EncryptionKeyDisabledException(_inner) => _inner.fmt(f),
495            Self::EncryptionKeyNotFoundException(_inner) => _inner.fmt(f),
496            Self::EncryptionKeyUnavailableException(_inner) => _inner.fmt(f),
497            Self::FileDoesNotExistException(_inner) => _inner.fmt(f),
498            Self::InvalidBranchNameException(_inner) => _inner.fmt(f),
499            Self::InvalidEmailException(_inner) => _inner.fmt(f),
500            Self::InvalidParentCommitIdException(_inner) => _inner.fmt(f),
501            Self::InvalidPathException(_inner) => _inner.fmt(f),
502            Self::InvalidRepositoryNameException(_inner) => _inner.fmt(f),
503            Self::NameLengthExceededException(_inner) => _inner.fmt(f),
504            Self::ParentCommitDoesNotExistException(_inner) => _inner.fmt(f),
505            Self::ParentCommitIdOutdatedException(_inner) => _inner.fmt(f),
506            Self::ParentCommitIdRequiredException(_inner) => _inner.fmt(f),
507            Self::PathRequiredException(_inner) => _inner.fmt(f),
508            Self::RepositoryDoesNotExistException(_inner) => _inner.fmt(f),
509            Self::RepositoryNameRequiredException(_inner) => _inner.fmt(f),
510            Self::Unhandled(_inner) => {
511                if let ::std::option::Option::Some(code) = ::aws_smithy_types::error::metadata::ProvideErrorMetadata::code(self) {
512                    write!(f, "unhandled error ({code})")
513                } else {
514                    f.write_str("unhandled error")
515                }
516            }
517        }
518    }
519}
520impl ::aws_smithy_types::retry::ProvideErrorKind for DeleteFileError {
521    fn code(&self) -> ::std::option::Option<&str> {
522        ::aws_smithy_types::error::metadata::ProvideErrorMetadata::code(self)
523    }
524    fn retryable_error_kind(&self) -> ::std::option::Option<::aws_smithy_types::retry::ErrorKind> {
525        ::std::option::Option::None
526    }
527}
528impl ::aws_smithy_types::error::metadata::ProvideErrorMetadata for DeleteFileError {
529    fn meta(&self) -> &::aws_smithy_types::error::ErrorMetadata {
530        match self {
531            Self::BranchDoesNotExistException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
532            Self::BranchNameIsTagNameException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
533            Self::BranchNameRequiredException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
534            Self::CommitMessageLengthExceededException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
535            Self::EncryptionIntegrityChecksFailedException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
536            Self::EncryptionKeyAccessDeniedException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
537            Self::EncryptionKeyDisabledException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
538            Self::EncryptionKeyNotFoundException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
539            Self::EncryptionKeyUnavailableException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
540            Self::FileDoesNotExistException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
541            Self::InvalidBranchNameException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
542            Self::InvalidEmailException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
543            Self::InvalidParentCommitIdException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
544            Self::InvalidPathException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
545            Self::InvalidRepositoryNameException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
546            Self::NameLengthExceededException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
547            Self::ParentCommitDoesNotExistException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
548            Self::ParentCommitIdOutdatedException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
549            Self::ParentCommitIdRequiredException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
550            Self::PathRequiredException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
551            Self::RepositoryDoesNotExistException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
552            Self::RepositoryNameRequiredException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
553            Self::Unhandled(_inner) => &_inner.meta,
554        }
555    }
556}
557impl ::aws_smithy_runtime_api::client::result::CreateUnhandledError for DeleteFileError {
558    fn create_unhandled_error(
559        source: ::std::boxed::Box<dyn ::std::error::Error + ::std::marker::Send + ::std::marker::Sync + 'static>,
560        meta: ::std::option::Option<::aws_smithy_types::error::ErrorMetadata>,
561    ) -> Self {
562        Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
563            source,
564            meta: meta.unwrap_or_default(),
565        })
566    }
567}
568impl ::aws_types::request_id::RequestId for crate::operation::delete_file::DeleteFileError {
569    fn request_id(&self) -> Option<&str> {
570        self.meta().request_id()
571    }
572}
573
574pub use crate::operation::delete_file::_delete_file_input::DeleteFileInput;
575
576pub use crate::operation::delete_file::_delete_file_output::DeleteFileOutput;
577
578mod _delete_file_input;
579
580mod _delete_file_output;
581
582/// Builders
583pub mod builders;