Sha256: 15fcd730a654466509a34222d83a2c1b36a34deb0dccd368fa9227193b1f3610
Contents?: true
Size: 1.97 KB
Versions: 4
Compression:
Stored size: 1.97 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.cira.ca parser # # Parser for the whois.cira.ca 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 WhoisCiraCa < Base property_supported :status do @status ||= if content_for_scanner =~ /Domain status:\s+(.*?)\n/ case $1.downcase.to_sym when :exist then :registered when :avail then :available end end end property_supported :available? do @available ||= (status == :available) end property_supported :registered? do !available? end property_supported :created_on do @created_on ||= if content_for_scanner =~ /Approval date:\s+(.*?)\n/ Time.parse($1) end end property_supported :updated_on do @updated_on ||= if content_for_scanner =~ /Updated date:\s+(.*?)\n/ Time.parse($1) end end property_supported :expires_on do @expires_on ||= if content_for_scanner =~ /Renewal date:\s+(.*?)\n/ Time.parse($1) end end property_supported :nameservers do @nameservers ||= if content_for_scanner =~ /Name servers:\n((?:\s+([^\s]+)\s+([^\s]+)\n)+)/ $1.split("\n").map { |value| value.split(" ").first } end @nameservers ||= [] end end end end end
Version data entries
4 entries across 4 versions & 1 rubygems