既存 dm-crypt LUKSデバイスのハッシュ仕様と反復時間を変更するにはどうすればよいですか?
newデバイスを作成する場合、明らかに、たとえば次のようなオプションを渡すことができます。
Sudo cryptsetup luksFormat --cipher aes-cbc-essiv:sha256 --key-size 256 --iter-time 2100 --hash sha512 /dev/loop0
しかし、デバイスが既に存在する場合、たとえばsha256
をsha1
に変更したり、デバイスを「破壊」せずに反復時間を変更するにはどうすればよいですか。 (明らかに、新しいハッシュが生成されるため、パスワードを再入力する必要があります。)
各キースロットには、独自の反復時間があります。反復回数を変更する場合は、同じパスフレーズと新しい反復回数で新しいスロットを作成してから、古いスロットを削除します。
cryptsetup -i 100000 --key-slot 2 luksAddKey $device
cryptsetup luksKillSlot $device 1
ハッシュアルゴリズムはスロットごとに構成できないと思います。常にグローバルに選択されたハッシュ関数を使用するPBKDF2です。
cryptsetupの最新バージョン ツールを含めるcryptsetup-reencrypt
、これはメインの暗号化キーとすべてのパラメーターを変更できますが、実験的なものと見なされています(パスワードベースのキー導出関数を変更するだけでなくても、デバイス全体を再暗号化します)。
変更したいのがハッシュだけであれば、再暗号化する必要はありません。ただし、新しいLUKSヘッダーを作成する必要があります。同じ暗号、同じマスターキー、同じオフセット、異なるハッシュ。
これを自分で試すことができます。最初に、LUKSデバイスを標準設定とお粗末な反復回数でセットアップします。
# truncate -s 8M /dev/shm/foobar
# cryptsetup --iter-time=42 luksFormat /dev/shm/foobar
WARNING!
========
This will overwrite data on /dev/shm/foobar irrevocably.
Are you sure? (Type uppercase yes): YES
Enter passphrase:
Verify passphrase:
# cryptsetup luksOpen /dev/shm/foobar foobar
Enter passphrase for /dev/shm/foobar:
# shred -z /dev/mapper/foobar
# echo Hello World I am LUKS > /dev/mapper/foobar
# strings /dev/mapper/foobar
Hello World I am LUKS
# cryptsetup luksClose foobar
この時点で、暗号化されたデータ「Hello World I am LUKS」を含むLUKSデバイスがあります。特に、次のようになります。
# cryptsetup luksDump /dev/shm/foobar
LUKS header information for /dev/shm/foobar
Version: 1
Cipher name: aes
Cipher mode: xts-plain64
Hash spec: sha1
Payload offset: 4096
MK bits: 256
MK digest: 30 87 62 81 8e 8f a9 15 68 e0 82 c0 dc ee 19 54 9b f2 eb 5c
MK salt: c3 e0 28 53 67 10 13 d4 43 e3 7b d1 ce 62 6b e3
58 85 ee 67 71 76 b6 48 78 a8 34 71 58 71 21 f8
MK iterations: 6175
UUID: 14a0a11d-0890-433e-bdcb-d2d1f5281bc2
Key Slot 0: ENABLED
Iterations: 26033
Salt: a1 7b 2b 5b 3d 8c 3c d1 3b 57 61 5a df 25 47 c8
29 97 62 09 08 2b e1 b2 af 61 56 80 2f af a6 ae
Key material offset: 8
AF stripes: 4000
Key Slot 1: DISABLED
Key Slot 2: DISABLED
Key Slot 3: DISABLED
Key Slot 4: DISABLED
Key Slot 5: DISABLED
Key Slot 6: DISABLED
Key Slot 7: DISABLED
ご覧のように、お粗末な繰り返しが重要であり、標準のsha1ハッシュです。
再暗号化せずに、反復回数を増やしてsha512ハッシュに切り替えるには、同じマスターキー、同じ暗号、同じペイロードオフセットを使用する新しいLUKSヘッダーが必要です。
マスターキーの取得:(警告:この例では、マスターキーを世界中の読み取り可能なファイル、プロセスリスト、シェルの履歴に漏らしています。安全のために、RAM = /ライブCDの/など)
# cryptsetup --dump-master-key luksDump /dev/shm/foobar
WARNING!
========
Header dump with volume key is sensitive information
which allows access to encrypted partition without passphrase.
This dump should be always stored encrypted on safe place.
Are you sure? (Type uppercase yes): YES
Enter passphrase:
LUKS header information for /dev/shm/foobar
Cipher name: aes
Cipher mode: xts-plain64
Payload offset: 4096
UUID: 14a0a11d-0890-433e-bdcb-d2d1f5281bc2
MK bits: 256
MK dump: eb aa 57 2d 42 93 fe 90 00 b9 d2 e0 e0 7b 73 26
4b 64 1b 8b 8e 61 75 84 1b c3 d6 f7 3f 03 d2 14
# printf '\xeb\xaa\x57\x2d\x42\x93\xfe\x90\x00\xb9\xd2\xe0\xe0\x7b\x73\x26\x4b\x64\x1b\x8b\x8e\x61\x75\x84\x1b\xc3\xd6\xf7\x3f\x03\xd2\x14' > /dev/shm/masterkey
# hexdump -C /dev/shm/masterkey
00000000 eb aa 57 2d 42 93 fe 90 00 b9 d2 e0 e0 7b 73 26 |..W-B........{s&|
00000010 4b 64 1b 8b 8e 61 75 84 1b c3 d6 f7 3f 03 d2 14 |Kd...au.....?...|
00000020
このキーを使用して新しいLUKSヘッダーを作成します:(失敗する可能性があります-最初に古いLUKSヘッダーのバックアップを作成してください!)
# cryptsetup --master-key-file=/dev/shm/masterkey --iter-time=5000 --hash=sha512 luksFormat /dev/shm/foobar
WARNING!
========
This will overwrite data on /dev/shm/foobar irrevocably.
Are you sure? (Type uppercase yes): YES
Enter passphrase:
Verify passphrase:
そして、それはどのように見えるかです:
# cryptsetup luksDump /dev/shm/foobar
LUKS header information for /dev/shm/foobar
Version: 1
Cipher name: aes
Cipher mode: xts-plain64
Hash spec: sha512
Payload offset: 4096
MK bits: 256
MK digest: 47 ab 7b c6 41 b0 7c d8 af 3c a0 a4 23 e6 72 87 9c 0f c6 a0
MK salt: 32 49 a5 b5 cb 4d 8a d7 25 69 72 ae e5 b2 9e 9d
14 09 00 1d 01 f3 c9 99 da e1 6c fc 69 78 e4 64
MK iterations: 393750
UUID: fd554ae8-a862-4609-8327-c6dd65ee9a83
Key Slot 0: ENABLED
Iterations: 1578295
Salt: e5 75 1c 1f 63 1d c6 0b d9 27 1a b1 27 85 b9 c1
89 e8 57 95 2a c8 a0 24 9c 29 c0 f2 27 d7 2f 9a
Key material offset: 8
AF stripes: 4000
Key Slot 1: DISABLED
Key Slot 2: DISABLED
Key Slot 3: DISABLED
Key Slot 4: DISABLED
Key Slot 5: DISABLED
Key Slot 6: DISABLED
Key Slot 7: DISABLED
今それがあります。同じ暗号、オフセット[異なる場合は、luksFormatとともに指定する必要があります]、新しいハッシュ、適切な反復回数。
しかし、コンテンツはまだそこにありますか?
# cryptsetup luksOpen /dev/shm/foobar foobar
Enter passphrase for /dev/shm/foobar:
# strings /dev/mapper/foobar
Hello World I am LUKS
どうぞ。