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/google/models/compute/disk.rb
2013-10-25 16:03:07 -07:00

115 lines
3.2 KiB
Ruby

require 'fog/core/model'
module Fog
module Compute
class Google
class Disk < Fog::Model
identity :name
attribute :kind, :aliases => 'kind'
attribute :id, :aliases => 'id'
attribute :creation_timestamp, :aliases => 'creationTimestamp'
attribute :zone_name, :aliases => 'zone'
attribute :status, :aliases => 'status'
attribute :description, :aliases => 'description'
attribute :size_gb, :aliases => 'sizeGb'
attribute :self_link, :aliases => 'selfLink'
attribute :source_image, :aliases => 'sourceImage'
attribute :source_snapshot, :aliases => 'sourceSnapshot'
attribute :source_snapshot_id, :aliases => 'sourceSnapshot'
def save
requires :name
requires :zone_name
options = {}
if source_image.nil?
options['sourceSnapshot'] = source_snapshot
end
options['sizeGb'] = size_gb
data = service.insert_disk(name, zone_name, source_image, options).body
data = service.backoff_if_unfound {service.get_disk(name, zone_name).body}
service.disks.merge_attributes(data)
end
def destroy
requires :name, :zone_name
service.delete_disk(name, zone_name)
end
def zone
if self.zone_name.is_a? String
service.get_zone(self.zone_name.split('/')[-1]).body["name"]
elsif zone_name.is_a? Excon::Response
service.get_zone(zone_name.body["name"]).body["name"]
else
self.zone_name
end
end
def get_as_boot_disk(writable=true)
mode = writable ? 'READ_WRITE' : 'READ_ONLY'
return {
'name' => name,
'type' => 'PERSISTENT',
'boot' => true,
'source' => self_link,
'mode' => mode
}
end
def ready?
data = service.get_disk(self.name, self.zone_name).body
data['zone_name'] = self.zone_name
self.merge_attributes(data)
self.status == RUNNING_STATE
end
def reload
requires :identity
requires :zone_name
return unless data = begin
collection.get(identity, zone_name)
rescue Excon::Errors::SocketError
nil
end
new_attributes = data.attributes
merge_attributes(new_attributes)
self
end
def create_snapshot(snap_name, snap_desc)
requires :name
requires :zone_name
if snap_name.nil? or snap_name.empty?
raise ArgumentError, 'Invalid snapshot name'
end
options = {
'name' => snap_name,
'description' => snap_desc,
}
service.insert_snapshot(name, self.zone, service.project, options)
data = service.backoff_if_unfound {
service.get_snapshot(snap_name, service.project).body
}
service.snapshots.merge_attributes(data)
# Try to return the representation of the snapshot we created
service.snapshots.get(snap_name)
end
RUNNING_STATE = "READY"
end
end
end
end