Пытаясь извлечь содержимое корзины S3 с помощью интерфейса командной строки AWS, я получаю следующее:
aws s3 cp --region us-east-1 s3://s3.amazonaws.com/my-bucket . --recursive
A client error (AccessDenied) occurred when calling the ListObjects operation: Access Denied
Completed 1 part(s) with ... file(s) remaining
С помощью aws s3 sync
аналогично не удается.
Политика пользователя:
{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Action": "s3:*",
"Resource": ["arn:aws:s3:::*"]
}
]
}
(Я тоже пробовал различные менее строгие политики, но безрезультатно).
Я пробовал политику пустого ведра, а также эту политику ведра:
{
"Id": "Policy1357935677554",
"Statement": [
{
"Sid": "Stmt1357935647218",
"Action": [
"*"
],
"Effect": "Allow",
"Resource": "arn:aws:s3:::my-bucket",
"Principal": {
"AWS": [
"arn:aws:iam::XXXXXXXXXX:user/my-user"
]
}
},
{
"Sid": "Stmt1357935676138",
"Action": [
"*"
],
"Effect": "Allow",
"Resource": "arn:aws:s3:::my-bucket/*",
"Principal": {
"AWS": [
"arn:aws:iam::XXXXXXXXXX:user/my-user"
]
}
}
]
}
Интересно, что это делает работай:
aws s3api list-objects --region us-east-1 --bucket my-bucket
Формат указания местоположения s3: s3://bucket/key
так что вместо s3://s3.amazonaws.com/my-bucket
вы бы использовали s3://my-bucket/
.