Skip to content

Latest commit

 

History

History
970 lines (735 loc) · 42.8 KB

changelog.md

File metadata and controls

970 lines (735 loc) · 42.8 KB

Changelog

1.0.0~rc1

0.14.0

Web Applications

  • Add support for setting journalist names, and expose via journalist API (#4425, #4459).
  • Update instructions for sources regarding Tor Browser 8.5 security settings (#4462, #4494).
  • Replace cloud icon with download icon in source interface (#4548).
  • Expose supported locales in source interface metadata API (#4467).
  • Remove unnecessary FontAwesome CSS from source interface (#4464).
  • Bug fix: If sessions expire on /generate on the source interface, redirect to index (#4496).
  • Add explanatory text for authenticator reset buttons in Journalist interface (#3274)

Operations

  • Use archive module for securedrop-admin logs command (#4497).
  • Fix Ansible deprecation warnings (#4499).
  • Update grsecurity kernels to version 4.4.182 (#4543).
  • Add intel-microcode as dependency (#4543).
  • Update securedrop-keyring to 0.1.3: update expiration of signing key and add uid (#4578)
  • Switch to keys.openpgp.org as the default keyserver (#4576)
  • Update securedrop-admin tool to use only hkps://keys.openpgp.org when retrieving release key (#4585)

Developer Workflow

  • Add new functional test of /metadata endpoint (#4536).
  • Add workaround for Circle CI’s problems with branch filtering (#4505).
  • Automatically rerun flaky admin tests (#4466).
  • Improve localization manager documentation and update script used for gathering translator names (#4493, #4482, #4469).

Documentation

  • Update SecureDrop screenshots for source, journalist and admin guides (#4564)
  • Update Admin Workstation setup instructions to use keys.openpgp.org (#4586)

0.13.1

  • Fix download of Journalist GPG key via Source Interface (#4523)

0.13.0

Web Application

  • Added fingerprint of GPG reply key to Source object in Journalist API (#4436)
  • Updated message for flagged sources in Source Interface (#4428)
  • Added type hinting in Journalist Interface (#4404, #4407)
  • Added a /logout endpoint to the Journalist API (#4349)
  • Fixed 500 error caused by inconsistent session (#4391)
  • Added submission file sha256 hash as Etag on downloads in Journalist Interface (#4314)
  • Added Python3 compliance for Source and Journalist Interface (#4239)
  • Updated Python cryptography dependency, updated safety check (#4297)
  • Added support for HTTP DELETE method on Journalist Interface for use by API (#4023)
  • Removed cssmin dependency (#4227)
  • Removed jQuery dependency from Journalist and Source Interface (#4211)

Operations

  • Removed support for Ubuntu 14.04 LTS (Trusty) (#4422, #4416, #4348, #4311, #4224)

Developer Workflow

  • Updated functional tests to run against the Tor Browser (#4347)
  • Consolidated CI lint Makefile targets (#4435)
  • Added 0.12.2 boxes for use with the Molecule upgrade scenario (#4393)
  • Added deb tests to builder image update (#4388)
  • Removed unused Jenkins configuration (#4337)
  • Added version pinning for Tor package fetch CI job (#4300)
  • Updated Tor version check to 0.3.5.8 (#4258)
  • Updated staging CI job timeout to 20 minutes (#4218)
  • Added CI job to run page layout tests in all supported languages for i18n-* branches (#4184)
  • Fixed bandit Makefile target (#4429)
  • Added multiple locale settings in staging environment (#4419)
  • Added hypothesis support and example hypothesis test on encrypt/decrypt functionality (#4412)
  • Added support for asynchronous jobs in dev container (#4392)
  • Updated Qubes staging environment to use Xenial by default (#4344, #4228)
  • Updated dev environment to use Xenial by default (#4213)
  • Fixed Dockerfile apt caching error, fixed error in create_dev_data.py (#4353)
  • Added support for use of VNC during functional tests (#4288, #4324)
  • Added support for staging-specific data to create-dev-data.py (#4298)
  • Removed firefox and other packages from app-test Ansible role (#4277)
  • Added option to control number of sources created in a dev environment (#4274)
  • Added check to ensure dev virtualenv uses Python 2 (#4127)

Documentation

  • Added instructions on backing up and restoring workstations with rsync (#4402)
  • Updated references to 4-port firewall in server setup docs (#4430)
  • Standardized references to Submission Key (#4413)
  • Updated links to Tails documentation (#4409)
  • Clarified use of KeePassX in passphrases documentation (#4368)
  • Renamed "Terminology" section to "Glossary" (#4405)
  • Added instructions for upgrading to Xenial after Trusty EOL (#4395)
  • Clarified workstation hardware requirements (#4369)
  • Updated logging documentation (#4359)
  • Updated release management documentation (#4386)
  • Updated nginx landing page example and journalist onboarding guide (#4370)
  • Added attacks and countermeasures to SecureDrop threat model document (#4244)
  • Added recommendation to backup workstations (#4302)
  • Updated recommended Apache configuration in landing page guide (#4238)
  • Updated pronouns in journalist guide (#4254)
  • Updated README to make it easier to credit i18n contributors (#4243)

0.12.2

Web Application

  • Remove NoScript upload instructions on Source Interface (#4160)
  • Disable Source Interface on instances running Trusty after April 30th (#4325)
  • SecureDrop application dependencies have been updated (#4346)

Operations

  • SecureDrop grsec kernels have been updated to 4.4.177 and provide support for Intel e1000e series NICs (#4308)
  • OSSEC test notifications will now generate ossec alerts (#4340)
  • Updated AppArmor for Apache2 (#4362)

Tails Environment

  • Backup script should now more reliably download large backups from the app server (#4326)
  • SecureDrop GUI updater should now be limited to a single running instance (#4309)

Documentation

  • Instruct admin to look up latest Tails version for Xenial upgrade (#4325)

0.12.1

Web Application

  • Add "Back to submission page" link to NoScript docs (#4208)

Operations

  • Ensured WiFi related packages are not installed on Xenial on upgrade (#4163)
  • Try harder to attach to a tmux session on upgrade (#4221)
  • Control locale during Ansible runs (#4252)

Tails Environment

  • Resolved error in GUI updater due to flaky keyservers (#4100)

Documentation

  • Add documentation indicating fresh installs should be done on the Ubuntu 16.04.6 iso (#4234)

0.12.0

Web Application

  • Add Romanian and Icelandic as supported languages (#4187)
  • Added toggle to show password for journalists on login (#3713)
  • Updated language referencing Tor button (#4131, #4141)
  • Added instructions for disabling NoScript XSS because of upload problem (#4078, #4159)
  • Prevented setting session cookies on API endpoints (#3876)
  • Updated API to allow clients to set a reply's UUID (#3957)
  • Changed GPG key generation to avoid leaking key creation date (#3912)
  • Fixed race condition that caused all public keys to be exported by API (#4005)
  • Added filename to payload when creating a reply via the API (#4047)
  • Fix bug that caused internal server errors on malformed auth tokens (#4053)
  • Added alert on journalist interface to alert when the operating system is out of date (#4027)
  • Added journalist UUID to payload when creating an auth token via the API (#4081)
  • Added GPG 2.1+ compatibility (#3622, #4013, #4038, #4035)
  • Added OS information to metadata endpoint (#4059)

Operations

  • Removed hardcoded Ansible plugin profile_tasks (#2943)
  • Fixed restore logic to ensure recreation of onion services (#3960, #4136)
  • Added logic to conditionally update the release-upgrades prompt (#4104, #4142)
  • Added logic to ensure packages required by Ansible are present on Xenial systems (#4109, #4143)
  • Ensured Tor is installed from FPF repo (#4175, #4169)
  • Set Debian packages to only use explicitly declared conffiles (#4176, #4161)
  • Removed iptables UID restrictions to allow apt to work correctly (#3952)
  • Updated kernels to 4.4.167 and removed wireless support (#2726)
  • Updated cron-apt remove action to occur after security (#4003)
  • Updated AppArmor profile for Xenial (#3962)
  • Removed common-auth PAM customizations (#3963)
  • Updated ./securedrop-admin logs command to log installed packages (#3967) and cron-apt logs (#4000)
  • Explicitly declared onion services as v2 (#4092)
  • Added ability to store both Trusty and Xenial Debian packages (#3961)
  • Added ability to fetch upstream Tor Debian packages for inclusion in FPF repo (#4101)
  • Run haveged confined on Xenial (#4098)
  • Updated PaX flag management for on Apache on Xenial (#4110)

Developer Workflow

  • Fixed the QA data loader to prevent clobbering data (#3793)
  • Fixed updated version script (#4146)
  • Added nested virtualized to CI (#3702)
  • Moved to Vagrant 2.1.x (#3350)
  • Fixed linting tasks on macOS (#3996)
  • Added automatic re-running of flaky admin tests (#4004)
  • Increased max line to 100 characters for Python files (#4006)
  • Re-added static analysis and Python dependency checking to CI (#4033)
  • Updated setuptools in CI (#4036)
  • Added Trusty and Xenial test targets to CI (#3966)
  • Moved CI nightly jobs to 4AM UTC (#4067)
  • Fixed bug where failed CI runs were reported as successes (#4066)
  • Fixed Xenial-specific errors in tests (#4037, #4039)
  • Added 0.11.1 upgrade testing boxes (#4093)
  • Ensured config test coverage on Xenial (#3964)

Documentation

  • Added documentation on how to test upgrades (#3832)
  • Added documentation on how to set the locales (#3846)
  • Added documentation for upgrading from 0.10.0 to 0.11.x (#3982)
  • Added documentation on how to prepare the app and mon servers for upgrade to Xenial (#4044)
  • Updated date where SecureDrop uses Ubuntu Trusty as default OS (#4062)
  • Updated list of hardware recommendations to remove Gigabyte BRIX (#3197, #4075) and added updates to NUCs and Mac Minis (#3976)
  • Added note about how dev can generate 2FA tokens (#4095)
  • Removed old markdown redirect (#4097)
  • Updated SecureDrop client references (#4102)

0.11.1

Operations

  • Security bugfix: Upgrade apt without following redirects on first install, addresses CVE-2019-3462 (#4061)

0.11.0

Web application

  • UX improvement: Add username constraints to admin user addition page text (#3746)
  • UX improvement: Removed screensaver from the source interface (#3722)
  • Update icons on source interface (#2508, #3809)
  • Replace 'administrator' with 'admin' in the journalist interface (#3940)
  • API: Posting replies returns uuid (#3915)
  • Bugfix: Save only the base filename in DB for replies using API (#3918)

Operations

  • Bugfix: resolve OSSEC GPG key import issue in Ansible (#3928)
  • Updated Ansible to 2.6.8 (#3945)
  • Update grsecurity kernels to 4.4.162 (#3913)
  • Security bugfix: Disable unecessary sshd config options (#3979)
  • Removes 3.14.x grsecurity kernels (#3913)

Developer Workflow

  • Updated instruction to merge translations to & from the new Weblate (#3929)
  • Updated requests module to 2.20.0 (#3908)
  • Updated copyright statement to acknowledge all contributors (#3930)
  • Added initial client documentation (#3922)

0.10.0

Web Applications

  • UX: modify size of input boxes to accommodate long passphrases (#3761)
  • Security bugfix: sources can no longer delete replies for other sources if they know the target filename (#3892)

Operations

  • Updated OSSEC to 3.0.0 and use GPG signatures for verifying sources (#3701)
  • Update paramiko to 2.4.2 (#3861)
  • Enforce use of the latest grsecurity-patched kernel on servers (#3842)

Development

  • Xenial transition: Enable clean install in Xenial staging environment (#3833)
  • Document Molecule upgrade scenario (#3720)

0.9.1

  • Bugfix: Resolve error in SecureDrop Updater due to incorrect working directory (#3796)

The issues for this release were tracked in the 0.9.1 milestone on GitHub: https://github.com/freedomofpress/securedrop/milestone/47

0.9.0

Web Applications

  • Argon2 is now used to hash journalist passwords (#3506)
  • Preserve conversation history only for journalists (#3688, #3690)
  • Journalist interface can now be accessed via API (#3700)

Operations

  • Updated the grsecurity-hardened Linux Kernels to 4.4.144 for app and mon servers (#3662)
  • Updated tor to version 0.3.3.9 (#3624)
  • Updated Flask to 1.0.2 and Werkzeug to 0.14.1 (#3741)
  • Updated securedrop-keyring package to 0.1.2 (#3752)

Tails Environment

  • Updated cryptography to 2.3 (#3679)

Developer Workflow

  • Dev container: Docker ports are now mapped only to localhost (#3693)

Documentation

  • Miscellaneous documentation improvements (#3623, #3624, #3655, #3670, #3717, #3710)

The issues for this release were tracked in the 0.9 milestone on Github: https://github.com/freedomofpress/securedrop/milestone/44

0.8.0

Web Applications

  • Adds a new supported language: Swedish (#3570)
  • Replace PyCryptodome with pyca/cryptography (#3458)
  • Add explanatory text to source interface screensaver (#3439, #3455)
  • Rename "Delete collection" on journalist interface for clarity (#2419)
  • Security: Login throttling is now per-user, mitigating a DoS vector (#3563)

Operations

  • Updated the grsecurity-hardened Linux Kernels to 4.4.135 on app and mon servers (#3494)
  • Fixed race condition with journalist notification where a daily notification would not be sent (#3479)
  • Removed 2FA for console logins for app and mon servers (#3507)
  • Suppresses OSSEC alerts asking SecureDrop administrators to upgrade to Xenial (#3205)
  • Upgraded to Tor 0.3.3.7 on app and mon servers (#3518)
  • Bugfix: Enable mon and app servers to use /32 addresses (#3465)

Tails Environment

  • Support conditional questions in securedrop-admin sdconfig (#3401)
  • Security: Ensure that a branch cannot accidentally be checked out after tag verification (#3567)

Developer Workflow

  • Use Alembic to version control database schema (#3211, #3260, #3273)
  • Integration tests for securedrop-admin sdconfig (#3472)
  • Use pytest for more Journalist Interface unit tests (#3456)
  • Rename Document Interface to Journalist Interface in Docker development environment (#3397)

Documentation

  • Miscellaneous documentation improvements (#3404, #3405, #3431, #3435,#3437, #3440, #3457, #3463, #3467, #3468, #3476, #3480)

The issues for this release were tracked in the 0.8 milestone on Github: https://github.com/freedomofpress/securedrop/milestone/43

0.7.0

Web Applications

  • Updated messages on source interface (#3036, #3132, #3321, #3322)
  • Use io.open instead of open across the web applications (#3064)
  • Include token reuse under login hardening flag (#3175)
  • Add Orbot warning in source interface (#3215)
  • Removed compression time metadata on submission gzip archives (#3305)
  • Resolve HTTPS CSRF validation failure due to Referrer-Policy on source interface (#3351)

Operations

  • Admins can optionally enable a daily encrypted email sent to journalists indicating whether or not they should check SecureDrop (#1195, #2803)
  • Admins can optionally disable the use of Tor for SSH and enable SSH over local network (#2592)
  • Remove vanilla Xenial Ubuntu kernels at install-time (#3158)
  • Added daily_reboot_time option in sdconfig (#3172)
  • Removes duplicate tor-apt repo from apt config (#3189)
  • Remove installed vanilla kernels via cron-apt (#3196)
  • Fixed typo in ansible restore script (#3263)

Tails Environment

  • Securedrop-admin update: Try alternate keyserver if primary is not available (#3257)
  • Fixed typo in ansible restore script (#3263)
  • Add SecureDrop Administrator Workstation updater GUI (#3300)
  • Add HTTPS-related variables to securedrop-admin sdconfig prompt (#3366)
  • Improved tag validation logic for securedrop-admin update (#3406)

Developer Workflow

  • Add test data to Docker development environment (#3081)
  • i18n: centralize the list of supported languages in ./i18n_tool.py (#3100)
  • The Vagrant development environment VM has been deprecated (#3271). The current supported development environments are as follows: ** The Docker development environments for application code changes and securedrop-admin changes. ** Staging or production Vagrant VMs for all other changes.
  • Improved application tests by using pytest fixtures (#3140, #3179, #3181, #3183, #3190, #3191, #3249, #3250, #3256)
  • Unit tests: Verify journalist username containing whitespace can login (#3218)
  • Added hashes for pluggy python wheels (#3272)

Documentation

  • Update branch management docs (#3171)
  • Add Release manager guide (#3202)
  • Miscellaneous documentation improvements (#3099, #3147, #3153, #3156, #3168, #3201, #3252, #3265, #3295, #3315, #3359).

The issues for this release were tracked in the 0.7 milestone on Github: https://github.com/freedomofpress/securedrop/milestones/0.7.

0.6

Web Applications

  • Adds CSS-based source deletion confirmation (#295 ,#2946).
  • Resolve responsive issues on source and journalist interfaces (#2891, #2974).
  • Remove config global state (#2969).
  • Add functional test coverage for all JavaScript functionality (#2405).
  • Migrate to Flask-SQLAlchemy (#2866).
  • Improve UX on admin logo uploads (#2876).
  • Enable vacuum and secure delete in the database (#2868).
  • Bugfix: Ensure session is available for async_genkey (#2988).
  • Bugfix: Fix user confirmation before 2FA reset (#2920).

Operations

  • Update grsecurity-hardened kernels to 4.4.115 (#3077).
  • Bump Ansible version to 2.4.2 (#2929).
  • Allow sasl_domain to be empty (#2482).
  • Bugfix: Update AppArmor rule for Apache (#3020).
  • Allow syscheck to monitor /var/lib/tor/services (#2960).

Tails Environment

  • Add commands to check for and apply updates to the securedrop-admin CLI (#2976).

Developer Workflow

  • Make the Docker-based development environment the default (#2902).
  • Rebase branches prior to running CI jobs (#2934).
  • Implement dev-shell script for interactive execution of commands in development containers (#2861, #2956).
  • Adds Bandit static analyzer for automated security scanning (#3055).
  • Adds initial support for checking type annotation (#3001, #3006, #3032).
  • Adds test user to development environment (#3040).
  • Update release script for new release candidate policy (#2950).

Documentation

  • Miscellaneous documentation improvements.

The issues for this release were tracked in the 0.6 milestone on Github: https://github.com/freedomofpress/securedrop/milestones/0.6.

0.5.2

  • Replace PyCrypto (#2903).
  • Use max_fail_percentage to force immediate Ansible exits in playbook runs (#2922).
  • Bugfix: Dynamically allocate firewall during OSSEC registration (#2748).
  • Bugfix: Add all languages to sdconfig prompt (#2935).

The issues for this release were tracked in the 0.5.2 milestone on Github: https://github.com/freedomofpress/securedrop/milestone/41

0.5.1

Web Applications

  • Add Arabic, Chinese, Turkish and Italian translations (#2830).
  • Enable administrators to update the SecureDrop logo via the Admin Interface (#2769).
  • Enable administrators to send test OSSEC alerts via the Admin Interface (#2771).
  • Improve the language menu (#2733).
  • Disable .map file generation when compiling CSS files from SASS (#2814).
  • User logout on password reset (#2756).
  • Update pip requirements (#2811).

Operations

  • Use apt mirror for Tor packages (#2441).
  • Push grsecurity tasks to the beginning of the install process (#2741).
  • Remove flaky SMTP/SASL host validation during SecureDrop configuration (#2815).
  • Automate post-Ubuntu install checks verifying DNS, NTP is working (#2129).
  • Validate GnuPG key is not a private key prior to install (#2735).
  • Remove HMAC-SHA1 from SSH config (#2730).

Monitoring

  • Prevent OSSEC from sending daily emails on startup (#2701).

Documentation

  • Replace Google Authenticator with FreeOTP (#2757).
  • Add recommended landing page content (#2752).

The issues for this release were tracked in the 0.5.1 milestone on Github: https://github.com/freedomofpress/securedrop/milestones/0.5.1.

0.5

Web Applications

  • Internationalize both web applications (#2470, #2392, #2400, #2374, #2626, #2354, #2338, #2333, #2229, #2223).
  • Localize in Dutch, French, German, Norwegian, Portuguese and Spanish.
  • Add language picker to web applications (#2557).
  • Refactor both web applications using Flask Blueprints (#2294).
  • Add default 120 minute session timeout on both interfaces (#880, #2503).
  • Only show source codename on first session (#2327).
  • Invert login_required decorator on journalist interface so that logins are required by default (#2460).
  • Require entry of old password before changing password (#2304).
  • Use whitespace control on Jinja templates (#2413).
  • Add reset icon to reset password button (#2423).
  • Improve form validation on new user creation in journalist interface (#2500).
  • Improve form validation on login form on source interface (#2376).
  • Resolve confusing use of first/third person on user creation (#2323).
  • Show which journalist is logged in on the journalist interface (#2293).
  • Create friendly session expiry page (#2290).
  • Improve UX to get to individual source page on journalist interface (#2130).
  • Improve UX on login forms by making fields longer (#2288).
  • Bugfix: Fix input validation on Yubikey for 2FA HOTP (#2311).
  • Bugfix: Remove extra level in folders in submission downloads (#2262).

Operations

  • Allow apache/apparmor file exception for proving onion ownership to a CA (#2602)
  • Enable admins to set supported locales via SecureDrop admin script (#2516)
  • Update AppArmor rules for Apache (#2507).
  • Reduce number of pip requirements files (#2175).

Monitoring

  • Add /boot to integrity checking (#2496).
  • Bugfix: Remove OSSEC syscheck monitoring of temporary files produced by bulk download (#2606).

Tails Environment

  • Bugfix: Use host for SASL and SMTP domain validation (#2591).
  • Bugfix: Add trusted metadata to SecureDrop .desktop files (#2586).

Developer Workflow

  • Add updated Data Flow Diagrams (#2370).
  • Add safety check for Python dependencies in CI (#2451).
  • Remove noisy GnuPG debug output on test failure (#2595).
  • Convert tests in SubmissionNotInMemoryTest to pytest (#2548).
  • Document virtualized Admin Workstation setup (#2204, #2607).
  • Bugfix: Remove extra rqworker start in unit tests (#2613).
  • Bugfix: Resolve test failures in VirtualBox (#2396).

Documentation

  • Add sample SecureDrop privacy policy to documentation (#2340).
  • Break out "Deployment Best Practices" into discrete docs section (#2339).

The issues for this release were tracked in the 0.5 milestone on Github: https://github.com/freedomofpress/securedrop/milestones/0.5.

0.4.4

Bugfix release. Fixes configuration management logic to ensure all packages are properly validated prior to installation.

  • Remove force=yes in package install tasks in Ansible config.
  • Upgrade Ansible to 2.3.2 to address CVE-2017-7481.
  • Add securedrop-admin logs command for collecting log files.
  • Increases expiration date on SecureDrop Release Signing Key to October 2018.

Since this is a bugfix release, the changes on the 0.4.4 milestone are not included here. Those issues have been postponed to a future release.

0.4.3

The issues for this release were tracked in the 0.4.3 milestone on Github: https://github.com/freedomofpress/securedrop/milestones/0.4.3.

Web Applications

  • Automatically generate diceware passphrases for SecureDrop journalists and administrators (#980).
  • Add minimum length check for journalist usernames (#1682).
  • Resolve inconsistently named source IDs (#1998).
  • Fix transient test errors (#2122, #2214, #2205).
  • Progress towards internationalizing SecureDrop: Add utilities for extracting strings for translation and for compiling translations (#2120), add DEFAULT_LOCATE to config.py (#2197).
  • Make source interface index responsive (#2235).
  • Remove safe filter from jinja templates (#2227).

Operations

  • Retry SMTP relay and SASL domain verification tasks in validate role (#2099).
  • Disable Postfix in the staging environment (#1164).
  • Refactor Debian package build logic (#2160).
  • Reboot staging servers on first provision (#1704).
  • Bugfix: Whitelist fontawesome-webfont.svg in AppArmor (#2075).

Tails Environment

  • Bugfix: Use .xsessionrc in SVS to prevent unpacking of office files (#2188).

Monitoring

  • Remove OSSEC alert for Tor Guard overloaded log event (#1670).
  • Remove OSSEC alert when journalists bulk delete submissions (#1691).
  • Remove OSSEC alert for OSSEC keepalive event (#2138).
  • Add "Ansible playbook run on server" OSSEC rule (#2224).
  • Update locations of logs on app server for OSSEC syscheck (#2153).
  • Adds regression testing for OSSEC false positives (#2137).

Developer Workflow

  • Adds flake8 linting (#886).
  • Add code style guide for contributors (#47).
  • Produce screenshots before and after Selenium tests for debugging (#2086).
  • Add HTML linting (#2081).
  • Add Makefile targets for linters (#1920).
  • Adds "page layout" automated tests that take screenshots of the source and journalist interface in each language (#2141).
  • Expose documentation on port 8000 on development machine (#2170).
  • Make Makefile self-documenting (#2169).
  • Add pre-commit hook for developers (#2234).
  • CI: Do not run staging CI if only documentation has changed (#2132).
  • CI: Use new Trusty image for Travis CI (#1876).

Documentation

  • Adds guide and glossary for translators (#2039, #2162).
  • Adds i18n guide for developers (#2118).
  • Adds note in Tails upgrade documentation about missing "Root Terminal" launcher in workstation backup procedure (#2065).
  • Update AppArmor developer documentation (#2077).
  • Adds pre-installation checklist (#2139).
  • Specify NTP server to use in install documentation (#2094).
  • Adds new tested printer for use in SecureDrop airgap (#2117).
  • Add documentation for multiple administrators managing config (#2096).
  • Update KeePassX (#2158).
  • Add documentation for using gksu nautilus in lieu of "Root Terminal" in Tails 3 backup process (#2069).
  • Update hardware requirements (#2207).

0.4.2

  • Explicitly enables DAC override capability in Apache AppArmor profile (#2105)

The issues for this release were tracked in the 0.4.2 milestone on Github: https://github.com/freedomofpress/securedrop/milestones/0.4.2.

0.4.1

  • Fixes a bug in one of the Tails scripts used to set up the Desktop icons for the SecureDrop interfaces (#2049)

The issues for this release were tracked in the 0.4.1 milestone on Github: https://github.com/freedomofpress/securedrop/milestones/0.4.1.

0.4

The issues for this release were tracked in the 0.4 milestone on Github: https://github.com/freedomofpress/securedrop/milestones/0.4.

This changelog shows major changes below. Please diff the tags to see the full list of changes.

Deployment

  • Enable optional HTTPS on the source interface (#1605).
  • Standardize SecureDrop server installation on a single username (#1796).
  • Add securedrop-admin script and update version of Ansible running in the workstation (#1146, #1885).
  • Add validation of user-provided values during SecureDrop installation (#1663, #749, #1257).
  • Removes prod-specific.yml configuration file (#1758).
  • Allow an administrator to set a custom daily reboot time (#1515).
  • Renames "document interface" to "journalist interface" (#1384, #1614).
  • Adds "Email from" option to OSSEC (#894, #1220).
  • Updated template for Firewall and adds instructions on how to use it (#1122, #1648)
  • Bugfix: Re-enable logging on journalist interface (#1606).

Developer Workflow

  • Reconciles divergent master and develop branches (#1559).
  • Increases unit test coverage to from 65% to 92%.
  • Adds testinfra system configuration test suite (#1580).
  • Removes unnecessary test wrappers (#1412).
  • Major improvements to SecureDrop CI and testing flow including adding the staging environment to CI (#1067).

Web App: Source

  • Mask codename on source interface (#525).
  • Replace confusing text on source interface landing bar (#1713).
  • Refresh of source UI (#1536, #1895, #1604).
  • Add metadata endpoint to source webapp for monitoring (#972).
  • Begin using EFF wordlist (#1361).

Web App: Journalist

  • Feature: Add unread submission icon and select all unread button to submission view (#1353).
  • Refresh of journalist UI (#1604).
  • Adds minimum password length requirements for new journalist accounts (#980).
  • Delete submissions that have had their sources deleted (#1188).
  • Bugfix: Empty replies can no longer be sent to a source (#1715).
  • Bugfix: Handle non hexadecimal digits for the 2FA secret (#1869).
  • Bugfix: Handle token reuse for the 2FA secret on /admin/2fa (#1687).
  • Bugfix: Handle attempts to make duplicate user accounts (#1693).
  • Bugfix: Fix confusing UI on message/reply icons (#1258).

Tails Environment

  • Improve folder structure for SecureDrop documents (#383).
  • Bugfix: Update provided KeePassX template to kdbx format (#1831).
  • Bugfix: Ensure the filename is restored when uncompressing an archive (#1862).

Documentation

  • Adds "What makes SecureDrop unique?" guide (#469).
  • Adds passphrase best practices guide (#1136).
  • Adds SecureDrop promotion guide (#1134).
  • Adds Administrator responsibilities guide (#1727).
  • Other minor miscelleanous documentation improvements.

0.3.12

  • Disables swap on Application Server via preinst script on securedrop-app-code package hook. Swap was not previously disabled permanently, so this automatic update will deactivate it, shred the swap partition if it was in use, then disable swap entries in /etc/fstab. A separate change in future release will enforce this configuration via the Ansible config at install time (#1620)

0.3.11

  • Instructs source to turn the Tor Browser security slider to High and to get a new Tor Browser identity after logout. Turning the security slider to high would disable the SVG icons so the icons and CSS on the source interface are updated to display properly using this setting (#1567, #1480, #1522)
  • Adds /logout route and button to base template (#1165)
  • Removes the choice of number of codename words from the source interface (#1521)
  • Adds SourceClear integration (#1520)
  • CSS fixes (#1186)
  • Adds coveragerc

The issues for this release were tracked in the 0.3.11 milestone on Github: https://github.com/freedomofpress/securedrop/milestones/0.3.11.

0.3.10

Creates new Debian package securedrop-keyring for managing the SecureDrop Release Signing Key. Rotates the signing key currently in use by setting a dependency on the other Debian packages, so that currently running deployments will have their apt keyrings updated via automatic nightly updates.

  • Installs securedrop-keyring package for managing apt signing key (#1416)

Admins must manually update the Release Signing Key on Admin Workstations. See documentation on configuring the Admin Workstation.

The issues for this release were tracked in the 0.3.10 milestone on Github: https://github.com/freedomofpress/securedrop/milestones/0.3.10.

0.3.9

Point release to fix some minor issues and update our Python dependencies.

  • Fix Unicode support regression and implement better Unicode tests (#1370)
  • Add OSSEC rule to ignore futile port scanning (#1374)
  • Update Apache AppArmor profile to allow access to webfonts and to execute uname (#1332, #1373)
  • Update Python dependencies of SD (#1379)
  • Fix a regression in the new install script (#1397)

The issues for this release were tracked in the 0.3.9 milestone on Github: https://github.com/freedomofpress/securedrop/milestones/0.3.9.

0.3.8

  • Re-include the pycrypto Python module to address the regression in 0.3.7 (#1344)
  • Switch to using bento boxes in Vagrantfile for more reproducible test environments
  • Minor fixes to update_version.sh

The issues for this release were tracked in the 0.3.8 milestone on Github: https://github.com/freedomofpress/securedrop/milestones/0.3.8

0.3.7

Point release to address some requests from SecureDrop administrators and upgrade various components on the SecureDrop architecture.

  • Improve backup and restore roles
  • Ensure SecureDrop-specific Tails configuration works on Tails 2.x
  • Document upgrading from Tails 1.x to Tails 2.x for current admins using 1.x
  • Upgrade SecureDrop's Python dependencies

The issues for the release were tracked with the 0.3.7 milestone on GitHub.

0.3.6

This is an emergency release to update the copy of the FPF code signing public key in the repo because it expired on Oct 26. This fix is required for new installs to succeed; otherwise, the installation will fail because apt's package authentication fails if the corresponding key is expired.

0.3.5

The issues for this release were tracked with the 0.3.5 milestone on Github: https://github.com/freedomofpress/securedrop/milestones/0.3.5

  • Use certificate verification instead of fingerprint verification by default for the OSSEC Postfix configuration (#1076)
  • Fix apache2 service failing to start on Digital Ocean (#1078)
  • Allow Apache to rotate its logs (#1074)
  • Prevent reboots during cron-apt upgrade (#1071)
  • Update documentation (#1107, #1112, #1113)
  • Blacklist additional kernel modules used for wireless networking (#1116)

0.3.4

The issues for this release were tracked with the 0.3.4 milestone on Github: https://github.com/freedomofpress/securedrop/milestones/0.3.4

This release contains fixes for issues described in the most recent security audit by iSec. It also contains some improvements and updates to the documentation, and a fix for Tor hidden service directory permissions that caused new installs to fail.

iSec audit fixes

  • Fix ineffective SSH connection throttling (iSEC-15FTC-7, #1053)
  • Remove debugging print statements that could leak sensitive information to the logs for the document interface (iSEC-15FTC-2, #1059)
  • Harden default iptables policies (iSEC-15FTC-3, #1053)
  • Don't check passwords or codenames that exceed a maximum length to prevent DoS via excessive scrypt computation (iSEC-15FTC-6, #1059)
  • Remove unnecessary capabilties from the Apache AppArmor profile (iSEC-15FTC-9, #1058).
  • Change postfix hostname to something generic to prevent fingerprinting via OSSEC email headers (iSEC-15FTC-10, #1057)

Other changes

  • Ensure correct permissions for Tor hidden service directories so new installs won't break (#1052)
  • Clarify server setup steps in the install documentation (#1027, #1061)
  • Clarify that Tor ATHS setup is now automatic and does not require manual changes (#1030)
  • Explain that you can only download files to the "Tor Browser" folder on Tails as of Tails 1.3, due to the addition of AppArmor confinement for the Tor Browser (#1036, #1062).
  • Explain that you must use the Unsafe Browser to configure the network firewall because the Tor Browser will be blocked from accessing LAN addresses starting in Tails 1.5 (#1050)
  • Fix "gotcha" in network firewall configuration where pfSense guesses the wrong CIDR subnet (#1060)
  • Update the upgrade docs to refer to the latest version of the 0.3.x release series instead of a specific version that would need to be updated every time (#1063)

0.3.3

The issues for this release were tracked with the 0.3.3 milestone on Github: https://github.com/freedomofpress/securedrop/milestones/0.3.3.

  • Remove unnecessary proxy command from Tails SSH aliases (#933)
  • Make grsec reboot idempotent to avoid unnecessary reboots on new installs (#939)
  • Make tmux the default shell on App and Monitor servers (#943)
  • Fully tested migration procedures for 0.2.1 and 0.3pre to 0.3 (#944, #993)
  • Ensure grub is not uninstalled in virtual machines (#945)
  • CSS fixes (#948)
  • Apache AppArmor profile should support TLS/SSL (#949)
  • Fix: document interface no longer flas new submissions as unread (#969)
  • Switch to NetworkManager for automatic ATHS setup on Admin Workstation (#1018)
  • Upgrade Selenium in testing dependencies so functional tests work (#991)
  • Clarify paths in install documentation (#1009)

0.3.2

  • Fixes security vulnerabilty (severity=high) in access control on Document Interface (#974)

0.3.1

  • Improved installation and setup documentation (#927, #907, #903, #900)
  • Fixed PEP8 and other style issue (#926, #893, #884, #890, #885)
  • Automatic torrc initialization in Tails via dotfiles persistence (#925)
  • Fix bug in installing grsecurity kernel when using new Ubuntu 14.04.2 .iso (#919)
  • Prevent sources from creating "empty" submissions (#918)
  • Autoremove unused packages after automatic upgrade (#916)
  • Remove the App Server (private) IP address from OSSEC alert email subject lines (#915)
  • Handle custom header image as a conffile in the securedrop-app-code Debian package (#911)
  • Upgrade path from 0.3pre (#908, #909)
  • Remove offensive words from source and journalist word lists (#891, #901)

0.3

Web App

This is a high-level overview of some of the more significant changes between SecureDrop 0.2 and 0.3. For the complete set of changes, diff the tags.

  • Reduce JS dependencies to JQuery (stable) only
  • Add functional tests, increase unit test coverage
  • Rewrite database layer (db.py) using SQLAlchemy declarative ORM
  • Automate dev. setup with Vagrant and integrate with Travis CI
  • Store more info in db and less on filesystem
    • "flagged" sources
    • metadata for new UI features (starring, etc.)
    • metadata for simpler/more efficient views in journalist.py
  • Do not set headers in the web app (handle by production config.)
  • Add 2fac auth for journalist interface
  • Allow OSSEC emails to be encrypted with admin GPG key
  • Install app server, monitor server, Python dependencies, and custom configuration via Debian packages
  • UI refresh on source and journalist interfaces
  • New UX for journalists:
    • "quick filter" box for codenames
    • "download unread" link
    • star sources
    • multi-select actions for sources (delete, star, unstar) and submissions (download, delete)
    • more detailed source listings
  • Normalize submission timestamps to that of the most recent submission to minimize metadata that could be used for correlation
  • Handle journalist authentication in the Document Interface instead of relying entirely on Authenticated Tor hidden services.
  • Document Interface supports two-factor authentication via Google Authenticator or YubiKey
    • These logins are hardened in a manner similar to that of the google-authenticator PAM module: tokens may only be used once, logins are rate limited, etc.
    • If you are using TOTP, the window is expanded from 1 period to 3 in order to help the situation where the server and client's clocks are skewed
  • Add Admin Interface so privileged "admin" users may add, edit, or delete other users on the Document Interface
  • Requests are automatically encrypted with an ephemeral key as they are buffered onto disk to mitigate forensic attacks
  • The haveged "high water" mark has been raised to maintain a higher average level of entropy on the system and minimize the appearance of the "flag for reply" flow
  • Secure removal (via srm) of data has been moved to an async worker to prevent hanging the interface when deleting large files or collections
  • New dedicated section of Source Interface for replies, instead of using flashed messages
  • Change default codename length from 8 words to 7 words, maintains a sufficient security level while hopefully improving usability for sources
  • Add recommendations for storing and memorizing the codename to the codename generation page
  • Improve the quality of journalist designations generated by reducing the adjectives and nouns lists to a smaller subset of common words
  • Use ntpd to continuously update the server time (especially important when using TOTP for two-factor authentication)
  • Move Document Interface to port 80 so we don't have to keep remembering to type ":8080"
  • We no longer ASCII-armor submissions when they are encrypted. This was unnecessary and bloated the size of the submissions, which is important to avoid because downloading large submissions over Tor is very slow.
  • Flask now uses X-Send-File for downloads, which fixed some reported issues are large downloads not finishing or being corrupted.

Environment

  • Add egress host firewall rules
  • Add google-authenticator apache module and basic auth for access to document interface
  • Encrypt bodies of OSSEC email alerts (add postfix+procmail to monitor server)
  • Create apparmor profiles for chrooted interface Tor process
  • Update interface apparmor profiles for changes to application code
  • Change installation method to use Ansible playbook and deb packages
  • Split securedrop repo into 3 separate repos for securedrop-specific code (the application, Python dependencies, and custom configuration) and the upstream packages that we maintain (OSSEC and the hardened grsecurity kernel for Ubuntu)
  • Add variety of development and testing environments for developers and researchers to use with Vagrant
  • Reduce OSSEC email alert noise through whitelisting errors that are reported by the default configuration but that we have investigated and determined to be safe to ignore
  • Document a thoroughly tested network firewall configuration with pfSense
  • Reboot the machine automatically every 24 hours to reduce the potential for plaintext to remain in memory
  • Add KeePassX password database template and document its use for journalists and admins
  • Add secure backup and recovery scripts
  • Add migration scripts
  • Major improvements to the installation and user documentation, including lots of detail, testing, and the addition of TOC

0.2.1

Web App

  • Fix for flagging errors
  • Validate journalist messages
  • Add logging using standard Python library.
  • Add delete collection
  • Replace bcrypt with scrypt
  • Clear referer on external links

Environment

  • Set maximum request body size in CONFIG_OPTIONS
  • Add security-related HTTP headers to Apache config
  • Remove mysql database, replace w/ sqlite. Update sqlite apparmor profile.
  • Add outbound iptables rule for source/document groups

0.2

  • Various documentation improvements

Web App

  • Remove javascript dependency in source interface
  • Add warning to source interface about using javascript (with Gritter)
  • Update to pycrypto 2.6.1
  • Validate filenames and codenames
  • Remove unsafe characters from codenames, remove diceware words that are not real words
  • Rewrite source.py and journalist.py with Flask
  • Add tests
  • Flag sources for journalist reply to avoid DOS attack by generating many GPG keys
  • Allow journalists to delete documents with SRM
  • Add bulk download to journalist interface
  • Add MySQL-python and SQLAlchemy dependency, db.py to perform database functions (ex: storing codenames)
  • Remove option to have codenames with <7 words
  • Use sqlite as default database
  • Add support for theming
  • bcrypt hash GPG passphrase for key stretching

Environment

  • Merge source and journalist servers into a single app server
  • Add apparmor profiles
  • Remove puppet, add base_install.sh script
  • Create interface-install.sh script to set up chroot jails
  • Add Ubuntu dev-setup script
  • Backup Tor private keys
  • Move config files into install scripts directory
  • Change SOURCE_IP to APP_IP
  • Set ownership and permissions for application code

0.1

  • Renamed DeadDrop to SecureDrop
  • Redesigned source and document web interface
  • Wrote detailed documentation
  • Improved installation process
  • Wrote unit & integration tests
  • Improved codename wordlist, based on Diceware
  • Use bcrypt instead of SHA
  • Removed VPN, replaced with authenticated Tor hidden service
  • Freedom of the Press Foundation taking over project

DeadDrop was originally written by Aaron Swartz.