Class: Fog::Storage::Atmos::File

Inherits:
Model
  • Object
show all
Defined in:
lib/fog/atmos/models/storage/file.rb

Instance Attribute Summary

Attributes inherited from Model

#collection, #service

Instance Method Summary collapse

Methods inherited from Model

#initialize, #inspect, #reload, #symbolize_keys, #to_json, #wait_for

Methods included from Attributes::ClassMethods

#_load, #aliases, #attribute, #attributes, #identity, #ignore_attributes, #ignored_attributes

Methods included from Core::DeprecatedConnectionAccessors

#connection, #connection=, #prepare_service_value

Methods included from Attributes::InstanceMethods

#_dump, #attributes, #dup, #identity, #identity=, #merge_attributes, #new_record?, #persisted?, #requires, #requires_one

Constructor Details

This class inherits a constructor from Fog::Model

Instance Method Details

#bodyObject



15
16
17
18
19
20
21
# File 'lib/fog/atmos/models/storage/file.rb', line 15

def body
  attributes[:body] ||= if objectid
    collection.get(identity).body
  else
    ''
  end
end

#body=(new_body) ⇒ Object



23
24
25
# File 'lib/fog/atmos/models/storage/file.rb', line 23

def body=(new_body)
  attributes[:body] = new_body
end

#copy(target_directory_key, target_file_key, options = {}) ⇒ Object



31
32
33
34
35
36
37
# File 'lib/fog/atmos/models/storage/file.rb', line 31

def copy(target_directory_key, target_file_key, options={})
  target_directory = service.directories.new(:key => target_directory_key)
  target_directory.files.create(
    :key => target_file_key,
    :body => body
  )
end

#destroyObject



39
40
41
42
43
# File 'lib/fog/atmos/models/storage/file.rb', line 39

def destroy
  requires :directory, :key
  service.delete_namespace([directory.key, key].join('/'))
  true
end

#directoryObject



27
28
29
# File 'lib/fog/atmos/models/storage/file.rb', line 27

def directory
  @directory
end

#public=(new_public) ⇒ Object

def owner=(new_owner)

if new_owner
  attributes[:owner] = {
    :display_name => new_owner['DisplayName'],
    :id           => new_owner['ID']
  }
end

end



54
55
56
# File 'lib/fog/atmos/models/storage/file.rb', line 54

def public=(new_public)
  # NOOP - we don't need to flag files as public, getting the public URL for a file handles it.
end

#public_url(expires = (Time.now + 5 * 365 * 24 * 60 * 60)) ⇒ Object

By default, expire in 5 years



59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
# File 'lib/fog/atmos/models/storage/file.rb', line 59

def public_url(expires = (Time.now + 5 * 365 * 24 * 60 * 60))
  file = directory.files.head(key)
  self.objectid = if file.present? then file.attributes['x-emc-meta'].scan(/objectid=(\w+),/).flatten[0] else nil end
  if self.objectid.present?
    uri = URI::HTTP.build(:scheme => service.ssl? ? "http" : "https" , :host => service.host, :port => service.port.to_i, :path => "/rest/objects/#{self.objectid}" )

    sb = "GET\n"
    sb += uri.path.downcase + "\n"
    sb += service.uid + "\n"
    sb += String(expires.to_i())

    signature = service.sign( sb )
    uri.query = "uid=#{CGI::escape(service.uid)}&expires=#{expires.to_i()}&signature=#{CGI::escape(signature)}"
    uri.to_s
  else
    nil
  end
end

#save(options = {}) ⇒ Object



78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
# File 'lib/fog/atmos/models/storage/file.rb', line 78

def save(options = {})
  requires :body, :directory, :key
  directory.kind_of?(Directory) ? ns = directory.key : ns = directory
  ns += key
  options[:headers] ||= {}
  options[:headers]['Content-Type'] = content_type if content_type
  options[:body] = body
  begin
    data = service.post_namespace(ns, options)
    self.objectid = data.headers['location'].split('/')[-1]
  rescue => error
    if error.message =~ /The resource you are trying to create already exists./
      data = service.put_namespace(ns, options)
    else
      raise error
    end
  end
  # merge_attributes(data.headers)
  true
end