/** * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. * SPDX-License-Identifier: Apache-2.0. */ #include #include #include #include using namespace Aws::Client; using namespace Aws::Utils; using namespace Aws::Amplify; using namespace Aws::Amplify::Model; namespace Aws { namespace Amplify { template<> AWS_AMPLIFY_API ResourceNotFoundException AmplifyError::GetModeledError() { assert(this->GetErrorType() == AmplifyErrors::RESOURCE_NOT_FOUND); return ResourceNotFoundException(this->GetJsonPayload().View()); } namespace AmplifyErrorMapper { static const int NOT_FOUND_HASH = HashingUtils::HashString("NotFoundException"); static const int UNAUTHORIZED_HASH = HashingUtils::HashString("UnauthorizedException"); static const int LIMIT_EXCEEDED_HASH = HashingUtils::HashString("LimitExceededException"); static const int DEPENDENT_SERVICE_FAILURE_HASH = HashingUtils::HashString("DependentServiceFailureException"); static const int BAD_REQUEST_HASH = HashingUtils::HashString("BadRequestException"); AWSError GetErrorForName(const char* errorName) { int hashCode = HashingUtils::HashString(errorName); if (hashCode == NOT_FOUND_HASH) { return AWSError(static_cast(AmplifyErrors::NOT_FOUND), false); } else if (hashCode == UNAUTHORIZED_HASH) { return AWSError(static_cast(AmplifyErrors::UNAUTHORIZED), false); } else if (hashCode == LIMIT_EXCEEDED_HASH) { return AWSError(static_cast(AmplifyErrors::LIMIT_EXCEEDED), true); } else if (hashCode == DEPENDENT_SERVICE_FAILURE_HASH) { return AWSError(static_cast(AmplifyErrors::DEPENDENT_SERVICE_FAILURE), false); } else if (hashCode == BAD_REQUEST_HASH) { return AWSError(static_cast(AmplifyErrors::BAD_REQUEST), false); } return AWSError(CoreErrors::UNKNOWN, false); } } // namespace AmplifyErrorMapper } // namespace Amplify } // namespace Aws