/** * 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 IoT { namespace Model { namespace CannedAccessControlListMapper { static const int private__HASH = HashingUtils::HashString("private"); static const int public_read_HASH = HashingUtils::HashString("public-read"); static const int public_read_write_HASH = HashingUtils::HashString("public-read-write"); static const int aws_exec_read_HASH = HashingUtils::HashString("aws-exec-read"); static const int authenticated_read_HASH = HashingUtils::HashString("authenticated-read"); static const int bucket_owner_read_HASH = HashingUtils::HashString("bucket-owner-read"); static const int bucket_owner_full_control_HASH = HashingUtils::HashString("bucket-owner-full-control"); static const int log_delivery_write_HASH = HashingUtils::HashString("log-delivery-write"); CannedAccessControlList GetCannedAccessControlListForName(const Aws::String& name) { int hashCode = HashingUtils::HashString(name.c_str()); if (hashCode == private__HASH) { return CannedAccessControlList::private_; } else if (hashCode == public_read_HASH) { return CannedAccessControlList::public_read; } else if (hashCode == public_read_write_HASH) { return CannedAccessControlList::public_read_write; } else if (hashCode == aws_exec_read_HASH) { return CannedAccessControlList::aws_exec_read; } else if (hashCode == authenticated_read_HASH) { return CannedAccessControlList::authenticated_read; } else if (hashCode == bucket_owner_read_HASH) { return CannedAccessControlList::bucket_owner_read; } else if (hashCode == bucket_owner_full_control_HASH) { return CannedAccessControlList::bucket_owner_full_control; } else if (hashCode == log_delivery_write_HASH) { return CannedAccessControlList::log_delivery_write; } EnumParseOverflowContainer* overflowContainer = Aws::GetEnumOverflowContainer(); if(overflowContainer) { overflowContainer->StoreOverflow(hashCode, name); return static_cast(hashCode); } return CannedAccessControlList::NOT_SET; } Aws::String GetNameForCannedAccessControlList(CannedAccessControlList enumValue) { switch(enumValue) { case CannedAccessControlList::private_: return "private"; case CannedAccessControlList::public_read: return "public-read"; case CannedAccessControlList::public_read_write: return "public-read-write"; case CannedAccessControlList::aws_exec_read: return "aws-exec-read"; case CannedAccessControlList::authenticated_read: return "authenticated-read"; case CannedAccessControlList::bucket_owner_read: return "bucket-owner-read"; case CannedAccessControlList::bucket_owner_full_control: return "bucket-owner-full-control"; case CannedAccessControlList::log_delivery_write: return "log-delivery-write"; default: EnumParseOverflowContainer* overflowContainer = Aws::GetEnumOverflowContainer(); if(overflowContainer) { return overflowContainer->RetrieveOverflow(static_cast(enumValue)); } return {}; } } } // namespace CannedAccessControlListMapper } // namespace Model } // namespace IoT } // namespace Aws