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
|
module Fog
module Storage
class GoogleXML
class Mock
def put_bucket_acl(_bucket_name, _acl)
# :no-coverage:
Fog::Mock.not_implemented
# :no-coverage:
end
end
class Real
# Change access control list for an Google Storage bucket
def put_bucket_acl(bucket_name, acl)
data = <<-DATA
<AccessControlList>
<Owner>
#{tag('ID', acl['Owner']['ID'])}
</Owner>
<Entries>
#{entries_list(acl['AccessControlList'])}
</Entries>
</AccessControlList>
DATA
request(:body => data,
:expects => 200,
:headers => {},
:host => "#{bucket_name}.#{@host}",
:method => "PUT",
:query => { "acl" => nil })
end
private
def tag(name, value)
"<#{name}>#{value}</#{name}>"
end
def scope_tag(scope)
if %w(AllUsers AllAuthenticatedUsers).include?(scope["type"])
"<Scope type='#{scope['type']}'/>"
else
"<Scope type='#{scope['type']}'>" +
scope.to_a.reject { |pair| pair[0] == "type" }.map { |pair| tag(pair[0], pair[1]) }.join("\n") +
"</Scope>"
end
end
def entries_list(access_control_list)
access_control_list.map do |entry|
tag("Entry", scope_tag(entry["Scope"]) + tag("Permission", entry["Permission"]))
end.join("\n")
end
end
end
end
end
|