wmap 2.4.4
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/CHANGELOG.md +141 -0
- data/LICENSE.txt +15 -0
- data/README.rdoc +98 -0
- data/TODO +13 -0
- data/bin/deprime +21 -0
- data/bin/distrust +38 -0
- data/bin/googleBot +23 -0
- data/bin/prime +21 -0
- data/bin/refresh +26 -0
- data/bin/run_tests +16 -0
- data/bin/spiderBot +26 -0
- data/bin/trust +38 -0
- data/bin/updateAll +57 -0
- data/bin/wadd +25 -0
- data/bin/wadds +26 -0
- data/bin/wcheck +28 -0
- data/bin/wdel +25 -0
- data/bin/wdump +21 -0
- data/bin/wmap +151 -0
- data/bin/wscan +32 -0
- data/data/cidrs +2 -0
- data/data/deactivated_sites +1 -0
- data/data/domains +2 -0
- data/data/hosts +1 -0
- data/data/prime_hosts +1 -0
- data/data/sites +2 -0
- data/data/sub_domains +2 -0
- data/demos/bruter.rb +27 -0
- data/demos/dns_brutes.rb +28 -0
- data/demos/filter_cidr.rb +18 -0
- data/demos/filter_crawls.rb +5 -0
- data/demos/filter_domain.rb +25 -0
- data/demos/filter_geoip.rb +26 -0
- data/demos/filter_known_services.rb +59 -0
- data/demos/filter_netinfo.rb +23 -0
- data/demos/filter_prime.rb +25 -0
- data/demos/filter_profiler.rb +3 -0
- data/demos/filter_redirection.rb +19 -0
- data/demos/filter_site.rb +40 -0
- data/demos/filter_siteip.rb +31 -0
- data/demos/filter_status.rb +17 -0
- data/demos/filter_timestamp.rb +23 -0
- data/demos/filter_url.rb +19 -0
- data/demos/new_fnd.rb +66 -0
- data/demos/nmap_parser.pl +138 -0
- data/demos/site_format.rb +18 -0
- data/demos/whois_domain.rb +78 -0
- data/dicts/GeoIP.dat +0 -0
- data/dicts/GeoIPASNum.dat +0 -0
- data/dicts/GeoLiteCity.dat +0 -0
- data/dicts/ccsld.txt +2646 -0
- data/dicts/cctld.txt +243 -0
- data/dicts/gtld.txt +25 -0
- data/dicts/hostnames-dict.big +1402 -0
- data/dicts/hostnames-dict.txt +101 -0
- data/lib/wmap/cidr_tracker.rb +327 -0
- data/lib/wmap/dns_bruter.rb +308 -0
- data/lib/wmap/domain_tracker/sub_domain.rb +142 -0
- data/lib/wmap/domain_tracker.rb +342 -0
- data/lib/wmap/geoip_tracker.rb +72 -0
- data/lib/wmap/google_search_scraper.rb +177 -0
- data/lib/wmap/host_tracker/primary_host.rb +130 -0
- data/lib/wmap/host_tracker.rb +550 -0
- data/lib/wmap/network_profiler.rb +144 -0
- data/lib/wmap/port_scanner.rb +208 -0
- data/lib/wmap/site_tracker/deactivated_site.rb +85 -0
- data/lib/wmap/site_tracker.rb +937 -0
- data/lib/wmap/url_checker.rb +314 -0
- data/lib/wmap/url_crawler.rb +381 -0
- data/lib/wmap/utils/domain_root.rb +184 -0
- data/lib/wmap/utils/logger.rb +53 -0
- data/lib/wmap/utils/url_magic.rb +343 -0
- data/lib/wmap/utils/utils.rb +333 -0
- data/lib/wmap/whois.rb +76 -0
- data/lib/wmap.rb +227 -0
- data/logs/wmap.log +17 -0
- data/ruby_whois_patches/base_cocca2.rb +149 -0
- data/ruby_whois_patches/kero.yachay.pe.rb +120 -0
- data/ruby_whois_patches/whois.PublicDomainRegistry.com.rb +124 -0
- data/ruby_whois_patches/whois.above.com.rb +61 -0
- data/ruby_whois_patches/whois.adamsnames.tc.rb +107 -0
- data/ruby_whois_patches/whois.aeda.net.ae.rb +105 -0
- data/ruby_whois_patches/whois.ai.rb +112 -0
- data/ruby_whois_patches/whois.arnes.si.rb +121 -0
- data/ruby_whois_patches/whois.ascio.com.rb +91 -0
- data/ruby_whois_patches/whois.cnnic.cn.rb +123 -0
- data/ruby_whois_patches/whois.corporatedomains.com.rb +67 -0
- data/ruby_whois_patches/whois.crsnic.net.rb +108 -0
- data/ruby_whois_patches/whois.denic.de.rb +174 -0
- data/ruby_whois_patches/whois.dk-hostmaster.dk.rb +120 -0
- data/ruby_whois_patches/whois.dns.be.rb +134 -0
- data/ruby_whois_patches/whois.dns.lu.rb +129 -0
- data/ruby_whois_patches/whois.dns.pl.rb +150 -0
- data/ruby_whois_patches/whois.dns.pt.rb +119 -0
- data/ruby_whois_patches/whois.domain.kg.rb +126 -0
- data/ruby_whois_patches/whois.domainregistry.my.rb +123 -0
- data/ruby_whois_patches/whois.domreg.lt.rb +110 -0
- data/ruby_whois_patches/whois.dot.tk.rb +140 -0
- data/ruby_whois_patches/whois.hkirc.hk.rb +121 -0
- data/ruby_whois_patches/whois.isnic.is.rb +130 -0
- data/ruby_whois_patches/whois.je.rb +119 -0
- data/ruby_whois_patches/whois.jprs.jp.rb +137 -0
- data/ruby_whois_patches/whois.kenic.or.ke.rb +140 -0
- data/ruby_whois_patches/whois.markmonitor.com.rb +118 -0
- data/ruby_whois_patches/whois.melbourneit.com.rb +58 -0
- data/ruby_whois_patches/whois.nic.as.rb +96 -0
- data/ruby_whois_patches/whois.nic.at.rb +109 -0
- data/ruby_whois_patches/whois.nic.ch.rb +141 -0
- data/ruby_whois_patches/whois.nic.cl.rb +117 -0
- data/ruby_whois_patches/whois.nic.ec.rb +157 -0
- data/ruby_whois_patches/whois.nic.im.rb +120 -0
- data/ruby_whois_patches/whois.nic.it.rb +170 -0
- data/ruby_whois_patches/whois.nic.lv.rb +116 -0
- data/ruby_whois_patches/whois.nic.ly.rb +127 -0
- data/ruby_whois_patches/whois.nic.mu.rb +27 -0
- data/ruby_whois_patches/whois.nic.mx.rb +123 -0
- data/ruby_whois_patches/whois.nic.net.sa.rb +111 -0
- data/ruby_whois_patches/whois.nic.or.kr.rb +101 -0
- data/ruby_whois_patches/whois.nic.tel.rb +129 -0
- data/ruby_whois_patches/whois.nic.tr.rb +133 -0
- data/ruby_whois_patches/whois.nic.us.rb +129 -0
- data/ruby_whois_patches/whois.nic.ve.rb +135 -0
- data/ruby_whois_patches/whois.norid.no.rb +127 -0
- data/ruby_whois_patches/whois.pandi.or.id.rb +118 -0
- data/ruby_whois_patches/whois.psi-usa.info.rb +63 -0
- data/ruby_whois_patches/whois.registro.br.rb +109 -0
- data/ruby_whois_patches/whois.registrygate.com.rb +55 -0
- data/ruby_whois_patches/whois.rrpproxy.net.rb +61 -0
- data/ruby_whois_patches/whois.sgnic.sg.rb +130 -0
- data/ruby_whois_patches/whois.srs.net.nz.rb +166 -0
- data/ruby_whois_patches/whois.tucows.com.rb +70 -0
- data/ruby_whois_patches/whois.twnic.net.tw.rb +133 -0
- data/settings/discovery_ports +24 -0
- data/settings/google_keywords.txt +9 -0
- data/settings/google_locator.txt +23 -0
- data/test/domain_tracker_test.rb +31 -0
- data/test/utils_test.rb +168 -0
- data/version.txt +13 -0
- data/wmap.gemspec +49 -0
- metadata +202 -0
@@ -0,0 +1,119 @@
|
|
1
|
+
#--
|
2
|
+
# Ruby Whois
|
3
|
+
#
|
4
|
+
# An intelligent pure Ruby WHOIS client and parser.
|
5
|
+
#
|
6
|
+
# Copyright (c) 2009-2012 Simone Carletti <weppos@weppos.net>
|
7
|
+
#++
|
8
|
+
|
9
|
+
|
10
|
+
require 'whois/record/parser/base'
|
11
|
+
|
12
|
+
|
13
|
+
module Whois
|
14
|
+
class Record
|
15
|
+
class Parser
|
16
|
+
|
17
|
+
# Parser for the whois.dns.pt server.
|
18
|
+
#
|
19
|
+
# @note This parser is just a stub and provides only a few basic methods
|
20
|
+
# to check for domain availability and get domain status.
|
21
|
+
# Please consider to contribute implementing missing methods.
|
22
|
+
#
|
23
|
+
# @see Whois::Record::Parser::Example
|
24
|
+
# The Example parser for the list of all available methods.
|
25
|
+
#
|
26
|
+
class WhoisDnsPt < Base
|
27
|
+
|
28
|
+
property_supported :status do
|
29
|
+
if content_for_scanner =~ /^Estado \/ Status:\s+(.+)\n/
|
30
|
+
case $1.downcase
|
31
|
+
when "active" then :registered
|
32
|
+
when "reserved" then :reserved
|
33
|
+
when "tech-pro" then :inactive
|
34
|
+
else
|
35
|
+
Whois.bug!(ParserError, "Unknown status `#{$1}'.")
|
36
|
+
end
|
37
|
+
else
|
38
|
+
:available
|
39
|
+
end
|
40
|
+
end
|
41
|
+
|
42
|
+
property_supported :available? do
|
43
|
+
!!(content_for_scanner =~ /^.* no match$/)
|
44
|
+
end
|
45
|
+
|
46
|
+
property_supported :registered? do
|
47
|
+
!available?
|
48
|
+
end
|
49
|
+
|
50
|
+
|
51
|
+
property_supported :created_on do
|
52
|
+
if content_for_scanner =~ / Creation Date .+?:\s+(.+)\n/
|
53
|
+
Time.utc(*$1.split("/").reverse)
|
54
|
+
end
|
55
|
+
end
|
56
|
+
|
57
|
+
property_not_supported :updated_on
|
58
|
+
|
59
|
+
property_supported :expires_on do
|
60
|
+
if content_for_scanner =~ / Expiration Date .+?:\s+(.+)\n/
|
61
|
+
Time.utc(*$1.split("/").reverse)
|
62
|
+
end
|
63
|
+
end
|
64
|
+
|
65
|
+
property_supported :nameservers do
|
66
|
+
content_for_scanner.scan(/Nameserver:\s(?:.+\t)?(.+?)\.\n/).flatten.map do |name|
|
67
|
+
Record::Nameserver.new(:name => name)
|
68
|
+
end
|
69
|
+
end
|
70
|
+
|
71
|
+
# The following methods are implemented by Yang Li on 01/24/2013
|
72
|
+
# ----------------------------------------------------------------------------
|
73
|
+
property_supported :domain do
|
74
|
+
return $1 if content_for_scanner =~ /Domain Name:\s+(.*)\n/i
|
75
|
+
end
|
76
|
+
|
77
|
+
property_not_supported :domain_id
|
78
|
+
|
79
|
+
property_not_supported :registrar
|
80
|
+
|
81
|
+
property_not_supported :admin_contacts
|
82
|
+
|
83
|
+
property_supported :registrant_contacts do
|
84
|
+
build_contact("Registrant", Whois::Record::Contact::TYPE_REGISTRANT)
|
85
|
+
end
|
86
|
+
|
87
|
+
property_supported :technical_contacts do
|
88
|
+
build_contact("Tech Contact", Whois::Record::Contact::TYPE_TECHNICAL)
|
89
|
+
end
|
90
|
+
|
91
|
+
property_supported :billing_contacts do
|
92
|
+
build_contact("Billing Contact", Whois::Record::Contact::TYPE_BILLING)
|
93
|
+
end
|
94
|
+
|
95
|
+
private
|
96
|
+
|
97
|
+
def build_contact(element, type)
|
98
|
+
reg=Record::Contact.new(:type => type)
|
99
|
+
if content_for_scanner.gsub(/\//,'') =~ /(.+#{element}\n(.+\n)+)\n/i
|
100
|
+
line_num=1
|
101
|
+
$1.split(%r{\n}).each do |line|
|
102
|
+
reg["name"]=line.strip if line_num==2
|
103
|
+
reg["organization"]=line.strip if line_num==2
|
104
|
+
reg["address"]=line.strip if line_num==3
|
105
|
+
reg["city"]=line.strip if line_num==4
|
106
|
+
reg["zip"]=line.strip if line_num==5
|
107
|
+
entry=line.split(':')
|
108
|
+
reg["email"]=entry[1].strip if entry[0]=~ /Email/i
|
109
|
+
line_num=line_num+1
|
110
|
+
end
|
111
|
+
end
|
112
|
+
return reg
|
113
|
+
end
|
114
|
+
# ----------------------------------------------------------------------------
|
115
|
+
|
116
|
+
end
|
117
|
+
end
|
118
|
+
end
|
119
|
+
end
|
@@ -0,0 +1,126 @@
|
|
1
|
+
#--
|
2
|
+
# Ruby Whois
|
3
|
+
#
|
4
|
+
# An intelligent pure Ruby WHOIS client and parser.
|
5
|
+
#
|
6
|
+
# Copyright (c) 2009-2012 Simone Carletti <weppos@weppos.net>
|
7
|
+
#++
|
8
|
+
|
9
|
+
|
10
|
+
require 'whois/record/parser/base'
|
11
|
+
|
12
|
+
|
13
|
+
module Whois
|
14
|
+
class Record
|
15
|
+
class Parser
|
16
|
+
|
17
|
+
#
|
18
|
+
# = whois.domain.kg
|
19
|
+
#
|
20
|
+
# Parser for the whois.domain.kg server.
|
21
|
+
#
|
22
|
+
# NOTE: This parser is just a stub and provides only a few basic methods
|
23
|
+
# to check for domain availability and get domain status.
|
24
|
+
# Please consider to contribute implementing missing methods.
|
25
|
+
# See WhoisNicIt parser for an explanation of all available methods
|
26
|
+
# and examples.
|
27
|
+
#
|
28
|
+
class WhoisDomainKg < Base
|
29
|
+
|
30
|
+
property_supported :status do
|
31
|
+
if available?
|
32
|
+
:available
|
33
|
+
else
|
34
|
+
:registered
|
35
|
+
end
|
36
|
+
end
|
37
|
+
|
38
|
+
property_supported :available? do
|
39
|
+
!!(content_for_scanner =~ /This domain is available for registration/)
|
40
|
+
end
|
41
|
+
|
42
|
+
property_supported :registered? do
|
43
|
+
!available?
|
44
|
+
end
|
45
|
+
|
46
|
+
|
47
|
+
property_supported :created_on do
|
48
|
+
if content_for_scanner =~ /Record created: (.+?)\n/
|
49
|
+
Time.parse($1)
|
50
|
+
end
|
51
|
+
end
|
52
|
+
|
53
|
+
property_supported :updated_on do
|
54
|
+
if content_for_scanner =~ /Record last updated on (.+?)\n/
|
55
|
+
Time.parse($1)
|
56
|
+
end
|
57
|
+
end
|
58
|
+
|
59
|
+
property_supported :expires_on do
|
60
|
+
if content_for_scanner =~ /Record expires on (.+?)\n/
|
61
|
+
Time.parse($1)
|
62
|
+
end
|
63
|
+
end
|
64
|
+
|
65
|
+
property_supported :nameservers do
|
66
|
+
if content_for_scanner =~ /Name servers in the listed order:\n\n((.+\n)+)\n/
|
67
|
+
$1.split("\n").map do |name|
|
68
|
+
Record::Nameserver.new(:name => name.downcase)
|
69
|
+
end
|
70
|
+
end
|
71
|
+
end
|
72
|
+
|
73
|
+
# The following methods are implemented by Yang Li on 02/13/2013
|
74
|
+
# ----------------------------------------------------------------------------
|
75
|
+
property_supported :domain do
|
76
|
+
return $1 if content_for_scanner =~ /^Domain\s+(.*)\n/i
|
77
|
+
end
|
78
|
+
|
79
|
+
property_not_supported :domain_id
|
80
|
+
|
81
|
+
property_supported :registrar do
|
82
|
+
reg=Record::Registrar.new
|
83
|
+
content_for_scanner.scan(/^(.+):\s+(.+)\n/).map do |entry|
|
84
|
+
reg["name"] = entry[1].strip if entry[0] =~ /Registrar/i
|
85
|
+
reg["organization"] = entry[1].strip if entry[0] =~ /Registrar/i
|
86
|
+
reg["url"] = entry[1].strip if entry[0] =~ /Referral URL/i
|
87
|
+
end
|
88
|
+
return reg
|
89
|
+
end
|
90
|
+
|
91
|
+
property_supported :admin_contacts do
|
92
|
+
build_contact("Administrative Contact", Whois::Record::Contact::TYPE_ADMIN)
|
93
|
+
end
|
94
|
+
|
95
|
+
property_not_supported :registrant_contacts
|
96
|
+
|
97
|
+
property_supported :technical_contacts do
|
98
|
+
build_contact("Technical Contact", Whois::Record::Contact::TYPE_TECHNICAL)
|
99
|
+
end
|
100
|
+
|
101
|
+
property_supported :billing_contacts do
|
102
|
+
build_contact("Billing Contact", Whois::Record::Contact::TYPE_BILLING)
|
103
|
+
end
|
104
|
+
|
105
|
+
private
|
106
|
+
|
107
|
+
def build_contact(element, type)
|
108
|
+
reg=Record::Contact.new(:type => type)
|
109
|
+
if content_for_scanner =~ /^#{element}:\n((.+\n)+)\n/i
|
110
|
+
$1.scan(/^(.+):(.+)\n/).map do |entry|
|
111
|
+
reg["id"]=entry[1] if entry[0] =~ /PID/i
|
112
|
+
reg["name"]=entry[1] if entry[0] =~ /Name/i
|
113
|
+
reg["address"]=entry[1] if entry[0] =~ /Address/i
|
114
|
+
reg["phone"]=entry[1] if entry[0] =~ /phone/i
|
115
|
+
reg["fax"]=entry[1] if entry[0] =~ /fax/i
|
116
|
+
reg["email"]=entry[1] if entry[0] =~ /Email/i
|
117
|
+
end
|
118
|
+
end
|
119
|
+
return reg
|
120
|
+
end
|
121
|
+
# ----------------------------------------------------------------------------
|
122
|
+
|
123
|
+
end
|
124
|
+
end
|
125
|
+
end
|
126
|
+
end
|
@@ -0,0 +1,123 @@
|
|
1
|
+
#--
|
2
|
+
# Ruby Whois
|
3
|
+
#
|
4
|
+
# An intelligent pure Ruby WHOIS client and parser.
|
5
|
+
#
|
6
|
+
# Copyright (c) 2009-2012 Simone Carletti <weppos@weppos.net>
|
7
|
+
#++
|
8
|
+
|
9
|
+
|
10
|
+
require 'whois/record/parser/base'
|
11
|
+
|
12
|
+
|
13
|
+
module Whois
|
14
|
+
class Record
|
15
|
+
class Parser
|
16
|
+
|
17
|
+
# Parser for the whois.domainregistry.my server.
|
18
|
+
#
|
19
|
+
# @note This parser is just a stub and provides only a few basic methods
|
20
|
+
# to check for domain availability and get domain status.
|
21
|
+
# Please consider to contribute implementing missing methods.
|
22
|
+
#
|
23
|
+
# @see Whois::Record::Parser::Example
|
24
|
+
# The Example parser for the list of all available methods.
|
25
|
+
class WhoisDomainregistryMy < Base
|
26
|
+
|
27
|
+
property_supported :status do
|
28
|
+
if available?
|
29
|
+
:available
|
30
|
+
else
|
31
|
+
:registered
|
32
|
+
end
|
33
|
+
end
|
34
|
+
|
35
|
+
property_supported :available? do
|
36
|
+
!!(content_for_scanner =~ /Domain Name [^ ]+ does not exist in data repository/)
|
37
|
+
end
|
38
|
+
|
39
|
+
property_supported :registered? do
|
40
|
+
!available?
|
41
|
+
end
|
42
|
+
|
43
|
+
|
44
|
+
property_supported :created_on do
|
45
|
+
if content_for_scanner =~ /\[Record Created\]\s+(.+?)\n/
|
46
|
+
Time.parse($1)
|
47
|
+
end
|
48
|
+
end
|
49
|
+
|
50
|
+
property_supported :updated_on do
|
51
|
+
if content_for_scanner =~ /\[Record Last Modified\]\s+(.+?)\n/
|
52
|
+
Time.parse($1)
|
53
|
+
end
|
54
|
+
end
|
55
|
+
|
56
|
+
property_supported :expires_on do
|
57
|
+
if content_for_scanner =~ /\[Record Expired\]\s+(.+?)\n/
|
58
|
+
Time.parse($1)
|
59
|
+
end
|
60
|
+
end
|
61
|
+
|
62
|
+
property_supported :nameservers do
|
63
|
+
content_for_scanner.scan(/\[(?:Primary|Secondary) Name Server\](?:.+?)\n(.+\n)/).flatten.map do |line|
|
64
|
+
name, ipv4 = line.strip.split(/\s+/)
|
65
|
+
Record::Nameserver.new(:name => name, :ipv4 => ipv4)
|
66
|
+
end
|
67
|
+
end
|
68
|
+
|
69
|
+
# The following methods are implemented by Yang Li on 02/05/2013
|
70
|
+
# ----------------------------------------------------------------------------
|
71
|
+
property_supported :domain do
|
72
|
+
return $1 if content_for_scanner =~ /Domain Name\]\s+(.*)\n/i
|
73
|
+
end
|
74
|
+
|
75
|
+
property_supported :domain_id do
|
76
|
+
return $1 if content_for_scanner =~ /Registration No\.\]\s+(.*)\n/i
|
77
|
+
end
|
78
|
+
|
79
|
+
property_not_supported :registrar
|
80
|
+
|
81
|
+
property_supported :admin_contacts do
|
82
|
+
build_contact("h", Whois::Record::Contact::TYPE_ADMIN)
|
83
|
+
end
|
84
|
+
|
85
|
+
property_supported :registrant_contacts do
|
86
|
+
build_contact("g", Whois::Record::Contact::TYPE_REGISTRANT)
|
87
|
+
end
|
88
|
+
|
89
|
+
property_supported :technical_contacts do
|
90
|
+
build_contact("j", Whois::Record::Contact::TYPE_TECHNICAL)
|
91
|
+
end
|
92
|
+
|
93
|
+
property_supported :billing_contacts do
|
94
|
+
build_contact("i", Whois::Record::Contact::TYPE_BILLING)
|
95
|
+
end
|
96
|
+
|
97
|
+
private
|
98
|
+
|
99
|
+
def build_contact(element, type)
|
100
|
+
reg=Record::Contact.new(:type => type)
|
101
|
+
if content_for_scanner =~ /^#{element}\s\[((.+\n)+)\n/i
|
102
|
+
line_num=0
|
103
|
+
$1.split(%r{\n}).each do |line|
|
104
|
+
reg["name"]=line.strip if line_num==1
|
105
|
+
reg["organization"]=line.strip if line_num==2
|
106
|
+
reg["address"]=line.strip if line_num==3
|
107
|
+
reg["city"]=line.strip if line_num==4
|
108
|
+
reg["state"]=line.strip if line_num==5
|
109
|
+
reg["country"]=line.strip if line_num==6
|
110
|
+
reg["email"]=line.strip if line =~ /\w+\@\w+\.\w+/
|
111
|
+
reg["phone"]=line.strip.split(' ')[1] if line =~ /\(Tel\)/i
|
112
|
+
reg["fax"]=line.strip.split(' ')[1] if line =~ /\(Fax\)/i
|
113
|
+
line_num=line_num+1
|
114
|
+
end
|
115
|
+
end
|
116
|
+
return reg
|
117
|
+
end
|
118
|
+
# ----------------------------------------------------------------------------
|
119
|
+
|
120
|
+
end
|
121
|
+
end
|
122
|
+
end
|
123
|
+
end
|
@@ -0,0 +1,110 @@
|
|
1
|
+
#--
|
2
|
+
# Ruby Whois
|
3
|
+
#
|
4
|
+
# An intelligent pure Ruby WHOIS client and parser.
|
5
|
+
#
|
6
|
+
# Copyright (c) 2009-2012 Simone Carletti <weppos@weppos.net>
|
7
|
+
#++
|
8
|
+
|
9
|
+
|
10
|
+
require 'whois/record/parser/base'
|
11
|
+
|
12
|
+
|
13
|
+
module Whois
|
14
|
+
class Record
|
15
|
+
class Parser
|
16
|
+
|
17
|
+
#
|
18
|
+
# = whois.domreg.lt parser
|
19
|
+
#
|
20
|
+
# Parser for the whois.domreg.lt server.
|
21
|
+
#
|
22
|
+
# NOTE: This parser is just a stub and provides only a few basic methods
|
23
|
+
# to check for domain availability and get domain status.
|
24
|
+
# Please consider to contribute implementing missing methods.
|
25
|
+
# See WhoisNicIt parser for an explanation of all available methods
|
26
|
+
# and examples.
|
27
|
+
#
|
28
|
+
class WhoisDomregLt < Base
|
29
|
+
|
30
|
+
property_supported :status do
|
31
|
+
if content_for_scanner =~ /Status:\s+(.*)\n/
|
32
|
+
$1.to_sym
|
33
|
+
end
|
34
|
+
end
|
35
|
+
|
36
|
+
property_supported :available? do
|
37
|
+
(status == :available)
|
38
|
+
end
|
39
|
+
|
40
|
+
property_supported :registered? do
|
41
|
+
!available?
|
42
|
+
end
|
43
|
+
|
44
|
+
|
45
|
+
property_supported :created_on do
|
46
|
+
if content_for_scanner =~ /Registered:\s+(.*)\n/
|
47
|
+
Time.parse($1)
|
48
|
+
end
|
49
|
+
end
|
50
|
+
|
51
|
+
property_not_supported :updated_on
|
52
|
+
|
53
|
+
property_not_supported :expires_on
|
54
|
+
|
55
|
+
|
56
|
+
property_supported :nameservers do
|
57
|
+
content_for_scanner.scan(/Nameserver:\s+(.+)\n/).flatten.map do |line|
|
58
|
+
if line =~ /(.+)\t\[(.+)\]/
|
59
|
+
Record::Nameserver.new(:name => $1, :ipv4 => $2)
|
60
|
+
else
|
61
|
+
Record::Nameserver.new(:name => line.strip)
|
62
|
+
end
|
63
|
+
end
|
64
|
+
end
|
65
|
+
|
66
|
+
# The following methods are implemented by Yang Li on 01/24/2013
|
67
|
+
# ----------------------------------------------------------------------------
|
68
|
+
property_supported :domain do
|
69
|
+
return $1 if content_for_scanner =~ /^Domain:\s+(.*)\n/i
|
70
|
+
end
|
71
|
+
|
72
|
+
property_not_supported :domain_id
|
73
|
+
|
74
|
+
property_supported :registrar do
|
75
|
+
reg=Record::Registrar.new
|
76
|
+
content_for_scanner.scan(/^(Registrar.*):\s+(.+)\n/).map do |entry|
|
77
|
+
reg["name"] = entry[1] if entry[0] == "Registrar"
|
78
|
+
reg["organization"] = entry[1] if entry[0] == "registrar"
|
79
|
+
reg["url"] = entry[1] if entry[0] =~ /website/i
|
80
|
+
end
|
81
|
+
return reg
|
82
|
+
end
|
83
|
+
|
84
|
+
property_not_supported :admin_contacts
|
85
|
+
|
86
|
+
property_supported :registrant_contacts do
|
87
|
+
build_contact("Contact", Whois::Record::Contact::TYPE_REGISTRANT)
|
88
|
+
end
|
89
|
+
|
90
|
+
property_not_supported :technical_contacts
|
91
|
+
|
92
|
+
property_not_supported :billing_contacts
|
93
|
+
|
94
|
+
private
|
95
|
+
|
96
|
+
def build_contact(element, type)
|
97
|
+
reg=Record::Contact.new(:type => type)
|
98
|
+
content_for_scanner.scan(/^#{element}(.+):\s+(.+)\n/).map do |entry|
|
99
|
+
reg["name"] = entry[1] if entry[0] =~ /organization/i
|
100
|
+
reg["organization"] = entry[1] if entry[0] =~ /organization/i
|
101
|
+
reg["email"] = entry[1] if entry[0] =~ /email/i
|
102
|
+
end
|
103
|
+
return reg
|
104
|
+
end
|
105
|
+
# ---------------------------------------------------------------------------
|
106
|
+
|
107
|
+
end
|
108
|
+
end
|
109
|
+
end
|
110
|
+
end
|
@@ -0,0 +1,140 @@
|
|
1
|
+
#--
|
2
|
+
# Ruby Whois
|
3
|
+
#
|
4
|
+
# An intelligent pure Ruby WHOIS client and parser.
|
5
|
+
#
|
6
|
+
# Copyright (c) 2009-2012 Simone Carletti <weppos@weppos.net>
|
7
|
+
#++
|
8
|
+
|
9
|
+
|
10
|
+
require 'whois/record/parser/base'
|
11
|
+
|
12
|
+
|
13
|
+
module Whois
|
14
|
+
class Record
|
15
|
+
class Parser
|
16
|
+
|
17
|
+
#
|
18
|
+
# = whois.dot.tk parser
|
19
|
+
#
|
20
|
+
# Parser for the whois.dot.tk server.
|
21
|
+
#
|
22
|
+
# NOTE: This parser is just a stub and provides only a few basic methods
|
23
|
+
# to check for domain availability and get domain status.
|
24
|
+
# Please consider to contribute implementing missing methods.
|
25
|
+
# See WhoisNicIt parser for an explanation of all available methods
|
26
|
+
# and examples.
|
27
|
+
#
|
28
|
+
class WhoisDotTk < Base
|
29
|
+
|
30
|
+
property_supported :status do
|
31
|
+
if available?
|
32
|
+
:available
|
33
|
+
else
|
34
|
+
:registered
|
35
|
+
end
|
36
|
+
end
|
37
|
+
|
38
|
+
property_supported :available? do
|
39
|
+
!!(content_for_scanner =~ /domain name not known/)
|
40
|
+
end
|
41
|
+
|
42
|
+
property_supported :registered? do
|
43
|
+
!available?
|
44
|
+
end
|
45
|
+
|
46
|
+
|
47
|
+
property_supported :created_on do
|
48
|
+
if content_for_scanner =~ /Domain registered:\s+(.*)\n/
|
49
|
+
DateTime.strptime($1, "%m/%d/%Y").to_time
|
50
|
+
end
|
51
|
+
end
|
52
|
+
|
53
|
+
property_not_supported :updated_on
|
54
|
+
|
55
|
+
property_supported :expires_on do
|
56
|
+
if content_for_scanner =~ /Record will expire on:\s+(.*)\n/
|
57
|
+
DateTime.strptime($1, "%m/%d/%Y").to_time
|
58
|
+
end
|
59
|
+
end
|
60
|
+
|
61
|
+
|
62
|
+
property_supported :nameservers do
|
63
|
+
if content_for_scanner =~ /Domain Nameservers:\n((.+\n)+)\s+\n/
|
64
|
+
$1.split("\n").map do |name|
|
65
|
+
Record::Nameserver.new(:name => name.strip.downcase)
|
66
|
+
end
|
67
|
+
end
|
68
|
+
end
|
69
|
+
|
70
|
+
# The following methods are implemented by Yang Li on 03/05/2013
|
71
|
+
# ----------------------------------------------------------------------------
|
72
|
+
property_supported :domain do
|
73
|
+
if content_for_scanner =~ /Domain name:\n(.+)\n\n/
|
74
|
+
return $1.strip
|
75
|
+
end
|
76
|
+
end
|
77
|
+
|
78
|
+
property_not_supported :domain_id
|
79
|
+
|
80
|
+
property_not_supported :registrar
|
81
|
+
|
82
|
+
property_supported :registrant_contacts do
|
83
|
+
build_contact("Organisation", Whois::Record::Contact::TYPE_REGISTRANT)
|
84
|
+
end
|
85
|
+
|
86
|
+
property_not_supported :admin_contacts
|
87
|
+
|
88
|
+
property_not_supported :technical_contacts
|
89
|
+
|
90
|
+
property_not_supported :billing_contacts
|
91
|
+
|
92
|
+
private
|
93
|
+
|
94
|
+
def build_contact(element, type)
|
95
|
+
reg=Record::Contact.new(:type => type)
|
96
|
+
if content_for_scanner =~ /#{element}:\n((.+\n)+)\n/
|
97
|
+
con=$1
|
98
|
+
contact=con.split(%r{\n})
|
99
|
+
reg["organization"]=contact.shift.strip
|
100
|
+
reg["name"]=contact.shift.strip
|
101
|
+
reg["phone"]=build_node("Phone",con)
|
102
|
+
reg["fax"]=build_node("Fax",con)
|
103
|
+
reg["email"]=build_node("E-mail",con)
|
104
|
+
myaddr=build_address(contact)
|
105
|
+
reg["address"]=myaddr["address"]
|
106
|
+
reg["city"]=myaddr["city"]
|
107
|
+
reg["zip"]=myaddr["zip"]
|
108
|
+
reg["state"]=myaddr["state"]
|
109
|
+
reg["country"]=myaddr["country"]
|
110
|
+
end
|
111
|
+
return reg
|
112
|
+
end
|
113
|
+
|
114
|
+
def build_node(element,context)
|
115
|
+
return $1.strip if context =~ /#{element}:(.+)\n/i
|
116
|
+
end
|
117
|
+
|
118
|
+
def build_address(context)
|
119
|
+
addr=Hash.new
|
120
|
+
line_num=2
|
121
|
+
context.each do |line|
|
122
|
+
line=line.chomp.strip
|
123
|
+
addr["address"]=line if line_num==2
|
124
|
+
addr["state"]=line if line_num==4
|
125
|
+
addr["country"]=line if line_num==5
|
126
|
+
if line_num==3 && !line.nil?
|
127
|
+
zips=line.split(' ')
|
128
|
+
addr["city"]=zips.pop
|
129
|
+
addr["zip"]=zips.join(' ')
|
130
|
+
end
|
131
|
+
line_num=line_num+1
|
132
|
+
end
|
133
|
+
return addr
|
134
|
+
end
|
135
|
+
# ----------------------------------------------------------------------------
|
136
|
+
end
|
137
|
+
|
138
|
+
end
|
139
|
+
end
|
140
|
+
end
|