7

aws s3 lsaws s3api list-bucketsで異なる動作が見られます

これが最初のものです:

$ aws s3 ls s3://demo.for.customers

Bucket: demo.for.customers
Prefix: 

      LastWriteTime     Length Name
      -------------     ------ ----
                           PRE 5CE4D191-FD14-4C85-8146-9FB8C29B7A7B/
                           PRE FFBC4675-F864-40E9-8AB8-BDF7A0437010/

したがって、バケットdemo.for.customers内のオブジェクトを一覧表示できます。

ここで、 s3apiを使用して同じことを実行すると、アクセスが拒否されます。

$ aws s3api list-objects --bucket demo.for.customers
A client error (AccessDenied) occurred: Access Denied

質問: s3api を介してオブジェクトを一覧表示すると、アクセスが拒否されるのはなぜですか。

この問題を提起する理由は、AWS S3 Ruby SDKを使用すると同じ問題が発生するためです。

ただし、aws s3 lsを使用すると問題ありません。

そのため、AWS S3 Ruby SDKaws s3apiは同じ動作を示しています。そのため、ここではaws s3api CLIの問題のみを貼り付けます。

ところで、上記のすべてのコマンドを実行しているユーザーに適用された IAM ポリシーは次のとおりです。

{
  "Statement": [
    {
      "Action": [
        "s3:ListAllMyBuckets",
        "s3:GetBucketLocation"
      ],
      "Effect": "Allow",
      "Resource": [
        "arn:aws:s3:::"
      ]
    },
    {
      "Action": [
        "s3:ListBucket"
      ],
      "Effect": "Allow",
      "Resource": [
        "arn:aws:s3:::demo.for.customers"
      ],
      "Condition": {
        "StringEquals": {
          "s3:prefix": [
            "",
            "FFBC4675-F864-40E9-8AB8-BDF7A0437010/"
          ],
          "s3:delimiter": [
            "/"
          ]
        }
      }
    },
    {
      "Effect": "Allow",
      "Action": [
        "s3:PutObject",
        "s3:GetObject",
        "s3:DeleteObject"
      ],
      "Resource": [
        "arn:aws:s3:::demo.for.customers/FFBC4675-F864-40E9-8AB8-BDF7A0437010/"
      ]
    }
  ]
}

そして、これはまったく同じエラーを生成するルビーコードです。

#!/usr/bin/ruby

require 'aws-sdk'
require 'awesome_print'
AWS.config( :access_key_id      => 'whatever', 
            :secret_access_key  => 'again whatever',
            :region             => 'us-west-2')

s3 = AWS.s3
buckets = s3.client.list_objects(:bucket_name => "demo.for.customers")
ap buckets

出力は次のとおりです。

# ruby s3policies.rb 
/var/lib/gems/1.9.1/gems/aws-sdk-1.14.1/lib/aws/core/client.rb:366:in `return_or_raise': Access Denied (AWS::S3::Errors::AccessDenied)
4

2 に答える 2