// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
/// Orchestration and serialization glue logic for `PutParameter`.
#[derive(::std::clone::Clone, ::std::default::Default, ::std::fmt::Debug)]
#[non_exhaustive]
pub struct PutParameter;
impl PutParameter {
/// Creates a new `PutParameter`
pub fn new() -> Self {
Self
}
pub(crate) async fn orchestrate(
runtime_plugins: &::aws_smithy_runtime_api::client::runtime_plugin::RuntimePlugins,
input: crate::operation::put_parameter::PutParameterInput,
) -> ::std::result::Result<
crate::operation::put_parameter::PutParameterOutput,
::aws_smithy_runtime_api::client::result::SdkError<
crate::operation::put_parameter::PutParameterError,
::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
>,
> {
let map_err = |err: ::aws_smithy_runtime_api::client::result::SdkError<
::aws_smithy_runtime_api::client::interceptors::context::Error,
::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
>| {
err.map_service_error(|err| {
err.downcast::<crate::operation::put_parameter::PutParameterError>()
.expect("correct error type")
})
};
let context = Self::orchestrate_with_stop_point(runtime_plugins, input, ::aws_smithy_runtime::client::orchestrator::StopPoint::None)
.await
.map_err(map_err)?;
let output = context.finalize().map_err(map_err)?;
::std::result::Result::Ok(
output
.downcast::<crate::operation::put_parameter::PutParameterOutput>()
.expect("correct output type"),
)
}
pub(crate) async fn orchestrate_with_stop_point(
runtime_plugins: &::aws_smithy_runtime_api::client::runtime_plugin::RuntimePlugins,
input: crate::operation::put_parameter::PutParameterInput,
stop_point: ::aws_smithy_runtime::client::orchestrator::StopPoint,
) -> ::std::result::Result<
::aws_smithy_runtime_api::client::interceptors::context::InterceptorContext,
::aws_smithy_runtime_api::client::result::SdkError<
::aws_smithy_runtime_api::client::interceptors::context::Error,
::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
>,
> {
let input = ::aws_smithy_runtime_api::client::interceptors::context::Input::erase(input);
use ::tracing::Instrument;
::aws_smithy_runtime::client::orchestrator::invoke_with_stop_point("SSM", "PutParameter", input, runtime_plugins, stop_point)
// Create a parent span for the entire operation. Includes a random, internal-only,
// seven-digit ID for the operation orchestration so that it can be correlated in the logs.
.instrument(::tracing::debug_span!(
"SSM.PutParameter",
"rpc.service" = "SSM",
"rpc.method" = "PutParameter",
"sdk_invocation_id" = ::fastrand::u32(1_000_000..10_000_000),
"rpc.system" = "aws-api",
))
.await
}
pub(crate) fn operation_runtime_plugins(
client_runtime_plugins: ::aws_smithy_runtime_api::client::runtime_plugin::RuntimePlugins,
client_config: &crate::config::Config,
config_override: ::std::option::Option<crate::config::Builder>,
) -> ::aws_smithy_runtime_api::client::runtime_plugin::RuntimePlugins {
let mut runtime_plugins = client_runtime_plugins.with_operation_plugin(Self::new());
if let ::std::option::Option::Some(config_override) = config_override {
for plugin in config_override.runtime_plugins.iter().cloned() {
runtime_plugins = runtime_plugins.with_operation_plugin(plugin);
}
runtime_plugins = runtime_plugins.with_operation_plugin(crate::config::ConfigOverrideRuntimePlugin::new(
config_override,
client_config.config.clone(),
&client_config.runtime_components,
));
}
runtime_plugins
}
}
impl ::aws_smithy_runtime_api::client::runtime_plugin::RuntimePlugin for PutParameter {
fn config(&self) -> ::std::option::Option<::aws_smithy_types::config_bag::FrozenLayer> {
let mut cfg = ::aws_smithy_types::config_bag::Layer::new("PutParameter");
cfg.store_put(::aws_smithy_runtime_api::client::ser_de::SharedRequestSerializer::new(
PutParameterRequestSerializer,
));
cfg.store_put(::aws_smithy_runtime_api::client::ser_de::SharedResponseDeserializer::new(
PutParameterResponseDeserializer,
));
cfg.store_put(::aws_smithy_runtime_api::client::auth::AuthSchemeOptionResolverParams::new(
crate::config::auth::Params::builder()
.operation_name("PutParameter")
.build()
.expect("required fields set"),
));
cfg.store_put(::aws_smithy_runtime_api::client::orchestrator::Metadata::new("PutParameter", "SSM"));
let mut signing_options = ::aws_runtime::auth::SigningOptions::default();
signing_options.double_uri_encode = true;
signing_options.content_sha256_header = false;
signing_options.normalize_uri_path = true;
signing_options.payload_override = None;
cfg.store_put(::aws_runtime::auth::SigV4OperationSigningConfig {
signing_options,
..::std::default::Default::default()
});
::std::option::Option::Some(cfg.freeze())
}
fn runtime_components(
&self,
_: &::aws_smithy_runtime_api::client::runtime_components::RuntimeComponentsBuilder,
) -> ::std::borrow::Cow<'_, ::aws_smithy_runtime_api::client::runtime_components::RuntimeComponentsBuilder> {
#[allow(unused_mut)]
let mut rcb = ::aws_smithy_runtime_api::client::runtime_components::RuntimeComponentsBuilder::new("PutParameter")
.with_interceptor(::aws_smithy_runtime_api::client::interceptors::SharedInterceptor::permanent(
::aws_smithy_runtime::client::stalled_stream_protection::StalledStreamProtectionInterceptor::default(),
))
.with_interceptor(::aws_smithy_runtime_api::client::interceptors::SharedInterceptor::permanent(
PutParameterEndpointParamsInterceptor,
))
.with_retry_classifier(::aws_smithy_runtime::client::retries::classifiers::TransientErrorClassifier::<
crate::operation::put_parameter::PutParameterError,
>::new())
.with_retry_classifier(::aws_smithy_runtime::client::retries::classifiers::ModeledAsRetryableClassifier::<
crate::operation::put_parameter::PutParameterError,
>::new())
.with_retry_classifier(::aws_runtime::retries::classifiers::AwsErrorCodeClassifier::<
crate::operation::put_parameter::PutParameterError,
>::new());
::std::borrow::Cow::Owned(rcb)
}
}
#[derive(Debug)]
struct PutParameterResponseDeserializer;
impl ::aws_smithy_runtime_api::client::ser_de::DeserializeResponse for PutParameterResponseDeserializer {
fn deserialize_nonstreaming_with_config(
&self,
response: &::aws_smithy_runtime_api::client::orchestrator::HttpResponse,
_cfg: &::aws_smithy_types::config_bag::ConfigBag,
) -> ::aws_smithy_runtime_api::client::interceptors::context::OutputOrError {
let (success, status) = (response.status().is_success(), response.status().as_u16());
let headers = response.headers();
let body = response.body().bytes().expect("body loaded");
#[allow(unused_mut)]
let mut force_error = false;
::tracing::debug!(request_id = ?::aws_types::request_id::RequestId::request_id(response));
let parse_result = if !success && status != 200 || force_error {
crate::protocol_serde::shape_put_parameter::de_put_parameter_http_error(status, headers, body)
} else {
crate::protocol_serde::shape_put_parameter::de_put_parameter_http_response(status, headers, body)
};
crate::protocol_serde::type_erase_result(parse_result)
}
}
#[derive(Debug)]
struct PutParameterRequestSerializer;
impl ::aws_smithy_runtime_api::client::ser_de::SerializeRequest for PutParameterRequestSerializer {
#[allow(unused_mut, clippy::let_and_return, clippy::needless_borrow, clippy::useless_conversion)]
fn serialize_input(
&self,
input: ::aws_smithy_runtime_api::client::interceptors::context::Input,
_cfg: &mut ::aws_smithy_types::config_bag::ConfigBag,
) -> ::std::result::Result<::aws_smithy_runtime_api::client::orchestrator::HttpRequest, ::aws_smithy_runtime_api::box_error::BoxError> {
let input = input
.downcast::<crate::operation::put_parameter::PutParameterInput>()
.expect("correct type");
let _header_serialization_settings = _cfg
.load::<crate::serialization_settings::HeaderSerializationSettings>()
.cloned()
.unwrap_or_default();
let mut request_builder = {
#[allow(clippy::uninlined_format_args)]
fn uri_base(
_input: &crate::operation::put_parameter::PutParameterInput,
output: &mut ::std::string::String,
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::BuildError> {
use ::std::fmt::Write as _;
::std::write!(output, "/").expect("formatting should succeed");
::std::result::Result::Ok(())
}
#[allow(clippy::unnecessary_wraps)]
fn update_http_builder(
input: &crate::operation::put_parameter::PutParameterInput,
builder: ::http_1x::request::Builder,
) -> ::std::result::Result<::http_1x::request::Builder, ::aws_smithy_types::error::operation::BuildError> {
let mut uri = ::std::string::String::new();
uri_base(input, &mut uri)?;
::std::result::Result::Ok(builder.method("POST").uri(uri))
}
let mut builder = update_http_builder(&input, ::http_1x::request::Builder::new())?;
builder = _header_serialization_settings.set_default_header(builder, ::http_1x::header::CONTENT_TYPE, "application/x-amz-json-1.1");
builder = _header_serialization_settings.set_default_header(
builder,
::http_1x::header::HeaderName::from_static("x-amz-target"),
"AmazonSSM.PutParameter",
);
builder
};
let body = ::aws_smithy_types::body::SdkBody::from(crate::protocol_serde::shape_put_parameter::ser_put_parameter_input(&input)?);
if let Some(content_length) = body.content_length() {
let content_length = content_length.to_string();
request_builder = _header_serialization_settings.set_default_header(request_builder, ::http_1x::header::CONTENT_LENGTH, &content_length);
}
::std::result::Result::Ok(request_builder.body(body).expect("valid request").try_into().unwrap())
}
}
#[derive(Debug)]
struct PutParameterEndpointParamsInterceptor;
#[::aws_smithy_runtime_api::client::interceptors::dyn_dispatch_hint]
impl ::aws_smithy_runtime_api::client::interceptors::Intercept for PutParameterEndpointParamsInterceptor {
fn name(&self) -> &'static str {
"PutParameterEndpointParamsInterceptor"
}
fn read_before_execution(
&self,
context: &::aws_smithy_runtime_api::client::interceptors::context::BeforeSerializationInterceptorContextRef<
'_,
::aws_smithy_runtime_api::client::interceptors::context::Input,
::aws_smithy_runtime_api::client::interceptors::context::Output,
::aws_smithy_runtime_api::client::interceptors::context::Error,
>,
cfg: &mut ::aws_smithy_types::config_bag::ConfigBag,
) -> ::std::result::Result<(), ::aws_smithy_runtime_api::box_error::BoxError> {
let _input = context
.input()
.downcast_ref::<PutParameterInput>()
.ok_or("failed to downcast to PutParameterInput")?;
let params = crate::config::endpoint::Params::builder()
.set_region(cfg.load::<::aws_types::region::Region>().map(|r| r.as_ref().to_owned()))
.set_use_dual_stack(cfg.load::<::aws_types::endpoint_config::UseDualStack>().map(|ty| ty.0))
.set_use_fips(cfg.load::<::aws_types::endpoint_config::UseFips>().map(|ty| ty.0))
.set_endpoint(cfg.load::<::aws_types::endpoint_config::EndpointUrl>().map(|ty| ty.0.clone()))
.build()
.map_err(|err| {
::aws_smithy_runtime_api::client::interceptors::error::ContextAttachedError::new("endpoint params could not be built", err)
})?;
cfg.interceptor_state()
.store_put(::aws_smithy_runtime_api::client::endpoint::EndpointResolverParams::new(params));
::std::result::Result::Ok(())
}
}
// The get_* functions below are generated from JMESPath expressions in the
// operationContextParams trait. They target the operation's input shape.
/// Error type for the `PutParameterError` operation.
#[non_exhaustive]
#[derive(::std::fmt::Debug)]
pub enum PutParameterError {
/// <p>A hierarchy can have a maximum of 15 levels. For more information, see <a href="https://docs.aws.amazon.com/systems-manager/latest/userguide/sysman-parameter-name-constraints.html">Requirements and constraints for parameter names</a> in the <i>Amazon Web Services Systems Manager User Guide</i>.</p>
HierarchyLevelLimitExceededException(crate::types::error::HierarchyLevelLimitExceededException),
/// <p>Parameter Store doesn't support changing a parameter type in a hierarchy. For example, you can't change a parameter from a <code>String</code> type to a <code>SecureString</code> type. You must create a new, unique parameter.</p>
HierarchyTypeMismatchException(crate::types::error::HierarchyTypeMismatchException),
/// <p>There is a conflict in the policies specified for this parameter. You can't, for example, specify two Expiration policies for a parameter. Review your policies, and try again.</p>
IncompatiblePolicyException(crate::types::error::IncompatiblePolicyException),
/// <p>An error occurred on the server side.</p>
InternalServerError(crate::types::error::InternalServerError),
/// <p>The request doesn't meet the regular expression requirement.</p>
InvalidAllowedPatternException(crate::types::error::InvalidAllowedPatternException),
/// <p>The query key ID isn't valid.</p>
InvalidKeyId(crate::types::error::InvalidKeyId),
/// <p>A policy attribute or its value is invalid.</p>
InvalidPolicyAttributeException(crate::types::error::InvalidPolicyAttributeException),
/// <p>The policy type isn't supported. Parameter Store supports the following policy types: Expiration, ExpirationNotification, and NoChangeNotification.</p>
InvalidPolicyTypeException(crate::types::error::InvalidPolicyTypeException),
/// <p>The parameter already exists. You can't create duplicate parameters.</p>
ParameterAlreadyExists(crate::types::error::ParameterAlreadyExists),
/// <p>You have exceeded the number of parameters for this Amazon Web Services account. Delete one or more parameters and try again.</p>
ParameterLimitExceeded(crate::types::error::ParameterLimitExceeded),
/// <p>Parameter Store retains the 100 most recently created versions of a parameter. After this number of versions has been created, Parameter Store deletes the oldest version when a new one is created. However, if the oldest version has a <i>label</i> attached to it, Parameter Store won't delete the version and instead presents this error message:</p>
/// <p><code>An error occurred (ParameterMaxVersionLimitExceeded) when calling the PutParameter operation: You attempted to create a new version of <i>parameter-name</i> by calling the PutParameter API with the overwrite flag. Version <i>version-number</i>, the oldest version, can't be deleted because it has a label associated with it. Move the label to another version of the parameter, and try again.</code></p>
/// <p>This safeguard is to prevent parameter versions with mission critical labels assigned to them from being deleted. To continue creating new parameters, first move the label from the oldest version of the parameter to a newer one for use in your operations. For information about moving parameter labels, see <a href="https://docs.aws.amazon.com/systems-manager/latest/userguide/sysman-paramstore-labels.html#sysman-paramstore-labels-console-move">Move a parameter label (console)</a> or <a href="https://docs.aws.amazon.com/systems-manager/latest/userguide/sysman-paramstore-labels.html#sysman-paramstore-labels-cli-move">Move a parameter label (CLI)</a> in the <i>Amazon Web Services Systems Manager User Guide</i>.</p>
ParameterMaxVersionLimitExceeded(crate::types::error::ParameterMaxVersionLimitExceeded),
/// <p>The parameter name isn't valid.</p>
ParameterPatternMismatchException(crate::types::error::ParameterPatternMismatchException),
/// <p>You specified more than the maximum number of allowed policies for the parameter. The maximum is 10.</p>
PoliciesLimitExceededException(crate::types::error::PoliciesLimitExceededException),
/// <p>There are concurrent updates for a resource that supports one update at a time.</p>
TooManyUpdates(crate::types::error::TooManyUpdates),
/// <p>The parameter type isn't supported.</p>
UnsupportedParameterType(crate::types::error::UnsupportedParameterType),
/// An unexpected error occurred (e.g., invalid JSON returned by the service or an unknown error code).
#[deprecated(note = "Matching `Unhandled` directly is not forwards compatible. Instead, match using a \
variable wildcard pattern and check `.code()`:
\
`err if err.code() == Some(\"SpecificExceptionCode\") => { /* handle the error */ }`
\
See [`ProvideErrorMetadata`](#impl-ProvideErrorMetadata-for-PutParameterError) for what information is available for the error.")]
Unhandled(crate::error::sealed_unhandled::Unhandled),
}
impl PutParameterError {
/// Creates the `PutParameterError::Unhandled` variant from any error type.
pub fn unhandled(
err: impl ::std::convert::Into<::std::boxed::Box<dyn ::std::error::Error + ::std::marker::Send + ::std::marker::Sync + 'static>>,
) -> Self {
Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
source: err.into(),
meta: ::std::default::Default::default(),
})
}
/// Creates the `PutParameterError::Unhandled` variant from an [`ErrorMetadata`](::aws_smithy_types::error::ErrorMetadata).
pub fn generic(err: ::aws_smithy_types::error::ErrorMetadata) -> Self {
Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
source: err.clone().into(),
meta: err,
})
}
///
/// Returns error metadata, which includes the error code, message,
/// request ID, and potentially additional information.
///
pub fn meta(&self) -> &::aws_smithy_types::error::ErrorMetadata {
match self {
Self::HierarchyLevelLimitExceededException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
Self::HierarchyTypeMismatchException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
Self::IncompatiblePolicyException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
Self::InternalServerError(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
Self::InvalidAllowedPatternException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
Self::InvalidKeyId(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
Self::InvalidPolicyAttributeException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
Self::InvalidPolicyTypeException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
Self::ParameterAlreadyExists(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
Self::ParameterLimitExceeded(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
Self::ParameterMaxVersionLimitExceeded(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
Self::ParameterPatternMismatchException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
Self::PoliciesLimitExceededException(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
Self::TooManyUpdates(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
Self::UnsupportedParameterType(e) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(e),
Self::Unhandled(e) => &e.meta,
}
}
/// Returns `true` if the error kind is `PutParameterError::HierarchyLevelLimitExceededException`.
pub fn is_hierarchy_level_limit_exceeded_exception(&self) -> bool {
matches!(self, Self::HierarchyLevelLimitExceededException(_))
}
/// Returns `true` if the error kind is `PutParameterError::HierarchyTypeMismatchException`.
pub fn is_hierarchy_type_mismatch_exception(&self) -> bool {
matches!(self, Self::HierarchyTypeMismatchException(_))
}
/// Returns `true` if the error kind is `PutParameterError::IncompatiblePolicyException`.
pub fn is_incompatible_policy_exception(&self) -> bool {
matches!(self, Self::IncompatiblePolicyException(_))
}
/// Returns `true` if the error kind is `PutParameterError::InternalServerError`.
pub fn is_internal_server_error(&self) -> bool {
matches!(self, Self::InternalServerError(_))
}
/// Returns `true` if the error kind is `PutParameterError::InvalidAllowedPatternException`.
pub fn is_invalid_allowed_pattern_exception(&self) -> bool {
matches!(self, Self::InvalidAllowedPatternException(_))
}
/// Returns `true` if the error kind is `PutParameterError::InvalidKeyId`.
pub fn is_invalid_key_id(&self) -> bool {
matches!(self, Self::InvalidKeyId(_))
}
/// Returns `true` if the error kind is `PutParameterError::InvalidPolicyAttributeException`.
pub fn is_invalid_policy_attribute_exception(&self) -> bool {
matches!(self, Self::InvalidPolicyAttributeException(_))
}
/// Returns `true` if the error kind is `PutParameterError::InvalidPolicyTypeException`.
pub fn is_invalid_policy_type_exception(&self) -> bool {
matches!(self, Self::InvalidPolicyTypeException(_))
}
/// Returns `true` if the error kind is `PutParameterError::ParameterAlreadyExists`.
pub fn is_parameter_already_exists(&self) -> bool {
matches!(self, Self::ParameterAlreadyExists(_))
}
/// Returns `true` if the error kind is `PutParameterError::ParameterLimitExceeded`.
pub fn is_parameter_limit_exceeded(&self) -> bool {
matches!(self, Self::ParameterLimitExceeded(_))
}
/// Returns `true` if the error kind is `PutParameterError::ParameterMaxVersionLimitExceeded`.
pub fn is_parameter_max_version_limit_exceeded(&self) -> bool {
matches!(self, Self::ParameterMaxVersionLimitExceeded(_))
}
/// Returns `true` if the error kind is `PutParameterError::ParameterPatternMismatchException`.
pub fn is_parameter_pattern_mismatch_exception(&self) -> bool {
matches!(self, Self::ParameterPatternMismatchException(_))
}
/// Returns `true` if the error kind is `PutParameterError::PoliciesLimitExceededException`.
pub fn is_policies_limit_exceeded_exception(&self) -> bool {
matches!(self, Self::PoliciesLimitExceededException(_))
}
/// Returns `true` if the error kind is `PutParameterError::TooManyUpdates`.
pub fn is_too_many_updates(&self) -> bool {
matches!(self, Self::TooManyUpdates(_))
}
/// Returns `true` if the error kind is `PutParameterError::UnsupportedParameterType`.
pub fn is_unsupported_parameter_type(&self) -> bool {
matches!(self, Self::UnsupportedParameterType(_))
}
}
impl ::std::error::Error for PutParameterError {
fn source(&self) -> ::std::option::Option<&(dyn ::std::error::Error + 'static)> {
match self {
Self::HierarchyLevelLimitExceededException(_inner) => ::std::option::Option::Some(_inner),
Self::HierarchyTypeMismatchException(_inner) => ::std::option::Option::Some(_inner),
Self::IncompatiblePolicyException(_inner) => ::std::option::Option::Some(_inner),
Self::InternalServerError(_inner) => ::std::option::Option::Some(_inner),
Self::InvalidAllowedPatternException(_inner) => ::std::option::Option::Some(_inner),
Self::InvalidKeyId(_inner) => ::std::option::Option::Some(_inner),
Self::InvalidPolicyAttributeException(_inner) => ::std::option::Option::Some(_inner),
Self::InvalidPolicyTypeException(_inner) => ::std::option::Option::Some(_inner),
Self::ParameterAlreadyExists(_inner) => ::std::option::Option::Some(_inner),
Self::ParameterLimitExceeded(_inner) => ::std::option::Option::Some(_inner),
Self::ParameterMaxVersionLimitExceeded(_inner) => ::std::option::Option::Some(_inner),
Self::ParameterPatternMismatchException(_inner) => ::std::option::Option::Some(_inner),
Self::PoliciesLimitExceededException(_inner) => ::std::option::Option::Some(_inner),
Self::TooManyUpdates(_inner) => ::std::option::Option::Some(_inner),
Self::UnsupportedParameterType(_inner) => ::std::option::Option::Some(_inner),
Self::Unhandled(_inner) => ::std::option::Option::Some(&*_inner.source),
}
}
}
impl ::std::fmt::Display for PutParameterError {
fn fmt(&self, f: &mut ::std::fmt::Formatter<'_>) -> ::std::fmt::Result {
match self {
Self::HierarchyLevelLimitExceededException(_inner) => _inner.fmt(f),
Self::HierarchyTypeMismatchException(_inner) => _inner.fmt(f),
Self::IncompatiblePolicyException(_inner) => _inner.fmt(f),
Self::InternalServerError(_inner) => _inner.fmt(f),
Self::InvalidAllowedPatternException(_inner) => _inner.fmt(f),
Self::InvalidKeyId(_inner) => _inner.fmt(f),
Self::InvalidPolicyAttributeException(_inner) => _inner.fmt(f),
Self::InvalidPolicyTypeException(_inner) => _inner.fmt(f),
Self::ParameterAlreadyExists(_inner) => _inner.fmt(f),
Self::ParameterLimitExceeded(_inner) => _inner.fmt(f),
Self::ParameterMaxVersionLimitExceeded(_inner) => _inner.fmt(f),
Self::ParameterPatternMismatchException(_inner) => _inner.fmt(f),
Self::PoliciesLimitExceededException(_inner) => _inner.fmt(f),
Self::TooManyUpdates(_inner) => _inner.fmt(f),
Self::UnsupportedParameterType(_inner) => _inner.fmt(f),
Self::Unhandled(_inner) => {
if let ::std::option::Option::Some(code) = ::aws_smithy_types::error::metadata::ProvideErrorMetadata::code(self) {
write!(f, "unhandled error ({code})")
} else {
f.write_str("unhandled error")
}
}
}
}
}
impl ::aws_smithy_types::retry::ProvideErrorKind for PutParameterError {
fn code(&self) -> ::std::option::Option<&str> {
::aws_smithy_types::error::metadata::ProvideErrorMetadata::code(self)
}
fn retryable_error_kind(&self) -> ::std::option::Option<::aws_smithy_types::retry::ErrorKind> {
::std::option::Option::None
}
}
impl ::aws_smithy_types::error::metadata::ProvideErrorMetadata for PutParameterError {
fn meta(&self) -> &::aws_smithy_types::error::ErrorMetadata {
match self {
Self::HierarchyLevelLimitExceededException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
Self::HierarchyTypeMismatchException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
Self::IncompatiblePolicyException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
Self::InternalServerError(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
Self::InvalidAllowedPatternException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
Self::InvalidKeyId(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
Self::InvalidPolicyAttributeException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
Self::InvalidPolicyTypeException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
Self::ParameterAlreadyExists(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
Self::ParameterLimitExceeded(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
Self::ParameterMaxVersionLimitExceeded(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
Self::ParameterPatternMismatchException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
Self::PoliciesLimitExceededException(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
Self::TooManyUpdates(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
Self::UnsupportedParameterType(_inner) => ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(_inner),
Self::Unhandled(_inner) => &_inner.meta,
}
}
}
impl ::aws_smithy_runtime_api::client::result::CreateUnhandledError for PutParameterError {
fn create_unhandled_error(
source: ::std::boxed::Box<dyn ::std::error::Error + ::std::marker::Send + ::std::marker::Sync + 'static>,
meta: ::std::option::Option<::aws_smithy_types::error::ErrorMetadata>,
) -> Self {
Self::Unhandled(crate::error::sealed_unhandled::Unhandled {
source,
meta: meta.unwrap_or_default(),
})
}
}
impl ::aws_types::request_id::RequestId for crate::operation::put_parameter::PutParameterError {
fn request_id(&self) -> Option<&str> {
self.meta().request_id()
}
}
pub use crate::operation::put_parameter::_put_parameter_input::PutParameterInput;
pub use crate::operation::put_parameter::_put_parameter_output::PutParameterOutput;
mod _put_parameter_input;
mod _put_parameter_output;
/// Builders
pub mod builders;