pastenum 0.2.2
Sign up to get free protection for your applications and to get access to all the features.
- data/Gemfile +10 -0
- data/LICENSE +22 -0
- data/README.md +54 -0
- data/RELEASE_NOTES +16 -0
- data/bin/pastenum +13 -0
- data/lib/pastenum.rb +24 -0
- data/lib/pastenum/cli.rb +180 -0
- data/lib/pastenum/json.rb +14 -0
- data/lib/pastenum/main.rb +9 -0
- data/lib/pastenum/report.rb +83 -0
- data/lib/pastenum/target.rb +26 -0
- data/lib/pastenum/targets/gist.rb +77 -0
- data/lib/pastenum/targets/github.rb +67 -0
- data/lib/pastenum/targets/pastebin.rb +45 -0
- data/lib/pastenum/targets/pastie.rb +57 -0
- data/lib/pastenum/version.rb +3 -0
- data/pastenum.gemspec +17 -0
- data/public/css/main.css +121 -0
- data/public/img/corelanlogo_small.jpg +0 -0
- metadata +67 -0
data/Gemfile
ADDED
data/LICENSE
ADDED
@@ -0,0 +1,22 @@
|
|
1
|
+
Copyright (c) 2011-2013 corelan, nullthreat, shadowbq
|
2
|
+
|
3
|
+
MIT License
|
4
|
+
|
5
|
+
Permission is hereby granted, free of charge, to any person obtaining
|
6
|
+
a copy of this software and associated documentation files (the
|
7
|
+
"Software"), to deal in the Software without restriction, including
|
8
|
+
without limitation the rights to use, copy, modify, merge, publish,
|
9
|
+
distribute, sublicense, and/or sell copies of the Software, and to
|
10
|
+
permit persons to whom the Software is furnished to do so, subject to
|
11
|
+
the following conditions:
|
12
|
+
|
13
|
+
The above copyright notice and this permission notice shall be
|
14
|
+
included in all copies or substantial portions of the Software.
|
15
|
+
|
16
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
17
|
+
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
18
|
+
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
19
|
+
NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
20
|
+
LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
21
|
+
OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
22
|
+
WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
data/README.md
ADDED
@@ -0,0 +1,54 @@
|
|
1
|
+
#Pastenum
|
2
|
+
|
3
|
+
Pastenum is a gem rewrite of nullthreat's original pastenum2 google scrapper.
|
4
|
+
|
5
|
+
Install:
|
6
|
+
------
|
7
|
+
* Install Ruby 1.9.*
|
8
|
+
|
9
|
+
* Install RubyGems
|
10
|
+
|
11
|
+
* gem install pastenum
|
12
|
+
|
13
|
+
Troubleshooting:
|
14
|
+
======
|
15
|
+
|
16
|
+
** Note: nokogiri in the gemfile requires native libxslt and libxml2 to be installed
|
17
|
+
|
18
|
+
Usage:
|
19
|
+
------
|
20
|
+
`$> pastenum.rb`
|
21
|
+
|
22
|
+
When prompted enter a search term.
|
23
|
+
Once the application is complete it will generate "report.html"
|
24
|
+
|
25
|
+
** Note: If more then 100 results are found, it can take some time to load the "report.html" file.
|
26
|
+
|
27
|
+
|
28
|
+
Notes on Future Versions:
|
29
|
+
------
|
30
|
+
|
31
|
+
Gist / Github
|
32
|
+
------
|
33
|
+
|
34
|
+
Use the appropriate API for github
|
35
|
+
|
36
|
+
http://developer.github.com/v3/repos/
|
37
|
+
|
38
|
+
Gscaper -> Google Custom Search API:
|
39
|
+
------
|
40
|
+
|
41
|
+
Important: The Google Custom Search API requires the use of an API key, which you can get from the Google APIs console. The API provides 100 search queries per day for free. If you need more, you may sign up for billing in the console.
|
42
|
+
|
43
|
+
https://developers.google.com/custom-search/v1/overview
|
44
|
+
|
45
|
+
Original Pastenum Credits:
|
46
|
+
------
|
47
|
+
|
48
|
+
Pastenum - A Corelan Team Production
|
49
|
+
Written by: Nullthreat
|
50
|
+
|
51
|
+
www.corelan.be
|
52
|
+
www.nullthreat.net
|
53
|
+
irc.freenode.net #corelan
|
54
|
+
|
data/RELEASE_NOTES
ADDED
@@ -0,0 +1,16 @@
|
|
1
|
+
|
2
|
+
RELEASE NOTES:
|
3
|
+
6/05/2011
|
4
|
+
v .2
|
5
|
+
Added BT5 install instructions to README
|
6
|
+
Fixed some formatting
|
7
|
+
Generally Cleaned Code
|
8
|
+
|
9
|
+
3/25/2011
|
10
|
+
v .1 RC2
|
11
|
+
Added github support
|
12
|
+
Added ability to enable and disable searches individually
|
13
|
+
|
14
|
+
3/22/2011
|
15
|
+
v .1 RC1
|
16
|
+
Initial public release
|
data/bin/pastenum
ADDED
@@ -0,0 +1,13 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
|
3
|
+
begin
|
4
|
+
require 'rubygems'
|
5
|
+
require 'bundler'
|
6
|
+
Bundler.setup(:default)
|
7
|
+
rescue ::Exception => e
|
8
|
+
end
|
9
|
+
|
10
|
+
# Executable with absolute path to lib for hacking and development
|
11
|
+
require File.join(File.dirname(__FILE__), '..', 'lib', 'pastenum', 'cli')
|
12
|
+
|
13
|
+
Pastenum::CLI.invoke
|
data/lib/pastenum.rb
ADDED
@@ -0,0 +1,24 @@
|
|
1
|
+
#STDLIBS
|
2
|
+
require 'uri'
|
3
|
+
require 'rubygems'
|
4
|
+
|
5
|
+
# RubyGems
|
6
|
+
require 'mechanize'
|
7
|
+
require 'uri/query_params'
|
8
|
+
require 'gscraper'
|
9
|
+
require 'colored'
|
10
|
+
require 'json'
|
11
|
+
|
12
|
+
# Internal
|
13
|
+
module Pastenum
|
14
|
+
$:.unshift(File.dirname(__FILE__))
|
15
|
+
require 'pastenum/main'
|
16
|
+
require 'pastenum/report'
|
17
|
+
require 'pastenum/json'
|
18
|
+
require 'pastenum/version'
|
19
|
+
require 'pastenum/target'
|
20
|
+
require 'pastenum/targets/gist'
|
21
|
+
require 'pastenum/targets/github'
|
22
|
+
require 'pastenum/targets/pastie'
|
23
|
+
require 'pastenum/targets/pastebin'
|
24
|
+
end
|
data/lib/pastenum/cli.rb
ADDED
@@ -0,0 +1,180 @@
|
|
1
|
+
require 'optparse'
|
2
|
+
require 'pastenum'
|
3
|
+
require 'colored'
|
4
|
+
require 'highline/import'
|
5
|
+
|
6
|
+
module Pastenum
|
7
|
+
class CLI
|
8
|
+
|
9
|
+
def self.invoke
|
10
|
+
self.new
|
11
|
+
end
|
12
|
+
|
13
|
+
|
14
|
+
def initialize
|
15
|
+
options = {}
|
16
|
+
|
17
|
+
options[:pastebin] = true
|
18
|
+
options[:gist] = true
|
19
|
+
options[:github] = true
|
20
|
+
options[:pastie] = false
|
21
|
+
|
22
|
+
options[:onion] = false
|
23
|
+
options[:test] = false
|
24
|
+
options[:verbose] = false
|
25
|
+
options[:maxpages] = 2
|
26
|
+
options[:tos] = false
|
27
|
+
|
28
|
+
opt_parser = OptionParser.new do |opt|
|
29
|
+
opt.banner = "Usage: pastenum [OPTIONS] \"search string\""
|
30
|
+
opt.separator ""
|
31
|
+
opt.separator "Sources::"
|
32
|
+
|
33
|
+
opt.on("-p","--[no-]pastebin","Search Pastebin.com (Gscraper)"," Default: #{options[:pastebin]}") do
|
34
|
+
options[:pastebin] = true
|
35
|
+
end
|
36
|
+
|
37
|
+
opt.on("-g","--[no-]gist","Search Gist.github.com"," Default: #{options[:gist]}") do
|
38
|
+
options[:gist] = true
|
39
|
+
end
|
40
|
+
|
41
|
+
opt.on("-G","--[no-]github","Search github.com"," Default: #{options[:github]}") do
|
42
|
+
options[:github] = true
|
43
|
+
end
|
44
|
+
|
45
|
+
opt.on("-i","--[no-]pasties","Search pastie.org (Gscraper)"," Default: #{options[:pastie]}") do
|
46
|
+
options[:pastie] = true
|
47
|
+
end
|
48
|
+
|
49
|
+
opt.separator "Output:: (Default output to STDOUT)"
|
50
|
+
|
51
|
+
opt.on("-R","--report","Create an iframed report.html ") do
|
52
|
+
options[:report] = true
|
53
|
+
end
|
54
|
+
|
55
|
+
opt.on("-J", "--json", "Create a JSON file with results ") do
|
56
|
+
options[:json] = true
|
57
|
+
end
|
58
|
+
|
59
|
+
|
60
|
+
opt.separator "Options::"
|
61
|
+
|
62
|
+
opt.on("-m","--maxpages=","maximum number of search results pages to iterate through" ," Default: #{options[:maxpages]}") do |v|
|
63
|
+
options[:maxpages] = v
|
64
|
+
end
|
65
|
+
|
66
|
+
opt.on("-x", "--tos", "Acknowledge Google INC. 'Terms of Service'") do
|
67
|
+
options[:tos] = true
|
68
|
+
end
|
69
|
+
=begin
|
70
|
+
opt.on("-o","--onion","use tor-network socks mode?") do
|
71
|
+
options[:onion] = true
|
72
|
+
end
|
73
|
+
|
74
|
+
opt.on("-t", "--test", "Run Test suite") do
|
75
|
+
options[:test] = v
|
76
|
+
end
|
77
|
+
=end
|
78
|
+
opt.on("-v", "--verbose", "Run verbosely") do
|
79
|
+
options[:verbose] = v
|
80
|
+
end
|
81
|
+
|
82
|
+
opt.on_tail("-h","--help","Display this screen") do
|
83
|
+
puts opt_parser
|
84
|
+
exit 0
|
85
|
+
end
|
86
|
+
|
87
|
+
|
88
|
+
end
|
89
|
+
|
90
|
+
#Verify the options
|
91
|
+
begin
|
92
|
+
raise unless ARGV.size > 0
|
93
|
+
opt_parser.parse!
|
94
|
+
|
95
|
+
#If options fail display help
|
96
|
+
rescue
|
97
|
+
puts opt_parser
|
98
|
+
exit
|
99
|
+
end
|
100
|
+
|
101
|
+
dork = ARGV[0]
|
102
|
+
|
103
|
+
if options[:onion]
|
104
|
+
session.set_tor
|
105
|
+
puts "Fetching Tor Exit IP"
|
106
|
+
session.tor_check
|
107
|
+
ensure_tor = ask("Are you protected? [NO/yes]")
|
108
|
+
exit 1 if ensure_tor != 'yes'
|
109
|
+
end
|
110
|
+
|
111
|
+
if !(options[:tos])
|
112
|
+
puts "You are using Gscraper, a non-compliant Google Search API screen scraping utility.".red
|
113
|
+
puts ""
|
114
|
+
puts "*** Google Terms of Service: March 1, 2012 "
|
115
|
+
puts " [..] This license is for the sole purpose of enabling you to "
|
116
|
+
puts " use and enjoy the benefit of the Services as provided by Google,"
|
117
|
+
puts " in the manner permitted by these terms. [..] *** "
|
118
|
+
puts ""
|
119
|
+
ensure_tos = ask("Do you want to continue? [NO/yes]")
|
120
|
+
exit 1 if ensure_tos != 'yes'
|
121
|
+
end
|
122
|
+
|
123
|
+
if options[:verbose]
|
124
|
+
puts "++++++++++++++++++++++++++++++++++++++++++++++".green
|
125
|
+
puts "+ Pastie Enum".green
|
126
|
+
puts "+ Version #{VERSION}".green
|
127
|
+
puts "++++++++++++++++++++++++++++++++++++++++++++++\n".green
|
128
|
+
end
|
129
|
+
|
130
|
+
@gist = Pastenum::Gist.new(dork)
|
131
|
+
@github = Pastenum::Github.new(dork)
|
132
|
+
@pastebin = Pastenum::Pastebin.new(dork)
|
133
|
+
@pastie = Pastenum::Pastie.new(dork)
|
134
|
+
|
135
|
+
|
136
|
+
if options[:gist]
|
137
|
+
|
138
|
+
@gist.verbose = options[:verbose]
|
139
|
+
@gist.max_pages = options[:maxpages]
|
140
|
+
@gist.search
|
141
|
+
@gist.summary
|
142
|
+
@gist.results.each { |hit| puts "https://gist.github.com#{hit}" } if !options[:report] && !options[:json]
|
143
|
+
end
|
144
|
+
|
145
|
+
if options[:github]
|
146
|
+
@github.verbose = options[:verbose]
|
147
|
+
@github.max_pages = options[:maxpages]
|
148
|
+
@github.search
|
149
|
+
@github.summary
|
150
|
+
puts @github.results if !options[:report] && !options[:json]
|
151
|
+
end
|
152
|
+
|
153
|
+
if options[:pastebin]
|
154
|
+
@pastebin.verbose = options[:verbose]
|
155
|
+
@pastebin.max_pages = options[:maxpages]
|
156
|
+
@pastebin.search
|
157
|
+
@pastebin.summary
|
158
|
+
@pastebin.results.each { |hit| puts "http://pastebin.com#{hit}" } if !options[:report] && !options[:json]
|
159
|
+
end
|
160
|
+
|
161
|
+
if options[:pastie]
|
162
|
+
@pastie.verbose = options[:verbose]
|
163
|
+
@pastie.max_pages = 2
|
164
|
+
@pastie.search
|
165
|
+
@pastie.summary
|
166
|
+
puts @pastie.results if !options[:report] && !options[:json]
|
167
|
+
end
|
168
|
+
|
169
|
+
if options[:report]
|
170
|
+
Pastenum::Report.new(dork, @pastie.results, @pastebin.results, @github.results, @gist.results).to_file
|
171
|
+
end
|
172
|
+
|
173
|
+
if options[:json]
|
174
|
+
Pastenum::JSON.new(dork, @gist, @github, @pastebin, @pastie)
|
175
|
+
end
|
176
|
+
|
177
|
+
end
|
178
|
+
|
179
|
+
end
|
180
|
+
end
|
@@ -0,0 +1,14 @@
|
|
1
|
+
module Pastenum
|
2
|
+
class JSON
|
3
|
+
|
4
|
+
def initialize(dork, pastie, pastebin, github, gist)
|
5
|
+
file = File.open('report.json', 'w')
|
6
|
+
data = [{:search => dork}, {gist.vendor => gist.results}, {github.vendor => github.results}, {pastebin.vendor => pastebin.results}, {pastie.vendor => pastie.results} ].to_json
|
7
|
+
file.write(data)
|
8
|
+
file.close
|
9
|
+
|
10
|
+
return data
|
11
|
+
end
|
12
|
+
|
13
|
+
end
|
14
|
+
end
|
@@ -0,0 +1,83 @@
|
|
1
|
+
module Pastenum
|
2
|
+
class Report
|
3
|
+
|
4
|
+
def initialize(dork,addresses_pastie,addresses_pastebin,addresses_github,addresses_gist)
|
5
|
+
@dork = dork
|
6
|
+
@addresses_pastie = addresses_pastie
|
7
|
+
@addresses_pastebin = addresses_pastebin
|
8
|
+
@addresses_github = addresses_github
|
9
|
+
@addresses_gist = addresses_gist
|
10
|
+
end
|
11
|
+
|
12
|
+
def to_file
|
13
|
+
puts "[*] Creating HTML Report".green
|
14
|
+
print "[*] Status: ".green
|
15
|
+
file = File.open('report.html', 'w')
|
16
|
+
|
17
|
+
# Header
|
18
|
+
|
19
|
+
file.write("<html><head><title>Pastenum - #{@dork}</title>\n")
|
20
|
+
file.write("<style>\n")
|
21
|
+
file.write("body{background-color:#931b1c;color:#aaa;font-family:Tahoma,Arial,Helvetica,sans-serif;font-size:.75em}#container{background-color:#000;margin:0 auto;padding:10px;width:90%}#logo{float:left;width:124px}#menu{background-color:#333;float:right;padding:10px;text-align:right;width:70%;height:17px}#footer{background-color:#333;clear:both;font-size:.80em;padding:2px;text-align:center;width:100%}#content{clear:both;padding-top:5px;padding-bottom:10px}img{border:0}#menu li{display:inline;margin-left:10px}#menu ul{margin:0;padding:0;list-style-type:none}#portfolio li{display:inline;margin-right:10px}#portfolio ul{margin:0;padding:0;list-style-type:none;padding-bottom:10px}a:hover{color:#ccc;text-decoration:none}a{color:#888;text-decoration:none}a.on{color:#ccc;text-decoration:none}h1{font-family:Georgia,\"Times New Roman\",Times,serif;font-weight:normal;font-size:1.3em}.center{text-align:center}input{background-color:#000;font-family:Tahoma,Arial,Helvetica,sans-serif;font-size:1em;color:#fff;border-color:#fff;border-width:thin}textarea{background-color:#fff;font-family:Tahoma,Arial,Helvetica,sans-serif;font-size:1em;color:#000;border-color:#fff;border-width:thin}\n")
|
22
|
+
|
23
|
+
file.write("</style>\n")
|
24
|
+
file.write("</head>\n")
|
25
|
+
|
26
|
+
file.write("<body><div id=\"container\"><div id=\"logo\">")
|
27
|
+
file.write("<img alt=\"Corelan Logo\" src=\"data:image/jpeg;base64,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\" />\n")
|
28
|
+
|
29
|
+
|
30
|
+
file.write("</div>\n")
|
31
|
+
file.write("<div id=\"menu\">Pastenum - Search Results for: '#{@dork}'</div>\n")
|
32
|
+
file.write("<div id=\"content\">")
|
33
|
+
|
34
|
+
#gist.github.com
|
35
|
+
unless @addresses_gist.empty?
|
36
|
+
file.write("<br /><h2>Site: Github Gist - Found: #{@addresses_gist.count} Items</h2>\n")
|
37
|
+
@addresses_gist.each do |links|
|
38
|
+
file.write("<p><script src=\"https://gist.github.com#{links}.js\"></script><p>link: <a href=\"#{links}\" target=\"_blank\">#{links}</a>\n")
|
39
|
+
print ".".green
|
40
|
+
end
|
41
|
+
end
|
42
|
+
|
43
|
+
#Github.com
|
44
|
+
unless @addresses_github.empty?
|
45
|
+
file.write("<br /><h2>Site: Github - Found: #{@addresses_github.count} Items</h2>\n")
|
46
|
+
file.write("NOTE: Github passes 'x-frame-options deny' so iframes are useless.\n")
|
47
|
+
@addresses_github.each do |links|
|
48
|
+
file.write("<p>link: <a href=\"#{links}\" target=\"_blank\">#{links}</a></p>\n")
|
49
|
+
print ".".green
|
50
|
+
end
|
51
|
+
end
|
52
|
+
|
53
|
+
# Pastebin.com
|
54
|
+
unless @addresses_pastebin.empty?
|
55
|
+
file.write("<br /><h2>Site: Pastebin - Found: #{@addresses_pastebin.count} Items</h2>\n")
|
56
|
+
@addresses_pastebin.each do |links|
|
57
|
+
file.write("<p><iframe src=\"http://pastebin.com/embed_iframe.php?i=#{links}\" style=\"border:none;width:100%;height:300px\"></iframe><p>link: <a href=\"http://pastebin.com/#{links}\" target=\"_blank\">http://pastebin.com/#{links}</a>\n")
|
58
|
+
print ".".green
|
59
|
+
end
|
60
|
+
file.write("<hr><hr>")
|
61
|
+
end
|
62
|
+
|
63
|
+
#Pastie.org
|
64
|
+
unless @addresses_pastie.empty?
|
65
|
+
file.write("<h2>Search Term: \"#{@dork}\" <br /> Site: Pastie - Found: #{@addresses_pastie.count} Items</h2>\n")
|
66
|
+
@addresses_pastie.each do |links|
|
67
|
+
file.write("<p><iframe src=#{links}/text style=\"width: 100%; height: 300px; background-color: white\"></iframe><p>link: <a href=\"#{links}\" target=\"_blank\">#{links}</a>\n")
|
68
|
+
print ".".green
|
69
|
+
end
|
70
|
+
file.write("<hr><hr>")
|
71
|
+
end
|
72
|
+
|
73
|
+
# Footer
|
74
|
+
|
75
|
+
file.write("</div>\n")
|
76
|
+
file.write("<div id=\"footer\">© Corelan Team | Written by Nullthreat\n")
|
77
|
+
file.write("</div></body></html>\n")
|
78
|
+
file.close
|
79
|
+
|
80
|
+
puts "\n[*] HTML Report Created".green
|
81
|
+
end
|
82
|
+
end
|
83
|
+
end
|
@@ -0,0 +1,26 @@
|
|
1
|
+
module Pastenum
|
2
|
+
class Target
|
3
|
+
|
4
|
+
attr_accessor :max_pages, :verbose
|
5
|
+
attr_reader :dork, :results, :vendor
|
6
|
+
|
7
|
+
def initialize(dork_url)
|
8
|
+
@dork = dork_url
|
9
|
+
@vendor = "TargetTemplate"
|
10
|
+
@results = Array.new
|
11
|
+
end
|
12
|
+
|
13
|
+
def search
|
14
|
+
raise TargetTemplateErrorDirectCall
|
15
|
+
end
|
16
|
+
|
17
|
+
def summary
|
18
|
+
if results.count == 0
|
19
|
+
puts "[!] No Items Found on #{@vendor}, Try Harder".red if @verbose
|
20
|
+
else
|
21
|
+
puts "[*] Total Items found on #{@vendor}: #{@results.count}".green if @verbose
|
22
|
+
end
|
23
|
+
end
|
24
|
+
|
25
|
+
end
|
26
|
+
end
|
@@ -0,0 +1,77 @@
|
|
1
|
+
# Internal Gist Gist.github Search
|
2
|
+
module Pastenum
|
3
|
+
class Gist < Target
|
4
|
+
|
5
|
+
def initialize(dork)
|
6
|
+
@dork = URI.escape(dork)
|
7
|
+
@agent = Mechanize.new
|
8
|
+
@max_pages = 25
|
9
|
+
@results = Array.new
|
10
|
+
@vendor = "gist.github.com"
|
11
|
+
end
|
12
|
+
|
13
|
+
def search
|
14
|
+
puts "[*] Searching Gist".green if @verbose
|
15
|
+
current_page = 1
|
16
|
+
page_numbers.times do
|
17
|
+
print ".".green if @verbose
|
18
|
+
page = @agent.get("https://gist.github.com/search?page=#{current_page}&q=#{@dork}")
|
19
|
+
page.links.each do |link|
|
20
|
+
|
21
|
+
# Example Hits to find
|
22
|
+
# "/shadowbq/4556950"
|
23
|
+
# "/shadowbq/2718948"
|
24
|
+
|
25
|
+
if link.href.match(/\w+\/[0-9]+/)
|
26
|
+
@results << link.href unless @results.include?(link.href)
|
27
|
+
end
|
28
|
+
end
|
29
|
+
current_page += 1
|
30
|
+
end
|
31
|
+
puts "\n" if @verbose
|
32
|
+
return @results
|
33
|
+
end
|
34
|
+
|
35
|
+
private
|
36
|
+
|
37
|
+
#TODO: This is very inefficient. This is double fetch reading.
|
38
|
+
def page_numbers
|
39
|
+
page_num = 1
|
40
|
+
next_page = true
|
41
|
+
|
42
|
+
print "[*] Parsing pages:".green if @verbose
|
43
|
+
while next_page && page_num < @max_pages
|
44
|
+
|
45
|
+
print "#".green if @verbose
|
46
|
+
begin
|
47
|
+
page = @agent.get("https://gist.github.com/search?page=#{page_num}&q=#{@dork}")
|
48
|
+
rescue
|
49
|
+
raise TargetUnreachable, "[!] ERROR: Can not load gist.github - Check Connectivity"
|
50
|
+
end
|
51
|
+
|
52
|
+
# Find the link with the -> arrow, is it enabled?
|
53
|
+
# //div[@class='pagination']
|
54
|
+
pagination_parsed = false
|
55
|
+
|
56
|
+
page.links.each do |link|
|
57
|
+
if link.href.match(/\/search\?page\=/)
|
58
|
+
if link.text.match(/#x2192/)
|
59
|
+
page_num += 1
|
60
|
+
else
|
61
|
+
next_page = false
|
62
|
+
end
|
63
|
+
pagination_parsed = true
|
64
|
+
end
|
65
|
+
end
|
66
|
+
|
67
|
+
#handle single page of results
|
68
|
+
next_page = false unless pagination_parsed
|
69
|
+
|
70
|
+
end
|
71
|
+
|
72
|
+
return page_num
|
73
|
+
|
74
|
+
end
|
75
|
+
|
76
|
+
end
|
77
|
+
end
|
@@ -0,0 +1,67 @@
|
|
1
|
+
#Internal www.github.com search scraper
|
2
|
+
module Pastenum
|
3
|
+
class Github < Target
|
4
|
+
|
5
|
+
def initialize(dork)
|
6
|
+
@dork = URI.escape(dork)
|
7
|
+
@agent = Mechanize.new
|
8
|
+
@max_pages = 25
|
9
|
+
@results = Array.new
|
10
|
+
@vendor = "github.com"
|
11
|
+
end
|
12
|
+
|
13
|
+
def search
|
14
|
+
puts "[*] Searching Github".green if @verbose
|
15
|
+
current_page = 1
|
16
|
+
page_numbers.times do
|
17
|
+
print ".".green if @verbose
|
18
|
+
page = @agent.get("https://github.com/search?langOverride=&language=&q=#{@dork}&repo=&start_value=#{current_page}&type=Code&x=21&y=22")
|
19
|
+
page.links.each do |link|
|
20
|
+
if link.text.match(/\//)
|
21
|
+
address = "https://github.com#{link.href}"
|
22
|
+
@results << address unless @results.include?(address)
|
23
|
+
end
|
24
|
+
current_page += 1
|
25
|
+
end
|
26
|
+
end
|
27
|
+
puts "\n" if @verbose
|
28
|
+
return @results
|
29
|
+
end
|
30
|
+
|
31
|
+
private
|
32
|
+
|
33
|
+
def page_numbers
|
34
|
+
print "[*] Parsing pages:".green if @verbose
|
35
|
+
|
36
|
+
print "#".green if @verbose
|
37
|
+
|
38
|
+
begin
|
39
|
+
page = @agent.get("http://github.com/search?langOverride=&language=&q=#{@dork}&repo=&start_value=1&type=Code&x=21&y=22")
|
40
|
+
rescue
|
41
|
+
raise TargetUnreachable, "[!] ERROR: Can not load github - Check Connectivity"
|
42
|
+
end
|
43
|
+
|
44
|
+
page_count = []
|
45
|
+
|
46
|
+
page.links.each do |link|
|
47
|
+
if link.href.match(/search\?langOverride/)
|
48
|
+
pagenum = link.text
|
49
|
+
if pagenum.match(/\d/)
|
50
|
+
page_count << pagenum.to_i
|
51
|
+
end
|
52
|
+
else
|
53
|
+
end
|
54
|
+
end
|
55
|
+
|
56
|
+
if page_count.max > @max_pages
|
57
|
+
#puts "[*] #{page_count.max} pages of results found.".green
|
58
|
+
#puts "[*] Getting the first #{@max_pages} pages".green
|
59
|
+
return @max_pages
|
60
|
+
else
|
61
|
+
#puts "[*] #{page_count.max} pages of results found.".green
|
62
|
+
return page_count.max
|
63
|
+
end
|
64
|
+
end
|
65
|
+
|
66
|
+
end
|
67
|
+
end
|
@@ -0,0 +1,45 @@
|
|
1
|
+
#Google sitesearch for pastebin using GScraper
|
2
|
+
module Pastenum
|
3
|
+
class Pastebin < Target
|
4
|
+
|
5
|
+
def initialize(dork)
|
6
|
+
@dork = dork
|
7
|
+
@max_pages = 25
|
8
|
+
@results = Array.new
|
9
|
+
@vendor = "pastebin.com"
|
10
|
+
end
|
11
|
+
|
12
|
+
def search
|
13
|
+
puts "[*] Searching Pastebin.com (Limit: First #{@max_pages} Pages)".green if @verbose
|
14
|
+
q = GScraper::Search.query(:query => @dork, :site => 'pastebin.com')
|
15
|
+
print "[*] Parsing pages: ".green if @verbose
|
16
|
+
begin
|
17
|
+
for i in 1..@max_pages do
|
18
|
+
print ".".green if @verbose
|
19
|
+
page = q.page(i)
|
20
|
+
page.each do |result|
|
21
|
+
result_url = result.url
|
22
|
+
url2 = result_url.to_s.split("&").first
|
23
|
+
url3 = url2.split("=").last
|
24
|
+
# url3 -> "http://pastebin.com/E7SmXKMs"
|
25
|
+
url4 = url3.split("/").last
|
26
|
+
# url4 -> "E7SmXKMs"
|
27
|
+
if url4.length == 8
|
28
|
+
if
|
29
|
+
@results.include?(url4) == true
|
30
|
+
else
|
31
|
+
# result.cached_url.to_s
|
32
|
+
@results << url4
|
33
|
+
end
|
34
|
+
end
|
35
|
+
end
|
36
|
+
end
|
37
|
+
rescue
|
38
|
+
raise TargetUnreachable, "[!] ERROR: Google search unreachable , Maybe the googles banned you?"
|
39
|
+
end
|
40
|
+
puts "\n" if @verbose
|
41
|
+
return @results
|
42
|
+
end
|
43
|
+
|
44
|
+
end
|
45
|
+
end
|
@@ -0,0 +1,57 @@
|
|
1
|
+
#Internal search implementation for pastie.org (deprecated, migrate to Gscraper)
|
2
|
+
module Pastenum
|
3
|
+
class Pastie < Target
|
4
|
+
|
5
|
+
def initialize(dork)
|
6
|
+
@dork = URI.escape(dork)
|
7
|
+
@agent = Mechanize.new
|
8
|
+
@results = Array.new
|
9
|
+
@vendor = "pastie.org"
|
10
|
+
end
|
11
|
+
|
12
|
+
def search
|
13
|
+
print "[*] Parsing pages:".green if @verbose
|
14
|
+
current_page = 1
|
15
|
+
page_numbers.times do
|
16
|
+
print ".".green if @verbose
|
17
|
+
page = @agent.get("http://pastie.org/search?&commit=Start+Search&page=#{current_page}&q=#{@dork}")
|
18
|
+
page.links.each do |link|
|
19
|
+
if link.href.match(/pastie\.org\/pastes/)
|
20
|
+
@results << link.href
|
21
|
+
end
|
22
|
+
end
|
23
|
+
current_page += 1
|
24
|
+
end
|
25
|
+
puts "\n" if @verbose
|
26
|
+
return @results
|
27
|
+
end
|
28
|
+
|
29
|
+
private
|
30
|
+
|
31
|
+
def page_numbers
|
32
|
+
puts "[*] Getting Results".green
|
33
|
+
begin
|
34
|
+
results = @agent.get("http://pastie.org/search?&commit=Start+Search&page=1&q=#{@dork}")
|
35
|
+
rescue
|
36
|
+
raise TargetUnreachable, "[!] ERROR: Can not load pastie.org - Check Connectivity"
|
37
|
+
end
|
38
|
+
puts "[*] Searching Pastie.org (Limit: 1000 Results)".green if @verbose
|
39
|
+
page_count = []
|
40
|
+
results.links.each do |link|
|
41
|
+
if link.href.match(/pastie.org\/pastes\//)
|
42
|
+
page_count << 1
|
43
|
+
else
|
44
|
+
page_count << 0
|
45
|
+
end
|
46
|
+
if link.href.match(/Start%2BSearch&page=/)
|
47
|
+
uri = link.href
|
48
|
+
url = URI("http://pastie.org/search/" + uri)
|
49
|
+
page_num = url.query_params['page']
|
50
|
+
page_count << page_num.to_i
|
51
|
+
end
|
52
|
+
end
|
53
|
+
page_count.max
|
54
|
+
end
|
55
|
+
|
56
|
+
end
|
57
|
+
end
|
data/pastenum.gemspec
ADDED
@@ -0,0 +1,17 @@
|
|
1
|
+
$LOAD_PATH.unshift File.expand_path('../lib', __FILE__)
|
2
|
+
name = "pastenum"
|
3
|
+
require "#{name}/version"
|
4
|
+
|
5
|
+
Gem::Specification.new name, Pastenum::VERSION do |s|
|
6
|
+
s.platform = Gem::Platform::RUBY
|
7
|
+
s.summary = "Search Pastebins for content, fork from nullthreat corelan pastenum2"
|
8
|
+
s.authors = ["nullthreat", "shadowbq"]
|
9
|
+
s.email = ["shadowbq@github.com"]
|
10
|
+
s.homepage = "http://github.com/shadowbq/#{name}"
|
11
|
+
s.files = `git ls-files`.split("\n")
|
12
|
+
s.license = 'MIT'
|
13
|
+
|
14
|
+
s.required_rubygems_version = ">= 1.8.1"
|
15
|
+
|
16
|
+
s.executables = ["pastenum"]
|
17
|
+
end
|
data/public/css/main.css
ADDED
@@ -0,0 +1,121 @@
|
|
1
|
+
/* Layout */
|
2
|
+
|
3
|
+
body {
|
4
|
+
background-color: #931B1C;
|
5
|
+
color: #AAA;
|
6
|
+
font-family: Tahoma, Arial, Helvetica, sans-serif;
|
7
|
+
font-size: .75em;
|
8
|
+
}
|
9
|
+
|
10
|
+
#container {
|
11
|
+
background-color: #000000;
|
12
|
+
margin: 0 auto;
|
13
|
+
padding: 10px;
|
14
|
+
width: 90%;
|
15
|
+
}
|
16
|
+
|
17
|
+
#logo {
|
18
|
+
float: left;
|
19
|
+
width: 124px;
|
20
|
+
}
|
21
|
+
|
22
|
+
#menu {
|
23
|
+
background-color: #333333;
|
24
|
+
float: right;
|
25
|
+
padding: 10px;
|
26
|
+
text-align: right;
|
27
|
+
width: 70%;
|
28
|
+
height: 17px;
|
29
|
+
}
|
30
|
+
|
31
|
+
#footer {
|
32
|
+
background-color: #333333;
|
33
|
+
clear: both;
|
34
|
+
font-size: .80em;
|
35
|
+
padding: 2px;
|
36
|
+
text-align: center;
|
37
|
+
width: 100%;
|
38
|
+
}
|
39
|
+
|
40
|
+
#content {
|
41
|
+
clear: both;
|
42
|
+
padding-top: 5px;
|
43
|
+
padding-bottom: 10px;
|
44
|
+
}
|
45
|
+
|
46
|
+
img {
|
47
|
+
border: none;
|
48
|
+
}
|
49
|
+
|
50
|
+
|
51
|
+
/* Menu */
|
52
|
+
#menu li {
|
53
|
+
display: inline;
|
54
|
+
margin-left: 10px;
|
55
|
+
}
|
56
|
+
|
57
|
+
#menu ul{
|
58
|
+
margin: 0;
|
59
|
+
padding: 0;
|
60
|
+
list-style-type: none;
|
61
|
+
}
|
62
|
+
|
63
|
+
|
64
|
+
/* Portfolio */
|
65
|
+
#portfolio li {
|
66
|
+
display: inline;
|
67
|
+
margin-right: 10px;
|
68
|
+
|
69
|
+
}
|
70
|
+
|
71
|
+
#portfolio ul{
|
72
|
+
margin: 0;
|
73
|
+
padding: 0;
|
74
|
+
list-style-type: none;
|
75
|
+
padding-bottom: 10px;
|
76
|
+
}
|
77
|
+
|
78
|
+
|
79
|
+
/* Text */
|
80
|
+
a:hover {
|
81
|
+
color: #CCCCCC;
|
82
|
+
text-decoration: none;
|
83
|
+
}
|
84
|
+
|
85
|
+
a {
|
86
|
+
color: #888888;
|
87
|
+
text-decoration: none;
|
88
|
+
}
|
89
|
+
|
90
|
+
a.on {
|
91
|
+
color: #CCCCCC;
|
92
|
+
text-decoration: none;
|
93
|
+
}
|
94
|
+
|
95
|
+
h1 {
|
96
|
+
font-family: Georgia, "Times New Roman", Times, serif;
|
97
|
+
font-weight: normal;
|
98
|
+
font-size: 1.3em;
|
99
|
+
}
|
100
|
+
|
101
|
+
.center {
|
102
|
+
text-align: center;
|
103
|
+
}
|
104
|
+
|
105
|
+
input {
|
106
|
+
background-color:#000000;
|
107
|
+
font-family:Tahoma, Arial, Helvetica, sans-serif;
|
108
|
+
font-size:1em;
|
109
|
+
color:#FFFFFF;
|
110
|
+
border-color:#FFFFFF;
|
111
|
+
border-width:thin;
|
112
|
+
}
|
113
|
+
|
114
|
+
textarea {
|
115
|
+
background-color:#000000;
|
116
|
+
font-family:Tahoma, Arial, Helvetica, sans-serif;
|
117
|
+
font-size:1em;
|
118
|
+
color:#FFFFFF;
|
119
|
+
border-color:#FFFFFF;
|
120
|
+
border-width:thin;
|
121
|
+
}
|
Binary file
|
metadata
ADDED
@@ -0,0 +1,67 @@
|
|
1
|
+
--- !ruby/object:Gem::Specification
|
2
|
+
name: pastenum
|
3
|
+
version: !ruby/object:Gem::Version
|
4
|
+
version: 0.2.2
|
5
|
+
prerelease:
|
6
|
+
platform: ruby
|
7
|
+
authors:
|
8
|
+
- nullthreat
|
9
|
+
- shadowbq
|
10
|
+
autorequire:
|
11
|
+
bindir: bin
|
12
|
+
cert_chain: []
|
13
|
+
date: 2013-02-14 00:00:00.000000000 Z
|
14
|
+
dependencies: []
|
15
|
+
description:
|
16
|
+
email:
|
17
|
+
- shadowbq@github.com
|
18
|
+
executables:
|
19
|
+
- pastenum
|
20
|
+
extensions: []
|
21
|
+
extra_rdoc_files: []
|
22
|
+
files:
|
23
|
+
- Gemfile
|
24
|
+
- LICENSE
|
25
|
+
- README.md
|
26
|
+
- RELEASE_NOTES
|
27
|
+
- bin/pastenum
|
28
|
+
- lib/pastenum.rb
|
29
|
+
- lib/pastenum/cli.rb
|
30
|
+
- lib/pastenum/json.rb
|
31
|
+
- lib/pastenum/main.rb
|
32
|
+
- lib/pastenum/report.rb
|
33
|
+
- lib/pastenum/target.rb
|
34
|
+
- lib/pastenum/targets/gist.rb
|
35
|
+
- lib/pastenum/targets/github.rb
|
36
|
+
- lib/pastenum/targets/pastebin.rb
|
37
|
+
- lib/pastenum/targets/pastie.rb
|
38
|
+
- lib/pastenum/version.rb
|
39
|
+
- pastenum.gemspec
|
40
|
+
- public/css/main.css
|
41
|
+
- public/img/corelanlogo_small.jpg
|
42
|
+
homepage: http://github.com/shadowbq/pastenum
|
43
|
+
licenses:
|
44
|
+
- MIT
|
45
|
+
post_install_message:
|
46
|
+
rdoc_options: []
|
47
|
+
require_paths:
|
48
|
+
- lib
|
49
|
+
required_ruby_version: !ruby/object:Gem::Requirement
|
50
|
+
none: false
|
51
|
+
requirements:
|
52
|
+
- - ! '>='
|
53
|
+
- !ruby/object:Gem::Version
|
54
|
+
version: '0'
|
55
|
+
required_rubygems_version: !ruby/object:Gem::Requirement
|
56
|
+
none: false
|
57
|
+
requirements:
|
58
|
+
- - ! '>='
|
59
|
+
- !ruby/object:Gem::Version
|
60
|
+
version: 1.8.1
|
61
|
+
requirements: []
|
62
|
+
rubyforge_project:
|
63
|
+
rubygems_version: 1.8.24
|
64
|
+
signing_key:
|
65
|
+
specification_version: 3
|
66
|
+
summary: Search Pastebins for content, fork from nullthreat corelan pastenum2
|
67
|
+
test_files: []
|