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

Implement Automatic OEM Factory Reset with diceware secrets resulting in QR code to be scanned prior of rebooting/shipping #1827

Open
tlaurion opened this issue Oct 30, 2024 · 9 comments

Comments

@tlaurion
Copy link
Collaborator

tlaurion commented Oct 30, 2024

This is to discuss requirements, turning #1521 into actionnable plan.

@wessel-novacustom @jan23 @JonathonHall-Purism (tag anyone from support teams): if you have time to draft what you would like to see as an OEM to start discussing plan and see if I can do this prior of feature freeze (most probably going to be postponed after November 20th 2024 (#1821)

Also distinguish what you understand what UX needs to be streamlined for better UX (meaning User experience, reduce their frictions)

Thanks!

@tlaurion tlaurion changed the title Implement Automatic OEM Factory Reset with diceware secrets resulting in QR code to be scanned prior of rebooting Implement Automatic OEM Factory Reset with diceware secrets resulting in QR code to be scanned prior of rebooting/shipping Oct 30, 2024
@wessel-novacustom
Copy link

Currently, we just flash Heads and the customer should do the re-ownership steps.

What we want is a situation in which Heads has already been setup by us and once booted, the end user can verify the integrity and take over the ownership including reencryption of the LUKS header, completely automatically with as less prompts as possible.

We don't do that yet because setting safe credentials and communicating them manually is time-consuming.

So what we need is an automated OEM factory reset with the most secure options that generates credentials automatically and combines this in only one QR code that contains all the necessary information for the end user.

In our production process, we split this content so that it will be partly communicated to the customer by paper with the order, and partly by email. We already do this for the LUKS disk encryption passphrase at the moment.

We see a risk that the end user would forget his actual LUKS passphrase if it isn't necessary to type this during boot. Can we mitigate this risk somehow? I'm thinking about a statement on the Important notes document that we deliver with every laptop already.

We have to keep things as simple as possible, especially for the end user, but also for our production process. That doesn't mean we cannot implement a solution on the product side to deliver credentials through two channels.

@tlaurion I'm looking forward to your proposal how this can work.

NovaCustom will take care of the funds after approval.

@tlaurion
Copy link
Collaborator Author

Qrcode can be used to pack all the info, as seen under Kunzisoft/KeePassDX#1443 (comment)

@wessel-novacustom
Copy link

Qrcode can be used to pack all the info, as seen under Kunzisoft/KeePassDX#1443 (comment)

That's great!

How to communicate these credentials to the client without manual intervention?

The customer needs to store all security components separately, which sounds like a hassle to me. I see a lot of confusion of customers who don't know what password is for what component.

@wessel-novacustom
Copy link

I will explain how I see how this can work. So when pressing 'o' upon OEM factory reset, the employee will be asked to:

  • Insert the Nitrokey
  • Provide the DRK recovery key¹, prompted by Heads²

Then, a QR code will be generated with these contents sealed in it:

  • Generated TPM ownership passphrase
  • Generated GPG Admin PIN
  • Generated GPG User PIN
  • Generated TPM Disk Unlock Key passphrase

So this all sealed in ONE transition password (or passphrase).

When customer boots the laptop for the first time, the laptop should automatically:

  • Ask to insert Nitrokey for validation
  • Ask to provide the transition password
  • Generate the new passphrases without asking (DRK passphrase, generate new TPM ownership passphrase, generate new GPG Admin PIN, generate new GPG User PIN, generate new TPM Disk Unlock Key passphrase)
  • Re-encrypt LUKS container without asking
  • Show all the generated credentials and making sure that the customer has saved all. No QR code here³.

And that's it, boot process is normal as it is right now after all steps above.

¹ The process should fail if the DRK is incorrect.
² The prompt should allow a USB keyboard. Real situation is that we can use our QR scan device.
³ To avoid confusion with TOTP scan code.

@tlaurion
Copy link
Collaborator Author

tlaurion commented Nov 10, 2024

@tlaurion
Copy link
Collaborator Author

tlaurion commented Nov 10, 2024

@tlaurion
Copy link
Collaborator Author

@tlaurion
Copy link
Collaborator Author

tlaurion commented Jan 16, 2025

Implemented by #1875

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

2 participants