/** * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. * SPDX-License-Identifier: Apache-2.0. */ #include #include #include #include using namespace Aws::Utils; namespace Aws { namespace CloudFront { namespace Model { namespace ViewerProtocolPolicyMapper { static const int allow_all_HASH = HashingUtils::HashString("allow-all"); static const int https_only_HASH = HashingUtils::HashString("https-only"); static const int redirect_to_https_HASH = HashingUtils::HashString("redirect-to-https"); ViewerProtocolPolicy GetViewerProtocolPolicyForName(const Aws::String& name) { int hashCode = HashingUtils::HashString(name.c_str()); if (hashCode == allow_all_HASH) { return ViewerProtocolPolicy::allow_all; } else if (hashCode == https_only_HASH) { return ViewerProtocolPolicy::https_only; } else if (hashCode == redirect_to_https_HASH) { return ViewerProtocolPolicy::redirect_to_https; } EnumParseOverflowContainer* overflowContainer = Aws::GetEnumOverflowContainer(); if(overflowContainer) { overflowContainer->StoreOverflow(hashCode, name); return static_cast(hashCode); } return ViewerProtocolPolicy::NOT_SET; } Aws::String GetNameForViewerProtocolPolicy(ViewerProtocolPolicy enumValue) { switch(enumValue) { case ViewerProtocolPolicy::allow_all: return "allow-all"; case ViewerProtocolPolicy::https_only: return "https-only"; case ViewerProtocolPolicy::redirect_to_https: return "redirect-to-https"; default: EnumParseOverflowContainer* overflowContainer = Aws::GetEnumOverflowContainer(); if(overflowContainer) { return overflowContainer->RetrieveOverflow(static_cast(enumValue)); } return {}; } } } // namespace ViewerProtocolPolicyMapper } // namespace Model } // namespace CloudFront } // namespace Aws