class Fog::DNS::Rackspace::Zones
Public Instance Methods
all(options={})
click to toggle source
List all domains. Return by default a maximum of 100 items @param [Hash] options Options to pass to the underlying API call @option options [String] :name search for domains containing the given substring @option options [Integer] :limit number of records to return @option options [Integer] :offset starting offset of records to return
# File lib/fog/rackspace/models/dns/zones.rb, line 18 def all(options={}) clear body = service.list_domains(options).body merge_attributes(body) load(body['domains']) end
each() { |zone| ... }
click to toggle source
# File lib/fog/rackspace/models/dns/zones.rb, line 27 def each return self unless block_given? params = { :limit => 100} # prime loop (100 Records is default page size for Rackspace Cloud) while params body = service.list_domains(params).body subset = dup.load(body["domains"]) self.merge_attributes(body) params = next_params(body) subset.each_zone_this_page {|zone| yield zone} end self end
Also aliased as: each_zone_this_page
get(zone_id)
click to toggle source
# File lib/fog/rackspace/models/dns/zones.rb, line 43 def get(zone_id) if zone_id.nil? or zone_id.to_s.empty? return nil end data = service.list_domain_details(zone_id).body new(data) rescue Fog::DNS::Rackspace::NotFound nil #Accessing a valid (but other customer's) id returns a 503 error rescue Fog::Rackspace::Errors::ServiceUnavailable nil end
Private Instance Methods
next_params(body)
click to toggle source
# File lib/fog/rackspace/models/dns/zones.rb, line 58 def next_params(body) # return if we don't have any links return nil unless body && body['links'] #return if links don't contain a href for the next page next_link = body['links'].find {|h| h['rel'] == 'next'} return nil unless next_link && next_link['href'] url = next_link['href'] uri = URI.parse url return nil unless uri.query CGI.parse uri.query end