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

107 lines
2.7 KiB
Ruby

require 'fog/core/model'
module Fog
module Compute
class AWS
class Volume < Fog::Model
identity :id, :aliases => 'volumeId'
attribute :attached_at, :aliases => 'attachTime'
attribute :availability_zone, :aliases => 'availabilityZone'
attribute :created_at, :aliases => 'createTime'
attribute :delete_on_termination, :aliases => 'deleteOnTermination'
attribute :device
attribute :server_id, :aliases => 'instanceId'
attribute :size
attribute :snapshot_id, :aliases => 'snapshotId'
attribute :state, :aliases => 'status'
attribute :tags, :aliases => 'tagSet'
def initialize(attributes = {})
# assign server first to prevent race condition with new_record?
self.server = attributes.delete(:server)
super
end
def destroy
requires :id
connection.delete_volume(id)
true
end
def ready?
state == 'available'
end
def save
raise Fog::Errors::Error.new('Resaving an existing object may create a duplicate') if identity
requires :availability_zone, :size
data = connection.create_volume(availability_zone, size, snapshot_id).body
new_attributes = data.reject {|key,value| key == 'requestId'}
merge_attributes(new_attributes)
if @server
self.server = @server
end
true
end
def server=(new_server)
if new_server
attach(new_server)
else
detach
end
end
def snapshots
requires :id
connection.snapshots(:volume => self)
end
private
def attachmentSet=(new_attachment_set)
merge_attributes(new_attachment_set.first || {})
end
def attach(new_server)
if new_record?
@server = new_server
self.availability_zone = new_server.availability_zone
elsif new_server
requires :device
@server = nil
self.server_id = new_server.id
connection.attach_volume(server_id, id, device)
reload
end
end
def detach
@server = nil
self.server_id = nil
unless new_record?
connection.detach_volume(id)
reload
end
end
def force_detach
@server = nil
self.server_id = nil
unless new_record?
connection.detach_volume(id, 'Force' => true)
reload
end
end
end
end
end
end