aws_sdk_quicksight/operation/
start_dashboard_snapshot_job_schedule.rs

1// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
2/// Orchestration and serialization glue logic for `StartDashboardSnapshotJobSchedule`.
3#[derive(::std::clone::Clone, ::std::default::Default, ::std::fmt::Debug)]
4#[non_exhaustive]
5pub struct StartDashboardSnapshotJobSchedule;
6impl StartDashboardSnapshotJobSchedule {
7    /// Creates a new `StartDashboardSnapshotJobSchedule`
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::start_dashboard_snapshot_job_schedule::StartDashboardSnapshotJobScheduleInput,
14    ) -> ::std::result::Result<
15        crate::operation::start_dashboard_snapshot_job_schedule::StartDashboardSnapshotJobScheduleOutput,
16        ::aws_smithy_runtime_api::client::result::SdkError<
17            crate::operation::start_dashboard_snapshot_job_schedule::StartDashboardSnapshotJobScheduleError,
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::start_dashboard_snapshot_job_schedule::StartDashboardSnapshotJobScheduleError>()
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::start_dashboard_snapshot_job_schedule::StartDashboardSnapshotJobScheduleOutput>()
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::start_dashboard_snapshot_job_schedule::StartDashboardSnapshotJobScheduleInput,
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            "QuickSight",
56            "StartDashboardSnapshotJobSchedule",
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            "QuickSight.StartDashboardSnapshotJobSchedule",
65            "rpc.service" = "QuickSight",
66            "rpc.method" = "StartDashboardSnapshotJobSchedule",
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 StartDashboardSnapshotJobSchedule {
94    fn config(&self) -> ::std::option::Option<::aws_smithy_types::config_bag::FrozenLayer> {
95        let mut cfg = ::aws_smithy_types::config_bag::Layer::new("StartDashboardSnapshotJobSchedule");
96
97        cfg.store_put(::aws_smithy_runtime_api::client::ser_de::SharedRequestSerializer::new(
98            StartDashboardSnapshotJobScheduleRequestSerializer,
99        ));
100        cfg.store_put(::aws_smithy_runtime_api::client::ser_de::SharedResponseDeserializer::new(
101            StartDashboardSnapshotJobScheduleResponseDeserializer,
102        ));
103
104        cfg.store_put(::aws_smithy_runtime_api::client::auth::AuthSchemeOptionResolverParams::new(
105            crate::config::auth::Params::builder()
106                .operation_name("StartDashboardSnapshotJobSchedule")
107                .build()
108                .expect("required fields set"),
109        ));
110
111        cfg.store_put(::aws_smithy_runtime_api::client::orchestrator::Metadata::new(
112            "StartDashboardSnapshotJobSchedule",
113            "QuickSight",
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("StartDashboardSnapshotJobSchedule")
135            .with_interceptor(::aws_smithy_runtime::client::stalled_stream_protection::StalledStreamProtectionInterceptor::default())
136            .with_interceptor(StartDashboardSnapshotJobScheduleEndpointParamsInterceptor)
137            .with_retry_classifier(::aws_smithy_runtime::client::retries::classifiers::TransientErrorClassifier::<
138                crate::operation::start_dashboard_snapshot_job_schedule::StartDashboardSnapshotJobScheduleError,
139            >::new())
140            .with_retry_classifier(::aws_smithy_runtime::client::retries::classifiers::ModeledAsRetryableClassifier::<
141                crate::operation::start_dashboard_snapshot_job_schedule::StartDashboardSnapshotJobScheduleError,
142            >::new())
143            .with_retry_classifier(::aws_runtime::retries::classifiers::AwsErrorCodeClassifier::<
144                crate::operation::start_dashboard_snapshot_job_schedule::StartDashboardSnapshotJobScheduleError,
145            >::new());
146
147        ::std::borrow::Cow::Owned(rcb)
148    }
149}
150
151#[derive(Debug)]
152struct StartDashboardSnapshotJobScheduleResponseDeserializer;
153impl ::aws_smithy_runtime_api::client::ser_de::DeserializeResponse for StartDashboardSnapshotJobScheduleResponseDeserializer {
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_start_dashboard_snapshot_job_schedule::de_start_dashboard_snapshot_job_schedule_http_error(
166                status, headers, body,
167            )
168        } else {
169            crate::protocol_serde::shape_start_dashboard_snapshot_job_schedule::de_start_dashboard_snapshot_job_schedule_http_response(
170                status, headers, body,
171            )
172        };
173        crate::protocol_serde::type_erase_result(parse_result)
174    }
175}
176#[derive(Debug)]
177struct StartDashboardSnapshotJobScheduleRequestSerializer;
178impl ::aws_smithy_runtime_api::client::ser_de::SerializeRequest for StartDashboardSnapshotJobScheduleRequestSerializer {
179    #[allow(unused_mut, clippy::let_and_return, clippy::needless_borrow, clippy::useless_conversion)]
180    fn serialize_input(
181        &self,
182        input: ::aws_smithy_runtime_api::client::interceptors::context::Input,
183        _cfg: &mut ::aws_smithy_types::config_bag::ConfigBag,
184    ) -> ::std::result::Result<::aws_smithy_runtime_api::client::orchestrator::HttpRequest, ::aws_smithy_runtime_api::box_error::BoxError> {
185        let input = input
186            .downcast::<crate::operation::start_dashboard_snapshot_job_schedule::StartDashboardSnapshotJobScheduleInput>()
187            .expect("correct type");
188        let _header_serialization_settings = _cfg
189            .load::<crate::serialization_settings::HeaderSerializationSettings>()
190            .cloned()
191            .unwrap_or_default();
192        let mut request_builder = {
193            #[allow(clippy::uninlined_format_args)]
194            fn uri_base(
195                _input: &crate::operation::start_dashboard_snapshot_job_schedule::StartDashboardSnapshotJobScheduleInput,
196                output: &mut ::std::string::String,
197            ) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::BuildError> {
198                use ::std::fmt::Write as _;
199                let input_1 = &_input.aws_account_id;
200                let input_1 = input_1
201                    .as_ref()
202                    .ok_or_else(|| ::aws_smithy_types::error::operation::BuildError::missing_field("aws_account_id", "cannot be empty or unset"))?;
203                let aws_account_id = ::aws_smithy_http::label::fmt_string(input_1, ::aws_smithy_http::label::EncodingStrategy::Default);
204                if aws_account_id.is_empty() {
205                    return ::std::result::Result::Err(::aws_smithy_types::error::operation::BuildError::missing_field(
206                        "aws_account_id",
207                        "cannot be empty or unset",
208                    ));
209                }
210                let input_2 = &_input.dashboard_id;
211                let input_2 = input_2
212                    .as_ref()
213                    .ok_or_else(|| ::aws_smithy_types::error::operation::BuildError::missing_field("dashboard_id", "cannot be empty or unset"))?;
214                let dashboard_id = ::aws_smithy_http::label::fmt_string(input_2, ::aws_smithy_http::label::EncodingStrategy::Default);
215                if dashboard_id.is_empty() {
216                    return ::std::result::Result::Err(::aws_smithy_types::error::operation::BuildError::missing_field(
217                        "dashboard_id",
218                        "cannot be empty or unset",
219                    ));
220                }
221                let input_3 = &_input.schedule_id;
222                let input_3 = input_3
223                    .as_ref()
224                    .ok_or_else(|| ::aws_smithy_types::error::operation::BuildError::missing_field("schedule_id", "cannot be empty or unset"))?;
225                let schedule_id = ::aws_smithy_http::label::fmt_string(input_3, ::aws_smithy_http::label::EncodingStrategy::Default);
226                if schedule_id.is_empty() {
227                    return ::std::result::Result::Err(::aws_smithy_types::error::operation::BuildError::missing_field(
228                        "schedule_id",
229                        "cannot be empty or unset",
230                    ));
231                }
232                ::std::write!(
233                    output,
234                    "/accounts/{AwsAccountId}/dashboards/{DashboardId}/schedules/{ScheduleId}",
235                    AwsAccountId = aws_account_id,
236                    DashboardId = dashboard_id,
237                    ScheduleId = schedule_id
238                )
239                .expect("formatting should succeed");
240                ::std::result::Result::Ok(())
241            }
242            #[allow(clippy::unnecessary_wraps)]
243            fn update_http_builder(
244                input: &crate::operation::start_dashboard_snapshot_job_schedule::StartDashboardSnapshotJobScheduleInput,
245                builder: ::http::request::Builder,
246            ) -> ::std::result::Result<::http::request::Builder, ::aws_smithy_types::error::operation::BuildError> {
247                let mut uri = ::std::string::String::new();
248                uri_base(input, &mut uri)?;
249                ::std::result::Result::Ok(builder.method("POST").uri(uri))
250            }
251            let mut builder = update_http_builder(&input, ::http::request::Builder::new())?;
252            builder
253        };
254        let body = ::aws_smithy_types::body::SdkBody::from("");
255
256        ::std::result::Result::Ok(request_builder.body(body).expect("valid request").try_into().unwrap())
257    }
258}
259#[derive(Debug)]
260struct StartDashboardSnapshotJobScheduleEndpointParamsInterceptor;
261
262impl ::aws_smithy_runtime_api::client::interceptors::Intercept for StartDashboardSnapshotJobScheduleEndpointParamsInterceptor {
263    fn name(&self) -> &'static str {
264        "StartDashboardSnapshotJobScheduleEndpointParamsInterceptor"
265    }
266
267    fn read_before_execution(
268        &self,
269        context: &::aws_smithy_runtime_api::client::interceptors::context::BeforeSerializationInterceptorContextRef<
270            '_,
271            ::aws_smithy_runtime_api::client::interceptors::context::Input,
272            ::aws_smithy_runtime_api::client::interceptors::context::Output,
273            ::aws_smithy_runtime_api::client::interceptors::context::Error,
274        >,
275        cfg: &mut ::aws_smithy_types::config_bag::ConfigBag,
276    ) -> ::std::result::Result<(), ::aws_smithy_runtime_api::box_error::BoxError> {
277        let _input = context
278            .input()
279            .downcast_ref::<StartDashboardSnapshotJobScheduleInput>()
280            .ok_or("failed to downcast to StartDashboardSnapshotJobScheduleInput")?;
281
282        let params = crate::config::endpoint::Params::builder()
283            .set_region(cfg.load::<::aws_types::region::Region>().map(|r| r.as_ref().to_owned()))
284            .set_use_dual_stack(cfg.load::<::aws_types::endpoint_config::UseDualStack>().map(|ty| ty.0))
285            .set_use_fips(cfg.load::<::aws_types::endpoint_config::UseFips>().map(|ty| ty.0))
286            .set_endpoint(cfg.load::<::aws_types::endpoint_config::EndpointUrl>().map(|ty| ty.0.clone()))
287            .build()
288            .map_err(|err| {
289                ::aws_smithy_runtime_api::client::interceptors::error::ContextAttachedError::new("endpoint params could not be built", err)
290            })?;
291        cfg.interceptor_state()
292            .store_put(::aws_smithy_runtime_api::client::endpoint::EndpointResolverParams::new(params));
293        ::std::result::Result::Ok(())
294    }
295}
296
297// The get_* functions below are generated from JMESPath expressions in the
298// operationContextParams trait. They target the operation's input shape.
299
300/// Error type for the `StartDashboardSnapshotJobScheduleError` operation.
301#[non_exhaustive]
302#[derive(::std::fmt::Debug)]
303pub enum StartDashboardSnapshotJobScheduleError {
304    /// <p>You don't have access to this item. The provided credentials couldn't be validated. You might not be authorized to carry out the request. Make sure that your account is authorized to use the Amazon Quick Sight service, that your policies have the correct permissions, and that you are using the correct credentials.</p>
305    AccessDeniedException(crate::types::error::AccessDeniedException),
306    /// <p>An internal failure occurred.</p>
307    InternalFailureException(crate::types::error::InternalFailureException),
308    /// <p>One or more parameters has a value that isn't valid.</p>
309    InvalidParameterValueException(crate::types::error::InvalidParameterValueException),
310    /// <p>A limit is exceeded.</p>
311    LimitExceededException(crate::types::error::LimitExceededException),
312    /// <p>One or more resources can't be found.</p>
313    ResourceNotFoundException(crate::types::error::ResourceNotFoundException),
314    /// <p>Access is throttled.</p>
315    ThrottlingException(crate::types::error::ThrottlingException),
316    /// <p>This error indicates that you are calling an operation on an Amazon Quick Suite subscription where the edition doesn't include support for that operation. Amazon Quick Suite currently has Standard Edition and Enterprise Edition. Not every operation and capability is available in every edition.</p>
317    UnsupportedUserEditionException(crate::types::error::UnsupportedUserEditionException),
318    /// An unexpected error occurred (e.g., invalid JSON returned by the service or an unknown error code).
319    #[deprecated(note = "Matching `Unhandled` directly is not forwards compatible. Instead, match using a \
320    variable wildcard pattern and check `.code()`:
321     \
322    &nbsp;&nbsp;&nbsp;`err if err.code() == Some(\"SpecificExceptionCode\") => { /* handle the error */ }`
323     \
324    See [`ProvideErrorMetadata`](#impl-ProvideErrorMetadata-for-StartDashboardSnapshotJobScheduleError) for what information is available for the error.")]
325    Unhandled(crate::error::sealed_unhandled::Unhandled),
326}
327impl StartDashboardSnapshotJobScheduleError {
328    /// Creates the `StartDashboardSnapshotJobScheduleError::Unhandled` variant from any error type.
329    pub fn unhandled(
330        err: impl ::std::convert::Into<::std::boxed::Box<dyn ::std::error::Error + ::std::marker::Send + ::std::marker::Sync + 'static>>,
331    ) -> Self {
332        Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
333            source: err.into(),
334            meta: ::std::default::Default::default(),
335        })
336    }
337
338    /// Creates the `StartDashboardSnapshotJobScheduleError::Unhandled` variant from an [`ErrorMetadata`](::aws_smithy_types::error::ErrorMetadata).
339    pub fn generic(err: ::aws_smithy_types::error::ErrorMetadata) -> Self {
340        Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
341            source: err.clone().into(),
342            meta: err,
343        })
344    }
345    ///
346    /// Returns error metadata, which includes the error code, message,
347    /// request ID, and potentially additional information.
348    ///
349    pub fn meta(&self) -> &::aws_smithy_types::error::ErrorMetadata {
350        match self {
351            Self::AccessDeniedException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
352            Self::InternalFailureException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
353            Self::InvalidParameterValueException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
354            Self::LimitExceededException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
355            Self::ResourceNotFoundException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
356            Self::ThrottlingException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
357            Self::UnsupportedUserEditionException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
358            Self::Unhandled(e) => &e.meta,
359        }
360    }
361    /// Returns `true` if the error kind is `StartDashboardSnapshotJobScheduleError::AccessDeniedException`.
362    pub fn is_access_denied_exception(&self) -> bool {
363        matches!(self, Self::AccessDeniedException(_))
364    }
365    /// Returns `true` if the error kind is `StartDashboardSnapshotJobScheduleError::InternalFailureException`.
366    pub fn is_internal_failure_exception(&self) -> bool {
367        matches!(self, Self::InternalFailureException(_))
368    }
369    /// Returns `true` if the error kind is `StartDashboardSnapshotJobScheduleError::InvalidParameterValueException`.
370    pub fn is_invalid_parameter_value_exception(&self) -> bool {
371        matches!(self, Self::InvalidParameterValueException(_))
372    }
373    /// Returns `true` if the error kind is `StartDashboardSnapshotJobScheduleError::LimitExceededException`.
374    pub fn is_limit_exceeded_exception(&self) -> bool {
375        matches!(self, Self::LimitExceededException(_))
376    }
377    /// Returns `true` if the error kind is `StartDashboardSnapshotJobScheduleError::ResourceNotFoundException`.
378    pub fn is_resource_not_found_exception(&self) -> bool {
379        matches!(self, Self::ResourceNotFoundException(_))
380    }
381    /// Returns `true` if the error kind is `StartDashboardSnapshotJobScheduleError::ThrottlingException`.
382    pub fn is_throttling_exception(&self) -> bool {
383        matches!(self, Self::ThrottlingException(_))
384    }
385    /// Returns `true` if the error kind is `StartDashboardSnapshotJobScheduleError::UnsupportedUserEditionException`.
386    pub fn is_unsupported_user_edition_exception(&self) -> bool {
387        matches!(self, Self::UnsupportedUserEditionException(_))
388    }
389}
390impl ::std::error::Error for StartDashboardSnapshotJobScheduleError {
391    fn source(&self) -> ::std::option::Option<&(dyn ::std::error::Error + 'static)> {
392        match self {
393            Self::AccessDeniedException(_inner) => ::std::option::Option::Some(_inner),
394            Self::InternalFailureException(_inner) => ::std::option::Option::Some(_inner),
395            Self::InvalidParameterValueException(_inner) => ::std::option::Option::Some(_inner),
396            Self::LimitExceededException(_inner) => ::std::option::Option::Some(_inner),
397            Self::ResourceNotFoundException(_inner) => ::std::option::Option::Some(_inner),
398            Self::ThrottlingException(_inner) => ::std::option::Option::Some(_inner),
399            Self::UnsupportedUserEditionException(_inner) => ::std::option::Option::Some(_inner),
400            Self::Unhandled(_inner) => ::std::option::Option::Some(&*_inner.source),
401        }
402    }
403}
404impl ::std::fmt::Display for StartDashboardSnapshotJobScheduleError {
405    fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
406        match self {
407            Self::AccessDeniedException(_inner) => _inner.fmt(f),
408            Self::InternalFailureException(_inner) => _inner.fmt(f),
409            Self::InvalidParameterValueException(_inner) => _inner.fmt(f),
410            Self::LimitExceededException(_inner) => _inner.fmt(f),
411            Self::ResourceNotFoundException(_inner) => _inner.fmt(f),
412            Self::ThrottlingException(_inner) => _inner.fmt(f),
413            Self::UnsupportedUserEditionException(_inner) => _inner.fmt(f),
414            Self::Unhandled(_inner) => {
415                if let ::std::option::Option::Some(code) = ::aws_smithy_types::error::metadata::ProvideErrorMetadata::code(self) {
416                    write!(f, "unhandled error ({code})")
417                } else {
418                    f.write_str("unhandled error")
419                }
420            }
421        }
422    }
423}
424impl ::aws_smithy_types::retry::ProvideErrorKind for StartDashboardSnapshotJobScheduleError {
425    fn code(&self) -> ::std::option::Option<&str> {
426        ::aws_smithy_types::error::metadata::ProvideErrorMetadata::code(self)
427    }
428    fn retryable_error_kind(&self) -> ::std::option::Option<::aws_smithy_types::retry::ErrorKind> {
429        ::std::option::Option::None
430    }
431}
432impl ::aws_smithy_types::error::metadata::ProvideErrorMetadata for StartDashboardSnapshotJobScheduleError {
433    fn meta(&self) -> &::aws_smithy_types::error::ErrorMetadata {
434        match self {
435            Self::AccessDeniedException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
436            Self::InternalFailureException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
437            Self::InvalidParameterValueException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
438            Self::LimitExceededException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
439            Self::ResourceNotFoundException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
440            Self::ThrottlingException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
441            Self::UnsupportedUserEditionException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
442            Self::Unhandled(_inner) => &_inner.meta,
443        }
444    }
445}
446impl ::aws_smithy_runtime_api::client::result::CreateUnhandledError for StartDashboardSnapshotJobScheduleError {
447    fn create_unhandled_error(
448        source: ::std::boxed::Box<dyn ::std::error::Error + ::std::marker::Send + ::std::marker::Sync + 'static>,
449        meta: ::std::option::Option<::aws_smithy_types::error::ErrorMetadata>,
450    ) -> Self {
451        Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
452            source,
453            meta: meta.unwrap_or_default(),
454        })
455    }
456}
457impl ::aws_types::request_id::RequestId for crate::operation::start_dashboard_snapshot_job_schedule::StartDashboardSnapshotJobScheduleError {
458    fn request_id(&self) -> Option<&str> {
459        self.meta().request_id()
460    }
461}
462
463pub use crate::operation::start_dashboard_snapshot_job_schedule::_start_dashboard_snapshot_job_schedule_output::StartDashboardSnapshotJobScheduleOutput;
464
465pub use crate::operation::start_dashboard_snapshot_job_schedule::_start_dashboard_snapshot_job_schedule_input::StartDashboardSnapshotJobScheduleInput;
466
467mod _start_dashboard_snapshot_job_schedule_input;
468
469mod _start_dashboard_snapshot_job_schedule_output;
470
471/// Builders
472pub mod builders;