# File lib/fog/ninefold/models/compute/address.rb, line 30 def initialize(attributes={}) super end
# File lib/fog/ninefold/models/compute/address.rb, line 34 def destroy requires :identity self.jobid = extract_job_id(service.disassociate_ip_address(:id => identity)) true end
# File lib/fog/ninefold/models/compute/address.rb, line 47 def disable_static_nat() self.jobid = extract_job_id(service.disable_static_nat(:ipaddressid => identity)) true end
# File lib/fog/ninefold/models/compute/address.rb, line 40 def enable_static_nat(server) server.kind_of?(Integer) ? serverid = server : serverid = server.identity res = service.enable_static_nat(:virtualmachineid => serverid, :ipaddressid => identity) reload to_boolean(res['success']) end
# File lib/fog/ninefold/models/compute/address.rb, line 59 def ready? if jobid && service.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 52 def reload self.virtualmachinedisplayname = nil self.virtualmachineid = nil self.virtualmachinename = nil super end
# File lib/fog/ninefold/models/compute/address.rb, line 68 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 = service.associate_ip_address(options) merge_attributes(data) true end
# File lib/fog/ninefold/models/compute/address.rb, line 85 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 94 def to_boolean(val) val && (val.to_s.match(/(true|t|yes|y|1)$/) != nil) end