<div dir="ltr">Jeremy, I believe you're running into a common issue that adding a PIN to an empty device is not supported, or at least is a no-op. The reason, I think, is that the PIN is implemented as symmetric encryption of the secrets it's protecting, so if no keys have been added, then there's nothing to encrypt, so the PIN effectively vanishes into thin air.<div><br></div><div>Since everyone appreciates armchair quarterbacking, I wonder whether it could have been done as a tagged structure of some sort that contains the keys, but also is > 0 bytes in length when empty. Then the PIN would have something to encrypt, and a way for the system to know whether an asserted PIN is valid.</div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Wed, Jan 30, 2019 at 11:41 AM Jeremy Drake <<a href="mailto:jeremydrake%2Bgnuk@eacceleration.com">jeremydrake+gnuk@eacceleration.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">On a related note, I have found that the process of setting PINs and<br>
loading keys (whether importing or generating) is highly order dependent,<br>
and if I do not do things in exactly the right order, unexpected things<br>
happen and I wind up having to start over. It looks like the order<br>
followed here is almost the same as the order I wrote down to follow that<br>
works for me, except I would have changed the admin pin before importing<br>
the key.<br>
<br>
<br>
<br>
On Tue, 29 Jan 2019, Mike Tsao wrote:<br>
<br>
> This is on FSIJ-1.2.13 running on an ST_DONGLE.<br>
><br>
> 1. Flash using standard method.<br>
> 2. gpg --card-edit<br>
> 3. factory-reset, y, yes<br>
> 4. rm -rf .gnupg, kill gpg-connect-agent, etc. so GnuPG is fresh<br>
> 5. gpg --import my-secret-subkeys.gpg<br>
> 6. gpg --edit-key myname<br>
> 7. key 1<br>
> 8. keytocard<br>
> 9. (answer menu for encryption key)<br>
> 10. when asked for admin PIN, enter 12345678<br>
> 11. when asked again for admin PIN, enter 12345678<br>
> 12. exit<br>
> 13. gpg --card-edit<br>
> 14. admin<br>
> 15. passwd<br>
> 16. enter 1 for user PIN<br>
> 17. *enter 12345678*<br>
> 18. when asked for new password, enter thisismypassword<br>
> 19. when asked again for new password, enter thisismypassword<br>
> 20. exit<br>
> 21. gpg --card-status to confirm that the gnuk device is now loaded with<br>
> the key<br>
> 22. gpg -d something-encrypted-with-this-key.asc<br>
> 23. when prompted, enter thisismypassword<br>
> 24. get "no decryption key"<br>
> 25. try again<br>
> 26. try again<br>
> 27. device is locked<br>
><br>
> Do you see what I did wrong? At step 17 I entered 12345678 instead of<br>
> 123456. I forgot that the default admin PIN is different from the default<br>
> user PIN. But the messages that GnuPG printed suggested that the password<br>
> change succeeded! (See transcript below.)<br>
><br>
> Moreover, I went back to step 25 and tried entering 123456. Nope -- the<br>
> password is indeed changed, but it's changed to neither 123456, 12345678,<br>
> or thisismypassword.<br>
><br>
> The bug I'm reporting is that I don't understand why GnuPG accepted the<br>
> wrong initial user PIN. Why didn't it report that the password change<br>
> failed? Aside from it being obviously frustrating because the only way to<br>
> fix it is to factory-reset and do the whole process over again. But it<br>
> could be a serious issue if a user believes the device is correctly set up,<br>
> and then (foolishly) discards other copies of the secret subkey.<br>
><br>
> I hope this is something within gnuk's control. If it's just GnuPG being<br>
> silly, then there isn't much this team can do about it.<br>
><br>
> (transcript of session follows)<br>
>> admin<br>
> Admin commands are allowed<br>
><br>
> gpg/card> passwd<br>
> gpg: OpenPGP card no. D2760001xxxxxxxx detected<br>
><br>
> 1 - change PIN<br>
> 2 - unblock PIN<br>
> 3 - change Admin PIN<br>
> 4 - set the Reset Code<br>
> Q - quit<br>
><br>
> Your selection? 1 [entered 12345678, then thisismypassword twice]<br>
><br>
> *PIN changed. <===== NOTE REPORT OF SUCCESS*<br>
><br>
> 1 - change PIN<br>
> 2 - unblock PIN<br>
> 3 - change Admin PIN<br>
> 4 - set the Reset Code<br>
> Q - quit<br>
><br>
> Your selection? q<br>
><br>
> gpg/card> verify [entered thisismypassword]<br>
><br>
> Reader ...........: 234B:0000:FSIJ-1.2.13-xxxxx<br>
> Application ID ...: D2760001xxxxxxx<br>
> Version ..........: 2.0<br>
> Manufacturer .....: unmanaged S/N range<br>
> Serial number ....: xxxxxx<br>
> Name of cardholder: [not set]<br>
> Language prefs ...: [not set]<br>
> Sex ..............: unspecified<br>
> URL of public key : [not set]<br>
> Login data .......: [not set]<br>
> Signature PIN ....: forced<br>
> Key attributes ...: ed25519 rsa2048 rsa2048<br>
> Max. PIN lengths .: 127 127 127<br>
> *PIN retry counter : 2 3 3 <===== NOTE DECREMENT*<br>
><br>
> (end transcript)<br>
><br>
</blockquote></div>