#-- # Ruby Whois # # An intelligent pure Ruby WHOIS client and parser. # # Copyright (c) 2009-2022 Simone Carletti #++ require_relative 'base' module Whois class Parsers # # = whois.museum parser # # Parser for the whois.museum 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 WhoisMuseum < Base property_supported :status do if available? :available else :registered end end property_supported :available? do !!(content_for_scanner =~ /NOT FOUND/) end property_supported :registered? do !available? end property_supported :created_on do if content_for_scanner =~ /Created On:(.*?)\n/ parse_time(::Regexp.last_match(1)) end end property_supported :updated_on do if content_for_scanner =~ /Last Updated On:(.*?)\n/ parse_time(::Regexp.last_match(1)) end end property_supported :expires_on do if content_for_scanner =~ /Expiration Date:(.*?)\n/ parse_time(::Regexp.last_match(1)) end end # Nameservers are listed in the following formats: # # Name Server: nic.frd.se # Name Server: nic.museum 130.242.24.5 # property_supported :nameservers do content_for_scanner.scan(/Name Server:\s+(.+)\n/).flatten.map do |line| name, ipv4 = line.split(/\s+/) Parser::Nameserver.new(:name => name, :ipv4 => ipv4) end end end end end