Files
beef/modules/network/detect_dns_address/module.rb
bcoles@gmail.com a0ba7fa7fc Added module: Detect DNS Address
Fixes issue 141



git-svn-id: https://beef.googlecode.com/svn/trunk@1211 b87d56ec-f9c0-11de-8c8a-61c5e9addfc9
2011-08-19 06:33:21 +00:00

47 lines
1.7 KiB
Ruby

#
# Copyright 2011 Wade Alcorn wade@bindshell.net
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#
# Uses the Packages.javax.naming package with DNS of "dns://"
# Technique discovered by Stefano Di Paola from Minded Security Research Labs
# Advisory: http://blog.mindedsecurity.com/2010/10/get-internal-network-information-with.html
class Detect_dns_address < BeEF::Core::Command
def pre_send
# Mount the doNothing.class on /doNothing.class
# Unsure if there's something we can add here to check if the module was already mounted?
BeEF::Core::NetworkStack::Handlers::AssetHandler.instance.bind('/modules/network/detect_dns_address/doNothing.class','/doNothing','class')
end
def self.options
return [
{'name'=>'command_timeout', 'ui_label'=>'Timeout (s)', 'value'=>'30'}
]
end
def callback
content = {}
content['dns_address'] = @datastore['dns_address'] if not @datastore['dns_address'].nil?
content['fail'] = @datastore['fail'] if not @datastore['fail'].nil?
content['fail'] = 'could not detect dns address' if content.empty?
save content
# Unmount the class now, it's no longer required.
BeEF::Core::NetworkStack::Handlers::AssetHandler.instance.unbind('/doNothing.class');
end
end