<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" "http://www.w3.org/TR/REC-html40/loose.dtd">
<html lang="en">
<head>
<meta content="text/html; charset=US-ASCII" http-equiv="Content-Type">
<title>
GitLab
</title>


<style>img {
max-width: 100%; height: auto;
}
</style>
</head>
<body>
<div class="content">

<p style="color: #777777;">
<a href="https://gitlab.com/dueno">Daiki Ueno</a>
commented on a
<a href="https://gitlab.com/gnutls/gnutls/issues/813#note_281041008">discussion</a>:
</p>
<div style="">
<blockquote dir="auto">
<p>Seeing how this is implemented in openssl and PKCS#11, such an API can get very messy and hard to use if everything needs to be handled.</p>
</blockquote>
<p dir="auto">While they have a good reason (i.e. new API addition is not easy) to provide a single API function that handles all KDF variants, I'm not sure GnuTLS needs to impose such restriction.</p>
<blockquote dir="auto">
<p>Not sure if it helps, but checking what model could fit for such a demanding/extensible API, the closest I see is some function similar to gnutls_session_set_verify_cert2 with gnutls_vdata_types_t, but most likely on steroids.</p>
</blockquote>
<p dir="auto">I'm not a big fan of this idea, because that would move the error checking to the run time.</p>
<p dir="auto">Given that GnuTLS (and nettle) currently only supports HKDF and PBKDF2, I propose to add 3 distinct functions for HKDF-Extract, HKDF-Expand, and PBKDF2 derivation. That way, most of the necessary parameters could be checked at compile time. Of course, it would be a problem if we support Argon2 or similar, but I don't think the number of supported KDFs explode in near future.</p>
</div>


</div>
<div class="footer" style="margin-top: 10px;">
<p style="font-size: small; color: #777;">

<br>
Reply to this email directly or <a href="https://gitlab.com/gnutls/gnutls/issues/813#note_281041008">view it on GitLab</a>.
<br>
You're receiving this email because of your account on gitlab.com.
If you'd like to receive fewer emails, you can
<a href="https://gitlab.com/sent_notifications/d24243bed40fcc09df1e4dfd8e7d547d/unsubscribe">unsubscribe</a>
from this thread or
adjust your notification settings.
<script type="application/ld+json">{"@context":"http://schema.org","@type":"EmailMessage","action":{"@type":"ViewAction","name":"View Issue","url":"https://gitlab.com/gnutls/gnutls/issues/813#note_281041008"}}</script>


</p>
</div>
</body>
</html>