Class: Fog::Aliyun::Storage::Files

Inherits:
Collection
  • Object
show all
Defined in:
lib/fog/aliyun/models/storage/files.rb

Instance Method Summary collapse

Instance Method Details

#all(options = {}) ⇒ Object



23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
# 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

#eachObject



47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
# 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

#each_file_this_pageObject



45
# File 'lib/fog/aliyun/models/storage/files.rb', line 45

alias_method :each_file_this_page, :each

#get(key, options = {}, &block) ⇒ Object



63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
# 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
    case error.http_code.to_i
      when 404
        nil
      else
        raise(error)
    end
  end
end

#get_http_url(key, expires, options = {}) ⇒ Object

Parameters:

  • options (Hash) (defaults to: {})

    No need to use



90
91
92
93
# File 'lib/fog/aliyun/models/storage/files.rb', line 90

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 = {}) ⇒ Object

Parameters:

  • options (Hash) (defaults to: {})

    No need to use



96
97
98
99
# File 'lib/fog/aliyun/models/storage/files.rb', line 96

def get_https_url(key, expires, options = {})
  requires :directory
  service.get_object_https_url_public(directory.key, key, expires)
end

#get_url(key, options = {}) ⇒ Object

Parameters:

  • options (Hash) (defaults to: {})

    No need to use



84
85
86
87
# File 'lib/fog/aliyun/models/storage/files.rb', line 84

def get_url(key, options = {})
  requires :directory
  service.get_object_http_url_public(directory.key, key, 3600)
end

#head(key, options = {}) ⇒ Object



101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
# File 'lib/fog/aliyun/models/storage/files.rb', line 101

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
    case error.http_code.to_i
      when 404
        nil
      else
        raise(error)
    end
  end
end

#new(attributes = {}) ⇒ Object



120
121
122
123
# File 'lib/fog/aliyun/models/storage/files.rb', line 120

def new(attributes = {})
  requires :directory
  super({ :directory => directory }.merge!(attributes))
end

#normalize_headers(data) ⇒ Object



125
126
127
128
# File 'lib/fog/aliyun/models/storage/files.rb', line 125

def normalize_headers(data)
  data.headers[:last_modified] = Time.parse(data.headers[:last_modified])
  data.headers[:etag] = data.headers[:etag].gsub('"','')
end