Class: Fog::Storage::AWS::Files
- Inherits:
-
Collection
- Object
- Collection
- Fog::Storage::AWS::Files
- Extended by:
- Deprecation
- Defined in:
- lib/fog/aws/models/storage/files.rb
Instance Method Summary collapse
- #all(options = {}) ⇒ Object
- #each ⇒ Object
- #each_file_this_page ⇒ Object
- #get(key, options = {}, &block) ⇒ Object
- #get_http_url(key, expires, options = {}) ⇒ Object
- #get_https_url(key, expires, options = {}) ⇒ Object
- #get_url(key, expires, options = {}) ⇒ Object
- #head(key, options = {}) ⇒ Object
- #head_url(key, expires, options = {}) ⇒ Object
- #new(attributes = {}) ⇒ Object
- #normalize_headers(data) ⇒ Object
Instance Method Details
#all(options = {}) ⇒ Object
20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 |
# File 'lib/fog/aws/models/storage/files.rb', line 20 def all( = {}) requires :directory = { 'delimiter' => delimiter, 'marker' => marker, 'max-keys' => max_keys, 'prefix' => prefix }.merge!() = .reject {|key,value| value.nil? || value.to_s.empty?} merge_attributes() parent = directory.collection.get( directory.key, ) if parent merge_attributes(parent.files.attributes) load(parent.files.map {|file| file.attributes}) else nil end end |
#each ⇒ Object
43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 |
# File 'lib/fog/aws/models/storage/files.rb', line 43 def each if !block_given? self else subset = dup.all subset.each_file_this_page {|f| yield f} while subset.is_truncated subset = subset.all(:marker => subset.last.key) subset.each_file_this_page {|f| yield f} end self end end |
#each_file_this_page ⇒ Object
42 |
# File 'lib/fog/aws/models/storage/files.rb', line 42 alias_method :each_file_this_page, :each |
#get(key, options = {}, &block) ⇒ Object
59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 |
# File 'lib/fog/aws/models/storage/files.rb', line 59 def get(key, = {}, &block) requires :directory data = service.get_object(directory.key, key, , &block) normalize_headers(data) file_data = data.headers.merge({ :body => data.body, :key => key }) new(file_data) rescue Excon::Errors::NotFound => error case error.response.body when /<Code>NoSuchKey<\/Code>/ nil when /<Code>NoSuchBucket<\/Code>/ raise(Fog::Storage::AWS::NotFound.new("Directory #{directory.identity} does not exist.")) else raise(error) end end |
#get_http_url(key, expires, options = {}) ⇒ Object
84 85 86 87 |
# File 'lib/fog/aws/models/storage/files.rb', line 84 def get_http_url(key, expires, = {}) requires :directory service.get_object_http_url(directory.key, key, expires, ) end |
#get_https_url(key, expires, options = {}) ⇒ Object
89 90 91 92 |
# File 'lib/fog/aws/models/storage/files.rb', line 89 def get_https_url(key, expires, = {}) requires :directory service.get_object_https_url(directory.key, key, expires, ) end |
#get_url(key, expires, options = {}) ⇒ Object
79 80 81 82 |
# File 'lib/fog/aws/models/storage/files.rb', line 79 def get_url(key, expires, = {}) requires :directory service.get_object_url(directory.key, key, expires, ) end |
#head(key, options = {}) ⇒ Object
99 100 101 102 103 104 105 106 107 108 109 |
# File 'lib/fog/aws/models/storage/files.rb', line 99 def head(key, = {}) requires :directory data = service.head_object(directory.key, key, ) normalize_headers(data) file_data = data.headers.merge({ :key => key }) new(file_data) rescue Excon::Errors::NotFound nil end |
#head_url(key, expires, options = {}) ⇒ Object
94 95 96 97 |
# File 'lib/fog/aws/models/storage/files.rb', line 94 def head_url(key, expires, = {}) requires :directory service.head_object_url(directory.key, key, expires, ) end |
#new(attributes = {}) ⇒ Object
111 112 113 114 |
# File 'lib/fog/aws/models/storage/files.rb', line 111 def new(attributes = {}) requires :directory super({ :directory => directory }.merge!(attributes)) end |
#normalize_headers(data) ⇒ Object
116 117 118 119 |
# File 'lib/fog/aws/models/storage/files.rb', line 116 def normalize_headers(data) data.headers['Last-Modified'] = Time.parse(data.get_header('Last-Modified')) data.headers['ETag'] = data.get_header('ETag').gsub('"','') end |