class Fog::Storage::HP::Files

Public Instance Methods

all(options = {}) click to toggle source
# File lib/fog/hp/models/storage/files.rb, line 16
def all(options = {})
  requires :directory
  options = {
    'limit'   => limit,
    'marker'  => marker,
    'path'    => path,
    'prefix'  => prefix
  }.merge!(options)
  merge_attributes(options)
  parent = directory.collection.get(
    directory.key,
    options
  )
  if parent
    load(parent.files.map {|file| file.attributes})
  else
    nil
  end
end
each() { |f| ... } click to toggle source
# File lib/fog/hp/models/storage/files.rb, line 37
def each
  if !block_given?
    self
  else
    subset = dup.all

    subset.each_file_this_page {|f| yield f}
    until subset.empty? || subset.length == (subset.limit || 10000)
      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, &block) click to toggle source
# File lib/fog/hp/models/storage/files.rb, line 53
def get(key, &block)
  requires :directory
  data = service.get_object(directory.key, key, &block)
  file_data = data.headers.merge({
    :body => data.body,
    :key  => key
  })
  new(file_data)
rescue Fog::Storage::HP::NotFound
  nil
end
get_cdn_ssl_url(key) click to toggle source
# File lib/fog/hp/models/storage/files.rb, line 103
def get_cdn_ssl_url(key)
  requires :directory
  if self.directory.cdn_public_ssl_url
    # escape the key to cover for special char. in object names
    "#{self.directory.cdn_public_ssl_url}/#{Fog::HP.escape(key)}"
  end
end
get_cdn_url(key) click to toggle source
# File lib/fog/hp/models/storage/files.rb, line 95
def get_cdn_url(key)
  requires :directory
  if self.directory.cdn_public_url
    # escape the key to cover for special char. in object names
    "#{self.directory.cdn_public_url}/#{Fog::HP.escape(key)}"
  end
end
get_http_url(key, expires, options = {}) click to toggle source

Get a temporary http url for a file.

required attributes: key @param key [String] the key of the file within the directory @param expires [String] number of seconds (since 1970-01-01 00:00) before url expires @param options [Hash] @return [String] url

# File lib/fog/hp/models/storage/files.rb, line 80
def get_http_url(key, expires, options = {})
  service.get_object_http_url(directory.key, key, expires, options)
end
get_https_url(key, expires, options = {}) click to toggle source

Get a temporary https url for a file.

required attributes: key @param key [String] the key of the file within the directory @param expires [String] number of seconds (since 1970-01-01 00:00) before url expires @param options [Hash] @return [String] url

# File lib/fog/hp/models/storage/files.rb, line 91
def get_https_url(key, expires, options = {})
  service.get_object_https_url(directory.key, key, expires, options)
end
get_url(key) click to toggle source
# File lib/fog/hp/models/storage/files.rb, line 65
def get_url(key)
  requires :directory
  if self.directory.public_url
    # escape the key to cover for special char. in object names
    "#{self.directory.public_url}/#{Fog::HP.escape(key)}"
  end
end
head(key, options = {}) click to toggle source
# File lib/fog/hp/models/storage/files.rb, line 111
def head(key, options = {})
  requires :directory
  data = service.head_object(directory.key, key)
  file_data = data.headers.merge({
    :key => key
  })
  new(file_data)
rescue Fog::Storage::HP::NotFound
  nil
end
new(attributes = {}) click to toggle source
Calls superclass method
# File lib/fog/hp/models/storage/files.rb, line 122
def new(attributes = {})
  requires :directory
  super({ :directory => directory }.merge!(attributes))
end