wmap 2.4.4

Sign up to get free protection for your applications and to get access to all the features.
Files changed (141) hide show
  1. checksums.yaml +7 -0
  2. data/CHANGELOG.md +141 -0
  3. data/LICENSE.txt +15 -0
  4. data/README.rdoc +98 -0
  5. data/TODO +13 -0
  6. data/bin/deprime +21 -0
  7. data/bin/distrust +38 -0
  8. data/bin/googleBot +23 -0
  9. data/bin/prime +21 -0
  10. data/bin/refresh +26 -0
  11. data/bin/run_tests +16 -0
  12. data/bin/spiderBot +26 -0
  13. data/bin/trust +38 -0
  14. data/bin/updateAll +57 -0
  15. data/bin/wadd +25 -0
  16. data/bin/wadds +26 -0
  17. data/bin/wcheck +28 -0
  18. data/bin/wdel +25 -0
  19. data/bin/wdump +21 -0
  20. data/bin/wmap +151 -0
  21. data/bin/wscan +32 -0
  22. data/data/cidrs +2 -0
  23. data/data/deactivated_sites +1 -0
  24. data/data/domains +2 -0
  25. data/data/hosts +1 -0
  26. data/data/prime_hosts +1 -0
  27. data/data/sites +2 -0
  28. data/data/sub_domains +2 -0
  29. data/demos/bruter.rb +27 -0
  30. data/demos/dns_brutes.rb +28 -0
  31. data/demos/filter_cidr.rb +18 -0
  32. data/demos/filter_crawls.rb +5 -0
  33. data/demos/filter_domain.rb +25 -0
  34. data/demos/filter_geoip.rb +26 -0
  35. data/demos/filter_known_services.rb +59 -0
  36. data/demos/filter_netinfo.rb +23 -0
  37. data/demos/filter_prime.rb +25 -0
  38. data/demos/filter_profiler.rb +3 -0
  39. data/demos/filter_redirection.rb +19 -0
  40. data/demos/filter_site.rb +40 -0
  41. data/demos/filter_siteip.rb +31 -0
  42. data/demos/filter_status.rb +17 -0
  43. data/demos/filter_timestamp.rb +23 -0
  44. data/demos/filter_url.rb +19 -0
  45. data/demos/new_fnd.rb +66 -0
  46. data/demos/nmap_parser.pl +138 -0
  47. data/demos/site_format.rb +18 -0
  48. data/demos/whois_domain.rb +78 -0
  49. data/dicts/GeoIP.dat +0 -0
  50. data/dicts/GeoIPASNum.dat +0 -0
  51. data/dicts/GeoLiteCity.dat +0 -0
  52. data/dicts/ccsld.txt +2646 -0
  53. data/dicts/cctld.txt +243 -0
  54. data/dicts/gtld.txt +25 -0
  55. data/dicts/hostnames-dict.big +1402 -0
  56. data/dicts/hostnames-dict.txt +101 -0
  57. data/lib/wmap/cidr_tracker.rb +327 -0
  58. data/lib/wmap/dns_bruter.rb +308 -0
  59. data/lib/wmap/domain_tracker/sub_domain.rb +142 -0
  60. data/lib/wmap/domain_tracker.rb +342 -0
  61. data/lib/wmap/geoip_tracker.rb +72 -0
  62. data/lib/wmap/google_search_scraper.rb +177 -0
  63. data/lib/wmap/host_tracker/primary_host.rb +130 -0
  64. data/lib/wmap/host_tracker.rb +550 -0
  65. data/lib/wmap/network_profiler.rb +144 -0
  66. data/lib/wmap/port_scanner.rb +208 -0
  67. data/lib/wmap/site_tracker/deactivated_site.rb +85 -0
  68. data/lib/wmap/site_tracker.rb +937 -0
  69. data/lib/wmap/url_checker.rb +314 -0
  70. data/lib/wmap/url_crawler.rb +381 -0
  71. data/lib/wmap/utils/domain_root.rb +184 -0
  72. data/lib/wmap/utils/logger.rb +53 -0
  73. data/lib/wmap/utils/url_magic.rb +343 -0
  74. data/lib/wmap/utils/utils.rb +333 -0
  75. data/lib/wmap/whois.rb +76 -0
  76. data/lib/wmap.rb +227 -0
  77. data/logs/wmap.log +17 -0
  78. data/ruby_whois_patches/base_cocca2.rb +149 -0
  79. data/ruby_whois_patches/kero.yachay.pe.rb +120 -0
  80. data/ruby_whois_patches/whois.PublicDomainRegistry.com.rb +124 -0
  81. data/ruby_whois_patches/whois.above.com.rb +61 -0
  82. data/ruby_whois_patches/whois.adamsnames.tc.rb +107 -0
  83. data/ruby_whois_patches/whois.aeda.net.ae.rb +105 -0
  84. data/ruby_whois_patches/whois.ai.rb +112 -0
  85. data/ruby_whois_patches/whois.arnes.si.rb +121 -0
  86. data/ruby_whois_patches/whois.ascio.com.rb +91 -0
  87. data/ruby_whois_patches/whois.cnnic.cn.rb +123 -0
  88. data/ruby_whois_patches/whois.corporatedomains.com.rb +67 -0
  89. data/ruby_whois_patches/whois.crsnic.net.rb +108 -0
  90. data/ruby_whois_patches/whois.denic.de.rb +174 -0
  91. data/ruby_whois_patches/whois.dk-hostmaster.dk.rb +120 -0
  92. data/ruby_whois_patches/whois.dns.be.rb +134 -0
  93. data/ruby_whois_patches/whois.dns.lu.rb +129 -0
  94. data/ruby_whois_patches/whois.dns.pl.rb +150 -0
  95. data/ruby_whois_patches/whois.dns.pt.rb +119 -0
  96. data/ruby_whois_patches/whois.domain.kg.rb +126 -0
  97. data/ruby_whois_patches/whois.domainregistry.my.rb +123 -0
  98. data/ruby_whois_patches/whois.domreg.lt.rb +110 -0
  99. data/ruby_whois_patches/whois.dot.tk.rb +140 -0
  100. data/ruby_whois_patches/whois.hkirc.hk.rb +121 -0
  101. data/ruby_whois_patches/whois.isnic.is.rb +130 -0
  102. data/ruby_whois_patches/whois.je.rb +119 -0
  103. data/ruby_whois_patches/whois.jprs.jp.rb +137 -0
  104. data/ruby_whois_patches/whois.kenic.or.ke.rb +140 -0
  105. data/ruby_whois_patches/whois.markmonitor.com.rb +118 -0
  106. data/ruby_whois_patches/whois.melbourneit.com.rb +58 -0
  107. data/ruby_whois_patches/whois.nic.as.rb +96 -0
  108. data/ruby_whois_patches/whois.nic.at.rb +109 -0
  109. data/ruby_whois_patches/whois.nic.ch.rb +141 -0
  110. data/ruby_whois_patches/whois.nic.cl.rb +117 -0
  111. data/ruby_whois_patches/whois.nic.ec.rb +157 -0
  112. data/ruby_whois_patches/whois.nic.im.rb +120 -0
  113. data/ruby_whois_patches/whois.nic.it.rb +170 -0
  114. data/ruby_whois_patches/whois.nic.lv.rb +116 -0
  115. data/ruby_whois_patches/whois.nic.ly.rb +127 -0
  116. data/ruby_whois_patches/whois.nic.mu.rb +27 -0
  117. data/ruby_whois_patches/whois.nic.mx.rb +123 -0
  118. data/ruby_whois_patches/whois.nic.net.sa.rb +111 -0
  119. data/ruby_whois_patches/whois.nic.or.kr.rb +101 -0
  120. data/ruby_whois_patches/whois.nic.tel.rb +129 -0
  121. data/ruby_whois_patches/whois.nic.tr.rb +133 -0
  122. data/ruby_whois_patches/whois.nic.us.rb +129 -0
  123. data/ruby_whois_patches/whois.nic.ve.rb +135 -0
  124. data/ruby_whois_patches/whois.norid.no.rb +127 -0
  125. data/ruby_whois_patches/whois.pandi.or.id.rb +118 -0
  126. data/ruby_whois_patches/whois.psi-usa.info.rb +63 -0
  127. data/ruby_whois_patches/whois.registro.br.rb +109 -0
  128. data/ruby_whois_patches/whois.registrygate.com.rb +55 -0
  129. data/ruby_whois_patches/whois.rrpproxy.net.rb +61 -0
  130. data/ruby_whois_patches/whois.sgnic.sg.rb +130 -0
  131. data/ruby_whois_patches/whois.srs.net.nz.rb +166 -0
  132. data/ruby_whois_patches/whois.tucows.com.rb +70 -0
  133. data/ruby_whois_patches/whois.twnic.net.tw.rb +133 -0
  134. data/settings/discovery_ports +24 -0
  135. data/settings/google_keywords.txt +9 -0
  136. data/settings/google_locator.txt +23 -0
  137. data/test/domain_tracker_test.rb +31 -0
  138. data/test/utils_test.rb +168 -0
  139. data/version.txt +13 -0
  140. data/wmap.gemspec +49 -0
  141. metadata +202 -0
