From Fedora Project Wiki
(Added use case notes from dlehman discussion)
 
(5 intermediate revisions by 3 users not shown)
Line 1: Line 1:
{{ Template:message/warning | This page is not being tracked as an ''Accepted Feature'' for Fedora 9.  The content here should probably be merged with http://fedoraproject.org/wiki/Releases/FeatureEncryptedFilesystems as discussed on #fedora-devel (poelcat 2008-02-07)  
{{Admon/important | This page is not being tracked as an ''Accepted Feature'' for Fedora 9.  The content here should probably be merged with [[Releases/FeatureEncryptedFilesystems]] as discussed on #fedora-devel (poelcat 2008-02-07)}}
}}


= Support Creation of Encrypted Block Devices within Anaconda =
= Support Creation of Encrypted Block Devices within Anaconda =


== Summary ==
== Summary ==
Line 25: Line 22:
* Improve passphrase prompting dialog (in anaconda) to note which device's passphrase to enter
* Improve passphrase prompting dialog (in anaconda) to note which device's passphrase to enter
* Allow specification of a global passphrase when creating encrypted partitions
* Allow specification of a global passphrase when creating encrypted partitions


== Detailed Description ==
== Detailed Description ==
Line 43: Line 39:
== Test Plan ==
== Test Plan ==


Cases:
Previously defined cases:
* Test that you can create an encrypted block device and boot and use it afterwards
* Test that you can create an encrypted block device and boot and use it afterwards
* Test installation using encrypted block devices only - [http://fedoraproject.org/wiki/QA/TestCases/PartitioningEncryptedAll PartitioningEncryptedAll]  
* Test installation using encrypted block devices only - [[QA/TestCases/PartitioningEncryptedAll |PartitioningEncryptedAll]]  
* Test installation using a mix of encrypted/non-encrypted block devices - [http://fedoraproject.org/wiki/QA/TestCases/PartitioningEncryptedMix PartitioningEncryptedMix]  
* Test installation using a mix of encrypted/non-encrypted block devices - [[QA/TestCases/PartitioningEncryptedMix |PartitioningEncryptedMix]]
* Test kickstart installation using encrypted block devices - [http://fedoraproject.org/wiki/QA/TestCases/KickstartEncryption KickstartEncryption]  
* Test kickstart installation using encrypted block devices - [[QA/TestCases/KickstartEncryption |KickstartEncryption]]
* Test rescue mode on a system whose root partition is encrypted
* Test rescue mode on a system whose root partition is encrypted
* Test different selinux modes so that it does not prevent this feature from working
* Test different selinux modes so that it does not prevent this feature from working


{{admon/important|2008-08-14 - FIXME|Dave Lehman noted there are no upgrade scenarios hilighted in the matrix below.}}


2008-04-30 Use case notes from discussion between dlehman and jlaska
Test matrix:


{| style="background-color: #def3fe; border: 1px solid #c5d7e0; color: black; padding: 5px; margin-bottom: 5px; min-height: 35px; padding-left: 45px;"
{| style="background-color: #def3fe; border: 1px solid #c5d7e0; color: black; padding: 5px; margin-bottom: 5px; min-height: 35px; padding-left: 45px;"
! colspan="2" align="left" | RAID Encryption
! colspan="2" align="left" | RAID
|-
|-
! colspan="2" align="left" style="font-weight: normal;" | These tests mix encryption across raid devices (/dev/md0) and raid members
! colspan="2" align="left" style="font-weight: normal;" | These tests mix encryption across raid devices (/dev/md0) and raid members
|-
|-
| [[QA/TestCases/EncryptedRAIDAllMembersEncrypted|EncryptedRAIDAllMembersEncrypted]] || [[QA/TestCases/UnEncryptedRAIDAllMembersEncrypted|UnEncryptedRAIDAllMembersEncrypted]]
| [[QA/TestCases/LUKS Encrypted RAID partitions, all mds encrypted|Encrypted RAID partitions, all mds encrypted]] || [[QA/TestCases/LUKS Encrypted RAID partitions, no mds encrypted|Encrypted RAID partitions, no mds encrypted]]
|-
| [[QA/TestCases/LUKS Encrypted RAID partitions, some mds encrypted|Encrypted RAID partitions, some mds encrypted]] || [[QA/TestCases/LUKS Select encryption (fs on partition of RAID device (md0))|Select encryption (fs on partition of RAID device (md0))]]
|-
|-
| [[QA/TestCases/EncryptedRAIDSomeMembersEncrypted|EncryptedRAIDSomeMembersEncrypted]] || [[QA/TestCases/UnEncryptedRAIDSomeMembersEncrypted|UnEncryptedRAIDSomeMembersEncrypted]]
| [[QA/TestCases/LUKS Select encryption (using RAID block device)|Select encryption (using RAID block device)]] || [[QA/TestCases/LUKS non-encrypted RAID partitions, all mds encrypted|non-encrypted RAID partitions, all mds encrypted]]
|-
|-
| [[QA/TestCases/EncryptedRAIDNoMembersEncrypted|EncryptedRAIDNoMembersEncrypted]] || [[QA/TestCases/UnEncryptedRAIDNoMembersEncrypted|UnEncryptedRAIDNoMembersEncrypted]]
| [[QA/TestCases/LUKS non-encrypted RAID partitions, no mds encrypted|non-encrypted RAID partitions, no mds encrypted]] || [[QA/TestCases/LUKS non-encrypted RAID partitions, some mds encrypted|non-encrypted RAID partitions, some mds encrypted]]
|-
|-
! colspan="2" align="left" | LVM Encryption
! colspan="2" align="left" | LVM
|-
|-
! colspan="2" align="left" style="font-weight: normal;" | These tests mix encryption across LVM physical (/dev/sda1) and logical (/dev/mapper/*) volumes
! colspan="2" align="left" style="font-weight: normal;" | These tests mix encryption across LVM physical (/dev/sda1) and logical (/dev/mapper/*) volumes
|-
|-
| [[QA/TestCases/EncryptedLvmPvAllLvsEncrypted|EncryptedLvmPvAllLvsEncrypted]] || [[QA/TestCases/UnEncryptedLvmPvAllLvsEncrypted|UnEncryptedLvmPvAllLvsEncrypted]]
| [[QA/TestCases/LUKS Encrypted LVM VG, all LVs encrypted|Encrypted LVM VG, all LVs encrypted]] || [[QA/TestCases/LUKS Encrypted LVM VG, no LVs encrypted|Encrypted LVM VG, no LVs encrypted]]
|-
| [[QA/TestCases/LUKS Encrypted LVM VG, some LVs encrypted|Encrypted LVM VG, some LVs encrypted]] || [[QA/TestCases/LUKS Select encryption (fs on LV of LVM PVs)|Select encryption (fs on LV of LVM PVs)]]
|-
|-
| [[QA/TestCases/EncryptedLvmPvSomeLvsEncrypted|EncryptedLvmPvSomeLvsEncrypted]] || [[QA/TestCases/UnEncryptedLvmPvSomeLvsEncrypted|UnEncryptedLvmPvSomeLvsEncrypted]]
| [[QA/TestCases/LUKS Select encryption (using LVM block device)|Select encryption (using LVM block device)]] || [[QA/TestCases/LUKS non-encrypted LVM VG, all LVs encrypted|non-encrypted LVM VG, all LVs encrypted]]
|-
|-
| [[QA/TestCases/EncryptedLvmPvNoLvsEncrypted|EncryptedLvmPvNoLvsEncrypted]] || [[QA/TestCases/UnEncryptedLvmPvNoLvsEncrypted|UnEncryptedLvmPvNoLvsEncrypted]]
| [[QA/TestCases/LUKS non-encrypted LVM VG, no LVs encrypted|non-encrypted LVM VG, no LVs encrypted]] || [[QA/TestCases/LUKS non-encrypted LVM VG, some LVs encrypted|non-encrypted LVM VG, some LVs encrypted]]
|-
|-
! colspan="2" align="left" | Partition Probing
! colspan="2" align="left" | Partition Probing
Line 79: Line 80:
! colspan="2" align="left" style="font-weight: normal;" | Ensure that anaconda will prompt for the passphrase when discovering LUKs encrypted devices during partition probe (rescue mode)
! colspan="2" align="left" style="font-weight: normal;" | Ensure that anaconda will prompt for the passphrase when discovering LUKs encrypted devices during partition probe (rescue mode)
|-
|-
| [[QA/TestCases/EncryptedPartitionProbe|EncryptedPartitionProbe]] ||
| [[QA/TestCases/LUKS Partition Probing (previous install)|Partition Probing (previous install)]] ||
|-
! colspan="2" align="left" | Passphrase Entry
|-
! colspan="2" align="left" style="font-weight: normal;" | Exercise the different methods of passphrase entry
|-
| [[QA/TestCases/LUKS Enter Passphrase|Enter Passphrase]] || [[QA/TestCases/LUKS Enter Passphrase (Create custom layout)|Enter Passphrase (Create custom layout)]]
|-
| [[QA/TestCases/LUKS Enter Passphrase (Remove all partitions on selected drives and create default layout)|Enter Passphrase (Remove all partitions on selected drives and create default layout)]] || [[QA/TestCases/LUKS Enter Passphrase (Resize existing partition and create default layout in free space)|Enter Passphrase (Resize existing partition and create default layout in free space)]]
|-
| [[QA/TestCases/LUKS Enter Passphrase (Use free space on selected drives and create default layout)|Enter Passphrase (Use free space on selected drives and create default layout)]] || [[QA/TestCases/LUKS Enter Passphrase (block device)|Enter Passphrase (block device)]]
|-
| [[QA/TestCases/LUKS Enter Passphrase (non-root filesystem)|Enter Passphrase (non-root filesystem)]] || [[QA/TestCases/LUKS Enter Passphrase (root filesystem)|Enter Passphrase (root filesystem)]]
|-
| [[QA/TestCases/LUKS Enter Passphrase to unlock previously encrypted fs|Enter Passphrase to unlock previously encrypted fs]] ||
|-
! colspan="2" align="left" | Rescue Mode
|-
! colspan="2" align="left" style="font-weight: normal;" | Validate that encrypted devices be discovered and managed during rescue-mode operation
|-
| [[QA/TestCases/LUKS rescue mode (non-rootfs is encrypted)|rescue mode (non-rootfs is encrypted)]] || [[QA/TestCases/LUKS rescue mode (rootfs is encrypted)|rescue mode (rootfs is encrypted)]]
|-
|-
|}
|}
Line 99: Line 120:
== Documentation ==
== Documentation ==


* New --encrypted and --passphrase= options are documented in [http://fedoraproject.org/wiki/Anaconda/Kickstart#head-f35f48e69e34319598484bd4723f79f9ac561cff kickstart] .
* New --encrypted and --passphrase= options are documented in [[Anaconda/Kickstart| kickstart]].
* Using /dev/random to fill up the device with junk data is not supported (and will probably not be in future). If you are paranoid you may use the %pre section in kickstart.
* Using /dev/random to fill up the device with junk data is not supported (and will probably not be in future). If you are paranoid you may use the %pre section in kickstart.


Line 107: Line 128:


----
----
[[Category:ProposedFeature]]
 
[[Category:FeaturePageIncomplete]]

Latest revision as of 15:48, 14 August 2008

This page is not being tracked as an Accepted Feature for Fedora 9. The content here should probably be merged with Releases/FeatureEncryptedFilesystems as discussed on #fedora-devel (poelcat 2008-02-07)

Support Creation of Encrypted Block Devices within Anaconda

Summary

To support Releases/FeatureEncryptedFilesystems , anaconda needs to grow support for encrypted block devices.

Owner

  • Name: DaveLehman

Current status

  • Targeted release: N/A
  • Last updated: 2008-02-05
  • Percentage of completion: 85%
  • Support for creating new devices exists in anaconda
  • Support for automatic partitioning using encrypted devices exists in anaconda
  • Support for creating initrds that can decrypt and mount encrypted devices exists in mkinitrd
  • Support for rescue of systems with encrypted partitions (LUKS only)
  • TODO
  • Discovery and handling (installation/partitioning) of existing encrypted devices in anaconda
  • Improve passphrase prompting dialog (in anaconda) to note which device's passphrase to enter
  • Allow specification of a global passphrase when creating encrypted partitions

Detailed Description

To fully supported encrypted filesystems, we need to be supporting them within the installer. Given that all current momentum is towards the use of LUKS, we need to support LUKS devices within anaconda.

This involves backend code to create LUKS devices, to recognize and unlock existing devices, and UI around the devices.

Benefit to Fedora

Stolen laptops are less likely to have data taken

Scope

The main scope of this is within anaconda. There are also pieces that snake out into low-levels of the OS such as mkinitrd and initscripts to ensure that what is being done is consistent across everything.

Test Plan

Previously defined cases:

  • Test that you can create an encrypted block device and boot and use it afterwards
  • Test installation using encrypted block devices only - PartitioningEncryptedAll
  • Test installation using a mix of encrypted/non-encrypted block devices - PartitioningEncryptedMix
  • Test kickstart installation using encrypted block devices - KickstartEncryption
  • Test rescue mode on a system whose root partition is encrypted
  • Test different selinux modes so that it does not prevent this feature from working
2008-08-14 - FIXME
Dave Lehman noted there are no upgrade scenarios hilighted in the matrix below.

Test matrix:

RAID
These tests mix encryption across raid devices (/dev/md0) and raid members
Encrypted RAID partitions, all mds encrypted Encrypted RAID partitions, no mds encrypted
Encrypted RAID partitions, some mds encrypted Select encryption (fs on partition of RAID device (md0))
Select encryption (using RAID block device) non-encrypted RAID partitions, all mds encrypted
non-encrypted RAID partitions, no mds encrypted non-encrypted RAID partitions, some mds encrypted
LVM
These tests mix encryption across LVM physical (/dev/sda1) and logical (/dev/mapper/*) volumes
Encrypted LVM VG, all LVs encrypted Encrypted LVM VG, no LVs encrypted
Encrypted LVM VG, some LVs encrypted Select encryption (fs on LV of LVM PVs)
Select encryption (using LVM block device) non-encrypted LVM VG, all LVs encrypted
non-encrypted LVM VG, no LVs encrypted non-encrypted LVM VG, some LVs encrypted
Partition Probing
Ensure that anaconda will prompt for the passphrase when discovering LUKs encrypted devices during partition probe (rescue mode)
Partition Probing (previous install)
Passphrase Entry
Exercise the different methods of passphrase entry
Enter Passphrase Enter Passphrase (Create custom layout)
Enter Passphrase (Remove all partitions on selected drives and create default layout) Enter Passphrase (Resize existing partition and create default layout in free space)
Enter Passphrase (Use free space on selected drives and create default layout) Enter Passphrase (block device)
Enter Passphrase (non-root filesystem) Enter Passphrase (root filesystem)
Enter Passphrase to unlock previously encrypted fs
Rescue Mode
Validate that encrypted devices be discovered and managed during rescue-mode operation
rescue mode (non-rootfs is encrypted) rescue mode (rootfs is encrypted)

User Experience

There are a number of pieces of the user experience here. The expert mode is to allow encryption of any individual block device and then to allow unlocking of it at boot.

With our default partitioning setup (/ and swap on LVs of one LVM VG), the best experience is likely to be to have the underlying physical volumes encrypted and with a single passphrase for all volumes.

Dependencies

To fully complete this will require changes to initscripts, mkinitrd and probably some other pieces

Contingency Plan

We disable the code and don't make it visible to the user

Documentation

  • New --encrypted and --passphrase= options are documented in kickstart.
  • Using /dev/random to fill up the device with junk data is not supported (and will probably not be in future). If you are paranoid you may use the %pre section in kickstart.

Release Notes

Definitely needed