/** * 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::AppSync; using namespace Aws::AppSync::Model; namespace Aws { namespace AppSync { template<> AWS_APPSYNC_API BadRequestException AppSyncError::GetModeledError() { assert(this->GetErrorType() == AppSyncErrors::BAD_REQUEST); return BadRequestException(this->GetJsonPayload().View()); } namespace AppSyncErrorMapper { static const int GRAPH_Q_L_SCHEMA_HASH = HashingUtils::HashString("GraphQLSchemaException"); static const int NOT_FOUND_HASH = HashingUtils::HashString("NotFoundException"); static const int API_KEY_VALIDITY_OUT_OF_BOUNDS_HASH = HashingUtils::HashString("ApiKeyValidityOutOfBoundsException"); static const int API_LIMIT_EXCEEDED_HASH = HashingUtils::HashString("ApiLimitExceededException"); static const int UNAUTHORIZED_HASH = HashingUtils::HashString("UnauthorizedException"); static const int LIMIT_EXCEEDED_HASH = HashingUtils::HashString("LimitExceededException"); static const int CONCURRENT_MODIFICATION_HASH = HashingUtils::HashString("ConcurrentModificationException"); static const int BAD_REQUEST_HASH = HashingUtils::HashString("BadRequestException"); static const int API_KEY_LIMIT_EXCEEDED_HASH = HashingUtils::HashString("ApiKeyLimitExceededException"); AWSError GetErrorForName(const char* errorName) { int hashCode = HashingUtils::HashString(errorName); if (hashCode == GRAPH_Q_L_SCHEMA_HASH) { return AWSError(static_cast(AppSyncErrors::GRAPH_Q_L_SCHEMA), false); } else if (hashCode == NOT_FOUND_HASH) { return AWSError(static_cast(AppSyncErrors::NOT_FOUND), false); } else if (hashCode == API_KEY_VALIDITY_OUT_OF_BOUNDS_HASH) { return AWSError(static_cast(AppSyncErrors::API_KEY_VALIDITY_OUT_OF_BOUNDS), false); } else if (hashCode == API_LIMIT_EXCEEDED_HASH) { return AWSError(static_cast(AppSyncErrors::API_LIMIT_EXCEEDED), false); } else if (hashCode == UNAUTHORIZED_HASH) { return AWSError(static_cast(AppSyncErrors::UNAUTHORIZED), false); } else if (hashCode == LIMIT_EXCEEDED_HASH) { return AWSError(static_cast(AppSyncErrors::LIMIT_EXCEEDED), true); } else if (hashCode == CONCURRENT_MODIFICATION_HASH) { return AWSError(static_cast(AppSyncErrors::CONCURRENT_MODIFICATION), false); } else if (hashCode == BAD_REQUEST_HASH) { return AWSError(static_cast(AppSyncErrors::BAD_REQUEST), false); } else if (hashCode == API_KEY_LIMIT_EXCEEDED_HASH) { return AWSError(static_cast(AppSyncErrors::API_KEY_LIMIT_EXCEEDED), false); } return AWSError(CoreErrors::UNKNOWN, false); } } // namespace AppSyncErrorMapper } // namespace AppSync } // namespace Aws