Yubikey - rule them all
Make your life secure with a hardware key
Finally I have one(two cause of backup) Yubikey 5 NFC and FINALLY I took the time to dig deeper into private security.
Here I will provide long story short summary about my learnings and a quick howto.
- Download tails image to USB and boot it
- Create secure passphrase with this commands, or with helper like
passphrase.html or passphrase.csv after print
lp -d Printer-Name passphrase.csvor with Dicewire
 Write them down on a paper, your PINs included and a backup flash drive with primary key andCERTIFY_PASS=$(LC_ALL=C tr -dc 'A-Z1-9' < /dev/urandom | \ tr -d "1IOS5U" | fold -w 30 | sed "-es/./ /"{1..26..5} | \ cut -c2- | tr " " "-" | head -1) ; echo "$CERTIFY_PASS"GNUPGHOMEdir
- Create a gpg key (export GNUPGHOME=$(mktemp -d -t gnupg-$(date +%Y-%m-%d)-XXXXXXXXXX))- gpg --quick-gen-key 'Sample <please@dont-spam.us>' ed25519 cert never
- Create subkeys- gpg --quick-add-key $KEYID ed25519 sign 2y
- gpg --quick-add-key $KEYID ed25519 auth 2y
- gpg --quick-add-key $KEYID cv25519 encrypt 2y
 
- Export public key gpg --export -a -o $KEYID.pub $KEYID
- Backup secret keys
 gpg --output $KEYID-Certify.key --armor --export-secret-keys $KEYID gpg --output $KEYID-Subkeys.key --armor --export-secret-subkeys $KEYID
- Configure yubikey- Check status with - gpg --card-status
- Create Admin & User PIN - ADMIN_PIN=$(LC_ALL=C tr -dc '0-9' < /dev/urandom | fold -w8 | head -1) USER_PIN=$(LC_ALL=C tr -dc '0-9' < /dev/urandom | fold -w6 | head -1) printf "\nAdmin PIN: %12s\nUser PIN: %13s\n\n" "$ADMIN_PIN" "$USER_PIN"
- Set Admin PIN - gpg --command-fd=0 --pinentry-mode=loopback --change-pin <<EOF 3 12345678 $ADMIN_PIN $ADMIN_PIN q EOF
- Set User PIN - gpg --command-fd=0 --pinentry-mode=loopback --change-pin <<EOF 1 123456 $USER_PIN $USER_PIN q EOF
- Set attributes, URL is for the possibility to fetch pub key from keyserver if given. - gpg --card-edit admin login name url
- Transfer subkeys 🔺 copy your - $GNUPGHOMEdir before transfer Make sure you have selected the right key, marked with *- gpg --edit-key $KEYID key X keytocard
- Verify key transfer with - gpg -K, each subkey should have- >sign, means not in store. TIP: Create a new- GNUPGHOMEand import your private keys, to move them to a backup Yubikey as well.
- Upload public key to keyserver, but first set keyserver in your - $GNUPGHOME/gpg.confwith- keyserver https://keys.openpgp.org, than send with- gpg --send-key $KEYIDand verify your email. TIP: Set your public key url in your yubikey with- gpg --card-edit
 
- Using yubikey- Import your public key gpg --import public-key.asc, or dofetchingpg --card-editif you set your url
- Trust this key withgpg --command-fd=0 --pinentry-mode=loopback --edit-key $KEYID <<EOF trust 5 y save EOF
- Set touch for yubikey actionsykman openpgp keys set-touch dec on ykman openpgp keys set-touch enc on ykman openpgp keys set-touch sig on ykman openpgp keys set-touch aut on
- Check your ssh public key with ssh-add -L, if you have some trouble, check SSH section
- Secure your iCloud with your Yubikey (you need 2 of them) Go to settings in your iPhone, open your apple account, open security, 2fa, than add your hardware keys.
- Secure your bitwarden 2FA with your key, open bitwarden (vaultwarden) on web, go to security, 2FA and add your keys at FIDO2/WebAuth
 
- Import your public key 
Sources: