Skip to content

Releases: go-piv/piv-go

v1.7.0

08 Dec 15:55
Compare
Choose a tag to compare
  • Implement import key functionality #83
  • Support added for x32 ARCH and other 32 bit architectures #81
  • Add method for accessing retired key management slots #72

v1.6.0

09 Sep 15:39
Compare
Choose a tag to compare
  • Fixes for older YubiKeys that don't support attestation certificates #59
  • Add yubikey 5ci form factor #63 @xoebus
  • Fix retry errors detection on some older YubiKeys #64
  • PIN policy can now be specified explicitly instead of being inferred by the attestation certificate #65
  • Ed25519 support as implemented by SoloKeys added #69 @nickray
  • FreeBSD support added #70 @gonzoua
  • TouchPolicyAlways and TouchPolicyCached variables now correspond to their spec values #74 @joemiller
  • cgo now uses pkg-config on Linux to discover pcsclite #75 @rawkode @philandstuff
  • ECDH support added #80 @tv42

v1.5.0

03 May 18:01
Compare
Choose a tag to compare
  • Fixes for PIN prompt for PIN policy once #44
  • Attestation certificate is used for determining PIN prompt strategy #50
  • Connections are now marked as exclusive #51
  • PC/SC errors on MacOS are now reported correctly #54
  • Add support for Windows #57 (@tobiaskohlbau)

v1.4.0

26 Apr 01:34
Compare
Choose a tag to compare
  • YubiKey structs are now exclusive, you can't have multiple YubiKey structs for the same card open #39
  • PINPrompt now works as expected for PINPolicyOnce #37
  • Attest returns ErrNotFound if the slot hasn't been initialized #40

v1.3.0

23 Apr 05:10
Compare
Choose a tag to compare

v1.2.0

19 Apr 23:18
Compare
Choose a tag to compare
  • Fix slot object IDs and add management key slot #30

NOTE: previous uses of SetCertificate for the SlotAuthentication and SlotCardAuthentication used the wrong object IDs. This updates them to use the correct values, which may cause breaking changes for previously written certificate. To migrate to the correct slots, use:

mk := piv.DefaultManagementKey
// Migrate SlotAuthenication certificate to the correct slot.
authCert, err := yk.Certificate(piv.SlotCardAuthentication)
if err != nil {
    // ...
}
if err := yk.SetCertificate(mk, piv.SlotAuthentication, authCert); err != nil {
    // ...
}

// Migrate SlotCardAuthentication certificate to the correct slot.
cardAuthCert, err := yk.Certificate(piv.SlotKeyManagement)
if err != nil {
    // ...
}
if err := yk.SetCertificate(mk, piv.SlotCardAuthentication, cardAuthCert); err != nil {
    // ...
}

v1.1.0

16 Apr 03:45
Compare
Choose a tag to compare
  • Document that a slot's public key is stored in the attestation cert #27
  • Update import path for package's new home #28