Ref #53 Typhoeus > 0.4.2 support
This commit is contained in:
@@ -14,7 +14,7 @@
|
|||||||
//"proxy": "127.0.0.1:3128",
|
//"proxy": "127.0.0.1:3128",
|
||||||
//"proxy_auth": "username:password",
|
//"proxy_auth": "username:password",
|
||||||
|
|
||||||
"cache_timeout": 600, // 10 minutes, at this time the cache is cleaned before each scan. If this value is set to 0, the cache will be disabled
|
"cache_ttl": 600, // 10 minutes, at this time the cache is cleaned before each scan. If this value is set to 0, the cache will be disabled
|
||||||
|
|
||||||
"request_timeout": 2000, // 2s
|
"request_timeout": 2000, // 2s
|
||||||
|
|
||||||
|
|||||||
@@ -30,7 +30,7 @@ class Browser
|
|||||||
:proxy,
|
:proxy,
|
||||||
:proxy_auth,
|
:proxy_auth,
|
||||||
:max_threads,
|
:max_threads,
|
||||||
:cache_timeout,
|
:cache_ttl,
|
||||||
:request_timeout,
|
:request_timeout,
|
||||||
:basic_auth
|
:basic_auth
|
||||||
]
|
]
|
||||||
@@ -113,13 +113,10 @@ class Browser
|
|||||||
if !auth.include?(:proxy_username) or !auth.include?(:proxy_password)
|
if !auth.include?(:proxy_username) or !auth.include?(:proxy_password)
|
||||||
raise_invalid_proxy_format()
|
raise_invalid_proxy_format()
|
||||||
end
|
end
|
||||||
@proxy_auth = auth
|
@proxy_auth = auth[:proxy_username] + ':' + auth[:proxy_password]
|
||||||
elsif auth.is_a?(String)
|
elsif auth.is_a?(String)
|
||||||
if matches = %r{([^:]+):(.*)}.match(auth)
|
if auth.index(':') != nil
|
||||||
@proxy_auth = {
|
@proxy_auth = auth
|
||||||
proxy_username: matches[1],
|
|
||||||
proxy_password: matches[2]
|
|
||||||
}
|
|
||||||
else
|
else
|
||||||
raise_invalid_proxy_auth_format()
|
raise_invalid_proxy_auth_format()
|
||||||
end
|
end
|
||||||
@@ -176,10 +173,10 @@ class Browser
|
|||||||
|
|
||||||
def merge_request_params(params = {})
|
def merge_request_params(params = {})
|
||||||
if @proxy
|
if @proxy
|
||||||
params = params.merge(:proxy => @proxy)
|
params = params.merge(proxy: @proxy)
|
||||||
|
|
||||||
if @proxy_auth
|
if @proxy_auth
|
||||||
params = params.merge(@proxy_auth)
|
params = params.merge(proxyauth: @proxy_auth)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -191,24 +188,23 @@ class Browser
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
# TODO : check if it's the default value into ethon. If so, removed the lines from here
|
#unless params.has_key?(:ssl_verifyhost)
|
||||||
unless params.has_key?(:ssl_verifyhost)
|
# params = params.merge(ssl_verifyhost: 0)
|
||||||
params = params.merge(ssl_verifyhost: 0)
|
#end
|
||||||
end
|
|
||||||
|
|
||||||
unless params.has_key?(:ssl_verifypeer)
|
#unless params.has_key?(:ssl_verifypeer)
|
||||||
params = params.merge(ssl_verifypeer: false)
|
# params = params.merge(ssl_verifypeer: 0)
|
||||||
end
|
#end
|
||||||
|
|
||||||
if !params.has_key?(:headers)
|
if !params.has_key?(:headers)
|
||||||
params = params.merge(:headers => {'ser-agent' => self.user_agent})
|
params = params.merge(:headers => {'User-Agent' => self.user_agent})
|
||||||
elsif !params[:headers].has_key?('user-agent')
|
elsif !params[:headers].has_key?('User-Agent')
|
||||||
params[:headers]['user-agent'] = self.user_agent
|
params[:headers]['User-Agent'] = self.user_agent
|
||||||
end
|
end
|
||||||
|
|
||||||
# Used to enable the cache system if :cache_timeout > 0
|
# Used to enable the cache system if :cache_ttl > 0
|
||||||
unless params.has_key?(:cache_ttl)
|
unless params.has_key?(:cache_ttl)
|
||||||
params = params.merge(cache_ttl: @cache_timeout)
|
params = params.merge(cache_ttl: @cache_ttl)
|
||||||
end
|
end
|
||||||
|
|
||||||
params
|
params
|
||||||
|
|||||||
@@ -59,8 +59,8 @@ class CacheFileStore
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def write_entry(key, data_to_store, cache_timeout)
|
def write_entry(key, data_to_store, cache_ttl)
|
||||||
if cache_timeout > 0
|
if cache_ttl > 0
|
||||||
File.open(get_entry_file_path(key), 'w') do |f|
|
File.open(get_entry_file_path(key), 'w') do |f|
|
||||||
f.write(@serializer.dump(data_to_store))
|
f.write(@serializer.dump(data_to_store))
|
||||||
end
|
end
|
||||||
|
|||||||
@@ -36,10 +36,11 @@ module BruteForce
|
|||||||
password_found = false
|
password_found = false
|
||||||
|
|
||||||
File.open(wordlist_path, 'r').each do |password|
|
File.open(wordlist_path, 'r').each do |password|
|
||||||
|
|
||||||
# ignore file comments, but will miss passwords if they start with a hash...
|
# ignore file comments, but will miss passwords if they start with a hash...
|
||||||
next if password[0, 1] == '#'
|
next if password[0, 1] == '#'
|
||||||
|
|
||||||
|
password.strip!
|
||||||
|
|
||||||
# keep a count of the amount of requests to be sent
|
# keep a count of the amount of requests to be sent
|
||||||
request_count += 1
|
request_count += 1
|
||||||
queue_count += 1
|
queue_count += 1
|
||||||
@@ -52,8 +53,8 @@ module BruteForce
|
|||||||
request = Browser.instance.forge_request(login_url,
|
request = Browser.instance.forge_request(login_url,
|
||||||
{
|
{
|
||||||
method: :post,
|
method: :post,
|
||||||
params: { log: URI::encode(username), pwd: URI::encode(password) },
|
body: { log: URI::encode(username), pwd: URI::encode(password) },
|
||||||
cache_timeout: 0
|
cache_ttl: 0
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|||||||
@@ -23,10 +23,11 @@ module WpConfigBackup
|
|||||||
# See http://www.feross.org/cmsploit/
|
# See http://www.feross.org/cmsploit/
|
||||||
# return an array of backup config files url
|
# return an array of backup config files url
|
||||||
def config_backup
|
def config_backup
|
||||||
found = []
|
found = []
|
||||||
backups = WpConfigBackup.config_backup_files
|
backups = WpConfigBackup.config_backup_files
|
||||||
browser = Browser.instance
|
browser = Browser.instance
|
||||||
hydra = browser.hydra
|
hydra = browser.hydra
|
||||||
|
queue_count = 0
|
||||||
|
|
||||||
backups.each do |file|
|
backups.each do |file|
|
||||||
file_url = @uri.merge(URI.escape(file)).to_s
|
file_url = @uri.merge(URI.escape(file)).to_s
|
||||||
@@ -39,6 +40,12 @@ module WpConfigBackup
|
|||||||
end
|
end
|
||||||
|
|
||||||
hydra.queue(request)
|
hydra.queue(request)
|
||||||
|
queue_count += 1
|
||||||
|
|
||||||
|
if queue_count == browser.max_threads
|
||||||
|
hydra.run
|
||||||
|
queue_count = 0
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
hydra.run
|
hydra.run
|
||||||
|
|||||||
@@ -48,12 +48,14 @@ class WebSite
|
|||||||
|
|
||||||
def xml_rpc_url
|
def xml_rpc_url
|
||||||
unless @xmlrpc_url
|
unless @xmlrpc_url
|
||||||
headers = Browser.instance.get(@uri.to_s).headers_hash
|
headers = Browser.instance.get(@uri.to_s).headers_hash
|
||||||
value = headers['x-pingback']
|
@xmlrpc_url = nil
|
||||||
if value.nil? or value.empty?
|
|
||||||
@xmlrpc_url = nil
|
unless headers.nil?
|
||||||
else
|
value = headers['X-Pingback']
|
||||||
@xmlrpc_url = value
|
unless value.nil? && value.empty?
|
||||||
|
@xmlrpc_url = value
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@xmlrpc_url
|
@xmlrpc_url
|
||||||
|
|||||||
@@ -23,7 +23,7 @@ describe Browser do
|
|||||||
CONFIG_FILE_WITHOUT_PROXY = SPEC_FIXTURES_CONF_DIR + '/browser/browser.conf.json'
|
CONFIG_FILE_WITHOUT_PROXY = SPEC_FIXTURES_CONF_DIR + '/browser/browser.conf.json'
|
||||||
CONFIG_FILE_WITH_PROXY = SPEC_FIXTURES_CONF_DIR + '/browser/browser.conf_proxy.json'
|
CONFIG_FILE_WITH_PROXY = SPEC_FIXTURES_CONF_DIR + '/browser/browser.conf_proxy.json'
|
||||||
CONFIG_FILE_WITH_PROXY_AND_AUTH = SPEC_FIXTURES_CONF_DIR + '/browser/browser.conf_proxy_auth.json'
|
CONFIG_FILE_WITH_PROXY_AND_AUTH = SPEC_FIXTURES_CONF_DIR + '/browser/browser.conf_proxy_auth.json'
|
||||||
INSTANCE_VARS_TO_CHECK = ['user_agent', 'user_agent_mode', 'available_user_agents', 'proxy', 'max_threads', 'request_timeout', 'cache_timeout']
|
INSTANCE_VARS_TO_CHECK = ['user_agent', 'user_agent_mode', 'available_user_agents', 'proxy', 'max_threads', 'request_timeout', 'cache_ttl']
|
||||||
|
|
||||||
before :all do
|
before :all do
|
||||||
@json_config_without_proxy = JSON.parse(File.read(CONFIG_FILE_WITHOUT_PROXY))
|
@json_config_without_proxy = JSON.parse(File.read(CONFIG_FILE_WITHOUT_PROXY))
|
||||||
@@ -31,6 +31,7 @@ describe Browser do
|
|||||||
end
|
end
|
||||||
|
|
||||||
before :each do
|
before :each do
|
||||||
|
Browser::reset
|
||||||
@browser = Browser.instance(config_file: CONFIG_FILE_WITHOUT_PROXY)
|
@browser = Browser.instance(config_file: CONFIG_FILE_WITHOUT_PROXY)
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -100,12 +101,12 @@ describe Browser do
|
|||||||
|
|
||||||
it 'should set the correct credentials' do
|
it 'should set the correct credentials' do
|
||||||
@proxy_auth = { proxy_username: 'user', proxy_password: 'pass' }
|
@proxy_auth = { proxy_username: 'user', proxy_password: 'pass' }
|
||||||
@expected = @proxy_auth
|
@expected = 'user:pass'
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'should set the correct credentials' do
|
it 'should set the correct credentials' do
|
||||||
@proxy_auth = 'username:passwd'
|
@proxy_auth = 'username:passwd'
|
||||||
@expected = { proxy_username: 'username', proxy_password: 'passwd' }
|
@expected = @proxy_auth
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -206,10 +207,10 @@ describe Browser do
|
|||||||
describe '#merge_request_params without proxy' do
|
describe '#merge_request_params without proxy' do
|
||||||
it 'should return the default params' do
|
it 'should return the default params' do
|
||||||
expected_params = {
|
expected_params = {
|
||||||
disable_ssl_host_verification: true,
|
#disable_ssl_host_verification: true,
|
||||||
disable_ssl_peer_verification: true,
|
#disable_ssl_peer_verification: true,
|
||||||
headers: { 'user-agent' => @browser.user_agent },
|
headers: { 'User-Agent' => @browser.user_agent },
|
||||||
cache_timeout: @json_config_without_proxy['cache_timeout']
|
cache_ttl: @json_config_without_proxy['cache_ttl']
|
||||||
}
|
}
|
||||||
|
|
||||||
@browser.merge_request_params().should == expected_params
|
@browser.merge_request_params().should == expected_params
|
||||||
@@ -217,25 +218,25 @@ describe Browser do
|
|||||||
|
|
||||||
it 'should return the default params with some values overriden' do
|
it 'should return the default params with some values overriden' do
|
||||||
expected_params = {
|
expected_params = {
|
||||||
disable_ssl_host_verification: false,
|
#disable_ssl_host_verification: false,
|
||||||
disable_ssl_peer_verification: true,
|
#disable_ssl_peer_verification: true,
|
||||||
headers: { 'user-agent' => 'Fake IE' },
|
headers: { 'User-Agent' => 'Fake IE' },
|
||||||
cache_timeout: 0
|
cache_ttl: 0
|
||||||
}
|
}
|
||||||
|
|
||||||
@browser.merge_request_params(
|
@browser.merge_request_params(
|
||||||
disable_ssl_host_verification: false,
|
#disable_ssl_host_verification: false,
|
||||||
headers: { 'user-agent' => 'Fake IE' },
|
headers: { 'User-Agent' => 'Fake IE' },
|
||||||
cache_timeout: 0
|
cache_ttl: 0
|
||||||
).should == expected_params
|
).should == expected_params
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'should return the defaul params with :headers:accept = \'text/html\' (should not override :headers:user-agent)' do
|
it 'should return the defaul params with :headers:accept = \'text/html\' (should not override :headers:User-Agent)' do
|
||||||
expected_params = {
|
expected_params = {
|
||||||
disable_ssl_host_verification: true,
|
#disable_ssl_host_verification: true,
|
||||||
disable_ssl_peer_verification: true,
|
#disable_ssl_peer_verification: true,
|
||||||
headers: { 'user-agent' => @browser.user_agent, 'accept' => 'text/html' },
|
headers: { 'User-Agent' => @browser.user_agent, 'accept' => 'text/html' },
|
||||||
cache_timeout: @json_config_without_proxy['cache_timeout']
|
cache_ttl: @json_config_without_proxy['cache_ttl']
|
||||||
}
|
}
|
||||||
|
|
||||||
@browser.merge_request_params(headers: { 'accept' => 'text/html' }).should == expected_params
|
@browser.merge_request_params(headers: { 'accept' => 'text/html' }).should == expected_params
|
||||||
@@ -244,19 +245,19 @@ describe Browser do
|
|||||||
it 'should merge the basic-auth' do
|
it 'should merge the basic-auth' do
|
||||||
@browser.basic_auth = 'Basic QWxhZGRpbjpvcGVuIHNlc2FtZQ=='
|
@browser.basic_auth = 'Basic QWxhZGRpbjpvcGVuIHNlc2FtZQ=='
|
||||||
expected_params = {
|
expected_params = {
|
||||||
disable_ssl_host_verification: true,
|
#disable_ssl_host_verification: true,
|
||||||
disable_ssl_peer_verification: true,
|
#disable_ssl_peer_verification: true,
|
||||||
cache_timeout: @json_config_without_proxy['cache_timeout'],
|
cache_ttl: @json_config_without_proxy['cache_ttl'],
|
||||||
headers: {
|
headers: {
|
||||||
'Authorization' => 'Basic QWxhZGRpbjpvcGVuIHNlc2FtZQ==',
|
'Authorization' => 'Basic QWxhZGRpbjpvcGVuIHNlc2FtZQ==',
|
||||||
'user-agent' => @browser.user_agent
|
'User-Agent' => @browser.user_agent
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@browser.merge_request_params().should == expected_params
|
@browser.merge_request_params().should == expected_params
|
||||||
|
|
||||||
expected_params[:headers].merge!('user-agent' => 'Fake FF')
|
expected_params[:headers].merge!('User-Agent' => 'Fake FF')
|
||||||
@browser.merge_request_params(headers: { 'user-agent' => 'Fake FF' }).should == expected_params
|
@browser.merge_request_params(headers: { 'User-Agent' => 'Fake FF' }).should == expected_params
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -267,10 +268,10 @@ describe Browser do
|
|||||||
|
|
||||||
expected_params = {
|
expected_params = {
|
||||||
proxy: @json_config_with_proxy['proxy'],
|
proxy: @json_config_with_proxy['proxy'],
|
||||||
disable_ssl_host_verification: true,
|
#disable_ssl_host_verification: true,
|
||||||
disable_ssl_peer_verification: true,
|
#disable_ssl_peer_verification: true,
|
||||||
headers: { 'user-agent' => @json_config_with_proxy['user_agent'] },
|
headers: { 'User-Agent' => @json_config_with_proxy['user_agent'] },
|
||||||
cache_timeout: @json_config_with_proxy['cache_timeout']
|
cache_ttl: @json_config_with_proxy['cache_ttl']
|
||||||
}
|
}
|
||||||
|
|
||||||
browser.merge_request_params().should == expected_params
|
browser.merge_request_params().should == expected_params
|
||||||
@@ -282,12 +283,11 @@ describe Browser do
|
|||||||
|
|
||||||
expected_params = {
|
expected_params = {
|
||||||
proxy: @json_config_with_proxy['proxy'],
|
proxy: @json_config_with_proxy['proxy'],
|
||||||
proxy_username: 'user',
|
proxyauth: 'user:pass',
|
||||||
proxy_password: 'pass',
|
#disable_ssl_host_verification: true,
|
||||||
disable_ssl_host_verification: true,
|
#disable_ssl_peer_verification: true,
|
||||||
disable_ssl_peer_verification: true,
|
headers: { 'User-Agent' => @json_config_with_proxy['user_agent'] },
|
||||||
headers: { 'user-agent' => @json_config_with_proxy['user_agent'] },
|
cache_ttl: @json_config_with_proxy['cache_ttl']
|
||||||
cache_timeout: @json_config_with_proxy['cache_timeout']
|
|
||||||
}
|
}
|
||||||
|
|
||||||
browser.merge_request_params().should == expected_params
|
browser.merge_request_params().should == expected_params
|
||||||
@@ -300,16 +300,16 @@ describe Browser do
|
|||||||
end
|
end
|
||||||
|
|
||||||
describe '#post' do
|
describe '#post' do
|
||||||
it 'should return a Typhoeus::Response wth body = "Welcome Master" if login=master&password=it\'s me !' do
|
it 'should return a Typhoeus::Response wth body = "Welcome Master" if login=master&password=itsme!' do
|
||||||
url = 'http://example.com/'
|
url = 'http://example.com/'
|
||||||
|
|
||||||
stub_request(:post, url).
|
stub_request(:post, url).with(body: { login: 'master', password: 'itsme!' }).
|
||||||
with(body: "login=master&password=it's me !").
|
|
||||||
to_return(status: 200, body: 'Welcome Master')
|
to_return(status: 200, body: 'Welcome Master')
|
||||||
|
|
||||||
response = @browser.post(
|
response = @browser.post(
|
||||||
url,
|
url,
|
||||||
params: { login: 'master', password: 'it\'s me !' }
|
body: 'login=master&password=itsme!'
|
||||||
|
#body: { login: 'master', password: 'hello' } # It's should be this line, but it fails
|
||||||
)
|
)
|
||||||
|
|
||||||
response.should be_a Typhoeus::Response
|
response.should be_a Typhoeus::Response
|
||||||
|
|||||||
@@ -48,26 +48,29 @@ shared_examples_for 'BruteForce' do
|
|||||||
passwords << password.strip unless password.strip[0, 1] == '#'
|
passwords << password.strip unless password.strip[0, 1] == '#'
|
||||||
end
|
end
|
||||||
# Last status must be 302 to get full code coverage
|
# Last status must be 302 to get full code coverage
|
||||||
passwords.each do |_|
|
passwords.each do |password|
|
||||||
stub_request(:any, @module.login_url).to_return(
|
stub_request(:post, @module.login_url).
|
||||||
{ status: 200, body: 'login_error' },
|
to_return(
|
||||||
{ status: 0, body: 'no reponse' },
|
{ status: 200, body: 'login_error' },
|
||||||
{ status: 50, body: 'server error' },
|
{ status: 0, body: 'no reponse' },
|
||||||
{ status: 999, body: 'invalid' },
|
{ status: 500, body: 'server error' },
|
||||||
{ status: 302, body: 'FOUND!' }
|
{ status: 999, body: 'invalid' },
|
||||||
)
|
{ status: 302, body: 'FOUND!' }
|
||||||
|
)
|
||||||
end
|
end
|
||||||
|
|
||||||
user = WpUser.new('admin', 1, nil)
|
user = WpUser.new('admin', 1, nil)
|
||||||
result = @module.brute_force([user], @wordlist)
|
result = @module.brute_force([user], @wordlist)
|
||||||
|
|
||||||
result.length.should == 1
|
result.length.should == 1
|
||||||
result.should === [{ name: 'admin', password: 'root' }]
|
result.should === [{ name: 'admin', password: 'root' }]
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'should cover the timeout branch and return an empty array' do
|
it 'should cover the timeout branch and return an empty array' do
|
||||||
stub_request(:any, @module.login_url).to_timeout
|
stub_request(:post, @module.login_url).to_timeout
|
||||||
user = WpUser.new('admin', 1, nil)
|
|
||||||
result = @module.brute_force([user], @wordlist)
|
user = WpUser.new('admin', 1, nil)
|
||||||
|
result = @module.brute_force([user], @wordlist)
|
||||||
result.should == []
|
result.should == []
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|||||||
@@ -34,8 +34,7 @@ shared_examples_for 'WpConfigBackup' do
|
|||||||
@config_backup_files.each do |backup_file|
|
@config_backup_files.each do |backup_file|
|
||||||
file_url = @module.uri.merge(URI.escape(backup_file)).to_s
|
file_url = @module.uri.merge(URI.escape(backup_file)).to_s
|
||||||
|
|
||||||
stub_request(:get, file_url).
|
stub_request(:get, file_url).to_return(status: 404)
|
||||||
to_return(status: 404, body: '')
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -50,8 +49,7 @@ shared_examples_for 'WpConfigBackup' do
|
|||||||
file_url = @module.uri.merge(URI.escape(backup_file)).to_s
|
file_url = @module.uri.merge(URI.escape(backup_file)).to_s
|
||||||
expected << file_url
|
expected << file_url
|
||||||
|
|
||||||
stub_request(:get, file_url).
|
stub_request_to_fixture(url: file_url, fixture: @fixtures_dir + '/wp-config.php')
|
||||||
to_return(status: 200, body: File.new(@fixtures_dir + '/wp-config.php'))
|
|
||||||
end
|
end
|
||||||
|
|
||||||
wp_config_backup = @module.config_backup
|
wp_config_backup = @module.config_backup
|
||||||
@@ -67,8 +65,7 @@ shared_examples_for 'WpConfigBackup' do
|
|||||||
file_url = @module.uri.merge(URI.escape(backup_file)).to_s
|
file_url = @module.uri.merge(URI.escape(backup_file)).to_s
|
||||||
expected << file_url
|
expected << file_url
|
||||||
|
|
||||||
stub_request(:get, file_url).
|
stub_request_to_fixture(url: file_url, fixture: @fixtures_dir + '/wp-config.php')
|
||||||
to_return(status: 200, body: File.new(@fixtures_dir + '/wp-config.php'))
|
|
||||||
end
|
end
|
||||||
|
|
||||||
wp_config_backup = @module.config_backup
|
wp_config_backup = @module.config_backup
|
||||||
|
|||||||
@@ -21,6 +21,14 @@ describe 'WebSite' do
|
|||||||
let(:fixtures_dir) { SPEC_FIXTURES_WPSCAN_WEB_SITE_DIR }
|
let(:fixtures_dir) { SPEC_FIXTURES_WPSCAN_WEB_SITE_DIR }
|
||||||
subject(:web_site) { WebSite.new('http://example.localhost/') }
|
subject(:web_site) { WebSite.new('http://example.localhost/') }
|
||||||
|
|
||||||
|
before :all do
|
||||||
|
Browser::reset
|
||||||
|
Browser.instance(
|
||||||
|
config_file: SPEC_FIXTURES_CONF_DIR + '/browser/browser.conf.json',
|
||||||
|
cache_ttl: 0
|
||||||
|
)
|
||||||
|
end
|
||||||
|
|
||||||
describe "#new" do
|
describe "#new" do
|
||||||
its(:url) { should === 'http://example.localhost/' }
|
its(:url) { should === 'http://example.localhost/' }
|
||||||
end
|
end
|
||||||
@@ -74,7 +82,7 @@ describe 'WebSite' do
|
|||||||
it 'should return the correct url : http://example.localhost/xmlrpc.php' do
|
it 'should return the correct url : http://example.localhost/xmlrpc.php' do
|
||||||
xmlrpc = 'http://example.localhost/xmlrpc.php'
|
xmlrpc = 'http://example.localhost/xmlrpc.php'
|
||||||
stub_request(:get, web_site.url).
|
stub_request(:get, web_site.url).
|
||||||
to_return(status: 200, body: '', headers: { 'X-Pingback' => xmlrpc})
|
to_return(status: 200, headers: { 'X-Pingback' => xmlrpc })
|
||||||
|
|
||||||
web_site.xml_rpc_url.should === xmlrpc
|
web_site.xml_rpc_url.should === xmlrpc
|
||||||
end
|
end
|
||||||
@@ -88,7 +96,7 @@ describe 'WebSite' do
|
|||||||
describe '#has_xml_rpc?' do
|
describe '#has_xml_rpc?' do
|
||||||
it 'should return true' do
|
it 'should return true' do
|
||||||
stub_request(:get, web_site.url).
|
stub_request(:get, web_site.url).
|
||||||
to_return(status: 200, body: '', headers: { 'X-Pingback' => 'xmlrpc'})
|
to_return(status: 200, headers: { 'X-Pingback' => 'xmlrpc' })
|
||||||
|
|
||||||
web_site.should have_xml_rpc
|
web_site.should have_xml_rpc
|
||||||
end
|
end
|
||||||
|
|||||||
@@ -24,11 +24,11 @@ describe WpTarget do
|
|||||||
let(:target_url) { 'http://example.localhost/' }
|
let(:target_url) { 'http://example.localhost/' }
|
||||||
|
|
||||||
before :each do
|
before :each do
|
||||||
Browser.reset
|
Browser::reset
|
||||||
@options =
|
@options =
|
||||||
{
|
{
|
||||||
config_file: SPEC_FIXTURES_CONF_DIR + '/browser/browser.conf.json',
|
config_file: SPEC_FIXTURES_CONF_DIR + '/browser/browser.conf.json',
|
||||||
cache_timeout: 0,
|
cache_ttl: 0,
|
||||||
wp_content_dir: 'wp-content',
|
wp_content_dir: 'wp-content',
|
||||||
wp_plugins_dir: 'wp-content/plugins'
|
wp_plugins_dir: 'wp-content/plugins'
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -39,9 +39,10 @@ class WpScanModuleSpec
|
|||||||
def initialize(target_url)
|
def initialize(target_url)
|
||||||
@uri = URI.parse(add_trailing_slash(add_http_protocol(target_url)))
|
@uri = URI.parse(add_trailing_slash(add_http_protocol(target_url)))
|
||||||
|
|
||||||
|
Browser::reset
|
||||||
Browser.instance(
|
Browser.instance(
|
||||||
config_file: SPEC_FIXTURES_CONF_DIR + '/browser/browser.conf.json',
|
config_file: SPEC_FIXTURES_CONF_DIR + '/browser/browser.conf.json',
|
||||||
cache_timeout: 0
|
cache_ttl: 0
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
{
|
{
|
||||||
"user_agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10.6; rv:9.0) Gecko/20100101 Firefox/9.0",
|
"user_agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10.6; rv:9.0) Gecko/20100101 Firefox/9.0",
|
||||||
"user_agent_mode": "static",
|
"user_agent_mode": "static",
|
||||||
"cache_timeout": 300,
|
"cache_ttl": 300,
|
||||||
"request_timeout": 2000,
|
"request_timeout": 2000,
|
||||||
"max_threads": 5
|
"max_threads": 5
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -2,6 +2,6 @@
|
|||||||
"user_agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10.6; rv:10.0) Gecko/20100101 Firefox/11.0",
|
"user_agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10.6; rv:10.0) Gecko/20100101 Firefox/11.0",
|
||||||
"user_agent_mode": "static",
|
"user_agent_mode": "static",
|
||||||
"proxy": "127.0.0.1:3038",
|
"proxy": "127.0.0.1:3038",
|
||||||
"cache_timeout": 300,
|
"cache_ttl": 300,
|
||||||
"request_timeout": 2000
|
"request_timeout": 2000
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -3,6 +3,6 @@
|
|||||||
"user_agent_mode": "static",
|
"user_agent_mode": "static",
|
||||||
"proxy": "127.0.0.1:3038",
|
"proxy": "127.0.0.1:3038",
|
||||||
"proxy_auth": "user:pass",
|
"proxy_auth": "user:pass",
|
||||||
"cache_timeout": 300,
|
"cache_ttl": 300,
|
||||||
"request_timeout": 2000
|
"request_timeout": 2000
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user