class Fog::Aliyun::Storage::Files

Public Instance Methods

all(options = {}) click to toggle source
# File lib/fog/aliyun/models/storage/files.rb, line 23
def all(options = {})
  requires :directory
  options = {
      'delimiter': delimiter,
      'marker': marker,
      'max-keys': max_keys.to_i,
      'prefix': prefix
  }.merge!(options)
  options = options.reject {|key,value| value.nil? || value.to_s.empty?}
  merge_attributes(options)
  parent = directory.collection.get(
      directory.key,
      options
  )
  if parent
    merge_attributes(parent.files.attributes)
    load(parent.files.map {|file| file.attributes})
  else
    nil
  end
end
each() { |f| ... } click to toggle source
# File lib/fog/aliyun/models/storage/files.rb, line 47
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
Also aliased as: each_file_this_page
each_file_this_page()
Alias for: each
get(key, options = {}, &block) click to toggle source
# File lib/fog/aliyun/models/storage/files.rb, line 63
def get(key, options = {}, &block)
  requires :directory
  begin
    data = service.get_object(directory.key, key, options, &block)
    normalize_headers(data)
    file_data = data.headers.merge({
                                       :body => data.body,
                                       :key  => key
                                   })
    new(file_data)
  rescue Exception => error
    if error.respond_to?(:http_code) && error.http_code.to_i == 404
      nil
    else
      raise(error)
    end
  end
end
get_http_url(key, expires, options = {}) click to toggle source

@param options No need to use

# File lib/fog/aliyun/models/storage/files.rb, line 89
def get_http_url(key, expires, options = {})
  requires :directory
  service.get_object_http_url_public(directory.key, key, expires)
end
get_https_url(key, expires, options = {}) click to toggle source

@param options No need to use

# File lib/fog/aliyun/models/storage/files.rb, line 95
def get_https_url(key, expires, options = {})
  requires :directory
  service.get_object_https_url_public(directory.key, key, expires)
end
get_url(key, options = {}) click to toggle source

@param options No need to use

# File lib/fog/aliyun/models/storage/files.rb, line 83
def get_url(key, options = {})
  requires :directory
  service.get_object_http_url_public(directory.key, key, 3600)
end
head(key, options = {}) click to toggle source
# File lib/fog/aliyun/models/storage/files.rb, line 100
def head(key, options = {})
  requires :directory
  begin
    data = service.head_object(directory.key, key, options)
    normalize_headers(data)
    file_data = data.headers.merge({
                                       :key => key
                                   })
    new(file_data)
  rescue Exception => error
    if error.respond_to?(:http_code) && error.http_code.to_i == 404
      nil
    else
      raise(error)
    end
  end
end
new(attributes = {}) click to toggle source
Calls superclass method
# File lib/fog/aliyun/models/storage/files.rb, line 118
def new(attributes = {})
  requires :directory
  super({ :directory => directory }.merge!(attributes))
end
normalize_headers(data) click to toggle source
# File lib/fog/aliyun/models/storage/files.rb, line 123
def normalize_headers(data)
  data.headers[:last_modified] = Time.parse(data.headers[:last_modified])
  data.headers[:etag] = data.headers[:etag].gsub('"','')
end