Commit dd4b93dd authored by Constantin Rack's avatar Constantin Rack

Merge pull request #1790 from hintjens/master

Problem: use of libsodium vs. tweetnacl is confused
parents 42ab88e4 ddbbe3b4
...@@ -127,6 +127,8 @@ test_udp ...@@ -127,6 +127,8 @@ test_udp
test_large_msg test_large_msg
test_use_fd_ipc test_use_fd_ipc
test_use_fd_tcp test_use_fd_tcp
test_pre_allocated_fd_ipc
test_pre_allocated_fd_tcp
tests/test*.log tests/test*.log
tests/test*.trs tests/test*.trs
src/platform.hpp* src/platform.hpp*
......
This diff is collapsed.
...@@ -269,11 +269,6 @@ src_libzmq_la_CPPFLAGS = ...@@ -269,11 +269,6 @@ src_libzmq_la_CPPFLAGS =
src_libzmq_la_CXXFLAGS = @LIBZMQ_EXTRA_CXXFLAGS@ src_libzmq_la_CXXFLAGS = @LIBZMQ_EXTRA_CXXFLAGS@
src_libzmq_la_LIBADD = src_libzmq_la_LIBADD =
if HAVE_SODIUM
src_libzmq_la_CPPFLAGS += ${sodium_CFLAGS}
src_libzmq_la_LIBADD += ${sodium_LIBS}
endif
if USE_TWEETNACL if USE_TWEETNACL
src_libzmq_la_SOURCES += \ src_libzmq_la_SOURCES += \
tweetnacl/src/tweetnacl.c \ tweetnacl/src/tweetnacl.c \
...@@ -283,6 +278,11 @@ src_libzmq_la_CXXFLAGS += \ ...@@ -283,6 +278,11 @@ src_libzmq_la_CXXFLAGS += \
-I$(top_builddir)/tweetnacl/src -I$(top_builddir)/tweetnacl/src
endif endif
if USE_LIBSODIUM
src_libzmq_la_CPPFLAGS += ${sodium_CFLAGS}
src_libzmq_la_LIBADD += ${sodium_LIBS}
endif
if HAVE_PGM if HAVE_PGM
src_libzmq_la_CPPFLAGS += ${pgm_CFLAGS} src_libzmq_la_CPPFLAGS += ${pgm_CFLAGS}
src_libzmq_la_LIBADD += ${pgm_LIBS} src_libzmq_la_LIBADD += ${pgm_LIBS}
......
...@@ -67,8 +67,6 @@ LIBZMQ_CHECK_ENABLE_DEBUG ...@@ -67,8 +67,6 @@ LIBZMQ_CHECK_ENABLE_DEBUG
# Check wheter to enable code coverage # Check wheter to enable code coverage
LIBZMQ_WITH_GCOV LIBZMQ_WITH_GCOV
AC_MSG_CHECKING([if TIPC is available and supports nonblocking connect]) AC_MSG_CHECKING([if TIPC is available and supports nonblocking connect])
AC_RUN_IFELSE( AC_RUN_IFELSE(
...@@ -103,7 +101,6 @@ AC_RUN_IFELSE( ...@@ -103,7 +101,6 @@ AC_RUN_IFELSE(
AC_MSG_RESULT([$libzmq_tipc_support]) AC_MSG_RESULT([$libzmq_tipc_support])
AC_ARG_WITH([relaxed], AC_ARG_WITH([relaxed],
[AS_HELP_STRING([--with-relaxed], [AS_HELP_STRING([--with-relaxed],
[Switch off pedantic compiler])], [Switch off pedantic compiler])],
...@@ -423,58 +420,49 @@ if test "x$require_libgssapi_krb5_ext" != "xno"; then ...@@ -423,58 +420,49 @@ if test "x$require_libgssapi_krb5_ext" != "xno"; then
AC_MSG_ERROR(libgssapi_krb5 is needed for GSSAPI security)) AC_MSG_ERROR(libgssapi_krb5 is needed for GSSAPI security))
fi fi
# build using libsodium # Select curve encryption library, defaults to tweetnacl
have_sodium_library="no" # To use libsodium instead, use --with-libsodium (must be installed)
# To disable curve, use --disable-curve
AC_ARG_WITH([libsodium], [AS_HELP_STRING([--with-libsodium],
[require libzmq build with libsodium crypto library. Requires pkg-config [default=check]])], AC_ARG_WITH([libsodium],
[require_libsodium_ext=$withval], AS_HELP_STRING([--with-libsodium], [Use libsodium instead of built-in tweetnacl [default=no]]))
[require_libsodium_ext=check])
AS_IF([test "x$with_libsodium" = "xyes"], [
AC_ARG_WITH([tweetnacl], [AS_HELP_STRING([--with-tweetnacl], PKG_CHECK_MODULES([sodium], [libsodium], [libsodium_found=yes], [
[build libzmq with bundled tweetnacl crypto library [default=no]])], AC_MSG_ERROR(libsodium is not installed. Install it, then run configure again)
[require_libsodium_ext=no
with_tweetnacl=yes
AC_MSG_CHECKING(for sodium)
AC_MSG_RESULT(tweetnacl)],
[with_tweetnacl=check])
# conditionally require libsodium package
if test "x$require_libsodium_ext" != "xno"; then
PKG_CHECK_MODULES([sodium], [libsodium],
[
have_sodium_library=yes
with_tweetnacl=no
],
[
if test "x$require_libsodium_ext" == "xyes"; then
AC_MSG_ERROR(libsodium has been requested but not found)
else
AC_MSG_RESULT([ libsodium not found, using tweetnacl])
have_sodium_library=no
with_tweetnacl=yes
fi
]) ])
fi ])
if test "x$have_sodium_library" != "xno"; then AC_ARG_ENABLE([curve],
AC_DEFINE(HAVE_LIBSODIUM, 1, [The libsodium library is to be used.]) AS_HELP_STRING([--disable-curve], [Disable CURVE security [default=no]]))
# ssp library is required for libsodium on Solaris-like systems if test "x$enable_curve" == "xno"; then
curve_library=""
AC_MSG_NOTICE([CURVE security is disabled])
elif test "x$with_libsodium" == "xyes"; then
AC_MSG_NOTICE([Using libsodium for CURVE security])
AC_DEFINE(ZMQ_HAVE_CURVE, [1], [Using curve encryption])
AC_DEFINE(HAVE_LIBSODIUM, [1], [Using libsodium for curve encryption])
curve_library="libsodium"
# On Solaris, libsodium depends on libssp
case "${host_os}" in case "${host_os}" in
*solaris*) *solaris*)
LDFLAGS="-lssp $LDFLAGS" LDFLAGS="-lssp $LDFLAGS"
CPPFLAGS="$CPPFLAGS -Wno-long-long" CPPFLAGS="-Wno-long-long $CPPFLAGS"
;; ;;
esac esac
elif test "x$with_tweetnacl" != "xno"; then else
AC_DEFINE(HAVE_LIBSODIUM, 1, [Sodium is provided by tweetnacl.]) AC_MSG_NOTICE([Using tweetnacl for CURVE security])
AC_DEFINE(HAVE_TWEETNACL, 1, [Using tweetnacl.]) AC_DEFINE(ZMQ_HAVE_CURVE, [1], [Using curve encryption])
libzmq_pedantic="no" AC_DEFINE(HAVE_TWEETNACL, [1], [Using tweetnacl for curve encryption])
curve_library="tweetnacl"
libzmq_pedantic="no" # Disable pedantic warnings
fi fi
AM_CONDITIONAL(HAVE_SODIUM, test "x$have_sodium_library" != "xno") AM_CONDITIONAL(USE_LIBSODIUM, test "$curve_library" == "sodium")
AM_CONDITIONAL(USE_TWEETNACL, test "x$with_tweetnacl" != "xno") AM_CONDITIONAL(USE_TWEETNACL, test "$curve_library" == "tweetnacl")
# build using pgm # build using pgm
have_pgm_library="no" have_pgm_library="no"
...@@ -507,8 +495,6 @@ AC_ARG_WITH([norm], ...@@ -507,8 +495,6 @@ AC_ARG_WITH([norm],
[with_norm_ext=$withval], [with_norm_ext=$withval],
[with_norm_ext=no]) [with_norm_ext=no])
AC_MSG_CHECKING("with_norm_ext = ${with_norm_ext}") AC_MSG_CHECKING("with_norm_ext = ${with_norm_ext}")
if test "x$with_norm_ext" != "xno"; then if test "x$with_norm_ext" != "xno"; then
......
...@@ -48,12 +48,10 @@ ...@@ -48,12 +48,10 @@
#include "err.hpp" #include "err.hpp"
#include "msg.hpp" #include "msg.hpp"
#ifdef HAVE_LIBSODIUM #if defined (HAVE_TWEETNACL)
#ifdef HAVE_TWEETNACL # include "randombytes.h"
#include "randombytes.h" #elif defined (HAVE_LIBSODIUM)
#else # include "sodium.h"
#include "sodium.h"
#endif
#endif #endif
#ifdef ZMQ_HAVE_VMCI #ifdef ZMQ_HAVE_VMCI
...@@ -63,7 +61,7 @@ ...@@ -63,7 +61,7 @@
#define ZMQ_CTX_TAG_VALUE_GOOD 0xabadcafe #define ZMQ_CTX_TAG_VALUE_GOOD 0xabadcafe
#define ZMQ_CTX_TAG_VALUE_BAD 0xdeadbeef #define ZMQ_CTX_TAG_VALUE_BAD 0xdeadbeef
int clipped_maxsocket(int max_requested) int clipped_maxsocket (int max_requested)
{ {
if (max_requested >= zmq::poller_t::max_fds () && zmq::poller_t::max_fds () != -1) if (max_requested >= zmq::poller_t::max_fds () && zmq::poller_t::max_fds () != -1)
// -1 because we need room for the reaper mailbox. // -1 because we need room for the reaper mailbox.
...@@ -127,8 +125,8 @@ zmq::ctx_t::~ctx_t () ...@@ -127,8 +125,8 @@ zmq::ctx_t::~ctx_t ()
// If we've done any Curve encryption, we may have a file handle // If we've done any Curve encryption, we may have a file handle
// to /dev/urandom open that needs to be cleaned up. // to /dev/urandom open that needs to be cleaned up.
#ifdef HAVE_LIBSODIUM #ifdef ZMQ_HAVE_CURVE
randombytes_close(); randombytes_close ();
#endif #endif
// Remove the tag, so that the object is considered dead. // Remove the tag, so that the object is considered dead.
......
...@@ -29,7 +29,7 @@ ...@@ -29,7 +29,7 @@
#include "platform.hpp" #include "platform.hpp"
#ifdef HAVE_LIBSODIUM #ifdef ZMQ_HAVE_CURVE
#ifdef ZMQ_HAVE_WINDOWS #ifdef ZMQ_HAVE_WINDOWS
#include "windows.hpp" #include "windows.hpp"
......
...@@ -30,15 +30,16 @@ ...@@ -30,15 +30,16 @@
#ifndef __ZMQ_CURVE_CLIENT_HPP_INCLUDED__ #ifndef __ZMQ_CURVE_CLIENT_HPP_INCLUDED__
#define __ZMQ_CURVE_CLIENT_HPP_INCLUDED__ #define __ZMQ_CURVE_CLIENT_HPP_INCLUDED__
#ifdef ZMQ_HAVE_CURVE
#include "platform.hpp" #include "platform.hpp"
#include "mutex.hpp" #include "mutex.hpp"
#ifdef HAVE_LIBSODIUM #if defined (HAVE_TWEETNACL)
#ifdef HAVE_TWEETNACL # include "tweetnacl_base.h"
#include "tweetnacl_base.h" # include "randombytes.h"
#include "randombytes.h" #elif defined (HAVE_LIBSODIUM)
#else # include "sodium.h"
#include "sodium.h"
#endif #endif
#if crypto_box_NONCEBYTES != 24 \ #if crypto_box_NONCEBYTES != 24 \
...@@ -46,7 +47,7 @@ ...@@ -46,7 +47,7 @@
|| crypto_box_SECRETKEYBYTES != 32 \ || crypto_box_SECRETKEYBYTES != 32 \
|| crypto_box_ZEROBYTES != 32 \ || crypto_box_ZEROBYTES != 32 \
|| crypto_box_BOXZEROBYTES != 16 || crypto_box_BOXZEROBYTES != 16
#error "libsodium not built properly" # error "libsodium not built properly"
#endif #endif
#include "mechanism.hpp" #include "mechanism.hpp"
......
...@@ -29,7 +29,7 @@ ...@@ -29,7 +29,7 @@
#include "platform.hpp" #include "platform.hpp"
#ifdef HAVE_LIBSODIUM #ifdef ZMQ_HAVE_CURVE
#ifdef ZMQ_HAVE_WINDOWS #ifdef ZMQ_HAVE_WINDOWS
#include "windows.hpp" #include "windows.hpp"
......
...@@ -30,15 +30,17 @@ ...@@ -30,15 +30,17 @@
#ifndef __ZMQ_CURVE_SERVER_HPP_INCLUDED__ #ifndef __ZMQ_CURVE_SERVER_HPP_INCLUDED__
#define __ZMQ_CURVE_SERVER_HPP_INCLUDED__ #define __ZMQ_CURVE_SERVER_HPP_INCLUDED__
#ifdef ZMQ_HAVE_CURVE
#include "platform.hpp" #include "platform.hpp"
#ifdef HAVE_LIBSODIUM #if defined (HAVE_TWEETNACL)
#ifdef HAVE_TWEETNACL # include "tweetnacl_base.h"
#include "tweetnacl_base.h" # include "randombytes.h"
#include "randombytes.h" #elif defined (HAVE_LIBSODIUM)
#else # include "sodium.h"
#include "sodium.h"
#endif #endif
#if crypto_box_NONCEBYTES != 24 \ #if crypto_box_NONCEBYTES != 24 \
|| crypto_box_PUBLICKEYBYTES != 32 \ || crypto_box_PUBLICKEYBYTES != 32 \
|| crypto_box_SECRETKEYBYTES != 32 \ || crypto_box_SECRETKEYBYTES != 32 \
...@@ -47,7 +49,7 @@ ...@@ -47,7 +49,7 @@
|| crypto_secretbox_NONCEBYTES != 24 \ || crypto_secretbox_NONCEBYTES != 24 \
|| crypto_secretbox_ZEROBYTES != 32 \ || crypto_secretbox_ZEROBYTES != 32 \
|| crypto_secretbox_BOXZEROBYTES != 16 || crypto_secretbox_BOXZEROBYTES != 16
#error "libsodium not built properly" # error "libsodium not built properly"
#endif #endif
#include "mechanism.hpp" #include "mechanism.hpp"
......
...@@ -320,7 +320,7 @@ int zmq::options_t::setsockopt (int option_, const void *optval_, ...@@ -320,7 +320,7 @@ int zmq::options_t::setsockopt (int option_, const void *optval_,
} }
break; break;
# if defined ZMQ_HAVE_SO_PEERCRED || defined ZMQ_HAVE_LOCAL_PEERCRED #if defined ZMQ_HAVE_SO_PEERCRED || defined ZMQ_HAVE_LOCAL_PEERCRED
case ZMQ_IPC_FILTER_UID: case ZMQ_IPC_FILTER_UID:
if (optvallen_ == 0 && optval_ == NULL) { if (optvallen_ == 0 && optval_ == NULL) {
ipc_uid_accept_filters.clear (); ipc_uid_accept_filters.clear ();
...@@ -344,9 +344,9 @@ int zmq::options_t::setsockopt (int option_, const void *optval_, ...@@ -344,9 +344,9 @@ int zmq::options_t::setsockopt (int option_, const void *optval_,
return 0; return 0;
} }
break; break;
# endif #endif
# if defined ZMQ_HAVE_SO_PEERCRED #if defined ZMQ_HAVE_SO_PEERCRED
case ZMQ_IPC_FILTER_PID: case ZMQ_IPC_FILTER_PID:
if (optvallen_ == 0 && optval_ == NULL) { if (optvallen_ == 0 && optval_ == NULL) {
ipc_pid_accept_filters.clear (); ipc_pid_accept_filters.clear ();
...@@ -358,7 +358,7 @@ int zmq::options_t::setsockopt (int option_, const void *optval_, ...@@ -358,7 +358,7 @@ int zmq::options_t::setsockopt (int option_, const void *optval_,
return 0; return 0;
} }
break; break;
# endif #endif
case ZMQ_PLAIN_SERVER: case ZMQ_PLAIN_SERVER:
if (is_int && (value == 0 || value == 1)) { if (is_int && (value == 0 || value == 1)) {
...@@ -403,8 +403,8 @@ int zmq::options_t::setsockopt (int option_, const void *optval_, ...@@ -403,8 +403,8 @@ int zmq::options_t::setsockopt (int option_, const void *optval_,
} }
break; break;
// If libsodium isn't installed, these options provoke EINVAL // If curve encryption isn't built, these options provoke EINVAL
# ifdef HAVE_LIBSODIUM #ifdef ZMQ_HAVE_CURVE
case ZMQ_CURVE_SERVER: case ZMQ_CURVE_SERVER:
if (is_int && (value == 0 || value == 1)) { if (is_int && (value == 0 || value == 1)) {
as_server = value; as_server = value;
...@@ -496,7 +496,7 @@ int zmq::options_t::setsockopt (int option_, const void *optval_, ...@@ -496,7 +496,7 @@ int zmq::options_t::setsockopt (int option_, const void *optval_,
} }
} }
break; break;
# endif #endif
case ZMQ_CONFLATE: case ZMQ_CONFLATE:
if (is_int && (value == 0 || value == 1)) { if (is_int && (value == 0 || value == 1)) {
...@@ -506,7 +506,7 @@ int zmq::options_t::setsockopt (int option_, const void *optval_, ...@@ -506,7 +506,7 @@ int zmq::options_t::setsockopt (int option_, const void *optval_,
break; break;
// If libgssapi isn't installed, these options provoke EINVAL // If libgssapi isn't installed, these options provoke EINVAL
# ifdef HAVE_LIBGSSAPI_KRB5 #ifdef HAVE_LIBGSSAPI_KRB5
case ZMQ_GSSAPI_SERVER: case ZMQ_GSSAPI_SERVER:
if (is_int && (value == 0 || value == 1)) { if (is_int && (value == 0 || value == 1)) {
as_server = value; as_server = value;
...@@ -538,7 +538,7 @@ int zmq::options_t::setsockopt (int option_, const void *optval_, ...@@ -538,7 +538,7 @@ int zmq::options_t::setsockopt (int option_, const void *optval_,
return 0; return 0;
} }
break; break;
# endif #endif
case ZMQ_HANDSHAKE_IVL: case ZMQ_HANDSHAKE_IVL:
if (is_int && value >= 0) { if (is_int && value >= 0) {
...@@ -577,7 +577,7 @@ int zmq::options_t::setsockopt (int option_, const void *optval_, ...@@ -577,7 +577,7 @@ int zmq::options_t::setsockopt (int option_, const void *optval_,
} }
break; break;
# ifdef ZMQ_HAVE_VMCI #ifdef ZMQ_HAVE_VMCI
case ZMQ_VMCI_BUFFER_SIZE: case ZMQ_VMCI_BUFFER_SIZE:
if (optvallen_ == sizeof (uint64_t)) { if (optvallen_ == sizeof (uint64_t)) {
vmci_buffer_size = *((uint64_t*) optval_); vmci_buffer_size = *((uint64_t*) optval_);
...@@ -605,7 +605,7 @@ int zmq::options_t::setsockopt (int option_, const void *optval_, ...@@ -605,7 +605,7 @@ int zmq::options_t::setsockopt (int option_, const void *optval_,
return 0; return 0;
} }
break; break;
# endif #endif
case ZMQ_USE_FD: case ZMQ_USE_FD:
if (is_int && value >= -1) { if (is_int && value >= -1) {
...@@ -888,8 +888,8 @@ int zmq::options_t::getsockopt (int option_, void *optval_, size_t *optvallen_) ...@@ -888,8 +888,8 @@ int zmq::options_t::getsockopt (int option_, void *optval_, size_t *optvallen_)
} }
break; break;
// If libsodium isn't installed, these options provoke EINVAL // If curve encryption isn't built, these options provoke EINVAL
# ifdef HAVE_LIBSODIUM #ifdef ZMQ_HAVE_CURVE
case ZMQ_CURVE_SERVER: case ZMQ_CURVE_SERVER:
if (is_int) { if (is_int) {
*value = as_server && mechanism == ZMQ_CURVE; *value = as_server && mechanism == ZMQ_CURVE;
...@@ -932,7 +932,7 @@ int zmq::options_t::getsockopt (int option_, void *optval_, size_t *optvallen_) ...@@ -932,7 +932,7 @@ int zmq::options_t::getsockopt (int option_, void *optval_, size_t *optvallen_)
return 0; return 0;
} }
break; break;
# endif #endif
case ZMQ_CONFLATE: case ZMQ_CONFLATE:
if (is_int) { if (is_int) {
...@@ -942,7 +942,7 @@ int zmq::options_t::getsockopt (int option_, void *optval_, size_t *optvallen_) ...@@ -942,7 +942,7 @@ int zmq::options_t::getsockopt (int option_, void *optval_, size_t *optvallen_)
break; break;
// If libgssapi isn't installed, these options provoke EINVAL // If libgssapi isn't installed, these options provoke EINVAL
# ifdef HAVE_LIBGSSAPI_KRB5 #ifdef HAVE_LIBGSSAPI_KRB5
case ZMQ_GSSAPI_SERVER: case ZMQ_GSSAPI_SERVER:
if (is_int) { if (is_int) {
*value = as_server && mechanism == ZMQ_GSSAPI; *value = as_server && mechanism == ZMQ_GSSAPI;
......
...@@ -39,20 +39,20 @@ ...@@ -39,20 +39,20 @@
#endif #endif
#if defined ZMQ_USE_KQUEUE #if defined ZMQ_USE_KQUEUE
#include "kqueue.hpp" # include "kqueue.hpp"
#elif defined ZMQ_USE_EPOLL #elif defined ZMQ_USE_EPOLL
#include "epoll.hpp" # include "epoll.hpp"
#elif defined ZMQ_USE_DEVPOLL #elif defined ZMQ_USE_DEVPOLL
#include "devpoll.hpp" # include "devpoll.hpp"
#elif defined ZMQ_USE_POLL #elif defined ZMQ_USE_POLL
#include "poll.hpp" # include "poll.hpp"
#elif defined ZMQ_USE_SELECT #elif defined ZMQ_USE_SELECT
#include "select.hpp" # include "select.hpp"
#elif defined ZMQ_HAVE_GNU #elif defined ZMQ_HAVE_GNU
#define ZMQ_USE_POLL # define ZMQ_USE_POLL
#include "poll.hpp" # include "poll.hpp"
#else #else
#error None of the ZMQ_USE_* macros defined # error None of the ZMQ_USE_* macros defined
#endif #endif
#if defined ZMQ_USE_SELECT #if defined ZMQ_USE_SELECT
......
...@@ -682,7 +682,7 @@ bool zmq::stream_engine_t::handshake () ...@@ -682,7 +682,7 @@ bool zmq::stream_engine_t::handshake ()
plain_client_t (options); plain_client_t (options);
alloc_assert (mechanism); alloc_assert (mechanism);
} }
#ifdef HAVE_LIBSODIUM #ifdef ZMQ_HAVE_CURVE
else else
if (options.mechanism == ZMQ_CURVE if (options.mechanism == ZMQ_CURVE
&& memcmp (greeting_recv + 12, "CURVE\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0", 20) == 0) { && memcmp (greeting_recv + 12, "CURVE\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0", 20) == 0) {
......
...@@ -1211,7 +1211,8 @@ int zmq_poller_wait (void *poller_, zmq_poller_event_t *event, long timeout_) ...@@ -1211,7 +1211,8 @@ int zmq_poller_wait (void *poller_, zmq_poller_event_t *event, long timeout_)
return -1; return -1;
} }
zmq::socket_poller_t::event_t e = {}; zmq::socket_poller_t::event_t e;
memset (&e, 0, sizeof (e));
int rc = ((zmq::socket_poller_t*)poller_)->wait (&e, timeout_); int rc = ((zmq::socket_poller_t*)poller_)->wait (&e, timeout_);
...@@ -1360,7 +1361,7 @@ int zmq_has (const char *capability) ...@@ -1360,7 +1361,7 @@ int zmq_has (const char *capability)
if (strcmp (capability, "norm") == 0) if (strcmp (capability, "norm") == 0)
return true; return true;
#endif #endif
#if defined (HAVE_LIBSODIUM) #if defined (ZMQ_HAVE_CURVE)
if (strcmp (capability, "curve") == 0) if (strcmp (capability, "curve") == 0)
return true; return true;
#endif #endif
......
...@@ -43,15 +43,13 @@ ...@@ -43,15 +43,13 @@
#include "windows.hpp" #include "windows.hpp"
#endif #endif
#ifdef HAVE_LIBSODIUM #if defined (HAVE_TWEETNACL)
#ifdef HAVE_TWEETNACL # include "tweetnacl_base.h"
#include "tweetnacl_base.h" # include "randombytes.h"
#else #elif defined (HAVE_LIBSODIUM)
#include "sodium.h" # include "sodium.h"
#endif
#endif #endif
void zmq_sleep (int seconds_) void zmq_sleep (int seconds_)
{ {
#if defined ZMQ_HAVE_WINDOWS #if defined ZMQ_HAVE_WINDOWS
...@@ -185,17 +183,17 @@ uint8_t *zmq_z85_decode (uint8_t *dest, const char *string) ...@@ -185,17 +183,17 @@ uint8_t *zmq_z85_decode (uint8_t *dest, const char *string)
} }
// -------------------------------------------------------------------------- // --------------------------------------------------------------------------
// Generate a public/private keypair with libsodium. // Generate a public/private keypair with tweetnacl or libsodium.
// Generated keys will be 40 byte z85-encoded strings. // Generated keys will be 40 byte z85-encoded strings.
// Returns 0 on success, -1 on failure, setting errno. // Returns 0 on success, -1 on failure, setting errno.
// Sets errno = ENOTSUP in the absence of libsodium. // Sets errno = ENOTSUP in the absence of a CURVE library.
int zmq_curve_keypair (char *z85_public_key, char *z85_secret_key) int zmq_curve_keypair (char *z85_public_key, char *z85_secret_key)
{ {
#ifdef HAVE_LIBSODIUM #if defined (ZMQ_HAVE_CURVE)
# if crypto_box_PUBLICKEYBYTES != 32 \ # if crypto_box_PUBLICKEYBYTES != 32 \
|| crypto_box_SECRETKEYBYTES != 32 || crypto_box_SECRETKEYBYTES != 32
# error "libsodium not built correctly" # error "CURVE encryption library not built correctly"
# endif # endif
uint8_t public_key [32]; uint8_t public_key [32];
...@@ -210,7 +208,7 @@ int zmq_curve_keypair (char *z85_public_key, char *z85_secret_key) ...@@ -210,7 +208,7 @@ int zmq_curve_keypair (char *z85_public_key, char *z85_secret_key)
zmq_z85_encode (z85_secret_key, secret_key, 32); zmq_z85_encode (z85_secret_key, secret_key, 32);
return 0; return 0;
#else // requires libsodium #else
(void) z85_public_key, (void) z85_secret_key; (void) z85_public_key, (void) z85_secret_key;
errno = ENOTSUP; errno = ENOTSUP;
return -1; return -1;
......
...@@ -55,7 +55,7 @@ int main (void) ...@@ -55,7 +55,7 @@ int main (void)
assert (!zmq_has ("norm")); assert (!zmq_has ("norm"));
#endif #endif
#if defined (HAVE_LIBSODIUM) #if defined (ZMQ_HAVE_CURVE)
assert (zmq_has ("curve")); assert (zmq_has ("curve"));
#else #else
assert (!zmq_has ("curve")); assert (!zmq_has ("curve"));
......
...@@ -102,11 +102,10 @@ static void zap_handler (void *handler) ...@@ -102,11 +102,10 @@ static void zap_handler (void *handler)
int main (void) int main (void)
{ {
#ifndef HAVE_LIBSODIUM #ifndef ZMQ_HAVE_CURVE
printf ("libsodium not installed, skipping CURVE test\n"); printf ("CURVE encryption not installed, skipping test\n");
return 0; return 0;
#endif #endif
// Generate new keypairs for this test // Generate new keypairs for this test
int rc = zmq_curve_keypair (client_public, client_secret); int rc = zmq_curve_keypair (client_public, client_secret);
assert (rc == 0); assert (rc == 0);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment