Sha256: 5ff8d6e46f7e41ab60aa52ad5e2c216481428a891737c9ba94ff175c5b30d90b
Contents?: true
Size: 1.96 KB
Versions: 10
Compression:
Stored size: 1.96 KB
Contents
# # = Ruby Whois # # An intelligent pure Ruby WHOIS client and parser. # # # Category:: Net # Package:: Whois # Author:: Simone Carletti <weppos@weppos.net> # License:: MIT License # #-- # #++ require 'whois/answer/parser/base' module Whois class Answer class Parser # # = whois.nic.coop parser # # Parser for the whois.nic.coop 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 WhoisNicCoop < Base property_supported :status do @status ||= if content_for_scanner =~ /Status:\s+(.+?)\n/ case $1.downcase when "ok" then :registered else Whois.bug!(ParserError, "Unknown status `#{$1}'.") end else :available end end property_supported :available? do @available ||= !!(content_for_scanner =~ /No domain records were found to match/) end property_supported :registered? do @registered ||= !available? end property_supported :created_on do @created_on ||= if content_for_scanner =~ /Created:\s+(.*)\n/ Time.parse($1) end end property_supported :updated_on do @updated_on ||= if content_for_scanner =~ /Last updated:\s+(.*)\n/ Time.parse($1) end end property_supported :expires_on do @expires_on ||= if content_for_scanner =~ /Expiry Date:\s+(.*)\n/ Time.parse($1) end end property_supported :nameservers do @nameservers ||= content_for_scanner.scan(/Host Name:\s+(.+)\n/).flatten end end end end end
Version data entries
10 entries across 10 versions & 1 rubygems