#[non_exhaustive]
#[derive(::std::fmt::Debug)]
pub enum Error {
AuthException(crate::types::error::AuthException),
Ec2InstanceNotFoundException(crate::types::error::Ec2InstanceNotFoundException),
Ec2InstanceStateInvalidException(crate::types::error::Ec2InstanceStateInvalidException),
Ec2InstanceTypeInvalidException(crate::types::error::Ec2InstanceTypeInvalidException),
Ec2InstanceUnavailableException(crate::types::error::Ec2InstanceUnavailableException),
InvalidArgsException(crate::types::error::InvalidArgsException),
SerialConsoleAccessDisabledException(crate::types::error::SerialConsoleAccessDisabledException),
SerialConsoleSessionLimitExceededException(crate::types::error::SerialConsoleSessionLimitExceededException),
SerialConsoleSessionUnavailableException(crate::types::error::SerialConsoleSessionUnavailableException),
ServiceException(crate::types::error::ServiceException),
ThrottlingException(crate::types::error::ThrottlingException),
#[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-Error) for what information is available for the error.")]
Unhandled(crate::error::sealed_unhandled::Unhandled),
}
impl ::std::fmt::Display for Error {
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
match self {
Error::AuthException(inner) => inner.fmt(f),
Error::Ec2InstanceNotFoundException(inner) => inner.fmt(f),
Error::Ec2InstanceStateInvalidException(inner) => inner.fmt(f),
Error::Ec2InstanceTypeInvalidException(inner) => inner.fmt(f),
Error::Ec2InstanceUnavailableException(inner) => inner.fmt(f),
Error::InvalidArgsException(inner) => inner.fmt(f),
Error::SerialConsoleAccessDisabledException(inner) => inner.fmt(f),
Error::SerialConsoleSessionLimitExceededException(inner) => inner.fmt(f),
Error::SerialConsoleSessionUnavailableException(inner) => inner.fmt(f),
Error::ServiceException(inner) => inner.fmt(f),
Error::ThrottlingException(inner) => inner.fmt(f),
Error::Unhandled(_) => {
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 From<::aws_smithy_types::error::operation::BuildError> for Error {
fn from(value: ::aws_smithy_types::error::operation::BuildError) -> Self {
Error::Unhandled(crate::error::sealed_unhandled::Unhandled {
source: value.into(),
meta: ::std::default::Default::default(),
})
}
}
impl ::aws_smithy_types::error::metadata::ProvideErrorMetadata for Error {
fn meta(&self) -> &::aws_smithy_types::error::metadata::ErrorMetadata {
match self {
Self::AuthException(inner) => inner.meta(),
Self::Ec2InstanceNotFoundException(inner) => inner.meta(),
Self::Ec2InstanceStateInvalidException(inner) => inner.meta(),
Self::Ec2InstanceTypeInvalidException(inner) => inner.meta(),
Self::Ec2InstanceUnavailableException(inner) => inner.meta(),
Self::InvalidArgsException(inner) => inner.meta(),
Self::SerialConsoleAccessDisabledException(inner) => inner.meta(),
Self::SerialConsoleSessionLimitExceededException(inner) => inner.meta(),
Self::SerialConsoleSessionUnavailableException(inner) => inner.meta(),
Self::ServiceException(inner) => inner.meta(),
Self::ThrottlingException(inner) => inner.meta(),
Self::Unhandled(inner) => &inner.meta,
}
}
}
impl<R>
From<
::aws_smithy_runtime_api::client::result::SdkError<
crate::operation::send_serial_console_ssh_public_key::SendSerialConsoleSSHPublicKeyError,
R,
>,
> for Error
where
R: Send + Sync + std::fmt::Debug + 'static,
{
fn from(
err: ::aws_smithy_runtime_api::client::result::SdkError<
crate::operation::send_serial_console_ssh_public_key::SendSerialConsoleSSHPublicKeyError,
R,
>,
) -> Self {
match err {
::aws_smithy_runtime_api::client::result::SdkError::ServiceError(context) => Self::from(context.into_err()),
_ => Error::Unhandled(crate::error::sealed_unhandled::Unhandled {
meta: ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(&err).clone(),
source: err.into(),
}),
}
}
}
impl From<crate::operation::send_serial_console_ssh_public_key::SendSerialConsoleSSHPublicKeyError> for Error {
fn from(err: crate::operation::send_serial_console_ssh_public_key::SendSerialConsoleSSHPublicKeyError) -> Self {
match err {
crate::operation::send_serial_console_ssh_public_key::SendSerialConsoleSSHPublicKeyError::AuthException(inner) => {
Error::AuthException(inner)
}
crate::operation::send_serial_console_ssh_public_key::SendSerialConsoleSSHPublicKeyError::Ec2InstanceNotFoundException(inner) => {
Error::Ec2InstanceNotFoundException(inner)
}
crate::operation::send_serial_console_ssh_public_key::SendSerialConsoleSSHPublicKeyError::Ec2InstanceStateInvalidException(inner) => {
Error::Ec2InstanceStateInvalidException(inner)
}
crate::operation::send_serial_console_ssh_public_key::SendSerialConsoleSSHPublicKeyError::Ec2InstanceTypeInvalidException(inner) => {
Error::Ec2InstanceTypeInvalidException(inner)
}
crate::operation::send_serial_console_ssh_public_key::SendSerialConsoleSSHPublicKeyError::Ec2InstanceUnavailableException(inner) => {
Error::Ec2InstanceUnavailableException(inner)
}
crate::operation::send_serial_console_ssh_public_key::SendSerialConsoleSSHPublicKeyError::InvalidArgsException(inner) => {
Error::InvalidArgsException(inner)
}
crate::operation::send_serial_console_ssh_public_key::SendSerialConsoleSSHPublicKeyError::SerialConsoleAccessDisabledException(inner) => {
Error::SerialConsoleAccessDisabledException(inner)
}
crate::operation::send_serial_console_ssh_public_key::SendSerialConsoleSSHPublicKeyError::SerialConsoleSessionLimitExceededException(
inner,
) => Error::SerialConsoleSessionLimitExceededException(inner),
crate::operation::send_serial_console_ssh_public_key::SendSerialConsoleSSHPublicKeyError::SerialConsoleSessionUnavailableException(
inner,
) => Error::SerialConsoleSessionUnavailableException(inner),
crate::operation::send_serial_console_ssh_public_key::SendSerialConsoleSSHPublicKeyError::ServiceException(inner) => {
Error::ServiceException(inner)
}
crate::operation::send_serial_console_ssh_public_key::SendSerialConsoleSSHPublicKeyError::ThrottlingException(inner) => {
Error::ThrottlingException(inner)
}
crate::operation::send_serial_console_ssh_public_key::SendSerialConsoleSSHPublicKeyError::Unhandled(inner) => Error::Unhandled(inner),
}
}
}
impl<R> From<::aws_smithy_runtime_api::client::result::SdkError<crate::operation::send_ssh_public_key::SendSSHPublicKeyError, R>> for Error
where
R: Send + Sync + std::fmt::Debug + 'static,
{
fn from(err: ::aws_smithy_runtime_api::client::result::SdkError<crate::operation::send_ssh_public_key::SendSSHPublicKeyError, R>) -> Self {
match err {
::aws_smithy_runtime_api::client::result::SdkError::ServiceError(context) => Self::from(context.into_err()),
_ => Error::Unhandled(crate::error::sealed_unhandled::Unhandled {
meta: ::aws_smithy_types::error::metadata::ProvideErrorMetadata::meta(&err).clone(),
source: err.into(),
}),
}
}
}
impl From<crate::operation::send_ssh_public_key::SendSSHPublicKeyError> for Error {
fn from(err: crate::operation::send_ssh_public_key::SendSSHPublicKeyError) -> Self {
match err {
crate::operation::send_ssh_public_key::SendSSHPublicKeyError::AuthException(inner) => Error::AuthException(inner),
crate::operation::send_ssh_public_key::SendSSHPublicKeyError::Ec2InstanceNotFoundException(inner) => {
Error::Ec2InstanceNotFoundException(inner)
}
crate::operation::send_ssh_public_key::SendSSHPublicKeyError::Ec2InstanceStateInvalidException(inner) => {
Error::Ec2InstanceStateInvalidException(inner)
}
crate::operation::send_ssh_public_key::SendSSHPublicKeyError::Ec2InstanceUnavailableException(inner) => {
Error::Ec2InstanceUnavailableException(inner)
}
crate::operation::send_ssh_public_key::SendSSHPublicKeyError::InvalidArgsException(inner) => Error::InvalidArgsException(inner),
crate::operation::send_ssh_public_key::SendSSHPublicKeyError::ServiceException(inner) => Error::ServiceException(inner),
crate::operation::send_ssh_public_key::SendSSHPublicKeyError::ThrottlingException(inner) => Error::ThrottlingException(inner),
crate::operation::send_ssh_public_key::SendSSHPublicKeyError::Unhandled(inner) => Error::Unhandled(inner),
}
}
}
impl ::std::error::Error for Error {
fn source(&self) -> std::option::Option<&(dyn ::std::error::Error + 'static)> {
match self {
Error::AuthException(inner) => inner.source(),
Error::Ec2InstanceNotFoundException(inner) => inner.source(),
Error::Ec2InstanceStateInvalidException(inner) => inner.source(),
Error::Ec2InstanceTypeInvalidException(inner) => inner.source(),
Error::Ec2InstanceUnavailableException(inner) => inner.source(),
Error::InvalidArgsException(inner) => inner.source(),
Error::SerialConsoleAccessDisabledException(inner) => inner.source(),
Error::SerialConsoleSessionLimitExceededException(inner) => inner.source(),
Error::SerialConsoleSessionUnavailableException(inner) => inner.source(),
Error::ServiceException(inner) => inner.source(),
Error::ThrottlingException(inner) => inner.source(),
Error::Unhandled(inner) => ::std::option::Option::Some(&*inner.source),
}
}
}
impl ::aws_types::request_id::RequestId for Error {
fn request_id(&self) -> Option<&str> {
match self {
Self::AuthException(e) => e.request_id(),
Self::Ec2InstanceNotFoundException(e) => e.request_id(),
Self::Ec2InstanceStateInvalidException(e) => e.request_id(),
Self::Ec2InstanceTypeInvalidException(e) => e.request_id(),
Self::Ec2InstanceUnavailableException(e) => e.request_id(),
Self::InvalidArgsException(e) => e.request_id(),
Self::SerialConsoleAccessDisabledException(e) => e.request_id(),
Self::SerialConsoleSessionLimitExceededException(e) => e.request_id(),
Self::SerialConsoleSessionUnavailableException(e) => e.request_id(),
Self::ServiceException(e) => e.request_id(),
Self::ThrottlingException(e) => e.request_id(),
Self::Unhandled(e) => e.meta.request_id(),
}
}
}