Skip to content

Latest commit

 

History

History
105 lines (79 loc) · 4.54 KB

README.md

File metadata and controls

105 lines (79 loc) · 4.54 KB

Docker Pulls Twitter Follow

Introduction

The Bug Bounty Reconnaissance Framework (BBRF) is intended to facilitate the workflows of security researchers across multiple devices. This repository contains the source files to deploy a BBRF server.

For more information about BBRF, read the blog post on https://honoki.net/2020/10/08/introducing-bbrf-yet-another-bug-bounty-reconnaissance-framework/

Once you have deployed a BBRF server, move on to install the BBRF client here

Installation

Docker

This is the recommended way to install the BBRF server. Simply run the preconfigured docker image to get started:

sudo docker run -p 443:6984 -e COUCHDB_USER=<choose admin username> -e COUCHDB_PASSWORD=<choose admin password> -e BBRF_PASSWORD=<choose bbrf password> honoki/bbrf-server

Note that this will expose port 443 (https) on your BBRF server to the internet. The Docker image generates a self-signed certificate which it stores in /etc/couchdb/cert. You can replace them with "valid" certificates manually if you want to avoid certificate warnings. Alternatively, you can use -p 80:5984 to expose plain HTTP on port 80, but this is not compatible with the BBRF dashboard and is generally discouraged.

You can specify your own BBRF_PASSWORD or remove it to have one automatically generated:

pieter@ferox:~$ sudo docker run -p 443:6984 -e COUCHDB_USER=myadmin -e COUCHDB_PASSWORD=mypassword honoki/bbrf-server
[BBRF] Created following password for user bbrf: 6f761a8554744d0883a0772bf73647cb8ebb61633609c45fba048fd9436de6c4
[BBRF] Initialization complete

Verify your installation by browsing to https://127.0.0.1/_utils/#database/bbrf/_all_docs

Axiom

If you're already using Axiom, deploying is made very easy thanks to @pry0cc

# to deploy a new instance and auto deploy bbrf server:
axiom-init bbrf --deploy=bbrf
# to deploy on an existing box:
axiom-deploy bbrf <your instance name>

Manual installation

To manually install a CouchDB server and configure it as a BBRF server, this is what you need to do:

  • Deploy the CouchDB image from Bitnami from the AWS Marketplace or using docker:

    curl -sSL https://raw.githubusercontent.com/bitnami/bitnami-docker-couchdb/master/docker-compose.yml > docker-compose.yml
    docker-compose up -d
  • My current setup runs on a t3a.small tier in AWS and seems to effortlessly support 116 thousand documents at the time of writing;

  • I strongly suggest enabling (only) https on your server;

  • When up and running, browse to the web interface on https://<your-instance>/_utils/#/_all_dbs and check if everything's OK

  • Create the bbrf user (additional documentation here) via curl:

    COUCHDB=https://<yourinstance>/
    
    curl -X PUT $COUCHDB"_users" \
         -u admin:password
         
    curl -X PUT curl -X PUT $COUCHDB"/_users/org.couchdb.user:bbrf" \
         -u admin:password \
         -H "Accept: application/json" \
         -H "Content-Type: application/json" \
         -d '{"name": "bbrf", "password": "<choose a decent password>", "roles": [], "type": "user"}'
  • Create a new database called bbrf:

    curl -X PUT $COUCHDB"bbrf" \
         -u admin:password
  • Grant access rights to the new database:

    curl -X PUT $COUCHDB"bbrf/_security" \
         -u admin:password \
         -d "{\"admins\": {\"names\": [\"bbrf\"],\"roles\": []}}"
  • Download views.json and configure the required views via curl:

    curl -X PUT $COUCHDB"bbrf/_design/bbrf" \
         -u admin:password \
         -H "Content-Type: application/json" \
         -d @views.json
  • Allow CORS requests from https://bbrf.me to use the dashboard:

    curl -X PUT $COUCHDB"_node/_local/_config/httpd/enable_cors"
         -u admin:password \
         -d '"true"'
    curl -X PUT $COUCHDB"_node/_local/_config/cors/origins" \
         -u admin:password \
         -d '"https://bbrf.me"'
    curl -X PUT $COUCHDB"_node/_local/_config/cors/credentials" \
         -u admin:password \
         -d '"true"'