GaloisInc / BESSPIN-Tool-Suite

The core tool of the BESSPIN Framework.
Other
6 stars 2 forks source link
This material is based upon work supported by the Defense Advanced
Research Project Agency (DARPA) under Contract No. HR0011-18-C-0013. 
Any opinions, findings, conclusions or recommendations expressed in
this material are those of the author(s) and do not necessarily
reflect the views of DARPA.

Distribution Statement "A" (Approved for Public Release, Distribution
Unlimited)

BESSPIN-Tool-Suite

The core tool of the BESSPIN Framework.

Disclaimer: This is prototype beta software, with support provided to SSITH TA-1 teams. It does not currently implement all planned features, and contains bugs both known and unknown. If you encounter a problem or would like to request improvements, please contact Galois through documented support channels.

Table of Contents


Overview

The tool performs a few different tasks that all revolve around the same function. The motivation behind the core functionality, i.e. the function, is to run a program on a target-under-test (TUT) in a robust and reproducible manner, where the TUT can be of multiple different OSes running on several different processor architectures running on multiple different backends.

In particular, the different tasks are called modes, and their different tool flows are described in detail in modes.md. The bug bounty modes have more details in this directory, the security evaluation mode is described in detail here, and the cyberphysical demonstrator's documentation can be found here.

The different OSes are detailed in OSes.md, while the different processors are mentioned here, and the different backends are explained in targets.md.


Software Requirements and Setup

To clone the repo and start the nix-shell, please use:

git clone git@github.com:GaloisInc/BESSPIN-Tool-Suite.git
cd BESSPIN-Tool-Suite
./utils/init_submodules.sh
nix-shell

Alternatively, there is a docker container that has the Nix store populated, and is ready to go. The resources needed to build the docker container are currently in the docker directory. The docker image is galoisinc/besspin:tool-suite, and requires Galois artifactory access to fetch. The recommended command to start the image is:

    sudo docker run -it --privileged=true --network host -v /path/to/BESSPIN-Tool-Suite:/home/besspinuser/BESSPIN-Tool-Suite galoisinc/besspin:tool-suite

Usage

To run the tool, use the following:

usage: besspin.py [-h] [-c CONFIGFILE | -cjson CONFIGFILESERIALIZED]
               [-w WORKINGDIRECTORY] [-l LOGFILE] [-d]
               [-ep {devHost,ciOnPrem,ciAWS,awsProd,awsDev}] [-job JOBID]

BESSPIN (Balancing Evaluation of System Security Properties with Industrial Needs)

optional arguments:
  -h, --help            show this help message and exit
  -c CONFIGFILE, --configFile CONFIGFILE
                        Overwrites the default config file: ./config.ini
  -cjson CONFIGFILESERIALIZED, --configFileSerialized CONFIGFILESERIALIZED
                        Overwrites and augments the default production
                        settings
  -w WORKINGDIRECTORY, --workingDirectory WORKINGDIRECTORY
                        Overwrites the default working directory: ./workDir/
  -l LOGFILE, --logFile LOGFILE
                        Overwrites the default logFile: ./${workDir}/besspin.log
  -d, --debug           Enable debugging mode.
  -ep {devHost,ciOnPrem,ciAWS,awsProd,awsDev}, --entrypoint {devHost,ciOnPrem,ciAWS,awsProd,awsDev}
                        The entrypoint
  -job JOBID, --jobId JOBID
                        The job ID in production mode.

Configuration is explained in detail in configuration.md. Although -cjson is an alternative option, it is strongly recommended to use an INI file as the document describes. The serialized option is specific to the production mode in bug bounty, and is intended to be used automatically by a cloud hook script on a host instantiated by the bug bounty website; more details can be found in the bug bounty documentation.

If the tool is executed manually, there is no need to provide an entrypoint (will be assigned devHost by default), or a job ID. These are for when the tool is executed in batch test mode and CI.

The debug mode will dramatically increase the size of the log file (./${workDir}/besspin.log by default), so please use it only if needed.


Submodules

The tool has the following submodules:


Developer Starter Kit