This release fixes one security issue, updates logging, and adds support for post quantum secure key exchange. Specific changes:
1. Converted various exceptions to info messages to reduce clutter in logs and provide more informative detail.
2. Add construction and printing of a code version hash.
3. Add key exchange versioning. This changes the on-the-wire format, and is presently done in a backwards-compatible way through the legacy tunable.
4. Add support for the post quantum secure hybrid key exchange algorithm Curve25519+sntrup761. This pairing was chosen because sntrup761 was not selected as a candidate for standardization by NIST, so is not likely to see further tweaks, and is independently implemented already in OpenSSH to provide pq security. Right now this requires manual installation of liboqs-python and changing a tunable to enable.
5. Fix a security issue where a malicious, active, MITM with a valid signing key could replace a key request random value with their own. It is not obviously exploitable beyond making denial of service easier. Controllers (if used) must be updated first.
As a consequence of the security fix, controllers must be updated first so that they no longer replace the random value with their own.