#-- # Ruby Whois # # An intelligent pure Ruby WHOIS client and parser. # # Copyright (c) 2009-2012 Simone Carletti #++ require 'whois/record/parser/base' module Whois class Record class Parser # # = whois.domain.kg # # Parser for the whois.domain.kg server. # # NOTE: This parser is just a stub and provides only a few basic methods # to check for domain availability and get domain status. # Please consider to contribute implementing missing methods. # See WhoisNicIt parser for an explanation of all available methods # and examples. # class WhoisDomainKg < Base property_supported :status do if available? :available else :registered end end property_supported :available? do !!(content_for_scanner =~ /This domain is available for registration/) end property_supported :registered? do !available? end property_supported :created_on do if content_for_scanner =~ /Record created: (.+?)\n/ Time.parse($1) end end property_supported :updated_on do if content_for_scanner =~ /Record last updated on (.+?)\n/ Time.parse($1) end end property_supported :expires_on do if content_for_scanner =~ /Record expires on (.+?)\n/ Time.parse($1) end end property_supported :nameservers do if content_for_scanner =~ /Name servers in the listed order:\n\n((.+\n)+)\n/ $1.split("\n").map do |name| Record::Nameserver.new(:name => name.downcase) end end end # The following methods are implemented by Yang Li on 02/13/2013 # ---------------------------------------------------------------------------- property_supported :domain do return $1 if content_for_scanner =~ /^Domain\s+(.*)\n/i end property_not_supported :domain_id property_supported :registrar do reg=Record::Registrar.new content_for_scanner.scan(/^(.+):\s+(.+)\n/).map do |entry| reg["name"] = entry[1].strip if entry[0] =~ /Registrar/i reg["organization"] = entry[1].strip if entry[0] =~ /Registrar/i reg["url"] = entry[1].strip if entry[0] =~ /Referral URL/i end return reg end property_supported :admin_contacts do build_contact("Administrative Contact", Whois::Record::Contact::TYPE_ADMIN) end property_not_supported :registrant_contacts property_supported :technical_contacts do build_contact("Technical Contact", Whois::Record::Contact::TYPE_TECHNICAL) end property_supported :billing_contacts do build_contact("Billing Contact", Whois::Record::Contact::TYPE_BILLING) end private def build_contact(element, type) reg=Record::Contact.new(:type => type) if content_for_scanner =~ /^#{element}:\n((.+\n)+)\n/i $1.scan(/^(.+):(.+)\n/).map do |entry| reg["id"]=entry[1] if entry[0] =~ /PID/i reg["name"]=entry[1] if entry[0] =~ /Name/i reg["address"]=entry[1] if entry[0] =~ /Address/i reg["phone"]=entry[1] if entry[0] =~ /phone/i reg["fax"]=entry[1] if entry[0] =~ /fax/i reg["email"]=entry[1] if entry[0] =~ /Email/i end end return reg end # ---------------------------------------------------------------------------- end end end end