mirror of
https://github.com/fog/fog.git
synced 2022-11-09 13:51:43 -05:00
f6d361b2e2
Logics have been centralised: * region to hostname * url generation * signature * chaning scheme also changes the port During the process a couple of inconsistencies have also been fixed. Known limitations: When using the @endpoint with a custom port you need to specify the port when using get_object_http_url or get_object_https_url. When using bucket names that contain dots outside of us-east-1 make sure to access it with the same region in your AWS::Storage.
81 lines
2.6 KiB
Ruby
81 lines
2.6 KiB
Ruby
module Fog
|
|
module Storage
|
|
class AWS
|
|
class Real
|
|
|
|
# Change logging status for an S3 bucket
|
|
#
|
|
# @param bucket_name [String] name of bucket to modify
|
|
# @param logging_status [Hash]:
|
|
# * Owner [Hash]:
|
|
# * ID [String]: id of owner
|
|
# * DisplayName [String]: display name of owner
|
|
# * AccessControlList [Array]:
|
|
# * Grantee [Hash]:
|
|
# * DisplayName [String] Display name of grantee
|
|
# * ID [String] Id of grantee
|
|
# or
|
|
# * EmailAddress [String] Email address of grantee
|
|
# or
|
|
# * URI [String] URI of group to grant access for
|
|
# * Permission [String] Permission, in [FULL_CONTROL, WRITE, WRITE_ACP, READ, READ_ACP]
|
|
#
|
|
# @see http://docs.amazonwebservices.com/AmazonS3/latest/API/RESTBucketPUTlogging.html
|
|
|
|
def put_bucket_logging(bucket_name, logging_status)
|
|
if logging_status['LoggingEnabled'].empty?
|
|
data =
|
|
<<-DATA
|
|
<BucketLoggingStatus xmlns="http://doc.s3.amazonaws.com/2006-03-01" />
|
|
DATA
|
|
else
|
|
data =
|
|
<<-DATA
|
|
<BucketLoggingStatus xmlns="http://doc.s3.amazonaws.com/2006-03-01">
|
|
<LoggingEnabled>
|
|
<TargetBucket>#{logging_status['LoggingEnabled']['TargetBucket']}</TargetBucket>
|
|
<TargetPrefix>#{logging_status['LoggingEnabled']['TargetBucket']}</TargetPrefix>
|
|
<TargetGrants>
|
|
DATA
|
|
|
|
acl['AccessControlList'].each do |grant|
|
|
data << " <Grant>"
|
|
type = case grant['Grantee'].keys.sort
|
|
when ['DisplayName', 'ID']
|
|
'CanonicalUser'
|
|
when ['EmailAddress']
|
|
'AmazonCustomerByEmail'
|
|
when ['URI']
|
|
'Group'
|
|
end
|
|
data << " <Grantee xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\" xsi:type=\"#{type}\">"
|
|
for key, value in grant['Grantee']
|
|
data << " <#{key}>#{value}</#{key}>"
|
|
end
|
|
data << " </Grantee>"
|
|
data << " <Permission>#{grant['Permission']}</Permission>"
|
|
data << " </Grant>"
|
|
end
|
|
|
|
data <<
|
|
<<-DATA
|
|
</TargetGrants>
|
|
</LoggingEnabled>
|
|
</BucketLoggingStatus>
|
|
DATA
|
|
end
|
|
|
|
request({
|
|
:body => data,
|
|
:expects => 200,
|
|
:headers => {},
|
|
:bucket_name => bucket_name,
|
|
:method => 'PUT',
|
|
:query => {'logging' => nil}
|
|
})
|
|
end
|
|
|
|
end
|
|
end
|
|
end
|
|
end
|