-
Notifications
You must be signed in to change notification settings - Fork 302
Installation
sudo apt-get install git
- Clone the Github repo,
git clone git://github.com/moloch--/RootTheBox.git
- Switch into the repo directory,
cd RootTheBox
- Run the dependency installation script,
sudo ./setup/depends.sh
follow on screen prompts
If you are on any operating system other than Ubuntu/Debian, you will need to install the dependancies manually, or at least until I get around to improving the setup script.
Root the Box supports MySQL, SQLite, and Postgres. However, it is recommended that you use MySQL.
- Login to mysql
sudo mysql -u root -p
- Create a local user
create user '<user>'@'localhost' identified by '<password>';
Remember your <user> and <password>, we'll need these later. - Create the database
create database rootthebox;
- Setup database permissions
grant all on rootthebox.* to '<user>'@'localhost';
- Exit MySQL
exit
- Clear your MySQL history
echo "" > ~/.mysql_history
- You will need to install the Python Postgres driver, this is not automatically installed by the setup scripts, you can easily install it using
sudo pip install py-postgresql
- Updated your configuration file accordingly
- No setup required, just edit your .cfg file; find the [Database] section and set dialect to sqlite a database file will be created based on the sql_database setting.
- First create a default configuration file by executing the following command:
./rootthebox.py --save
This should create a file in ./files/rootthebox.cfg
with the default config; please note that this the ./files/
directory is the only directory that the application user needs write-access to. These directories can also be optionally changed via the command line interface or thru the config file.
- Find the [Database] section, and edit settings accordingly.
- Be sure to whitelist any IP addresses that need access to the admin interface. This can be done by editing the admin_ips setting, in the [Server] section.
- Ensure that origin is set correctly under the [Server] section, this will be used for websocket connections; if any real-time features are not working properly (notifications, scoreboards, etc) this setting is most likely incorrect.
- To access the admin interface memcached need to be started:
sudo systemctl start memcached
Edit any other applicable settings, please note that you can also modify some settings from the administrative web interface later. For an explanation of each settings please see the configuration details page.
- Next we need to create and initialize the database tables, execute the following command (you only need to do this once):
./rootthebox.py --setup=prod
- Optionally, run
./rootthebox.py --xml foo.xml
to import any XML file(s), you can also import/export XML files later through the web interface. - You may also optionally recompile the Windows botnet binaries if you don't trust the ones from the repo, this can be done using the bot/build_bot.py script (requires Py2Exe). (I'm planning to add cross-compile support at a later time)
- Run the application
./rootthebox.py --start
or if you want to use pypypypy rootthebox.py --start
- Open a Web browser and go to http://<domain>:<port> and you should be greeted with a splash screen.
If everything seems to be working move on to the game setup. NOTE: The admin web interface can only be accessed from whitelisted ip addresses, by default only localhost
is whitelisted.
Some preformatted Avatar images have been assembled to make getting started a little easier: Marvel User Pack and Assorted Team Pack (pw: rootthebox)
. Extract the packs into the relevant user or team directories under files/avatars
.
Root the Box runs well on the Pypy v2.4 (Python 2.7.x) JIT Python implementation. You can find instructions here for building the latest version of Pypy on your platform. There are also binary releases available here. Please note the you will need to install the dependancies into Pypy's site-packages; this is easy to do if you install Pip into Pypy's directory, for example:
$ curl -O https://raw.githubusercontent.com/pypa/pip/master/contrib/get-pip.py
$ ./pypy-2.4/bin/pypy get-pip.py
$ ./pypy-2.4/bin/pip install tornado
You may wish to use Nginx in front of Root the Box; this can be useful for a variety of things. For example we can offload serving static content to Nginx, there is a sample Nginx config file distributed with Root the Box in the setup/
directory. However, you may need to make modifications depending on your platform. If you do use Nginx it is important to firewall off Root The Box's listen port so that it can only talk to Nginx, and enable x_headers
in your Root the Box configuration.
If you run into problems and need to debug here are some useful commands to help, be warned running the application in debug mode will disable certain security features
- Start the application in debug mode:
rootthebox.py --start --debug
- Increase the verbosity of the logs:
rootthebox.py --start --logging=debug
- All of the above:
rootthebox.py --start --debug --logging=debug
- All of the above and log SQL queries:
rootthebox.py --start --debug --logging=debug --log_sql
- Write the logs to a file:
rootthebox.py --start --logging=debug --log_file_prefix=./files/rtb.log