@@ -0,0 +1,157 @@
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.nic.ec parser
19
+ #
20
+ # Parser for the whois.nic.ec 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 WhoisNicEc < 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 not registered/)
40
+ end
41
+
42
+ property_supported :registered? do
43
+ !available?
44
+ end
45
+
46
+ property_supported :created_on do
47
+ t=build_node("Created",content_for_scanner)
48
+ Time.parse(t)
49
+ end
50
+
51
+ property_supported :updated_on do
52
+ t=build_node("Modified",content_for_scanner)
53
+ Time.parse(t)
54
+ end
55
+
56
+ property_supported :expires_on do
57
+ t=build_node("Expires",content_for_scanner)
58
+ Time.parse(t)
59
+ end
60
+
61
+ property_supported :nameservers do
62
+ if content_for_scanner =~ /Servidores de dominio \(Name Servers\)\n((.+\n)+)\n/
63
+ $1.split("\n").map do |name|
64
+ Record::Nameserver.new(:name => name)
65
+ end
66
+ end
67
+ end
68
+
69
+ # The following methods are implemented by Yang Li on 03/04/2013
70
+ # ----------------------------------------------------------------------------
71
+ property_supported :domain do
72
+ return build_node("Query",content_for_scanner)
73
+ end
74
+
75
+ property_not_supported :domain_id
76
+
77
+ property_supported :registrar do
78
+ reg=Record::Registrar.new
79
+ if content_for_scanner =~ /^Registrar Information\n((.+\n)+)\n/
80
+ registrar=$1
81
+ reg["name"] = build_node("Registrar Name", registrar)
82
+ reg["organization"] = build_node("Registrar Name", registrar)
83
+ reg["url"] = build_node("Registration URL", registrar)
84
+ reg["country"] = build_node("Country", registrar)
85
+ end
86
+ return reg
87
+ end
88
+
89
+ property_supported :registrant_contacts do
90
+ build_contact("Registrant", Whois::Record::Contact::TYPE_REGISTRANT)
91
+ end
92
+
93
+ property_supported :admin_contacts do
94
+ build_contact("Admin Contact", Whois::Record::Contact::TYPE_ADMIN)
95
+ end
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\n/
110
+ contact=$1
111
+ reg["name"]=build_node("Name", contact)
112
+ reg["organization"]=build_node("Organisation", contact)
113
+ if contact =~ /^(Address:\n(.+\n)+)/
114
+ addrs=$1
115
+ myaddr=build_address(addrs)
116
+ reg["address"]=myaddr["address"]
117
+ reg["city"]=myaddr["city"]
118
+ reg["zip"]=myaddr["zip"]
119
+ reg["state"]=myaddr["state"]
120
+ reg["country_code"]=myaddr["country_code"]
121
+ end
122
+ reg["phone"]=build_node("Phone Number",contact)
123
+ reg["fax"]=build_node("Fax Number",contact)
124
+ reg["email"]=build_node("Email Address",contact)
125
+ end
126
+ return reg
127
+ end
128
+
129
+ def build_node(element,context)
130
+ return $1.strip if context =~ /^#{element}:(.+)\n/i
131
+ end
132
+
133
+ def build_address(context)
134
+ addr=Hash.new
135
+ line_num=1
136
+ context.split(%r{\n}).each do |line|
137
+ line=line.chomp.strip
138
+ addr["address"]=line if line_num==2
139
+ addr["country_code"]=line if line_num==4
140
+ if line_num==3
141
+ addr["city"]=line.split(',')[0]
142
+ zips=line.split(',')[1].split(' ')
143
+ unless zips.nil?
144
+ addr["state"]=zips.shift
145
+ addr["zip"]=zips.join(' ')
146
+ end
147
+ end
148
+ line_num=line_num+1
149
+ end
150
+ return addr
151
+ end
152
+ # ----------------------------------------------------------------------------
153
+ end
154
+
155
+ end
156
+ end
157
+ end
@@ -0,0 +1,120 @@
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.nic.im parser
19
+ #
20
+ # Parser for the whois.nic.im 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 WhoisNicIm < 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 =~ /was not found/)
40
+ end
41
+
42
+ property_supported :registered? do
43
+ !available?
44
+ end
45
+
46
+ property_not_supported :created_on
47
+
48
+ property_not_supported :updated_on
49
+
50
+ property_supported :expires_on do
51
+ if content_for_scanner =~ /Expiry Date:\s+(.*?)\n/
52
+ Time.parse($1.gsub("/", "-"))
53
+ end
54
+ end
55
+
56
+ property_supported :nameservers do
57
+ content_for_scanner.scan(/Name Server:\s+(.+)\n/).flatten.map do |name|
58
+ Record::Nameserver.new(:name => name.chomp("."))
59
+ end
60
+ end
61
+
62
+ # The following methods are implemented by Yang Li on 02/04/2013
63
+ # ----------------------------------------------------------------------------
64
+ property_supported :domain do
65
+ return $1 if content_for_scanner =~ /Domain Name:\s+(.*)\n/i
66
+ end
67
+
68
+ property_not_supported :domain_id
69
+
70
+ property_supported :registrar do
71
+ reg=Record::Registrar.new
72
+ if content_for_scanner =~ /^Domain Managers\n((.+\n)+)^Administrative\sContact\n/
73
+ $1.scan(/(.+):(.+)\n/).map do |entry|
74
+ reg["name"] = entry[1] if entry[0] =~ /Name/i
75
+ reg["organization"] = entry[1] if entry[0] =~ /Name/i
76
+ end
77
+ end
78
+ return reg
79
+ end
80
+
81
+ property_not_supported :admin_contacts do
82
+ build_contact("Administrative Contact", Whois::Record::Contact::TYPE_ADMIN)
83
+ end
84
+
85
+ property_supported :registrant_contacts do
86
+ build_contact("Registrant", Whois::Record::Contact::TYPE_REGISTRANT)
87
+ end
88
+
89
+ property_supported :technical_contacts do
90
+ build_contact("Technical Contact", Whois::Record::Contact::TYPE_TECHNICAL)
91
+ end
92
+
93
+ property_supported :billing_contacts do
94
+ build_contact("Billing Contact", 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}\n((.+\n)+)/i
102
+ line_num=1
103
+ $1.split(%r{\n}).each do |line|
104
+ reg["name"]=line.split(':')[1].strip if line_num==1
105
+ reg["organization"]=line.split(':')[1].strip if line_num==1
106
+ reg["address"]=line.strip if line_num==3
107
+ reg["city"]=line.strip if line_num==4
108
+ reg["zip"]=line.strip if line_num==5
109
+ reg["country"]=line.strip if line_num==6
110
+ line_num=line_num+1
111
+ end
112
+ end
113
+ return reg
114
+ end
115
+ # ----------------------------------------------------------------------------
116
+
117
+ end
118
+ end
119
+ end
120
+ end
@@ -0,0 +1,170 @@
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
+ require 'whois/record/scanners/whois.nic.it.rb'
12
+
13
+
14
+ module Whois
15
+ class Record
16
+ class Parser
17
+
18
+ # Parser for the whois.nic.it server.
19
+ class WhoisNicIt < Base
20
+ include Scanners::Ast
21
+
22
+
23
+ property_supported :disclaimer do
24
+ node("Disclaimer")
25
+ end
26
+
27
+
28
+ property_supported :domain do
29
+ node("Domain") { |str| str.downcase }
30
+ end
31
+
32
+ property_not_supported :domain_id
33
+
34
+
35
+ property_not_supported :referral_whois
36
+
37
+ property_not_supported :referral_url
38
+
39
+
40
+ property_supported :status do
41
+ case s = node("Status").to_s.downcase
42
+ when /^ok/, "active", /\bclient/
43
+ :registered
44
+ when "grace-period", "no-provider"
45
+ :registered
46
+ when /^pendingupdate/
47
+ :registered
48
+ when /^pendingtransfer/
49
+ :registered
50
+ when /redemption\-/
51
+ :redemption
52
+ when "pending-delete"
53
+ :redemption
54
+ # The domain will be deleted in 5 days
55
+ when /^pendingdelete/
56
+ :redemption
57
+ when "unassignable"
58
+ :reserved
59
+ when "available"
60
+ :available
61
+ when /^inactive/
62
+ :inactive
63
+ else
64
+ Whois.bug!(ParserError, "Unknown status `#{s}'.")
65
+ end
66
+ end
67
+
68
+ property_supported :available? do
69
+ status == :available
70
+ end
71
+
72
+ property_supported :registered? do
73
+ status != :reserved &&
74
+ !available?
75
+ end
76
+
77
+ # NEWPROPERTY
78
+ def reserved?
79
+ status == :reserved
80
+ end
81
+
82
+
83
+ property_supported :created_on do
84
+ node("Created") { |str| Time.parse(str) }
85
+ end
86
+
87
+ property_supported :updated_on do
88
+ node("Last Update") { |str| Time.parse(str) }
89
+ end
90
+
91
+ property_supported :expires_on do
92
+ node("Expire Date") { |str| Time.parse(str) }
93
+ end
94
+
95
+
96
+ property_supported :registrar do
97
+ node("Registrar") do |str|
98
+ Record::Registrar.new(
99
+ :id => str["Name"],
100
+ :name => str["Name"],
101
+ :organization => str["Organization"]
102
+ )
103
+ end
104
+ end
105
+
106
+ property_supported :registrant_contacts do
107
+ build_contact("Registrant", Whois::Record::Contact::TYPE_REGISTRANT)
108
+ end
109
+
110
+ property_supported :admin_contacts do
111
+ build_contact("Admin Contact", Whois::Record::Contact::TYPE_ADMIN)
112
+ end
113
+
114
+ property_supported :technical_contacts do
115
+ build_contact("Technical Contacts", Whois::Record::Contact::TYPE_TECHNICAL)
116
+ end
117
+
118
+
119
+ property_supported :nameservers do
120
+ Array.wrap(node("Nameservers")).map do |name|
121
+ Record::Nameserver.new(:name => name)
122
+ end
123
+ end
124
+
125
+
126
+ # Checks whether this response contains a message
127
+ # that can be reconducted to a "WHOIS Server Unavailable" status.
128
+ #
129
+ # @return [Boolean]
130
+ def response_unavailable?
131
+ !!node("response:unavailable")
132
+ end
133
+
134
+ # Initializes a new {Scanners::WhoisNicIt} instance
135
+ # passing the {#content_for_scanner}
136
+ # and calls +parse+ on it.
137
+ #
138
+ # @return [Hash]
139
+ def parse
140
+ Scanners::WhoisNicIt.new(content_for_scanner).parse
141
+ end
142
+
143
+
144
+ private
145
+
146
+ def build_contact(element, type)
147
+ node(element) do |str|
148
+ address = (str["Address"] || "").split("\n")
149
+ company = address.size == 6 ? address.shift : nil
150
+ Record::Contact.new(
151
+ :id => str["ContactID"],
152
+ :type => type,
153
+ :name => str["Name"],
154
+ :organization => str["Organization"] || company,
155
+ :address => address[0],
156
+ :city => address[1],
157
+ :zip => address[2],
158
+ :state => address[3],
159
+ :country_code => address[4],
160
+ :created_on => str["Created"] ? Time.parse(str["Created"]) : nil,
161
+ :updated_on => str["Last Update"] ? Time.parse(str["Last Update"]) : nil
162
+ )
163
+ end
164
+ end
165
+
166
+ end
167
+
168
+ end
169
+ end
170
+ end
@@ -0,0 +1,116 @@
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
+ # = whois.nic.lv parser
18
+ #
19
+ # Parser for the whois.nic.lv server.
20
+ #
21
+ # NOTE: This parser is just a stub and provides only a few basic methods
22
+ # to check for domain availability and get domain status.
23
+ # Please consider to contribute implementing missing methods.
24
+ # See WhoisNicIt parser for an explanation of all available methods
25
+ # and examples.
26
+ #
27
+ class WhoisNicLv < Base
28
+
29
+ property_supported :status do
30
+ if available?
31
+ :available
32
+ else
33
+ :registered
34
+ end
35
+ end
36
+
37
+ property_supported :available? do
38
+ !!(content_for_scanner =~ /Status: free/)
39
+ end
40
+
41
+ property_supported :registered? do
42
+ !available?
43
+ end
44
+
45
+ property_not_supported :created_on
46
+
47
+ property_supported :updated_on do
48
+ if content_for_scanner =~ /Changed:\s+(.+)\n/
49
+ Time.parse($1)
50
+ end
51
+ end
52
+
53
+ property_not_supported :expires_on
54
+
55
+ property_supported :nameservers do
56
+ content_for_scanner.scan(/Nserver:\s+(.+)\n/).flatten.map do |name|
57
+ Record::Nameserver.new(:name => name)
58
+ end
59
+ end
60
+
61
+ # The following methods are implemented by Yang Li on 01/24/2013
62
+ # ----------------------------------------------------------------------------
63
+ property_supported :domain do
64
+ return $1 if content_for_scanner =~ /Domain:\s+(.*)\n/i
65
+ end
66
+
67
+ property_not_supported :domain_id
68
+
69
+ property_supported :registrar do
70
+ reg=Record::Registrar.new
71
+ if content_for_scanner =~ /^\[Registrar\]\n((.+\n)+)\n/
72
+ contacts=$1
73
+ contacts.scan(/(.+):(.+)\n/).map do |entry|
74
+ reg["name"] = entry[1] if entry[0] =~ /Name/i
75
+ reg["organization"] = entry[1] if entry[0] =~ /Name/i
76
+ reg["url"] = entry[1] if entry[0] =~ /email/i
77
+ end
78
+ end
79
+ return reg
80
+ end
81
+
82
+ property_not_supported :admin_contacts
83
+
84
+ property_supported :registrant_contacts do
85
+ build_contact("Holder", Whois::Record::Contact::TYPE_REGISTRANT)
86
+ end
87
+
88
+ property_supported :technical_contacts do
89
+ build_contact("Tech", Whois::Record::Contact::TYPE_TECHNICAL)
90
+ end
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
+ if content_for_scanner.gsub(/\//,'') =~ /^\[#{element}\]\n((.+\n)+)\n/i
99
+ contacts=$1
100
+ contacts.scan(/^(.+):\s+(.+)\n/).map do |entry|
101
+ reg["name"]=entry[1] if entry[0] =~ /Name/i
102
+ reg["organization"]=entry[1] if entry[0]=~ /Name/i
103
+ reg["address"]=entry[1] if entry[0]=~ /Address/i
104
+ reg["phone"]=entry[1] if entry[0]=~ /Phone/i
105
+ reg["fax"]=entry[1] if entry[0]=~ /Fax/i
106
+ reg["email"]=entry[1] if entry[0]=~ /Email/i
107
+ end
108
+ end
109
+ return reg
110
+ end
111
+ # ----------------------------------------------------------------------------
112
+
113
+ end
114
+ end
115
+ end
116
+ end
@@ -0,0 +1,127 @@
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.nic.ly parser
19
+ #
20
+ # Parser for the whois.nic.ly 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 WhoisNicLy < 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.strip == "Not found")
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 =~ /Created:\s+(.*)\n/
49
+ Time.parse($1)
50
+ end
51
+ end
52
+
53
+ property_supported :updated_on do
54
+ if content_for_scanner =~ /Updated:\s+(.*)\n/
55
+ Time.parse($1)
56
+ end
57
+ end
58
+
59
+ property_supported :expires_on do
60
+ if content_for_scanner =~ /Expired:\s+(.*)\n/
61
+ Time.parse($1)
62
+ end
63
+ end
64
+
65
+
66
+ property_supported :nameservers do
67
+ if content_for_scanner =~ /Domain servers in listed order:\n((.+\n)+)\n/
68
+ $1.split("\n").map do |name|
69
+ Record::Nameserver.new(:name => name.strip)
70
+ end
71
+ end
72
+ end
73
+
74
+ # The following methods are implemented by Yang Li on 01/24/2013
75
+ # ----------------------------------------------------------------------------
76
+ property_supported :domain do
77
+ return $1.strip if content_for_scanner =~ /Domain Name:\s+(.*)\n/i
78
+ end
79
+
80
+ property_not_supported :domain_id
81
+
82
+ property_not_supported :registrar
83
+
84
+ property_supported :admin_contacts do
85
+ build_contact("Administrative Contact", Whois::Record::Contact::TYPE_REGISTRANT)
86
+ end
87
+
88
+ property_supported :registrant_contacts do
89
+ build_contact("Registrant", Whois::Record::Contact::TYPE_REGISTRANT)
90
+ end
91
+
92
+ property_supported :technical_contacts do
93
+ build_contact("Technical Contact", Whois::Record::Contact::TYPE_TECHNICAL)
94
+ end
95
+
96
+ property_supported :billing_contacts do
97
+ build_contact("Billing Contact", Whois::Record::Contact::TYPE_BILLING)
98
+ end
99
+
100
+ private
101
+
102
+ def build_contact(element, type)
103
+ reg=Record::Contact.new(:type => type)
104
+ if content_for_scanner =~ /^#{element}:\n((.+\n)+)\n/i
105
+ line_num=1
106
+ $1.split(%r{\n}).each do |line|
107
+ reg["name"]=line.strip if line_num==1
108
+ reg["organization"]=line.strip if line_num==2
109
+ reg["address"]=line.strip if line_num==3
110
+ reg["city"]=line.strip if line_num==4
111
+ reg["state"]=line.strip if line_num==5
112
+ reg["country"]=line.strip if line_num==6
113
+ reg["zip"]=line.strip.split(':').last if line_num==7
114
+ reg["phone"]=line.strip.split(':').last if line_num==8
115
+ reg["fax"]=line.strip.split(':').last if line_num==9
116
+ reg["email"]=line.strip if line_num==10
117
+ line_num=line_num+1
118
+ end
119
+ end
120
+ return reg
121
+ end
122
+ # ----------------------------------------------------------------------------
123
+
124
+ end
125
+ end
126
+ end
127
+ end