mirror of
https://github.com/fog/fog.git
synced 2022-11-09 13:51:43 -05:00
54 lines
1.6 KiB
Ruby
54 lines
1.6 KiB
Ruby
|
module Fog
|
||
|
module AWS
|
||
|
module S3
|
||
|
class Real
|
||
|
|
||
|
# Get access control list for an S3 bucket
|
||
|
#
|
||
|
# ==== Parameters
|
||
|
# * bucket_name<~String> - name of bucket to get access control list for
|
||
|
#
|
||
|
# ==== Returns
|
||
|
# * response<~Excon::Response>:
|
||
|
# * body<~Hash>:
|
||
|
# * 'AccessControlPolicy'<~Hash>
|
||
|
# * 'Owner'<~Hash>:
|
||
|
# * 'DisplayName'<~String> - Display name of object owner
|
||
|
# * 'ID'<~String> - Id of object owner
|
||
|
# * 'AccessControlList'<~Array>:
|
||
|
# * 'Grant'<~Hash>:
|
||
|
# * 'Grantee'<~Hash>:
|
||
|
# * 'DisplayName'<~String> - Display name of grantee
|
||
|
# * 'ID'<~String> - Id of grantee
|
||
|
# or
|
||
|
# * 'URI'<~String> - URI of group to grant access for
|
||
|
# * 'Permission'<~String> - Permission, in [FULL_CONTROL, WRITE, WRITE_ACP, READ, READ_ACP]
|
||
|
#
|
||
|
def get_bucket_acl(bucket_name)
|
||
|
unless bucket_name
|
||
|
raise ArgumentError.new('bucket_name is required')
|
||
|
end
|
||
|
request({
|
||
|
:expects => 200,
|
||
|
:headers => {},
|
||
|
:host => "#{bucket_name}.#{@host}",
|
||
|
:idempotent => true,
|
||
|
:method => 'GET',
|
||
|
:parser => Fog::Parsers::AWS::S3::AccessControlList.new,
|
||
|
:query => 'acl'
|
||
|
})
|
||
|
end
|
||
|
|
||
|
end
|
||
|
|
||
|
class Mock
|
||
|
|
||
|
def get_bucket_acl(bucket_name)
|
||
|
raise MockNotImplemented.new("Contributions welcome!")
|
||
|
end
|
||
|
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
end
|