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