-
Notifications
You must be signed in to change notification settings - Fork 1.8k
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
Multiple encryption keys/key methods #6824
Comments
I too desire multiple key slots. My thoughts are these:
For the last, it could very well be numerical order, and not Master / Secondary. That would be useful if we had more than 2 keys. Having watched the chaos when users have used FreeNAS's Geli disk encryption, and not understood it, I would prefer a scheme that had more than 1 key slot. (Still won't protect users from themselves. But, this may protect Unix SysAdmins from having to perform restores when someone else looses or changes the key, and can't supply any key...) |
@sjau, in regards to;
This sort of works already. It's in the manual page, (which I don't have handy). I did submit a feature request to allow RAW keys to be stored on disk partitions, (like an USB flash drive), #6556 |
well the think with auto-unlock was how I used luks/dm-crypt... I can either provide the key file or enter manually the key... which is convenvient |
All variations are supported if I remember correctly. Prompt or path to passphrase or key; Prompt for passphrase Path to file with passphrase As I said, I don't have the manual page handy to show examples. And if the path does not exist, it defaults back to prompt, (if I remember correctly...). |
the benefit is if you have multiple key slots... if you can provide a password or a path to file.. just whatever seems more convenient... e.g. have a keyfile in /root on your server, take out the disk, use it somewhere else and since the keyfile won't exist on the other system, provide password |
Yes, that would be useful at times. Plus. it would allow for split mirror pools. Basically have a mirrored pool, (at least 2 way, but more is supported), and use the |
that's why I suggested it... |
Is this possible to add as feature? |
Yes. The current implementation was actually designed with the ability to support multiple keys at some point. It has just not been a priority for me at the moment and I currently have a few other projects which I've committed to working on first. With regards to some of the specific features and use-cases that have been mentioned:
This is probably the biggest use case that I can think of.
This really just boils down to the above use case of having 2 people with different passphrases / keys.
Unfortunately, the cryptography here doesn't allow for this. All data is protected with symmetric key encryption, so there is no R/O key. Using public key cryptography would render the implementation uselessly slow. Without the ability to do this, it becomes impossible to have primary / secondary keys since then the secondary key could only be stopped from making changes via permissions which are trivial to patch over if you have root access to the machine. As a general rule, we have decided not to implement encryption functionality that cannot be enforced with cryptography so that we don't have this odd distinction between things that can / can't be done maliciously and things that can / can't be done inadvertently. My personal belief on the matter is that encryption and permissions need to be thought of differently and kept separate.
Not quite sure if I understand here. Couldn't you just copy the key and use it for the new pool? |
No worries... just take your time.. I know you're quite busy... but at least #8684 is merged now :) I wasn't sure if you've seen this before, that's why I sent a message to you. It's a convenience feature and I'm glad to hear that the current encryption is designed with multi-slots use later on. |
As a quick side note, scrubs / resilvers can be accomplished without any loaded keys. Backups can be taken without keys as well if you use the |
I think it's really great that scrubs / resilver / raw send don't required to load the keys. So even third parties can do that maintenance easily :) |
Any chance this feature will be included in a 0.8 point upgrade? |
In general, point releases are meant for bug fixes and so I would not expect this feature to show up in 0.8.x release. I am also not currently working on this feature at the moment. |
This feature would be awesome to have. I'm really paranoid about my keyfile being somehow corrupted or something, and my data being inaccessible without it. I will of course backup the keyfile to several locations, but still, one can't help but worry. |
I agree that this feature would be nice to have, but I don't think it will help you with protecting your key file from corruption. At the end of the day keeping access to your data is just a matter of keeping access to a key that will work. Therefore, having a backup of the key is exactly the same as having a different key for this purpose. This feature is more about allowing multiple people to have their own passwords or keys to access the data. |
The general way to do this is to have an encrypted key, and then multiple keys which can be used to decrypt it. (Tom knows this, I'm just not sure how much other people do, so sorry if it sounds condescending.) So the change here would be to add user/key pairs somewhere, which would then be used to unlock the main key. |
@kithrup Isn't that the idea behind the current implementation? Aren't the user provided passwords/keys just used as a wrapper for the real encryption key? |
Yes, the user/key mapping just hasn't been done :). |
Consider another vote for interest in the feature. I want to implement a clevis/tang unlocker for ZFS. Use case is needing a breakglass key in case the tang server goes up in flames. I like clevis/tang, but I'm not willing to run it (in production) without a backup way to decrypt the data. |
Could we use properties for this securely, as an interim/0.8.x measure?
And then running the inverse ( -d ) and setting keyformat=raw keylocation=outfile. My interest is disaster recovery here; this would probably be inconvenient for frequent key swapping. Some simple scripts could help. I think this wouldn't work for pools with encrypted root datasets, but if somebody could correct me about the status of the root-level properties being encrypted or not that would be great. |
@bill-mcgonigle yes that should work as long as you are happy with the sercurity of aes-cbc. I'm not actually all that familiar with the openssl command line tool, but this looks right. It should also work for pools with encrypted root filesystems. You can still import such pools to |
@bill-mcgonigle I am not sure if I correctly understand what you're doing here. I assume that tank-test.key is the (unique) encryption key, and you're storing an encrypted version of it (encrypted using password |
Is this currently being worked on? I was hoping I could replace LUKS with native ZFS encryption soon. |
We need some form of recover password as it was said earlier but it is very important topic |
Until /etc/init.d/zfs-load-key is merged and this is implemented, I use this workaround. /usr/lib/dracut/modules.d/99local/module-setup.sh
/usr/lib/dracut/modules.d/99local/zfs-load-key-all.sh
|
@crocket Isn't this something else? The issue is about having multiple keys for a single zpool/zfs dataset, not a single key for multiple zpools/zfs datasets. |
Yes, it is something else. I just wanted one password to unlock everything. |
Is there any movement on this issue? It is the only thing stopping us from using zfs :( |
There is a discussion on Practical ZFS about in which some developer has announced to be actively working on some of these issues. I have pointed them to the discussion here. If any organisation around is able to funnel funds towards their direction, it would be possible to use an existing momentum and build upon that. Esp. now with the review offer. |
I agree with tcaputi on the re-key attack issue. It is not mitigated by what is proposed in this issue, but is mitigated with #12649. Also, if I'm understanding the underlying mechanisms correctly, old snapshots would still be using the old user key. Since a rekey only changes the user key (what the user enters), and not the master key (what the system actually encrypts blocks with), one could likely use I attempted to tackle this issue last summer, but the scope of the project defeated me. I'll be graduating in the spring, and I may be able to take another stab at it after that. I did manage to write a shell script that accomplishes much of the same thing using user properties. Obviously, this has its own small stack of caveats. I'll see what state that code is in and post a link to it here, hopefully in the next few days. |
@1da1a172 If we can save these parameters in a separate file which can be stored securely, these parameters should always be usable to decrypt the master key as long as the user remembers the corresponding password. This could be used in break-glass kind of situations, but it also comes with a (manageable) security risk that anyone who can access this file AND the password has a permanent way to access the dataset. Theoretically, though, the implementation shouldn't be that hard. We just need to save the parameters needed to derive the user key to a file and then allow the proper hooks into the kernel to allow those parameters to be used instead of the ones that are saved in zfs. Then that would need to be wired out into the command line interface. |
@tcaputi Hey Tom: It has been a couple months and nobody on the team has even responded to my CVE submission. Do you have an inside track on who to poke or best forum to raise this issue? Does anyone even own encryption since you left? |
I'm not 100% sure who the best person to ask about this is at the moment. In general, zfs is a pretty large project with a ton of users and so the maintainers (including me, formerly) regularly had to pick and choose issues which we felt had the highest value and were the easiest / clearest to implement. In several cases, I prioritized work that was important to my company, which I think was fair since they were the ones paying me to work on an open source project. Other maintainers (on all sorts of open source projects, not just zfs) are in a similar boat. If you feel this issue has been overlooked I would consider sending an email to one of the core maintainers (such as @behlendorf or @ahrens), but just keep these challenges in mind when you do.
In general, I would say this is a bit of a misunderstanding of how the project works. Nobody 'owns' encryption because all of the maintainers work on the whole project. I think all of us have bits of the code that we are more familiar with than others, but many new features (especially larger ones) tend to impact many areas. ZFS is able to do a lot of neat things because the borders between layers are a little blurrier than in a traditional filesystem / block device / caching stack. Hope that helps. |
I certainly understand priorities and have an idea of the breadth/depth of the project. However I'm not looking for someone to drop everything and work the issue immediately, as much as that would make me happy and a lot less nervous. I am looking for someone to acknowledge that there is a vulnerability and approve the CVE. As evidenced by your need to explain to @1da1a172 (above), users need to be made aware that using encryption with the otherwise fantastic filesystem can potentially be a ransom-trap. This way each may weigh the risk according to their own requirements. @ahrens: I see that you gave a thumbs up...could you have a peek at my CVE and forward to whoever needs to review? If it is not valid or needs amending, I would be happy to be better informed and will make changes or withdraw as appropriate. Otherwise, please see that it is approved so it doesn't just sit in limbo... |
@f1d094 It seems that you need to create a separate issue for that. That issue doesn't seem relevant to multiple key slots. |
Sorry for hijacking this thread earlier. I finally made a separate issue #15952 please comment there. Thanks! |
Agreed, it got a bit off-topic. If multiple keyslots were implemented, I would state that we should put them behind a feature flag, and work with both Linux and (Free)BSD to bring their ZFS version/implementation up to date. Has anyone from OpenZFS discussed multiple keyslots with the BSD and Linux folks? |
The problem is that native zfs encryption is unmaintained. Once somebody becomes dedicated to this, we can worry about BSD. |
It turns out that I needed only one key slot. With keyformat=passphrase and keylocation=file:///path/to/keyfile, even if I lose the keyfile, I can reconstruct it if I remember the passphrase. I can just write the passphrase in keyfile. I use the same passphrase for root filesystem and other filesystems. Before I knew this, I thought I needed one key slot for a keyfile and another key slot for a passphrase. If your goal is just to unlock all zfs pools with one passphrase. You don't need multiple key slots. I unlock the root filesystem with one passphrase, and the keyfile will unlock other filesystems with the passphrase. |
+1 for this feature request. I want to be able to auto-unlock using a key stored in a TPM with a backup passphrase stored in hard-copy if the motherboard fails. |
Are you sure you want TPM? It will just unlock your computer without password. If an adversary has physical access to your computer, an unlocked computer can be read easily. |
I can use the TPM with Secure Boot attestation. |
If your threat model is an advanced adversary with physical access to your computer, TPM and secure boot will only enable them to read everything from the hardware. Requiring a password for unlocking storage is more secure. You have to assume they can just take your computer and read what's on it. Technical adversaries who have unlimited physical access will just read what's on a machine that doesn't require a password for unlocking storage. NSA. FBI. CIA. Etc... And, TPM and secure boot have been pushed by microsoft because they want control over your computers. Those mechanisms will be used to take control of your computer away from you. I just disable secure boot and TPM when they are available. If I can't disable them, then they probably exist to benefit microsoft and their allies. TPM and secure boot will be used to implement hardware-level DRM and prevent softwares that haven't been approved by microsoft from running. Once attackers gain access to your computer remotely via software vulnerabilities, TPM and secure boot are useless. TPM and secure boot cannot protect you from physical attacks and software vulnerabilities. |
@anna328p In case you missed the earlier comment, there is a slightly convoluted workaround you can use to combine LUKS key management with ZFS native encryption:
As you described, I have a recovery key in one keyslot, and for the other I use a TPM and Secure Boot. I also use a PIN with the TPM. The effect is that I enter the PIN at boot, and my ZFS filesystems are unlocked and mounted. If I lose the PIN or the TPM PCRs don't match, I have to enter the recovery key. Since the LUKS volume is a zvol on the same pool, it gets the same benefits from ZFS as other data (replication, bitrot protection, etc). |
Also, if your computer boots fully without any password, any attacker who stole your computer will not even need to circumvent encryption because the operating system is already fully functional without a password. |
@Majiir If you are worried about losing keyfile, you can use a passphrase keyfile which contains a passphrase. If you lose the keyfile, you can reconstruct it from your memory. You can remember the passphrase if you use it everyday. I unlock the root filesystem with one passphrase, and the other zfs file systems are unlocked with the same passphrase keyfile on the root filesystem. |
Well, I meant to post this a long time ago. It is another work-around using zfs user properties. |
I'm not worried about anything. I was just explaining the mechanics of the workaround.
I understand the scheme that you are using. However, it does not meet my needs, nor those of some others who have posted here. Multiple keyslots are necessary in order to have a recovery key in addition to a normal passphrase that's tied to a security key or TPM, for example. |
The solution I posted gives you multiple key slots. It just does it by layering on top of what already exists instead of adding it as a first party feature (which would obviously be better). |
@amano-kenji I'm not worried about state-level adversaries backdooring my TPM. I'm not worried about being forced to sign stuff with Microsoft's keys (my laptop, like all x86_64 machines with secure boot tend to, allows custom key management) or MS somehow spying on me via some data I load into a chip on my motherboard. And I require a login password on my machine. My use-case is convenience and allowing unattended boot while making it difficult to read personal information from my laptop if it is stolen or lost. @Majiir Thank you for that workaround, it's really clever and I will probably do something like that on my next install. |
@anna328p Unattended boot means any hacker who has physical access to your computer can read your computer. At the very least, you should protect TPM with a password. |
...if they have arbitrary code execution inside getty or gdm. No, they can't just freeze and pull the RAM, my CPU has transparent memory encryption and the RAM on my laptop is soldered. Either way, my threat model isn't a hacker who would have detailed knowledge of exploiting obscure unix setups, it's someone who steals my computer or picks it up if I lose it. |
If NSA steals your laptop, they will boot it up and somehow read it. TPM has already been backdoored for state-level adversaries. But, your threat model isn't NSA or mossad. Frankly, it is they who have valuable information. Not you. |
@amano-kenji can you please stop this? This has nothing to do with the ticket and also is completely out of place to unsolicitely educate someone on your personal opinions on TPM and state level attackers. |
Just adding myself here to follow this issue. I think it is critical and I was quite disappointed when I found out I still cannot replace LUKS with native ZFS encryption, even though the ticket is almost 8 years old. |
I too would like to see support for multiple keys. For example, if an employee goes AWOL, a sysadmin with a second key can unlock their ZFS dataset, and the company can assign the documents to another employee. |
I'd like to propose a feature request to support multiple key slots/method slots like LUKS does it.
This can be very useful so that for example 2 different people have different passwords and they can independantly open up the encrypted dataset without needing to know the other's (highly secure and complex) passphrase.
Also, if you have multiple zpools it could be useful to provide path to the keyfile to automatically unlock it if needed...
The text was updated successfully, but these errors were encountered: