1
0
Fork 0
mirror of https://github.com/fog/fog-aws.git synced 2022-11-09 13:50:52 -05:00
fog--fog-aws/lib/fog/aws/models/compute/volumes.rb

118 lines
3.4 KiB
Ruby
Raw Normal View History

require 'fog/core/collection'
require 'fog/aws/models/compute/volume'
module Fog
module Compute
class Aws
class Volumes < Fog::Collection
attribute :filters
attribute :server
model Fog::Compute::AWS::Volume
# 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.
#
def initialize(attributes)
self.filters ||= {}
super
end
# 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.
#
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
# 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={}
# >
#
def get(volume_id)
if volume_id
self.class.new(:service => service).all('volume-id' => volume_id).first
end
end
def new(attributes = {})
if server
super({ :server => server }.merge!(attributes))
else
super
end
end
end
end
end
end