From 97f82741293c67cc0ba9c343456e9ea0dde00055 Mon Sep 17 00:00:00 2001 From: Luca Boccassi Date: Sun, 23 Aug 2020 13:47:07 +0100 Subject: [PATCH] Problem: setsockopt of CURVE key ignores parameter length Solution: create std::string using length to avoid overflow --- src/options.cpp | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/src/options.cpp b/src/options.cpp index 3edc5fcd..83e3e918 100644 --- a/src/options.cpp +++ b/src/options.cpp @@ -276,13 +276,16 @@ int zmq::options_t::set_curve_key (uint8_t *destination_, mechanism = ZMQ_CURVE; return 0; - case CURVE_KEYSIZE_Z85 + 1: - if (zmq_z85_decode (destination_, - reinterpret_cast (optval_))) { + case CURVE_KEYSIZE_Z85 + 1: { + const std::string s (static_cast (optval_), + optvallen_); + + if (zmq_z85_decode (destination_, s.c_str ())) { mechanism = ZMQ_CURVE; return 0; } break; + } case CURVE_KEYSIZE_Z85: char z85_key[CURVE_KEYSIZE_Z85 + 1];