crypt

package
v0.9.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Oct 6, 2021 License: MIT Imports: 11 Imported by: 0

Documentation

Index

Constants

View Source
const (
	SEEK_DATA = 3
	SEEK_HOLE = 4
)

The following constants aren't defined in the io or os libraries.

Variables

This section is empty.

Functions

func CleanupCryptDevice

func CleanupCryptDevice(source string) error

CleanupCryptDevice removes the dm-crypt device created by EncryptDevice

func EncryptDevice

func EncryptDevice(ctx context.Context, source string) (path string, err error)

EncryptDevice creates a dm-crypt target for a container scratch vhd.

In order to mount a block device as an encrypted device:

  1. Generate a random key. It doesn't matter which key it is, the aim is to protect the contents of the scratch disk from the host OS. It can be deleted after mounting the encrypted device.
  1. The original block device has to be formatted with cryptsetup with the generated key. This results in that block device becoming an encrypted block device that can't be mounted directly.
  1. Open the block device with cryptsetup. It is needed to assign it a device name. We are using names that follow `cryptDeviceTemplate`, where "%s" is a unique name generated from the path of the original block device. In this case, it's just the path of the block device with all non-alphanumeric characters replaced by a '-'.

    The kernel exposes the unencrypted block device at the path /dev/mapper/`cryptDeviceTemplate`. This can be mounted directly, but it doesn't have any format yet.

4. Format the unencrypted block device as ext4:

A normal invocation of luksFormat wipes the target device. This takes
a really long time, which isn't acceptable in our use-case. Passing the
option --integrity-no-wipe prevents this from happening so that the
command ends in an instant.

Because of using --integrity-no-wipe, the resulting device isn't wiped and
all the integrity tags are incorrect. This means that any attempt to read
from it will cause an I/O error, which programs aren't prepared to handle.
For example, mkfs.ext4 tries to read blocks before writing to them, and
there is no way around it. When it gets an I/O error, it just exits.

The solution is to create a file with the same size as the resulting
device, format it as ext4, then use dd to copy the format to the device
(dd won't try to read anything).

However, creating a file that is several GB in size isn't a good solution
either because doing dd of the whole file would take as long as letting
luksFormat wipe the disk.

The solution is to create a sparse file and format it. Then, it is
possible to copy the format to the block device by doing a sparse copy
(only copy the data parts of the file, not the holes). This makes
formatting the device almost instantaneous.

4.1. Get size of scratch disk.

4.2. Create sparse filesystem image with the same size as the scratch
     device. It can be removed afterwards.

4.3. Format it as ext4. This way the file is only as big as the few blocks
     of the image that have the filesystem information, the ones modified
     by mkfs.ext4.

4.4. Do a sparse copy of the filesystem into the unencrypted block device.
     This updates the integrity tags.

Types

This section is empty.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL