Class: Fog::Compute::AWS::Volumes

Inherits:
Fog::Collection show all
Defined in:
lib/fog/aws/models/compute/volumes.rb

Instance Attribute Summary

Attributes inherited from Fog::Collection

#service

Instance Method Summary collapse

Methods inherited from Fog::Collection

#clear, #create, #destroy, #inspect, #load, model, #model, #reload, #table, #to_json

Methods included from Attributes::ClassMethods

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

Methods included from Fog::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

#initialize(attributes) ⇒ Volumes

Used to create a volume. There are 3 arguments and availability_zone and size are required. You can generate a new key_pair as follows: AWS.volumes.create(:availability_zone => ‘us-east-1a’, :size => 10)

Returns

<Fog::AWS::Compute::Volume

id="vol-1e2028b9",
attached_at=nil,
availability_zone="us-east-1a",
created_at=Tue Nov 23 23:30:29 -0500 2010,
delete_on_termination=nil,
device=nil,
server_id=nil,
size=10,
snapshot_id=nil,
state="creating",
tags=nil

>

The volume can be retrieved by running AWS.volumes.get(“vol-1e2028b9”). See get method below.



37
38
39
40
# File 'lib/fog/aws/models/compute/volumes.rb', line 37

def initialize(attributes)
  self.filters ||= {}
  super
end

Instance Method Details

#all(filters = filters) ⇒ Object

Used to return all volumes. AWS.volumes.all

Returns

>>AWS.volumes.all <Fog::AWS::Compute::Volume

id="vol-1e2028b9",
attached_at=nil,
availability_zone="us-east-1a",
created_at=Tue Nov 23 23:30:29 -0500 2010,
delete_on_termination=nil,
device=nil,
server_id=nil,
size=10,
snapshot_id=nil,
state="creating",
tags=nil

>

The volume can be retrieved by running AWS.volumes.get(“vol-1e2028b9”). See get method below.



65
66
67
68
69
70
71
72
73
74
75
76
77
# File 'lib/fog/aws/models/compute/volumes.rb', line 65

def all(filters = filters)
  unless filters.is_a?(Hash)
    Fog::Logger.deprecation("all with #{filters.class} param is deprecated, use all('volume-id' => []) instead [light_black](#{caller.first})[/]")
    filters = {'volume-id' => [*filters]}
  end
  self.filters = filters
  data = service.describe_volumes(filters).body
  load(data['volumeSet'])
  if server
    self.replace(self.select {|volume| volume.server_id == server.id})
  end
  self
end

#get(volume_id) ⇒ Object

Used to retrieve a volume volume_id is required to get the associated volume information.

You can run the following command to get the details: AWS.volumes.get(“vol-1e2028b9”)

Returns

>> AWS.volumes.get(“vol-1e2028b9”) <Fog::AWS::Compute::Volume

  id="vol-1e2028b9",
  attached_at=nil,
  availability_zone="us-east-1a",
  created_at=Tue Nov 23 23:30:29 -0500 2010,
  delete_on_termination=nil,
  device=nil,
  server_id=nil,
  size=10,
  snapshot_id=nil,
  state="available",
  tags={}
>


103
104
105
106
107
# File 'lib/fog/aws/models/compute/volumes.rb', line 103

def get(volume_id)
  if volume_id
    self.class.new(:service => service).all('volume-id' => volume_id).first
  end
end

#new(attributes = {}) ⇒ Object



109
110
111
112
113
114
115
# File 'lib/fog/aws/models/compute/volumes.rb', line 109

def new(attributes = {})
  if server
    super({ :server => server }.merge!(attributes))
  else
    super
  end
end