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