mirror of
https://github.com/zeromq/libzmq.git
synced 2024-12-14 19:13:52 +01:00
Problem: gssapi_mechanism_base_t aborts the application when it receives a message it cannot decode
Solution: emit an ZMQ_EVENT_HANDSHAKE_FAILED_PROTOCOL event instead of using zmq_assert
This commit is contained in:
parent
31c72e22ab
commit
898691e2eb
@ -181,12 +181,18 @@ int zmq::gssapi_mechanism_base_t::decode_message (msg_t *msg_)
|
|||||||
maj_stat = gss_unwrap(&min_stat, context, &wrapped, &plaintext,
|
maj_stat = gss_unwrap(&min_stat, context, &wrapped, &plaintext,
|
||||||
&state, (gss_qop_t *) NULL);
|
&state, (gss_qop_t *) NULL);
|
||||||
|
|
||||||
// TODO I don't think it is a good idea to use zmq_assert here. If
|
if (maj_stat != GSS_S_COMPLETE)
|
||||||
// decryption fails, gss_unwrap returns GSS_S_BAD_SIG. This opens up
|
{
|
||||||
// to DoS attacks by clients! Instead, a
|
// TODO is it correct to release the plaintext buffer if gss_unwrap
|
||||||
// ZMQ_PROTOCOL_ERROR_ZMTP_CRYPTOGRAPHIC event should be emitted.
|
// did not succeed?
|
||||||
|
gss_release_buffer (&min_stat, &plaintext);
|
||||||
zmq_assert(maj_stat == GSS_S_COMPLETE);
|
free (wrapped);
|
||||||
|
session->get_socket ()->event_handshake_failed_protocol (
|
||||||
|
session->get_endpoint (),
|
||||||
|
ZMQ_PROTOCOL_ERROR_ZMTP_CRYPTOGRAPHIC);
|
||||||
|
errno = EPROTO;
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
zmq_assert(state);
|
zmq_assert(state);
|
||||||
|
|
||||||
// Re-initialize msg_ for plaintext
|
// Re-initialize msg_ for plaintext
|
||||||
|
Loading…
Reference in New Issue
Block a user