@@ -173,4 +173,30 @@
#endif /* OPENSSL_VERSION_NUMBER < 0x30000000L */
+#if OPENSSL_VERSION_NUMBER < 0x30500000 && (!defined(LIBRESSL_VERSION_NUMBER) || LIBRESSL_VERSION_NUMBER > 0x3050400fL)
+static inline int
+SSL_get0_peer_signature_name(SSL *ssl, const char **sigalg)
+{
+ int peer_sig_nid;
+ if (SSL_get_peer_signature_nid(ssl, &peer_sig_nid)
+ && peer_sig_nid != NID_undef)
+ {
+ *sigalg = OBJ_nid2sn(peer_sig_nid);
+ return 1;
+ }
+ return 0;
+}
+#elif defined(LIBRESSL_VERSION_NUMBER) && LIBRESSL_VERSION_NUMBER <= 0x3050400fL
+/* The older LibreSSL version do not implement any variant of getting the peer
+ * signature */
+static inline int
+SSL_get0_peer_signature_name(const SSL *ssl, const char **sigalg)
+{
+ *sigalg = NULL;
+ return 0;
+}
+#endif /* if OPENSSL_VERSION_NUMBER < 0x30500000 && (!defined(LIBRESSL_VERSION_NUMBER) || LIBRESSL_VERSION_NUMBER > 0x3050400fL) */
+
+
+
#endif /* OPENSSL_COMPAT_H_ */
@@ -2454,20 +2454,17 @@
static void
print_peer_signature(SSL *ssl, char *buf, size_t buflen)
{
- int peer_sig_nid = NID_undef, peer_sig_type_nid = NID_undef;
- const char *peer_sig = "unknown";
+ int peer_sig_type_nid = NID_undef;
+ const char *peer_sig_unknown = "unknown";
+ const char *peer_sig = peer_sig_unknown;
const char *peer_sig_type = "unknown type";
- /* Even though these methods use the deprecated NIDs instead of using
- * string as new OpenSSL APIs do, there seem to be no API that replaces
- * it yet */
-#if !defined(LIBRESSL_VERSION_NUMBER) || LIBRESSL_VERSION_NUMBER > 0x3050400fL
- if (SSL_get_peer_signature_nid(ssl, &peer_sig_nid)
- && peer_sig_nid != NID_undef)
+ const char *signame = NULL;
+ SSL_get0_peer_signature_name(ssl, &signame);
+ if (signame)
{
- peer_sig = OBJ_nid2sn(peer_sig_nid);
+ peer_sig = signame;
}
-#endif
#if !defined(LIBRESSL_VERSION_NUMBER) \
|| (defined(LIBRESSL_VERSION_NUMBER) && LIBRESSL_VERSION_NUMBER >= 0x3090000fL)
@@ -2480,7 +2477,7 @@
}
#endif
- if (peer_sig_nid == NID_undef && peer_sig_type_nid == NID_undef)
+ if (peer_sig == peer_sig_unknown && peer_sig_type_nid == NID_undef)
{
return;
}