Skip to content

Latest commit

 

History

History
212 lines (148 loc) · 8.05 KB

develop.md

File metadata and controls

212 lines (148 loc) · 8.05 KB

Development Guide

Table of Contents generated with DocToc

Setup your local environment

Ubuntu/Debian

Tested on Ubuntu 14.04

sudo apt-get install -y dpkg-dev virtualbox-dkms linux-headers-$(uname -r) build-essential git
git clone https://github.com/freedomofpress/securedrop
cd securedrop

We recommend using the latest stable version of Vagrant, which is newer than what is in the Ubuntu repositories at the time of this writing. Download the current version from https://www.vagrantup.com/downloads.html (Tested with vagrant 1.6.5)

sudo dpkg -i vagrant.deb
sudo dpkg-reconfigure virtualbox-dkms

vagrant box add trusty64 https://cloud-images.ubuntu.com/vagrant/trusty/current/trusty-server-cloudimg-amd64-vagrant-disk1.box

Finally, install Ansible so it can be used with Vagrant to automatically provision VM's.

Generally, we recommend you install Ansible using pip, which will ensure you have the latest stable version.

sudo apt-get install python-pip
sudo pip install ansible

If you're using Ubuntu, you can install a sufficiently recent version of Ansible from backports (if you prefer): sudo apt-get install ansible/trusty-backports

Tested: ansible 1.7.2

Warning: for now, we do not recommend installing vagrant-cachier. It destroys apt's state unless the VM's are always shutdown/rebooted with vagrant, which conflicts with the tasks in the Ansible playbooks. The instructions in Vagrantfile that would enable vagrant-cachier are currently commented out.

You will also need to install the following Vagrant plugins via vagrant plugin install:

  • vagrant-hostmanager (1.5.0)

Mac OS X

First, install the requirements:

  1. Vagrant
  2. VirtualBox
  3. Ansible
    • There are several ways to install Ansible on a Mac. We recommend using pip instead of homebrew so you will get the latest stable version. To install Ansible via pip,

      $ sudo easy_install pip
      $ sudo pip install ansible
      
  4. You will also need to install the following Vagrant plugins via vagrant plugin install <plugin>:
    • vagrant-hostmanager (1.5.0)

Now you're ready to use vagrant to provision SecureDrop VM's!

Overview

There are predefined VM configurations in the vagrantfile: development, staging, app and mon (production).

  • development: for working on the application code
    • Source Interface: localhost:8080
    • Document Interface: localhost:8081
  • app-staging: for working on the environment and hardening
    • Source Interface: localhost:8082
    • Document Interface: localhost:8083
    • The interfaces and ssh are also available over tor and direct access.
    • A copy of the the Onion urls for source, document and ssh access are written to the vagrant host's ansible-base directory. The files will be named: app-source-ths, app-document-aths, app-ssh-aths
  • mon-staging: for working on the environment and hardening
    • OSSEC alert configuration are in install_files/asnible-base/staging-specific.yml
  • app-prod: This is like a production installation with all of the hardening applied but virtualized
    • A copy of the the Onion urls for source, document and ssh access are written to the vagrant host's ansible-base directory. The files will be named: app-source-ths, app-document-aths, app-ssh-aths
    • Putting the apparmor profiles in complain mode (default) or enforce mode can be done with the ansible tags apparmor-complain or apparmor-enforce.
  • mon-prod: This is a like production installation with all of the hardening applied but virtualized

Development

vagrant up
vagrant ssh development
cd /vagrant/securedrop
./manage.py test        # run the unit and functional tests
./manage.py start       # starts the application servers
./manage.py add_admin   # create a user to use when logging in to the document interface

Staging

The staging environment is a virtual production server that still allows direct access. (you can ssh and hit the web interfaces directly without tor)

If you uncomment the line in the Vagrantfile ansible.skip-tags: [ 'install_local_pkgs' ] the playbook will look for:

securedrop-app-code-0.3-amd64.deb

securedrop-ossec-server-0.3-amd64.deb

securedrop-ossec-agent-0.3-amd64.deb

vagrant up /staging$/
vagrant ssh app-staging
sudo su
cd /var/www/securedrop
./manage.py add_admin
./manage.py test

Prod

You will need to fill out the conf file securedrop/install_files/ansible_base/prod-specific.yml.

To just up a specific server run:

vagrant up /prod$/
vagrant ssh app-prod
sudo su
cd /var/www/securedrop/
./manage.py add_admin

NOTE: The demo instance run the production playbooks (only difference being the production installs are not virtualized). Part of the production playbook validates that staging values are not used in production. One of the values it verifies is that the user ansible runs as is not vagrant To be able to run this playbook in a vagrant/virtualbox environment you will need to disable the validate role.

vagrant up /demo$/ --no-provision
ansible-playbook -i .vagrant/provisioners/ansible/inventory/vagrant_ansible_inventory --private-key ~/.vagrant.d/insecure_private_key -u vagrant install_files/ansible-base/site.yml

In order to access the servers after the install is completed you will need to install and configure a proxy tool to proxy your SSH connection over Tor. Torify and connect-proxy are two tools that can be used to proxy SSH connections over Tor. You can find out the SSH addresses for each server by TODO

connect-proxy (Ubuntu only)

Ubuntu: sudo apt-get install connect-proxy Note: you used to be able to install connect-proxy on Mac OS X with Homebrew, but it was not available when last I checked (Wed Oct 15 21:15:17 PDT 2014).

After installing connect-proxy via apt-get, you can use something along the lines of the following example to access the server. Again you need Tor running in the background.

ssh [email protected] -o ProxyCommand="/usr/bin/connect-proxy -5 -S localhost:9050 %h %p"

You can also configure your SSH client to make the settings for proxying over Tor persistent, and then connect using the regular SSH command syntax. Add the following lines to your ~/.ssh/config:

Hosts *.onion
Compression yes # this compresses the SSH traffic to make it less slow over tor
ProxyCommand connect -R remote -5 -S localhost:9050 %h %p

This proxies all requests to *.onion address through connect-proxy, which will connect to the standard Tor SOCKS port on localhost:9050. You can now connect to the SSH hidden service with:

torify (Ubuntu and Mac OS X)

Ubuntu: torsocks should be installed by the tor package. If it is not installed, make sure you are using tor from the Tor Project's repo, and not Ubuntu's package. Mac OS X (Homebrew): brew install torsocks

If you have torify on your system ($ which torify) and you're Tor running in the background, simply prepend it to the SSH command:

torify ssh [email protected]

Version Notes

Tested with:

vagrant --version
Vagrant 1.6.5
vagrant-cachier (1.0.0)
vagrant-digitalocean (0.7.0)
vagrant-hostmanager (1.5.0)
vagrant-login (1.0.1, system)
vagrant-share (1.1.2, system)
ansible --version
ansible 1.7.2