module Fog
module DNS
class Zerigo
class Real
# Update the parameters of a zone
# ==== Parameters
#
# * zone_id<~Integer>
# * options<~Hash> - optional paramaters
# * default_ttl<~Integer>
# * ns_type<~String>
# * ns1<~String> - required if ns_type == sec
# * nx_ttl<~Integer> -
# * slave_nameservers<~String> - required if ns_type == pri
# * axfr_ips<~String> - comma-separated list of IPs or IP blocks allowed to perform AXFRs
# * custom_nameservers<~String> - comma-separated list of custom nameservers
# * custom_ns<~String> - indicates if vanity (custom) nameservers are enabled for this domain
# * hostmaster<~String> - email of the DNS administrator or hostmaster
# * notes<~String> - notes about the domain
# * restrict_axfr<~String> - indicates if AXFR transfers should be restricted to IPs in axfr-ips
# * tag_list<~String> - List of all tags associated with this domain
#
# ==== Returns
# * response<~Excon::Response>:
# * 'status'<~Integer> - 200 for success
def update_zone( zone_id, options = {})
optional_tags= ''
options.each { |option, value|
case option
when :default_ttl
optional_tags+= "#{value}"
when :ns_type
optional_tags+= "#{value}"
when :ns1
optional_tags+= "#{value}"
when :nx_ttl
optional_tags+= "#{value}"
when :slave_nameservers
optional_tags+= "#{value}"
when :axfr_ips
optional_tags+= "#{value}"
when :custom_nameservers
optional_tags+= "#{value}"
when :custom_ns
optional_tags+= "#{value}"
when :hostmaster
optional_tags+= "#{value}"
when :notes
optional_tags+= "#{value}"
when :restrict_axfr
optional_tags+= "#{value}"
when :tag_list
optional_tags+= "#{value}"
end
}
request(
:body => %Q{#{optional_tags}},
:expects => 200,
:method => 'PUT',
:path => "/api/1.1/zones/#{zone_id}.xml"
)
end
end
end
end
end