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/zerigo/requests/dns/get_zone.rb
2014-02-19 12:30:59 +00:00

66 lines
1.9 KiB
Ruby

module Fog
module DNS
class Zerigo
class Real
require 'fog/zerigo/parsers/dns/get_zone'
# Get details of a DNS zone. The response is similar to list_zones, with the
# addition of hosts-count and possibly hosts.
#
# ==== Parameters
# * zone<~String> - Either the zone ID or the zone name (ie sample-domain.com)
#
# ==== Returns
# * response<~Excon::Response>:
# * body<~Hash>:
# * 'default-ttl'<~Integer>
# * 'id'<~Integer>
# * 'nx-ttl'<~Integer>
# * 'hosts-count'<~Integer>
# * 'created-at'<~String>
# * 'custom-nameservers'<~String>
# * 'custom-ns'<~String>
# * 'domain'<~String>
# * 'hostmaster'<~String>
# * 'notes'<~String>
# * 'ns1'<~String>
# * 'ns-type'<~String>
# * 'slave-nameservers'<~String>
# * 'tag-list'<~String>
# * 'updated-at'<~String>
# * 'hosts'<~Array> - a list of all host records. For the format of host info, see get_host()
# * 'axfr-ips'<~String>
# * 'restrict-axfr'<~String>
# * 'status'<~Integer> - 200 indicates success
def get_zone(zone_id_or_domain)
request(
:expects => 200,
:method => 'GET',
:parser => Fog::Parsers::DNS::Zerigo::GetZone.new,
:path => "/api/1.1/zones/#{zone_id_or_domain}.xml"
)
end
end
class Mock # :nodoc:all
def get_zone(zone_id_or_domain)
zone = find_by_zone_id(zone_id_or_domain) || find_by_domain(zone_id_or_domain)
response = Excon::Response.new
if zone
response.status = 200
response.body = zone
else
response.status = 404
end
response
end
end
end
end
end