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

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

Instance Method Summary collapse

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.



34
35
36
37
# File 'lib/fog/aws/models/compute/volumes.rb', line 34

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

Instance Method Details

#all(filters_arg = 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.



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

def all(filters_arg = filters)
  unless filters_arg.is_a?(Hash)
    Fog::Logger.deprecation("all with #{filters_arg.class} param is deprecated, use all('volume-id' => []) instead [light_black](#{caller.first})[/]")
    filters_arg = {'volume-id' => [*filters_arg]}
  end
  filters = filters_arg
  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={}
>


100
101
102
103
104
# File 'lib/fog/aws/models/compute/volumes.rb', line 100

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

#new(attributes = {}) ⇒ Object



106
107
108
109
110
111
112
# File 'lib/fog/aws/models/compute/volumes.rb', line 106

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