aboutsummaryrefslogtreecommitdiffstats
path: root/contrib/libs/aws-sdk-cpp/aws-cpp-sdk-s3/source/model/ObjectCannedACL.cpp
blob: a6cd1c626bb350314f4bd7b01ce02655319dbfdf (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
/**
 * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
 * SPDX-License-Identifier: Apache-2.0.
 */

#include <aws/s3/model/ObjectCannedACL.h>
#include <aws/core/utils/HashingUtils.h>
#include <aws/core/Globals.h>
#include <aws/core/utils/EnumParseOverflowContainer.h>

using namespace Aws::Utils;


namespace Aws
{
  namespace S3
  {
    namespace Model
    {
      namespace ObjectCannedACLMapper
      {

        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 authenticated_read_HASH = HashingUtils::HashString("authenticated-read");
        static const int aws_exec_read_HASH = HashingUtils::HashString("aws-exec-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");


        ObjectCannedACL GetObjectCannedACLForName(const Aws::String& name)
        {
          int hashCode = HashingUtils::HashString(name.c_str());
          if (hashCode == private__HASH)
          {
            return ObjectCannedACL::private_;
          }
          else if (hashCode == public_read_HASH)
          {
            return ObjectCannedACL::public_read;
          }
          else if (hashCode == public_read_write_HASH)
          {
            return ObjectCannedACL::public_read_write;
          }
          else if (hashCode == authenticated_read_HASH)
          {
            return ObjectCannedACL::authenticated_read;
          }
          else if (hashCode == aws_exec_read_HASH)
          {
            return ObjectCannedACL::aws_exec_read;
          }
          else if (hashCode == bucket_owner_read_HASH)
          {
            return ObjectCannedACL::bucket_owner_read;
          }
          else if (hashCode == bucket_owner_full_control_HASH)
          {
            return ObjectCannedACL::bucket_owner_full_control;
          }
          EnumParseOverflowContainer* overflowContainer = Aws::GetEnumOverflowContainer();
          if(overflowContainer)
          {
            overflowContainer->StoreOverflow(hashCode, name);
            return static_cast<ObjectCannedACL>(hashCode);
          }

          return ObjectCannedACL::NOT_SET;
        }

        Aws::String GetNameForObjectCannedACL(ObjectCannedACL enumValue)
        {
          switch(enumValue)
          {
          case ObjectCannedACL::private_:
            return "private";
          case ObjectCannedACL::public_read:
            return "public-read";
          case ObjectCannedACL::public_read_write:
            return "public-read-write";
          case ObjectCannedACL::authenticated_read:
            return "authenticated-read";
          case ObjectCannedACL::aws_exec_read:
            return "aws-exec-read";
          case ObjectCannedACL::bucket_owner_read:
            return "bucket-owner-read";
          case ObjectCannedACL::bucket_owner_full_control:
            return "bucket-owner-full-control";
          default:
            EnumParseOverflowContainer* overflowContainer = Aws::GetEnumOverflowContainer();
            if(overflowContainer)
            {
              return overflowContainer->RetrieveOverflow(static_cast<int>(enumValue));
            }

            return {}; 
          }
        }

      } // namespace ObjectCannedACLMapper
    } // namespace Model
  } // namespace S3
} // namespace Aws