Commit ec620973 authored by Luca Boccassi's avatar Luca Boccassi

Merge pull request #1832 from hintjens/master

Problem: can't be sure crypto_box always returns 0
parents 708c2060 5b7bf750
...@@ -202,7 +202,6 @@ int zmq::curve_client_t::decode (msg_t *msg_) ...@@ -202,7 +202,6 @@ int zmq::curve_client_t::decode (msg_t *msg_)
} }
cn_peer_nonce = nonce; cn_peer_nonce = nonce;
const size_t clen = crypto_box_BOXZEROBYTES + (msg_->size () - 16); const size_t clen = crypto_box_BOXZEROBYTES + (msg_->size () - 16);
uint8_t *message_plaintext = static_cast <uint8_t *> (malloc (clen)); uint8_t *message_plaintext = static_cast <uint8_t *> (malloc (clen));
...@@ -270,7 +269,8 @@ int zmq::curve_client_t::produce_hello (msg_t *msg_) ...@@ -270,7 +269,8 @@ int zmq::curve_client_t::produce_hello (msg_t *msg_)
int rc = crypto_box (hello_box, hello_plaintext, int rc = crypto_box (hello_box, hello_plaintext,
sizeof hello_plaintext, sizeof hello_plaintext,
hello_nonce, server_key, cn_secret); hello_nonce, server_key, cn_secret);
zmq_assert (rc == 0); if (rc == -1)
return -1;
rc = msg_->init_size (200); rc = msg_->init_size (200);
errno_assert (rc == 0); errno_assert (rc == 0);
...@@ -349,7 +349,8 @@ int zmq::curve_client_t::produce_initiate (msg_t *msg_) ...@@ -349,7 +349,8 @@ int zmq::curve_client_t::produce_initiate (msg_t *msg_)
int rc = crypto_box (vouch_box, vouch_plaintext, int rc = crypto_box (vouch_box, vouch_plaintext,
sizeof vouch_plaintext, sizeof vouch_plaintext,
vouch_nonce, cn_server, secret_key); vouch_nonce, cn_server, secret_key);
zmq_assert (rc == 0); if (rc == -1)
return -1;
// Assume here that metadata is limited to 256 bytes // Assume here that metadata is limited to 256 bytes
uint8_t initiate_nonce [crypto_box_NONCEBYTES]; uint8_t initiate_nonce [crypto_box_NONCEBYTES];
...@@ -385,7 +386,8 @@ int zmq::curve_client_t::produce_initiate (msg_t *msg_) ...@@ -385,7 +386,8 @@ int zmq::curve_client_t::produce_initiate (msg_t *msg_)
rc = crypto_box (initiate_box, initiate_plaintext, rc = crypto_box (initiate_box, initiate_plaintext,
mlen, initiate_nonce, cn_server, cn_secret); mlen, initiate_nonce, cn_server, cn_secret);
zmq_assert (rc == 0); if (rc == -1)
return -1;
rc = msg_->init_size (113 + mlen - crypto_box_BOXZEROBYTES); rc = msg_->init_size (113 + mlen - crypto_box_BOXZEROBYTES);
errno_assert (rc == 0); errno_assert (rc == 0);
......
...@@ -382,7 +382,8 @@ int zmq::curve_server_t::produce_welcome (msg_t *msg_) ...@@ -382,7 +382,8 @@ int zmq::curve_server_t::produce_welcome (msg_t *msg_)
rc = crypto_box (welcome_ciphertext, welcome_plaintext, rc = crypto_box (welcome_ciphertext, welcome_plaintext,
sizeof welcome_plaintext, sizeof welcome_plaintext,
welcome_nonce, cn_client, secret_key); welcome_nonce, cn_client, secret_key);
zmq_assert (rc == 0); if (rc == -1)
return -1;
rc = msg_->init_size (168); rc = msg_->init_size (168);
errno_assert (rc == 0); errno_assert (rc == 0);
......
...@@ -155,7 +155,7 @@ int main (void) ...@@ -155,7 +155,7 @@ int main (void)
// Check CURVE security with a garbage server key // Check CURVE security with a garbage server key
// This will be caught by the curve_server class, not passed to ZAP // This will be caught by the curve_server class, not passed to ZAP
char garbage_key [] = "0000111122223333444455556666777788889999"; char garbage_key [] = "0000000000000000000000000000000000000000";
client = zmq_socket (ctx, ZMQ_DEALER); client = zmq_socket (ctx, ZMQ_DEALER);
assert (client); assert (client);
rc = zmq_setsockopt (client, ZMQ_CURVE_SERVERKEY, garbage_key, 41); rc = zmq_setsockopt (client, ZMQ_CURVE_SERVERKEY, garbage_key, 41);
......
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