Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Use the new Tails Persistent Storage copy option where applicable #492

Merged
merged 7 commits into from
Nov 19, 2024
59 changes: 27 additions & 32 deletions docs/admin/deployment/onboarding_admins.rst
nathandyer marked this conversation as resolved.
Show resolved Hide resolved
Original file line number Diff line number Diff line change
Expand Up @@ -32,62 +32,57 @@ To set up AW2, follow these steps:
2. Ensure that Tails and the SecureDrop version on AW1 are up-to-date.
If not, update now by following the :ref:`most recent upgrade guide <latest_upgrade_guide>`.
3. Log into the *Journalist Interface* using your admin credentials, and create
a new user account with admin rights. Record its passphrase securely;
you will add it to the password manager on AW2.
a new user account with admin rights. Record its passphrase securely;
you will add it to the password manager on AW2 in step 11.

(You will need to on-board the new admin's 2FA device to complete this step.
If this is not possible yet, you can defer it until later.)
(You will need to on-board the new admin's 2FA device to complete this step.
If this is not possible yet, you can defer it until later.)
4. Insert the empty AW2 USB drive.
5. Launch the Tails installer (**Applications ▸ Tails ▸ Tails Installer**) and install Tails on AW2.
This will delete all data on the AW2 USB drive.
6. Shut down AW1.
7. Boot AW2.
8. Configure its persistent volume (**Applications ▸ Tails ▸ Configure persistent volume**).
Set a unique passphrase for AW2 and record it securely. Enable all persistence options.
9. Reboot AW2, unlock its persistent volume, and set an admin password on the welcome screen.
10. Connect to the Internet.
11. Open the file manager (**Applications ▸ Accessories ▸ Files**).
12. Insert AW1. It should show up in the list of storage devices in the file manager under
a label like "7.0 GB Encrypted". Click the label and enter the drive
password when prompted to unlock it.
13. In a terminal, type the following command:

``rsync -a --info=progress2 /media/amnesia/TailsData/Persistent/securedrop ~/Persistent``

This will copy *only* the ``securedrop`` directory from AW1 to AW2.
14. Generate a new keypair on AW2 using the following command:
5. Launch the Tails Cloner (**Applications ▸ Tails ▸ Tails Cloner**).
Select the option to **Clone the current Tails.** This will delete all data on the AW2 USB drive.
6. Check the box marked **Clone the current Persistent Storage.**
7. Click **Install**.
8. Choose a unique passphrase for the new Persistent Storage Volume on AW2
(a 6-word Diceware passphrase is recommended) and record it securely.
9. Shut down AW1.
10. Boot AW2 and unlock the Persistent Storage.
11. Open the KeePassXC database, delete unneeded credentials from AW1,
right-click the **Recycle Bin** item under **Root** in the KeePassXC sidebar,
and select **Empty recycle bin**. Then, store the new account credentials you
created in step 3.
12. Generate a new keypair on AW2 using the following command:
nathandyer marked this conversation as resolved.
Show resolved Hide resolved

``ssh-keygen -t rsa -b 4096``

When prompted, store the keypair in the default location.
15. Run the command ``./securedrop-admin tailsconfig`` in ``~/Persistent/securedrop``.
13. Run the command ``./securedrop-admin tailsconfig`` in ``~/Persistent/securedrop``.

This will set up the *SecureDrop Menu* and SSH access.
16. In a terminal, type the following commands to authorize the newly created SSH keypair
14. In a terminal, type the following commands to authorize the newly created SSH keypair
on your servers:

* ``ssh-add``
* ``ssh-add /media/amnesia/TailsData/openssh-client/id_rsa``
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

If we've booted AW2 in new step (10), then /media/amnesia/TailsData is AW1's persistent storage. Don't we still need old step (12) to mount AW1 and old step (17) to unmount it?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@cfm I don't believe so; /media/amnesia/tailsData should be AW2's persistent storage, not AW1s. Unlike the original instructions, we're never actually copying directly from AW1 to AW2 (I mean that in the spiritual sense, rather than literal - the contents of that persistent volume are being copied, it's just a more transparent operation during the drive creation process). With the Tails Cloner, AW1's persistent storage gets duplicated as AW2's during the cloning (because of the option checked in new step 6). So when you shut down AW1, boot into AW2, and then unlock the storage, at that point AW1 is completely out of the picture.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Noting for the sake of posterity here within the ticket: I just had a great conversation with @cfm, who explained that the issue here is that step 12 (as it stands) overwrites the existing SSH key, so that step 14 is no longer possible due to the original SSH key (needed for adding the new SSH key to the servers) is not available.

The fix to this is to add a few additional steps to insert AW1, unlock persistent storage, perform step 14, then remove AW1 again.

Commit incoming.

* ``ssh-copy-id app``
* ``ssh-copy-id mon``
* ``ssh-add -D``
17. From the file manager (**Applications ▸ Accessories ▸ Files**), eject AW1.
18. Confirm that you are able to access ``mon`` and ``app`` via SSH. The

15. Confirm that you are able to access ``mon`` and ``app`` via SSH. The
following commands should produce the following output::

amnesia@amnesia:~$ ssh app hostname
app
amnesia@amnesia:~$ ssh mon hostname
mon

19. Confirm that you are able to access the *Source Interface* and the *Journalist
16. Confirm that you are able to access the *Source Interface* and the *Journalist
Interface* using the *SecureDrop Menu*.
20. :ref:`Initialize a passphrase database <keepassxc_setup>` on AW2.
17. :ref:`Initialize a passphrase database <keepassxc_setup>` on AW2.
Store the admin account details using KeePassXC, and other account
information this admin will need in the course of administering this
system.
21. Shut down AW2.
22. :doc:`Back up AW2 <../maintenance/backup_workstations>`.
18. Shut down AW2.
19. :doc:`Back up AW2 <../maintenance/backup_workstations>`.

You can now provide AW2 to the new administrator. Ensure that they store the
disk encryption passphrase in a secure manner: in most configurations, it is the
Expand Down
5 changes: 1 addition & 4 deletions docs/admin/deployment/remote.rst
Original file line number Diff line number Diff line change
Expand Up @@ -96,9 +96,6 @@ In order to create a new SVS for remote use, you will need the following:
and microphones. A computer used as an SVS should never be used
for any other purpose.

* An up-to-date Tails USB (the primary Tails USB). You do not need to set up
persistent storage on this device, as it will not be used during the SVS
setup process.
* The current SVS USB, and its persistent volume’s passphrase
* A USB key to act as the new SVS USB

Expand Down Expand Up @@ -224,4 +221,4 @@ your SecureDrop instance, we recommend the following steps:
In most cases, restoring the instance, whether in their original hosting
location or elsewhere, is a matter of reconnecting the servers to the
firewall, attaching a WAN connection that allows unfiltered access to Tor to
the firewall WAN port, and powering everything on.
the firewall WAN port, and powering everything on.