# File lib/fog/ninefold/models/compute/address.rb, line 32 def initialize(attributes={}) super end
# File lib/fog/ninefold/models/compute/address.rb, line 36 def destroy requires :identity self.jobid = extract_job_id(connection.disassociate_ip_address(:id => identity)) true end
# File lib/fog/ninefold/models/compute/address.rb, line 49 def disable_static_nat() self.jobid = extract_job_id(connection.disable_static_nat(:ipaddressid => identity)) true end
# File lib/fog/ninefold/models/compute/address.rb, line 42 def enable_static_nat(server) server.kind_of?(Integer) ? serverid = server : serverid = server.identity res = connection.enable_static_nat(:virtualmachineid => serverid, :ipaddressid => identity) reload to_boolean(res['success']) end
# File lib/fog/ninefold/models/compute/address.rb, line 61 def ready? if jobid && connection.query_async_job_result(:jobid => jobid)['jobstatus'] == 0 false else # No running job, we are ready. Refresh data. reload true end end
# File lib/fog/ninefold/models/compute/address.rb, line 54 def reload self.virtualmachinedisplayname = nil self.virtualmachineid = nil self.virtualmachinename = nil super end
# File lib/fog/ninefold/models/compute/address.rb, line 70 def save raise "Operation not supported" if self.identity requires :zoneid options = { :zoneid => zoneid, :networkid => networkid, :account => account, :domainid => domainid }.delete_if {|k,v| v.nil? || v == "" } data = connection.associate_ip_address(options) merge_attributes(data) true end
# File lib/fog/ninefold/models/compute/address.rb, line 87 def extract_job_id(job) if job.kind_of? Integer job else job['jobid'] || job['id'] end end
needed to hack around API inconsistencies
# File lib/fog/ninefold/models/compute/address.rb, line 96 def to_boolean(val) val && (val.to_s.match(/(true|t|yes|y|1)$/) != nil) end