Class: Fog::AWS::Storage::Directory
Instance Attribute Summary
Attributes inherited from Model
#collection, #connection
Instance Method Summary
collapse
deprecate, self_deprecate
Methods inherited from Model
#initialize, #inspect, #reload, #to_json, #wait_for
#_load, #aliases, #attribute, #attributes, #identity, #ignore_attributes, #ignored_attributes
#_dump, #attributes, #identity, #identity=, #merge_attributes, #new_record?, #requires
Constructor Details
This class inherits a constructor from Fog::Model
Instance Method Details
#acl=(new_acl) ⇒ Object
17
18
19
20
21
22
23
|
# File 'lib/fog/storage/models/aws/directory.rb', line 17
def acl=(new_acl)
valid_acls = ['private', 'public-read', 'public-read-write', 'authenticated-read']
unless valid_acls.include?(new_acl)
raise ArgumentError.new("acl must be one of [#{valid_acls.join(', ')}]")
end
@acl = new_acl
end
|
#destroy ⇒ Object
25
26
27
28
29
30
31
|
# File 'lib/fog/storage/models/aws/directory.rb', line 25
def destroy
requires :key
connection.delete_bucket(key)
true
rescue Excon::Errors::NotFound
false
end
|
#files ⇒ Object
43
44
45
46
47
48
49
50
|
# File 'lib/fog/storage/models/aws/directory.rb', line 43
def files
@files ||= begin
Fog::AWS::Storage::Files.new(
:directory => self,
:connection => connection
)
end
end
|
#location ⇒ Object
33
34
35
36
37
|
# File 'lib/fog/storage/models/aws/directory.rb', line 33
def location
requires :key
data = connection.get_bucket_location(key)
data.body['LocationConstraint']
end
|
#location=(new_location) ⇒ Object
39
40
41
|
# File 'lib/fog/storage/models/aws/directory.rb', line 39
def location=(new_location)
@location = new_location
end
|
#payer ⇒ Object
52
53
54
55
56
|
# File 'lib/fog/storage/models/aws/directory.rb', line 52
def payer
requires :key
data = connection.get_request_payment(key)
data.body['Payer']
end
|
#payer=(new_payer) ⇒ Object
58
59
60
61
62
|
# File 'lib/fog/storage/models/aws/directory.rb', line 58
def payer=(new_payer)
requires :key
connection.put_request_payment(key, new_payer)
@payer = new_payer
end
|
#public=(new_public) ⇒ Object
64
65
66
67
68
69
70
71
|
# File 'lib/fog/storage/models/aws/directory.rb', line 64
def public=(new_public)
if new_public
@acl = 'public-read'
else
@acl = 'private'
end
new_public
end
|
#public_url ⇒ Object
73
74
75
76
77
78
79
80
81
82
83
84
|
# File 'lib/fog/storage/models/aws/directory.rb', line 73
def public_url
requires :key
if connection.get_bucket_acl(key).body['AccessControlList'].detect {|grant| grant['Grantee']['URI'] == 'http://acs.amazonaws.com/groups/global/AllUsers' && grant['Permission'] == 'READ'}
if key.to_s =~ /^(?:[a-z]|\d(?!\d{0,2}(?:\.\d{1,3}){3}$))(?:[a-z0-9]|\.(?![\.\-])|\-(?![\.])){1,61}[a-z0-9]$/
"https://#{key}.s3.amazonaws.com"
else
"https://s3.amazonaws.com/#{key}"
end
else
nil
end
end
|
#save ⇒ Object
86
87
88
89
90
91
92
93
94
95
96
97
|
# File 'lib/fog/storage/models/aws/directory.rb', line 86
def save
requires :key
options = {}
if @acl
options['x-amz-acl'] = @acl
end
if @location
options['LocationConstraint'] = @location
end
connection.put_bucket(key, options)
true
end
|