aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/README.md
diff options
context:
space:
mode:
authordrduh <github@duh.to>2021-08-15 15:24:30 -0700
committerGitHub <noreply@github.com>2021-08-15 15:24:30 -0700
commit92e2a5e8ac320c677a5941fddb8baddadf03df9b (patch)
tree0ea691afd3005b6808602a7fd5a91ea796c01d60 /README.md
parentMerge pull request #264 from iandstanley/master (diff)
parentadded to section multiple Yubikeys section re: switching between Yubikeys (diff)
downloadYubiKey-Guide-92e2a5e8ac320c677a5941fddb8baddadf03df9b.tar.gz
Merge pull request #262 from iandstanley/patch-1
switching between Yubikeys
Diffstat (limited to 'README.md')
-rw-r--r--README.md25
1 files changed, 25 insertions, 0 deletions
diff --git a/README.md b/README.md
index 3adb6c4..f2fb290 100644
--- a/README.md
+++ b/README.md
@@ -1529,6 +1529,31 @@ $ cp -avi /mnt/encrypted-storage/tmp.XXX $GNUPGHOME
$ cd $GNUPGHOME
```
+## Switching between two or more Yubikeys.
+
+When you add a GPG key to a Yubikey using the *keytocard* command, GPG deletes the key form your keyring and adds a *stub* pointing to that exact Yubikey (the stub identifies the GPG KeyID and the Yubikey's serial number).
+
+However, when you do this same operation for a second Yubikey, the stub in your keyring is overwritten by the *keytocard* operation and now the stub points to your second Yubikey. Adding more repeats this overwriting operation.
+
+In other words, the stub will point ONLY to the LAST Yubikey written to.
+
+When using GPG key operations with the GPG key you placed onto the Yubikeys, GPG will request a specific Yubikey asking that you insert a Yubikey with a given serial number (referenced by the stub). GPG will not recognise another Yubikey with a different serial number without manual intervention.
+
+You can force GPG to scan the card and re-create the stubs to point to another Yubikey.
+
+Having created two (or more Yubikeys) with the same GPG key (as described above) where the stubs are pointing to the second Yubikey:
+
+Insert the first Yubikey (which has a different serial numnber) and run the following command:
+
+```console
+$ gpg-connect-agent "scd serialno" "learn --force" /bye
+```
+GPG will then scan your first Yubikey for GPG keys and recreate the stubs to point to the GPG keyID and Yubikey Serial number of this first Yubikey.
+
+To return to using the second Yubikey just repeat (insert other Yubikey and re-run command).
+
+Obviously this command is not easy to remember so it is recommended to either create a script or a shell alias to make this more user friendly.
+
# Cleanup
Ensure you have: