156 lines
5.8 KiB
Ruby
Executable File
156 lines
5.8 KiB
Ruby
Executable File
#!/usr/bin/env ruby
|
|
|
|
#
|
|
# Copyright (c) 2006-2016 Wade Alcorn - wade@bindshell.net
|
|
# Browser Exploitation Framework (BeEF) - http://beefproject.com
|
|
# See the file 'doc/COPYING' for copying permission
|
|
#
|
|
|
|
# stop deprecation warning from being displayed
|
|
$VERBOSE = nil
|
|
|
|
# @note Version check to ensure BeEF is running Ruby 1.9 >
|
|
if RUBY_VERSION < '1.9'
|
|
puts "\n"
|
|
puts "Ruby version " + RUBY_VERSION + " is no longer supported. Please upgrade 1.9 or later."
|
|
puts "OSX:"
|
|
puts "See Readme"
|
|
puts "\n"
|
|
exit
|
|
end
|
|
|
|
$:.unshift(File.join(File.expand_path(File.dirname(__FILE__)), '.'))
|
|
$root_dir = File.expand_path('..', __FILE__)
|
|
|
|
# @note Prevent some errors on encoding: encoding handling changed (improved) from 1.8.7 to 1.9.1/2.
|
|
if RUBY_VERSION =~ /1.9/
|
|
Encoding.default_external = Encoding::UTF_8
|
|
Encoding.default_internal = Encoding::UTF_8
|
|
end
|
|
|
|
# @note Require core loader's
|
|
require 'core/loader'
|
|
|
|
# @note Initialize the Configuration object. Eventually loads a different config.yaml if -c flag was passed.
|
|
if BeEF::Core::Console::CommandLine.parse[:ext_config].empty?
|
|
config = BeEF::Core::Configuration.new("#{$root_dir}/config.yaml")
|
|
else
|
|
config = BeEF::Core::Configuration.new("#{BeEF::Core::Console::CommandLine.parse[:ext_config]}")
|
|
end
|
|
|
|
# @note After the BeEF core is loaded, bootstrap the rest of the framework internals
|
|
require 'core/bootstrap'
|
|
|
|
# @note Loads enabled extensions
|
|
BeEF::Extensions.load
|
|
|
|
# @note Prints the BeEF ascii art if the -a flag was passed
|
|
if BeEF::Core::Console::CommandLine.parse[:ascii_art] == true
|
|
BeEF::Core::Console::Banners.print_ascii_art
|
|
end
|
|
|
|
# @note Check if port and WebSocket port need to be updated from command line parameters
|
|
unless BeEF::Core::Console::CommandLine.parse[:port].empty?
|
|
config.set('beef.http.port', BeEF::Core::Console::CommandLine.parse[:port])
|
|
end
|
|
|
|
unless BeEF::Core::Console::CommandLine.parse[:ws_port].empty?
|
|
config.set('beef.http.websocket.port', BeEF::Core::Console::CommandLine.parse[:ws_port])
|
|
end
|
|
|
|
# @note Check if interactive was specified from the command line, therefore override the extension to enable
|
|
if BeEF::Core::Console::CommandLine.parse[:interactive] == true
|
|
config.set('beef.extension.console.shell.enable',true)
|
|
end
|
|
|
|
# @note Prints BeEF welcome message
|
|
BeEF::Core::Console::Banners.print_welcome_msg
|
|
|
|
# @note Loads enabled modules
|
|
BeEF::Modules.load
|
|
|
|
# @note Disable reverse dns
|
|
Socket.do_not_reverse_lookup = true
|
|
|
|
# @note Database setup - use DataMapper::Logger.new($stdout, :debug) for development debugging
|
|
case config.get("beef.database.driver")
|
|
when "sqlite"
|
|
DataMapper.setup(:default, "sqlite3://#{$root_dir}/#{config.get("beef.database.db_file")}")
|
|
when "mysql", "postgres"
|
|
DataMapper.setup(:default,
|
|
:adapter => config.get("beef.database.driver"),
|
|
:host => config.get("beef.database.db_host"),
|
|
:port => config.get("beef.database.db_port"),
|
|
:username => config.get("beef.database.db_user"),
|
|
:password => config.get("beef.database.db_passwd"),
|
|
:database => config.get("beef.database.db_name"),
|
|
:encoding => config.get("beef.database.db_encoding")
|
|
)
|
|
else
|
|
print_error 'No default database selected. Please add one in config.yaml'
|
|
end
|
|
|
|
# @note Resets the database if the -x flag was passed
|
|
if BeEF::Core::Console::CommandLine.parse[:resetdb]
|
|
print_info 'Resetting the database for BeEF.'
|
|
DataMapper.auto_migrate!
|
|
else
|
|
DataMapper.auto_upgrade!
|
|
end
|
|
|
|
# @note Extensions may take a moment to load, thus we print out a please wait message
|
|
print_info 'BeEF is loading. Wait a few seconds...'
|
|
|
|
# @note Execute migration procedure, checks for new modules
|
|
BeEF::Core::Migration.instance.update_db!
|
|
|
|
# @note Create HTTP Server and prepare it to run
|
|
http_hook_server = BeEF::Core::Server.instance
|
|
http_hook_server.prepare
|
|
|
|
# @note Prints information back to the user before running the server
|
|
BeEF::Core::Console::Banners.print_loaded_extensions
|
|
BeEF::Core::Console::Banners.print_loaded_modules
|
|
BeEF::Core::Console::Banners.print_network_interfaces_count
|
|
BeEF::Core::Console::Banners.print_network_interfaces_routes
|
|
|
|
#@note Prints the API key needed to use the RESTful API
|
|
print_info "RESTful API key: #{BeEF::Core::Crypto::api_token}"
|
|
|
|
#@note Starts the WebSocket server
|
|
if config.get("beef.http.websocket.enable")
|
|
BeEF::Core::Websocket::Websocket.instance
|
|
print_info "Starting WebSocket server on port [#{config.get("beef.http.websocket.port").to_i}], timer [#{config.get("beef.http.websocket.alive_timer")}]"
|
|
if config.get("beef.http.websocket.secure")
|
|
print_info "Starting WebSocketSecure server on port [#{config.get("beef.http.websocket.secure_port").to_i}], timer [#{config.get("beef.http.websocket.alive_timer")}]"
|
|
end
|
|
end
|
|
|
|
|
|
# @note Call the API method 'pre_http_start'
|
|
BeEF::API::Registrar.instance.fire(BeEF::API::Server, 'pre_http_start', http_hook_server)
|
|
|
|
# Load any ARE (Autorun Rule Engine) rules scanning the <beef_root>/arerules/enabled directory
|
|
BeEF::Core::AutorunEngine::RuleLoader.instance.load_directory
|
|
|
|
# @note Start the HTTP Server, we additionally check whether we load the Console Shell or not
|
|
if config.get("beef.extension.console.shell.enable") == true
|
|
require 'extensions/console/shell'
|
|
puts ""
|
|
begin
|
|
log_dir = File.expand_path(config.get("beef.extension.console.shell.historyfolder"))
|
|
FileUtils.mkdir_p(log_dir) unless File.directory?(log_dir)
|
|
rescue => e
|
|
print_error "Could not create log directory for shell history '#{log_dir}': #{e.message}"
|
|
exit 1
|
|
end
|
|
begin
|
|
BeEF::Extension::Console::Shell.new(BeEF::Extension::Console::Shell::DefaultPrompt,
|
|
BeEF::Extension::Console::Shell::DefaultPromptChar, {'config' => config, 'http_hook_server' => http_hook_server}).run
|
|
rescue Interrupt
|
|
end
|
|
else
|
|
print_info 'BeEF server started (press control+c to stop)'
|
|
http_hook_server.start
|
|
end
|