mirror of
https://github.com/zeromq/libzmq.git
synced 2024-12-14 02:57:47 +01:00
commit
0ad600c7de
@ -417,6 +417,8 @@ ZMQ_EXPORT const char *zmq_msg_gets (zmq_msg_t *msg, const char *property);
|
||||
#define ZMQ_EVENT_CLOSE_FAILED 0x0100
|
||||
#define ZMQ_EVENT_DISCONNECTED 0x0200
|
||||
#define ZMQ_EVENT_MONITOR_STOPPED 0x0400
|
||||
#define ZMQ_EVENT_HANDSHAKE_FAILED 0x0800
|
||||
#define ZMQ_EVENT_HANDSHAKE_SUCCEED 0x1000
|
||||
#define ZMQ_EVENT_ALL 0xFFFF
|
||||
|
||||
ZMQ_EXPORT void *zmq_socket (void *, int type);
|
||||
|
@ -310,13 +310,14 @@ int zmq::curve_server_t::process_hello (msg_t *msg_)
|
||||
sizeof hello_box,
|
||||
hello_nonce, cn_client, secret_key);
|
||||
if (rc != 0) {
|
||||
// Temporary support for security debugging
|
||||
puts ("CURVE I: cannot open client HELLO -- wrong server key?");
|
||||
errno = EPROTO;
|
||||
return -1;
|
||||
// Hard error, the client knows a wrong server public key, it shall not try to reconnect using the same.
|
||||
status_code = "100";
|
||||
state = send_error;
|
||||
rc = 0;
|
||||
}
|
||||
|
||||
else
|
||||
state = send_welcome;
|
||||
|
||||
return rc;
|
||||
}
|
||||
|
||||
|
@ -421,7 +421,8 @@ void zmq::session_base_t::engine_error (
|
||||
if (pipe)
|
||||
clean_pipes ();
|
||||
|
||||
zmq_assert (reason == stream_engine_t::connection_error
|
||||
zmq_assert (reason == stream_engine_t::encryption_error
|
||||
|| reason == stream_engine_t::connection_error
|
||||
|| reason == stream_engine_t::timeout_error
|
||||
|| reason == stream_engine_t::protocol_error);
|
||||
|
||||
@ -433,6 +434,7 @@ void zmq::session_base_t::engine_error (
|
||||
else
|
||||
terminate ();
|
||||
break;
|
||||
case stream_engine_t::encryption_error:
|
||||
case stream_engine_t::protocol_error:
|
||||
terminate ();
|
||||
break;
|
||||
|
@ -1678,6 +1678,16 @@ void zmq::socket_base_t::event_disconnected (const std::string &addr_, zmq::fd_t
|
||||
event(addr_, fd_, ZMQ_EVENT_DISCONNECTED);
|
||||
}
|
||||
|
||||
void zmq::socket_base_t::event_handshake_failed(const std::string &addr_, int err_)
|
||||
{
|
||||
event(addr_, err_, ZMQ_EVENT_HANDSHAKE_FAILED);
|
||||
}
|
||||
|
||||
void zmq::socket_base_t::event_handshake_succeed(const std::string &addr_, int err_)
|
||||
{
|
||||
event(addr_, err_, ZMQ_EVENT_HANDSHAKE_SUCCEED);
|
||||
}
|
||||
|
||||
void zmq::socket_base_t::event(const std::string &addr_, intptr_t value_, int type_)
|
||||
{
|
||||
scoped_lock_t lock(monitor_sync);
|
||||
|
@ -133,6 +133,8 @@ namespace zmq
|
||||
void event_closed (const std::string &addr_, zmq::fd_t fd_);
|
||||
void event_close_failed (const std::string &addr_, int err_);
|
||||
void event_disconnected (const std::string &addr_, zmq::fd_t fd_);
|
||||
void event_handshake_failed(const std::string &addr_, int err_);
|
||||
void event_handshake_succeed(const std::string &addr_, int err_);
|
||||
|
||||
protected:
|
||||
|
||||
|
@ -356,6 +356,9 @@ void zmq::stream_engine_t::in_event ()
|
||||
// or the session has rejected the message.
|
||||
if (rc == -1) {
|
||||
if (errno != EAGAIN) {
|
||||
if(this->process_msg == &stream_engine_t::process_handshake_command)
|
||||
error(encryption_error);
|
||||
else
|
||||
error(protocol_error);
|
||||
return;
|
||||
}
|
||||
@ -784,8 +787,12 @@ int zmq::stream_engine_t::next_handshake_command (msg_t *msg_)
|
||||
}
|
||||
else {
|
||||
const int rc = mechanism->next_handshake_command (msg_);
|
||||
|
||||
if (rc == 0)
|
||||
msg_->set_flags (msg_t::command);
|
||||
if(mechanism->status() == mechanism_t::error)
|
||||
socket->event_handshake_failed(endpoint, 0);
|
||||
|
||||
return rc;
|
||||
}
|
||||
}
|
||||
@ -863,6 +870,8 @@ void zmq::stream_engine_t::mechanism_ready ()
|
||||
zmq_assert (metadata == NULL);
|
||||
if (!properties.empty ())
|
||||
metadata = new (std::nothrow) metadata_t (properties);
|
||||
|
||||
socket->event_handshake_succeed(endpoint, 0);
|
||||
}
|
||||
|
||||
int zmq::stream_engine_t::pull_msg_from_session (msg_t *msg_)
|
||||
@ -967,6 +976,8 @@ void zmq::stream_engine_t::error (error_reason_t reason)
|
||||
terminator.close();
|
||||
}
|
||||
zmq_assert (session);
|
||||
if(reason == encryption_error)
|
||||
socket->event_handshake_failed(endpoint, (int) s);
|
||||
socket->event_disconnected (endpoint, (int) s);
|
||||
session->flush ();
|
||||
session->engine_error (reason);
|
||||
|
@ -65,7 +65,8 @@ namespace zmq
|
||||
enum error_reason_t {
|
||||
protocol_error,
|
||||
connection_error,
|
||||
timeout_error
|
||||
timeout_error,
|
||||
encryption_error
|
||||
};
|
||||
|
||||
stream_engine_t (fd_t fd_, const options_t &options_,
|
||||
|
Loading…
Reference in New Issue
Block a user