aboutsummaryrefslogtreecommitdiff
path: root/src/sp/transport/dtls/dtls.c
diff options
context:
space:
mode:
authorGarrett D'Amore <garrett@damore.org>2025-10-05 16:51:15 -0700
committerGarrett D'Amore <garrett@damore.org>2025-10-05 20:56:39 -0700
commit06d6d80f8c92ef1d3bd7c00c919e10a411183cb3 (patch)
treeedf8d4cff9b2f595ccd9e3cb4db3cf31eb13bc02 /src/sp/transport/dtls/dtls.c
parentd1bd64c8251171ac8e1d4e71ab8726c2a64fd55a (diff)
downloadnng-06d6d80f8c92ef1d3bd7c00c919e10a411183cb3.tar.gz
nng-06d6d80f8c92ef1d3bd7c00c919e10a411183cb3.tar.bz2
nng-06d6d80f8c92ef1d3bd7c00c919e10a411183cb3.zip
fixes #2173 New TLS cert API - replaces the properties for CN and ALTNAMES.
This will replace the NNG_OPT_TLS_PEER_ALTNAMES and NNG_OPT_TLS_PEER_CN properties, and gives a bit more access to the certificate, as well as direct access to the raw DER form, which should allow use in other APIs.
Diffstat (limited to 'src/sp/transport/dtls/dtls.c')
-rw-r--r--src/sp/transport/dtls/dtls.c49
1 files changed, 29 insertions, 20 deletions
diff --git a/src/sp/transport/dtls/dtls.c b/src/sp/transport/dtls/dtls.c
index e95560de..400709a1 100644
--- a/src/sp/transport/dtls/dtls.c
+++ b/src/sp/transport/dtls/dtls.c
@@ -6,18 +6,18 @@
// found online at https://opensource.org/licenses/MIT.
//
-#include "core/aio.h"
-#include "core/defs.h"
-#include "core/idhash.h"
-#include "core/message.h"
-#include "core/nng_impl.h"
-#include "core/options.h"
-#include "core/pipe.h"
-#include "core/platform.h"
-#include "core/socket.h"
-#include "core/stats.h"
+#include "../../../core/aio.h"
+#include "../../../core/defs.h"
+#include "../../../core/idhash.h"
+#include "../../../core/message.h"
+#include "../../../core/nng_impl.h"
+#include "../../../core/options.h"
+#include "../../../core/pipe.h"
+#include "../../../core/platform.h"
+#include "../../../core/socket.h"
+#include "../../../core/stats.h"
+#include "../../../supplemental/tls/tls_common.h"
#include "nng/nng.h"
-#include "supplemental/tls/tls_common.h"
#include <string.h>
@@ -1070,6 +1070,14 @@ dtls_pipe_getopt(
return (nni_getopt(dtls_pipe_options, name, p, buf, szp, t));
}
+static nng_err
+dtls_pipe_peer_cert(void *arg, nng_tls_cert **certp)
+{
+ dtls_pipe *p = arg;
+
+ return (nni_tls_peer_cert(&p->tls, certp));
+}
+
static void
dtls_ep_fini(void *arg)
{
@@ -1676,15 +1684,16 @@ dtls_ep_accept(void *arg, nni_aio *aio)
}
static nni_sp_pipe_ops dtls_pipe_ops = {
- .p_size = dtls_pipe_size,
- .p_init = dtls_pipe_init,
- .p_fini = dtls_pipe_fini,
- .p_stop = dtls_pipe_stop,
- .p_send = dtls_pipe_send,
- .p_recv = dtls_pipe_recv,
- .p_close = dtls_pipe_close,
- .p_peer = dtls_pipe_peer,
- .p_getopt = dtls_pipe_getopt,
+ .p_size = dtls_pipe_size,
+ .p_init = dtls_pipe_init,
+ .p_fini = dtls_pipe_fini,
+ .p_stop = dtls_pipe_stop,
+ .p_send = dtls_pipe_send,
+ .p_recv = dtls_pipe_recv,
+ .p_close = dtls_pipe_close,
+ .p_peer = dtls_pipe_peer,
+ .p_getopt = dtls_pipe_getopt,
+ .p_peer_cert = dtls_pipe_peer_cert,
};
static const nni_option dtls_ep_opts[] = {