0
0
mirror of https://github.com/zeromq/libzmq.git synced 2025-01-15 10:18:01 +08:00

add session->zap_enabled()

checks mechanism != NULL, or NULL + non-empty zap_domain
This commit is contained in:
Min RK 2014-12-03 13:46:28 -08:00 committed by Pieter Hintjens
parent 56e09c80f8
commit 14c94c0df9
3 changed files with 12 additions and 3 deletions

View File

@ -331,6 +331,14 @@ int zmq::session_base_t::zap_connect ()
return 0; return 0;
} }
bool zmq::session_base_t::zap_enabled ()
{
return (
options.mechanism != ZMQ_NULL ||
(options.mechanism == ZMQ_NULL && options.zap_domain.length() > 0)
);
}
void zmq::session_base_t::process_attach (i_engine *engine_) void zmq::session_base_t::process_attach (i_engine *engine_)
{ {
zmq_assert (engine_ != NULL); zmq_assert (engine_ != NULL);

View File

@ -69,6 +69,7 @@ namespace zmq
int push_msg (msg_t *msg_); int push_msg (msg_t *msg_);
int zap_connect (); int zap_connect ();
bool zap_enabled ();
// Fetches a message. Returns 0 if successful; -1 otherwise. // Fetches a message. Returns 0 if successful; -1 otherwise.
// The caller is responsible for freeing the message when no // The caller is responsible for freeing the message when no

View File

@ -534,7 +534,7 @@ bool zmq::stream_engine_t::handshake ()
// Is the peer using ZMTP/1.0 with no revision number? // Is the peer using ZMTP/1.0 with no revision number?
// If so, we send and receive rest of identity message // If so, we send and receive rest of identity message
if (greeting_recv [0] != 0xff || !(greeting_recv [9] & 0x01)) { if (greeting_recv [0] != 0xff || !(greeting_recv [9] & 0x01)) {
if (session->zap_connect () == 0) { if (session->zap_enabled ()) {
// reject ZMTP 1.0 connections if ZAP is enabled // reject ZMTP 1.0 connections if ZAP is enabled
error (protocol_error); error (protocol_error);
return false; return false;
@ -581,7 +581,7 @@ bool zmq::stream_engine_t::handshake ()
} }
else else
if (greeting_recv [revision_pos] == ZMTP_1_0) { if (greeting_recv [revision_pos] == ZMTP_1_0) {
if (session->zap_connect () == 0) { if (session->zap_enabled ()) {
// reject ZMTP 1.0 connections if ZAP is enabled // reject ZMTP 1.0 connections if ZAP is enabled
error (protocol_error); error (protocol_error);
return false; return false;
@ -597,7 +597,7 @@ bool zmq::stream_engine_t::handshake ()
} }
else else
if (greeting_recv [revision_pos] == ZMTP_2_0) { if (greeting_recv [revision_pos] == ZMTP_2_0) {
if (session->zap_connect () == 0) { if (session->zap_enabled ()) {
// reject ZMTP 2.0 connections if ZAP is enabled // reject ZMTP 2.0 connections if ZAP is enabled
error (protocol_error); error (protocol_error);
return false; return false;