Added DNS database model to load resource records from.

Now modules/extensions can dynamically add new RR's. However, changes
don't take effect until BeEF restarts (fix incoming).
This commit is contained in:
soh_cah_toa
2013-05-08 00:03:08 -04:00
parent d24a00a639
commit c7eb1c7fc9
4 changed files with 66 additions and 4 deletions

View File

@@ -11,13 +11,21 @@ module DNS
include Singleton
#UPSTREAM = RubyDNS::Resolver.new([[:udp, '8.8.8.8', 53], [:tcp, '8.8.8.8', 53]])
def run_server(address, port)
EventMachine::next_tick do
RubyDNS::run_server(:listen => [[:udp, address, port]]) do
upstream = RubyDNS::Resolver.new([[:udp, '8.8.8.8', 53], [:tcp, '8.8.8.8', 53]])
BeEF::Core::Models::DNS.each do |record|
name = record.name
type = BeEF::Extension::DNS::DNS.parse_type(record.type)
value = record.value
match(name, type) do |transaction|
transaction.respond!(value)
end
end
otherwise do |transaction|
transaction.passthrough!(upstream)
end
@@ -25,6 +33,31 @@ module DNS
end
end
def add_rule(name, type, value)
d = BeEF::Core::Models::DNS.new(
:name => name,
:type => type,
:value => value
).save
type = BeEF::Extension::DNS::DNS.parse_type(type)
RubyDNS::stop_server
run_server
end
# XXX Why must this be a class method? As a private instance method,
# it throws NoMethodError.
def self.parse_type(type)
resolv = 'Resolv::DNS::Resource'
if type =~ /(A|AAAA|SRV|WKS)/
resolv += '::IN'
end
eval "#{resolv}::#{type}"
end
end
end

View File

@@ -21,3 +21,4 @@ end
require 'extensions/dns/api'
require 'extensions/dns/dns'
require 'extensions/dns/ruby'
require 'extensions/dns/model'

24
extensions/dns/model.rb Normal file
View File

@@ -0,0 +1,24 @@
#
# Copyright (c) 2006-2013 Wade Alcorn - wade@bindshell.net
# Browser Exploitation Framework (BeEF) - http://beefproject.com
# See the file 'doc/COPYING' for copying permission
#
module BeEF
module Core
module Models
class DNS
include DataMapper::Resource
property :name, String
property :type, String
property :value, String
property :id, Serial, :key => true
end
end
end
end

View File

@@ -16,9 +16,9 @@ module RubyDNS
options[:listen].each do |spec|
if spec[0] == :udp
EventMachine.open_datagram_socket(spec[1], spec[2], UDPHandler, server)
@signature = EventMachine.open_datagram_socket(spec[1], spec[2], UDPHandler, server)
elsif spec[0] == :tcp
EventMachine.start_server(spec[1], spec[2], TCPHandler, server)
@signature = EventMachine.start_server(spec[1], spec[2], TCPHandler, server)
end
end
@@ -28,6 +28,10 @@ module RubyDNS
server.fire(:stop)
end
def self.stop_server
EventMachine.stop_server(@signature)
end
class Transaction
# Behaves exactly the same, except using debug logger instead of info