Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
L
libzmq
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
libzmq
Commits
c5acd1bd
Commit
c5acd1bd
authored
Mar 31, 2017
by
Doron Somech
Committed by
GitHub
Mar 31, 2017
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #2486 from evoskuil/master
Problem: msg_t leaks/unhandled failures (and bad style).
parents
d91cd414
7952c584
Hide whitespace changes
Inline
Side-by-side
Showing
10 changed files
with
126 additions
and
129 deletions
+126
-129
curve_server.cpp
src/curve_server.cpp
+15
-15
gssapi_server.cpp
src/gssapi_server.cpp
+15
-15
msg.cpp
src/msg.cpp
+1
-1
msg.hpp
src/msg.hpp
+8
-6
null_mechanism.cpp
src/null_mechanism.cpp
+14
-14
plain_server.cpp
src/plain_server.cpp
+16
-16
proxy.cpp
src/proxy.cpp
+13
-12
sub.cpp
src/sub.cpp
+1
-8
xpub.cpp
src/xpub.cpp
+33
-32
test_xpub_welcome_msg.cpp
tests/test_xpub_welcome_msg.cpp
+10
-10
No files found.
src/curve_server.cpp
View file @
c5acd1bd
...
@@ -580,7 +580,7 @@ int zmq::curve_server_t::send_zap_request (const uint8_t *key)
...
@@ -580,7 +580,7 @@ int zmq::curve_server_t::send_zap_request (const uint8_t *key)
msg
.
set_flags
(
msg_t
::
more
);
msg
.
set_flags
(
msg_t
::
more
);
rc
=
session
->
write_zap_msg
(
&
msg
);
rc
=
session
->
write_zap_msg
(
&
msg
);
if
(
rc
!=
0
)
if
(
rc
!=
0
)
return
send_failure
(
&
msg
);
return
close_and_return
(
&
msg
,
-
1
);
// Version frame
// Version frame
rc
=
msg
.
init_size
(
3
);
rc
=
msg
.
init_size
(
3
);
...
@@ -589,7 +589,7 @@ int zmq::curve_server_t::send_zap_request (const uint8_t *key)
...
@@ -589,7 +589,7 @@ int zmq::curve_server_t::send_zap_request (const uint8_t *key)
msg
.
set_flags
(
msg_t
::
more
);
msg
.
set_flags
(
msg_t
::
more
);
rc
=
session
->
write_zap_msg
(
&
msg
);
rc
=
session
->
write_zap_msg
(
&
msg
);
if
(
rc
!=
0
)
if
(
rc
!=
0
)
return
send_failure
(
&
msg
);
return
close_and_return
(
&
msg
,
-
1
);
// Request ID frame
// Request ID frame
rc
=
msg
.
init_size
(
1
);
rc
=
msg
.
init_size
(
1
);
...
@@ -598,7 +598,7 @@ int zmq::curve_server_t::send_zap_request (const uint8_t *key)
...
@@ -598,7 +598,7 @@ int zmq::curve_server_t::send_zap_request (const uint8_t *key)
msg
.
set_flags
(
msg_t
::
more
);
msg
.
set_flags
(
msg_t
::
more
);
rc
=
session
->
write_zap_msg
(
&
msg
);
rc
=
session
->
write_zap_msg
(
&
msg
);
if
(
rc
!=
0
)
if
(
rc
!=
0
)
return
send_failure
(
&
msg
);
return
close_and_return
(
&
msg
,
-
1
);
// Domain frame
// Domain frame
rc
=
msg
.
init_size
(
options
.
zap_domain
.
length
());
rc
=
msg
.
init_size
(
options
.
zap_domain
.
length
());
...
@@ -607,7 +607,7 @@ int zmq::curve_server_t::send_zap_request (const uint8_t *key)
...
@@ -607,7 +607,7 @@ int zmq::curve_server_t::send_zap_request (const uint8_t *key)
msg
.
set_flags
(
msg_t
::
more
);
msg
.
set_flags
(
msg_t
::
more
);
rc
=
session
->
write_zap_msg
(
&
msg
);
rc
=
session
->
write_zap_msg
(
&
msg
);
if
(
rc
!=
0
)
if
(
rc
!=
0
)
return
send_failure
(
&
msg
);
return
close_and_return
(
&
msg
,
-
1
);
// Address frame
// Address frame
rc
=
msg
.
init_size
(
peer_address
.
length
());
rc
=
msg
.
init_size
(
peer_address
.
length
());
...
@@ -616,7 +616,7 @@ int zmq::curve_server_t::send_zap_request (const uint8_t *key)
...
@@ -616,7 +616,7 @@ int zmq::curve_server_t::send_zap_request (const uint8_t *key)
msg
.
set_flags
(
msg_t
::
more
);
msg
.
set_flags
(
msg_t
::
more
);
rc
=
session
->
write_zap_msg
(
&
msg
);
rc
=
session
->
write_zap_msg
(
&
msg
);
if
(
rc
!=
0
)
if
(
rc
!=
0
)
return
send_failure
(
&
msg
);
return
close_and_return
(
&
msg
,
-
1
);
// Identity frame
// Identity frame
rc
=
msg
.
init_size
(
options
.
identity_size
);
rc
=
msg
.
init_size
(
options
.
identity_size
);
...
@@ -625,7 +625,7 @@ int zmq::curve_server_t::send_zap_request (const uint8_t *key)
...
@@ -625,7 +625,7 @@ int zmq::curve_server_t::send_zap_request (const uint8_t *key)
msg
.
set_flags
(
msg_t
::
more
);
msg
.
set_flags
(
msg_t
::
more
);
rc
=
session
->
write_zap_msg
(
&
msg
);
rc
=
session
->
write_zap_msg
(
&
msg
);
if
(
rc
!=
0
)
if
(
rc
!=
0
)
return
send_failure
(
&
msg
);
return
close_and_return
(
&
msg
,
-
1
);
// Mechanism frame
// Mechanism frame
rc
=
msg
.
init_size
(
5
);
rc
=
msg
.
init_size
(
5
);
...
@@ -634,7 +634,7 @@ int zmq::curve_server_t::send_zap_request (const uint8_t *key)
...
@@ -634,7 +634,7 @@ int zmq::curve_server_t::send_zap_request (const uint8_t *key)
msg
.
set_flags
(
msg_t
::
more
);
msg
.
set_flags
(
msg_t
::
more
);
rc
=
session
->
write_zap_msg
(
&
msg
);
rc
=
session
->
write_zap_msg
(
&
msg
);
if
(
rc
!=
0
)
if
(
rc
!=
0
)
return
send_failure
(
&
msg
);
return
close_and_return
(
&
msg
,
-
1
);
// Credentials frame
// Credentials frame
rc
=
msg
.
init_size
(
crypto_box_PUBLICKEYBYTES
);
rc
=
msg
.
init_size
(
crypto_box_PUBLICKEYBYTES
);
...
@@ -642,7 +642,7 @@ int zmq::curve_server_t::send_zap_request (const uint8_t *key)
...
@@ -642,7 +642,7 @@ int zmq::curve_server_t::send_zap_request (const uint8_t *key)
memcpy
(
msg
.
data
(),
key
,
crypto_box_PUBLICKEYBYTES
);
memcpy
(
msg
.
data
(),
key
,
crypto_box_PUBLICKEYBYTES
);
rc
=
session
->
write_zap_msg
(
&
msg
);
rc
=
session
->
write_zap_msg
(
&
msg
);
if
(
rc
!=
0
)
if
(
rc
!=
0
)
return
send_failure
(
&
msg
);
return
close_and_return
(
&
msg
,
-
1
);
return
0
;
return
0
;
}
}
...
@@ -661,12 +661,12 @@ int zmq::curve_server_t::receive_and_process_zap_reply ()
...
@@ -661,12 +661,12 @@ int zmq::curve_server_t::receive_and_process_zap_reply ()
for
(
int
i
=
0
;
i
<
7
;
i
++
)
{
for
(
int
i
=
0
;
i
<
7
;
i
++
)
{
rc
=
session
->
read_zap_msg
(
&
msg
[
i
]);
rc
=
session
->
read_zap_msg
(
&
msg
[
i
]);
if
(
rc
==
-
1
)
if
(
rc
==
-
1
)
return
send_failure
(
msg
);
return
close_and_return
(
msg
,
-
1
);
if
((
msg
[
i
].
flags
()
&
msg_t
::
more
)
==
(
i
<
6
?
0
:
msg_t
::
more
))
{
if
((
msg
[
i
].
flags
()
&
msg_t
::
more
)
==
(
i
<
6
?
0
:
msg_t
::
more
))
{
// Temporary support for security debugging
// Temporary support for security debugging
puts
(
"CURVE I: ZAP handler sent incomplete reply message"
);
puts
(
"CURVE I: ZAP handler sent incomplete reply message"
);
errno
=
EPROTO
;
errno
=
EPROTO
;
return
send_failure
(
msg
);
return
close_and_return
(
msg
,
-
1
);
}
}
}
}
...
@@ -675,7 +675,7 @@ int zmq::curve_server_t::receive_and_process_zap_reply ()
...
@@ -675,7 +675,7 @@ int zmq::curve_server_t::receive_and_process_zap_reply ()
// Temporary support for security debugging
// Temporary support for security debugging
puts
(
"CURVE I: ZAP handler sent malformed reply message"
);
puts
(
"CURVE I: ZAP handler sent malformed reply message"
);
errno
=
EPROTO
;
errno
=
EPROTO
;
return
send_failure
(
msg
);
return
close_and_return
(
msg
,
-
1
);
}
}
// Version frame
// Version frame
...
@@ -683,7 +683,7 @@ int zmq::curve_server_t::receive_and_process_zap_reply ()
...
@@ -683,7 +683,7 @@ int zmq::curve_server_t::receive_and_process_zap_reply ()
// Temporary support for security debugging
// Temporary support for security debugging
puts
(
"CURVE I: ZAP handler sent bad version number"
);
puts
(
"CURVE I: ZAP handler sent bad version number"
);
errno
=
EPROTO
;
errno
=
EPROTO
;
return
send_failure
(
msg
);
return
close_and_return
(
msg
,
-
1
);
}
}
// Request id frame
// Request id frame
...
@@ -691,7 +691,7 @@ int zmq::curve_server_t::receive_and_process_zap_reply ()
...
@@ -691,7 +691,7 @@ int zmq::curve_server_t::receive_and_process_zap_reply ()
// Temporary support for security debugging
// Temporary support for security debugging
puts
(
"CURVE I: ZAP handler sent bad request ID"
);
puts
(
"CURVE I: ZAP handler sent bad request ID"
);
errno
=
EPROTO
;
errno
=
EPROTO
;
return
send_failure
(
msg
);
return
close_and_return
(
msg
,
-
1
);
}
}
// Status code frame
// Status code frame
...
@@ -699,7 +699,7 @@ int zmq::curve_server_t::receive_and_process_zap_reply ()
...
@@ -699,7 +699,7 @@ int zmq::curve_server_t::receive_and_process_zap_reply ()
// Temporary support for security debugging
// Temporary support for security debugging
puts
(
"CURVE I: ZAP handler rejected client authentication"
);
puts
(
"CURVE I: ZAP handler rejected client authentication"
);
errno
=
EACCES
;
errno
=
EACCES
;
return
send_failure
(
msg
);
return
close_and_return
(
msg
,
-
1
);
}
}
// Save status code
// Save status code
...
@@ -713,7 +713,7 @@ int zmq::curve_server_t::receive_and_process_zap_reply ()
...
@@ -713,7 +713,7 @@ int zmq::curve_server_t::receive_and_process_zap_reply ()
msg
[
6
].
size
(),
true
);
msg
[
6
].
size
(),
true
);
if
(
rc
!=
0
)
if
(
rc
!=
0
)
return
send_failure
(
msg
);
return
close_and_return
(
msg
,
-
1
);
// Close all reply frames
// Close all reply frames
for
(
int
i
=
0
;
i
<
7
;
i
++
)
{
for
(
int
i
=
0
;
i
<
7
;
i
++
)
{
...
...
src/gssapi_server.cpp
View file @
c5acd1bd
...
@@ -161,7 +161,7 @@ int zmq::gssapi_server_t::send_zap_request ()
...
@@ -161,7 +161,7 @@ int zmq::gssapi_server_t::send_zap_request ()
msg
.
set_flags
(
msg_t
::
more
);
msg
.
set_flags
(
msg_t
::
more
);
rc
=
session
->
write_zap_msg
(
&
msg
);
rc
=
session
->
write_zap_msg
(
&
msg
);
if
(
rc
!=
0
)
if
(
rc
!=
0
)
return
send_failure
(
&
msg
);
return
close_and_return
(
&
msg
,
-
1
);
// Version frame
// Version frame
rc
=
msg
.
init_size
(
3
);
rc
=
msg
.
init_size
(
3
);
...
@@ -170,7 +170,7 @@ int zmq::gssapi_server_t::send_zap_request ()
...
@@ -170,7 +170,7 @@ int zmq::gssapi_server_t::send_zap_request ()
msg
.
set_flags
(
msg_t
::
more
);
msg
.
set_flags
(
msg_t
::
more
);
rc
=
session
->
write_zap_msg
(
&
msg
);
rc
=
session
->
write_zap_msg
(
&
msg
);
if
(
rc
!=
0
)
if
(
rc
!=
0
)
return
send_failure
(
&
msg
);
return
close_and_return
(
&
msg
,
-
1
);
// Request ID frame
// Request ID frame
rc
=
msg
.
init_size
(
1
);
rc
=
msg
.
init_size
(
1
);
...
@@ -179,7 +179,7 @@ int zmq::gssapi_server_t::send_zap_request ()
...
@@ -179,7 +179,7 @@ int zmq::gssapi_server_t::send_zap_request ()
msg
.
set_flags
(
msg_t
::
more
);
msg
.
set_flags
(
msg_t
::
more
);
rc
=
session
->
write_zap_msg
(
&
msg
);
rc
=
session
->
write_zap_msg
(
&
msg
);
if
(
rc
!=
0
)
if
(
rc
!=
0
)
return
send_failure
(
&
msg
);
return
close_and_return
(
&
msg
,
-
1
);
// Domain frame
// Domain frame
rc
=
msg
.
init_size
(
options
.
zap_domain
.
length
());
rc
=
msg
.
init_size
(
options
.
zap_domain
.
length
());
...
@@ -188,7 +188,7 @@ int zmq::gssapi_server_t::send_zap_request ()
...
@@ -188,7 +188,7 @@ int zmq::gssapi_server_t::send_zap_request ()
msg
.
set_flags
(
msg_t
::
more
);
msg
.
set_flags
(
msg_t
::
more
);
rc
=
session
->
write_zap_msg
(
&
msg
);
rc
=
session
->
write_zap_msg
(
&
msg
);
if
(
rc
!=
0
)
if
(
rc
!=
0
)
return
send_failure
(
&
msg
);
return
close_and_return
(
&
msg
,
-
1
);
// Address frame
// Address frame
rc
=
msg
.
init_size
(
peer_address
.
length
());
rc
=
msg
.
init_size
(
peer_address
.
length
());
...
@@ -197,7 +197,7 @@ int zmq::gssapi_server_t::send_zap_request ()
...
@@ -197,7 +197,7 @@ int zmq::gssapi_server_t::send_zap_request ()
msg
.
set_flags
(
msg_t
::
more
);
msg
.
set_flags
(
msg_t
::
more
);
rc
=
session
->
write_zap_msg
(
&
msg
);
rc
=
session
->
write_zap_msg
(
&
msg
);
if
(
rc
!=
0
)
if
(
rc
!=
0
)
return
send_failure
(
&
msg
);
return
close_and_return
(
&
msg
,
-
1
);
// Identity frame
// Identity frame
rc
=
msg
.
init_size
(
options
.
identity_size
);
rc
=
msg
.
init_size
(
options
.
identity_size
);
...
@@ -206,7 +206,7 @@ int zmq::gssapi_server_t::send_zap_request ()
...
@@ -206,7 +206,7 @@ int zmq::gssapi_server_t::send_zap_request ()
msg
.
set_flags
(
msg_t
::
more
);
msg
.
set_flags
(
msg_t
::
more
);
rc
=
session
->
write_zap_msg
(
&
msg
);
rc
=
session
->
write_zap_msg
(
&
msg
);
if
(
rc
!=
0
)
if
(
rc
!=
0
)
return
send_failure
(
&
msg
);
return
close_and_return
(
&
msg
,
-
1
);
// Mechanism frame
// Mechanism frame
rc
=
msg
.
init_size
(
6
);
rc
=
msg
.
init_size
(
6
);
...
@@ -215,7 +215,7 @@ int zmq::gssapi_server_t::send_zap_request ()
...
@@ -215,7 +215,7 @@ int zmq::gssapi_server_t::send_zap_request ()
msg
.
set_flags
(
msg_t
::
more
);
msg
.
set_flags
(
msg_t
::
more
);
rc
=
session
->
write_zap_msg
(
&
msg
);
rc
=
session
->
write_zap_msg
(
&
msg
);
if
(
rc
!=
0
)
if
(
rc
!=
0
)
return
send_failure
(
&
msg
);
return
close_and_return
(
&
msg
,
-
1
);
// Principal frame
// Principal frame
gss_buffer_desc
principal
;
gss_buffer_desc
principal
;
...
@@ -227,7 +227,7 @@ int zmq::gssapi_server_t::send_zap_request ()
...
@@ -227,7 +227,7 @@ int zmq::gssapi_server_t::send_zap_request ()
rc
=
session
->
write_zap_msg
(
&
msg
);
rc
=
session
->
write_zap_msg
(
&
msg
);
gss_release_buffer
(
&
min_stat
,
&
principal
);
gss_release_buffer
(
&
min_stat
,
&
principal
);
if
(
rc
!=
0
)
if
(
rc
!=
0
)
return
send_failure
(
&
msg
);
return
close_and_return
(
&
msg
,
-
1
);
return
0
;
return
0
;
}
}
...
@@ -246,35 +246,35 @@ int zmq::gssapi_server_t::receive_and_process_zap_reply ()
...
@@ -246,35 +246,35 @@ int zmq::gssapi_server_t::receive_and_process_zap_reply ()
for
(
int
i
=
0
;
i
<
7
;
i
++
)
{
for
(
int
i
=
0
;
i
<
7
;
i
++
)
{
rc
=
session
->
read_zap_msg
(
&
msg
[
i
]);
rc
=
session
->
read_zap_msg
(
&
msg
[
i
]);
if
(
rc
==
-
1
)
if
(
rc
==
-
1
)
return
send_failure
(
msg
);
return
close_and_return
(
msg
,
-
1
);
if
((
msg
[
i
].
flags
()
&
msg_t
::
more
)
==
(
i
<
6
?
0
:
msg_t
::
more
))
{
if
((
msg
[
i
].
flags
()
&
msg_t
::
more
)
==
(
i
<
6
?
0
:
msg_t
::
more
))
{
errno
=
EPROTO
;
errno
=
EPROTO
;
return
send_failure
(
msg
);
return
close_and_return
(
msg
,
-
1
);
}
}
}
}
// Address delimiter frame
// Address delimiter frame
if
(
msg
[
0
].
size
()
>
0
)
{
if
(
msg
[
0
].
size
()
>
0
)
{
errno
=
EPROTO
;
errno
=
EPROTO
;
return
send_failure
(
msg
);
return
close_and_return
(
msg
,
-
1
);
}
}
// Version frame
// Version frame
if
(
msg
[
1
].
size
()
!=
3
||
memcmp
(
msg
[
1
].
data
(),
"1.0"
,
3
))
{
if
(
msg
[
1
].
size
()
!=
3
||
memcmp
(
msg
[
1
].
data
(),
"1.0"
,
3
))
{
errno
=
EPROTO
;
errno
=
EPROTO
;
return
send_failure
(
msg
);
return
close_and_return
(
msg
,
-
1
);
}
}
// Request id frame
// Request id frame
if
(
msg
[
2
].
size
()
!=
1
||
memcmp
(
msg
[
2
].
data
(),
"1"
,
1
))
{
if
(
msg
[
2
].
size
()
!=
1
||
memcmp
(
msg
[
2
].
data
(),
"1"
,
1
))
{
errno
=
EPROTO
;
errno
=
EPROTO
;
return
send_failure
(
msg
);
return
close_and_return
(
msg
,
-
1
);
}
}
// Status code frame
// Status code frame
if
(
msg
[
3
].
size
()
!=
3
||
memcmp
(
msg
[
3
].
data
(),
"200"
,
3
))
{
if
(
msg
[
3
].
size
()
!=
3
||
memcmp
(
msg
[
3
].
data
(),
"200"
,
3
))
{
errno
=
EACCES
;
errno
=
EACCES
;
return
send_failure
(
msg
);
return
close_and_return
(
msg
,
-
1
);
}
}
// Save user id
// Save user id
...
@@ -285,7 +285,7 @@ int zmq::gssapi_server_t::receive_and_process_zap_reply ()
...
@@ -285,7 +285,7 @@ int zmq::gssapi_server_t::receive_and_process_zap_reply ()
msg
[
6
].
size
(),
true
);
msg
[
6
].
size
(),
true
);
if
(
rc
!=
0
)
if
(
rc
!=
0
)
return
send_failure
(
msg
);
return
close_and_return
(
msg
,
-
1
);
// Close all reply frames
// Close all reply frames
for
(
int
i
=
0
;
i
<
7
;
i
++
)
{
for
(
int
i
=
0
;
i
<
7
;
i
++
)
{
...
...
src/msg.cpp
View file @
c5acd1bd
...
@@ -241,7 +241,7 @@ int zmq::msg_t::close ()
...
@@ -241,7 +241,7 @@ int zmq::msg_t::close ()
if
(
is_zcmsg
())
if
(
is_zcmsg
())
{
{
zmq_assert
(
u
.
zclmsg
.
content
->
ffn
);
zmq_assert
(
u
.
zclmsg
.
content
->
ffn
);
// If the content is not shared, or if it is shared and the reference
// If the content is not shared, or if it is shared and the reference
// count has dropped to zero, deallocate it.
// count has dropped to zero, deallocate it.
...
...
src/msg.hpp
View file @
c5acd1bd
...
@@ -247,19 +247,21 @@ namespace zmq
...
@@ -247,19 +247,21 @@ namespace zmq
}
u
;
}
u
;
};
};
inline
int
send_failure
(
zmq
::
msg_t
*
msg
)
inline
int
close_and_return
(
zmq
::
msg_t
*
msg
,
int
echo
)
{
{
// Since we abort on close failure we preserve errno for success case.
int
err
=
errno
;
const
int
rc
=
msg
->
close
();
const
int
rc
=
msg
->
close
();
errno_assert
(
rc
==
0
);
errno_assert
(
rc
==
0
);
return
-
1
;
errno
=
err
;
return
echo
;
}
}
inline
int
send_failure
(
zmq
::
msg_t
msg
[],
int
count
)
inline
int
close_and_return
(
zmq
::
msg_t
msg
[],
int
count
,
int
echo
)
{
{
for
(
int
i
=
0
;
i
<
count
;
i
++
)
for
(
int
i
=
0
;
i
<
count
;
i
++
)
send_failure
(
&
msg
[
i
]);
close_and_return
(
&
msg
[
i
],
0
);
return
echo
;
return
-
1
;
}
}
}
}
...
...
src/null_mechanism.cpp
View file @
c5acd1bd
...
@@ -225,7 +225,7 @@ int zmq::null_mechanism_t::send_zap_request ()
...
@@ -225,7 +225,7 @@ int zmq::null_mechanism_t::send_zap_request ()
msg
.
set_flags
(
msg_t
::
more
);
msg
.
set_flags
(
msg_t
::
more
);
rc
=
session
->
write_zap_msg
(
&
msg
);
rc
=
session
->
write_zap_msg
(
&
msg
);
if
(
rc
!=
0
)
if
(
rc
!=
0
)
return
send_failure
(
&
msg
);
return
close_and_return
(
&
msg
,
-
1
);
// Version frame
// Version frame
rc
=
msg
.
init_size
(
3
);
rc
=
msg
.
init_size
(
3
);
...
@@ -234,7 +234,7 @@ int zmq::null_mechanism_t::send_zap_request ()
...
@@ -234,7 +234,7 @@ int zmq::null_mechanism_t::send_zap_request ()
msg
.
set_flags
(
msg_t
::
more
);
msg
.
set_flags
(
msg_t
::
more
);
rc
=
session
->
write_zap_msg
(
&
msg
);
rc
=
session
->
write_zap_msg
(
&
msg
);
if
(
rc
!=
0
)
if
(
rc
!=
0
)
return
send_failure
(
&
msg
);
return
close_and_return
(
&
msg
,
-
1
);
// Request id frame
// Request id frame
rc
=
msg
.
init_size
(
1
);
rc
=
msg
.
init_size
(
1
);
...
@@ -243,7 +243,7 @@ int zmq::null_mechanism_t::send_zap_request ()
...
@@ -243,7 +243,7 @@ int zmq::null_mechanism_t::send_zap_request ()
msg
.
set_flags
(
msg_t
::
more
);
msg
.
set_flags
(
msg_t
::
more
);
rc
=
session
->
write_zap_msg
(
&
msg
);
rc
=
session
->
write_zap_msg
(
&
msg
);
if
(
rc
!=
0
)
if
(
rc
!=
0
)
return
send_failure
(
&
msg
);
return
close_and_return
(
&
msg
,
-
1
);
// Domain frame
// Domain frame
rc
=
msg
.
init_size
(
options
.
zap_domain
.
length
());
rc
=
msg
.
init_size
(
options
.
zap_domain
.
length
());
...
@@ -252,7 +252,7 @@ int zmq::null_mechanism_t::send_zap_request ()
...
@@ -252,7 +252,7 @@ int zmq::null_mechanism_t::send_zap_request ()
msg
.
set_flags
(
msg_t
::
more
);
msg
.
set_flags
(
msg_t
::
more
);
rc
=
session
->
write_zap_msg
(
&
msg
);
rc
=
session
->
write_zap_msg
(
&
msg
);
if
(
rc
!=
0
)
if
(
rc
!=
0
)
return
send_failure
(
&
msg
);
return
close_and_return
(
&
msg
,
-
1
);
// Address frame
// Address frame
rc
=
msg
.
init_size
(
peer_address
.
length
());
rc
=
msg
.
init_size
(
peer_address
.
length
());
...
@@ -261,7 +261,7 @@ int zmq::null_mechanism_t::send_zap_request ()
...
@@ -261,7 +261,7 @@ int zmq::null_mechanism_t::send_zap_request ()
msg
.
set_flags
(
msg_t
::
more
);
msg
.
set_flags
(
msg_t
::
more
);
rc
=
session
->
write_zap_msg
(
&
msg
);
rc
=
session
->
write_zap_msg
(
&
msg
);
if
(
rc
!=
0
)
if
(
rc
!=
0
)
return
send_failure
(
&
msg
);
return
close_and_return
(
&
msg
,
-
1
);
// Identity frame
// Identity frame
rc
=
msg
.
init_size
(
options
.
identity_size
);
rc
=
msg
.
init_size
(
options
.
identity_size
);
...
@@ -270,7 +270,7 @@ int zmq::null_mechanism_t::send_zap_request ()
...
@@ -270,7 +270,7 @@ int zmq::null_mechanism_t::send_zap_request ()
msg
.
set_flags
(
msg_t
::
more
);
msg
.
set_flags
(
msg_t
::
more
);
rc
=
session
->
write_zap_msg
(
&
msg
);
rc
=
session
->
write_zap_msg
(
&
msg
);
if
(
rc
!=
0
)
if
(
rc
!=
0
)
return
send_failure
(
&
msg
);
return
close_and_return
(
&
msg
,
-
1
);
// Mechanism frame
// Mechanism frame
rc
=
msg
.
init_size
(
4
);
rc
=
msg
.
init_size
(
4
);
...
@@ -278,7 +278,7 @@ int zmq::null_mechanism_t::send_zap_request ()
...
@@ -278,7 +278,7 @@ int zmq::null_mechanism_t::send_zap_request ()
memcpy
(
msg
.
data
(),
"NULL"
,
4
);
memcpy
(
msg
.
data
(),
"NULL"
,
4
);
rc
=
session
->
write_zap_msg
(
&
msg
);
rc
=
session
->
write_zap_msg
(
&
msg
);
if
(
rc
!=
0
)
if
(
rc
!=
0
)
return
send_failure
(
&
msg
);
return
close_and_return
(
&
msg
,
-
1
);
return
0
;
return
0
;
}
}
...
@@ -297,12 +297,12 @@ int zmq::null_mechanism_t::receive_and_process_zap_reply ()
...
@@ -297,12 +297,12 @@ int zmq::null_mechanism_t::receive_and_process_zap_reply ()
for
(
int
i
=
0
;
i
<
7
;
i
++
)
{
for
(
int
i
=
0
;
i
<
7
;
i
++
)
{
rc
=
session
->
read_zap_msg
(
&
msg
[
i
]);
rc
=
session
->
read_zap_msg
(
&
msg
[
i
]);
if
(
rc
==
-
1
)
if
(
rc
==
-
1
)
return
send_failure
(
msg
);
return
close_and_return
(
msg
,
-
1
);
if
((
msg
[
i
].
flags
()
&
msg_t
::
more
)
==
(
i
<
6
?
0
:
msg_t
::
more
))
{
if
((
msg
[
i
].
flags
()
&
msg_t
::
more
)
==
(
i
<
6
?
0
:
msg_t
::
more
))
{
// Temporary support for security debugging
// Temporary support for security debugging
puts
(
"NULL I: ZAP handler sent incomplete reply message"
);
puts
(
"NULL I: ZAP handler sent incomplete reply message"
);
errno
=
EPROTO
;
errno
=
EPROTO
;
return
send_failure
(
msg
);
return
close_and_return
(
msg
,
-
1
);
}
}
}
}
...
@@ -311,7 +311,7 @@ int zmq::null_mechanism_t::receive_and_process_zap_reply ()
...
@@ -311,7 +311,7 @@ int zmq::null_mechanism_t::receive_and_process_zap_reply ()
// Temporary support for security debugging
// Temporary support for security debugging
puts
(
"NULL I: ZAP handler sent malformed reply message"
);
puts
(
"NULL I: ZAP handler sent malformed reply message"
);
errno
=
EPROTO
;
errno
=
EPROTO
;
return
send_failure
(
msg
);
return
close_and_return
(
msg
,
-
1
);
}
}
// Version frame
// Version frame
...
@@ -319,7 +319,7 @@ int zmq::null_mechanism_t::receive_and_process_zap_reply ()
...
@@ -319,7 +319,7 @@ int zmq::null_mechanism_t::receive_and_process_zap_reply ()
// Temporary support for security debugging
// Temporary support for security debugging
puts
(
"NULL I: ZAP handler sent bad version number"
);
puts
(
"NULL I: ZAP handler sent bad version number"
);
errno
=
EPROTO
;
errno
=
EPROTO
;
return
send_failure
(
msg
);
return
close_and_return
(
msg
,
-
1
);
}
}
// Request id frame
// Request id frame
...
@@ -327,7 +327,7 @@ int zmq::null_mechanism_t::receive_and_process_zap_reply ()
...
@@ -327,7 +327,7 @@ int zmq::null_mechanism_t::receive_and_process_zap_reply ()
// Temporary support for security debugging
// Temporary support for security debugging
puts
(
"NULL I: ZAP handler sent bad request ID"
);
puts
(
"NULL I: ZAP handler sent bad request ID"
);
errno
=
EPROTO
;
errno
=
EPROTO
;
return
send_failure
(
msg
);
return
close_and_return
(
msg
,
-
1
);
}
}
// Status code frame
// Status code frame
...
@@ -335,7 +335,7 @@ int zmq::null_mechanism_t::receive_and_process_zap_reply ()
...
@@ -335,7 +335,7 @@ int zmq::null_mechanism_t::receive_and_process_zap_reply ()
// Temporary support for security debugging
// Temporary support for security debugging
puts
(
"NULL I: ZAP handler rejected client authentication"
);
puts
(
"NULL I: ZAP handler rejected client authentication"
);
errno
=
EPROTO
;
errno
=
EPROTO
;
return
send_failure
(
msg
);
return
close_and_return
(
msg
,
-
1
);
}
}
// Save status code
// Save status code
...
@@ -349,7 +349,7 @@ int zmq::null_mechanism_t::receive_and_process_zap_reply ()
...
@@ -349,7 +349,7 @@ int zmq::null_mechanism_t::receive_and_process_zap_reply ()
msg
[
6
].
size
(),
true
);
msg
[
6
].
size
(),
true
);
if
(
rc
!=
0
)
if
(
rc
!=
0
)
return
send_failure
(
msg
);
return
close_and_return
(
msg
,
-
1
);
// Close all reply frames
// Close all reply frames
for
(
int
i
=
0
;
i
<
7
;
i
++
)
{
for
(
int
i
=
0
;
i
<
7
;
i
++
)
{
...
...
src/plain_server.cpp
View file @
c5acd1bd
...
@@ -289,7 +289,7 @@ int zmq::plain_server_t::send_zap_request (const std::string &username,
...
@@ -289,7 +289,7 @@ int zmq::plain_server_t::send_zap_request (const std::string &username,
msg
.
set_flags
(
msg_t
::
more
);
msg
.
set_flags
(
msg_t
::
more
);
rc
=
session
->
write_zap_msg
(
&
msg
);
rc
=
session
->
write_zap_msg
(
&
msg
);
if
(
rc
!=
0
)
if
(
rc
!=
0
)
return
send_failure
(
&
msg
);
return
close_and_return
(
&
msg
,
-
1
);
// Version frame
// Version frame
rc
=
msg
.
init_size
(
3
);
rc
=
msg
.
init_size
(
3
);
...
@@ -298,7 +298,7 @@ int zmq::plain_server_t::send_zap_request (const std::string &username,
...
@@ -298,7 +298,7 @@ int zmq::plain_server_t::send_zap_request (const std::string &username,
msg
.
set_flags
(
msg_t
::
more
);
msg
.
set_flags
(
msg_t
::
more
);
rc
=
session
->
write_zap_msg
(
&
msg
);
rc
=
session
->
write_zap_msg
(
&
msg
);
if
(
rc
!=
0
)
if
(
rc
!=
0
)
return
send_failure
(
&
msg
);
return
close_and_return
(
&
msg
,
-
1
);
// Request id frame
// Request id frame
rc
=
msg
.
init_size
(
1
);
rc
=
msg
.
init_size
(
1
);
...
@@ -307,7 +307,7 @@ int zmq::plain_server_t::send_zap_request (const std::string &username,
...
@@ -307,7 +307,7 @@ int zmq::plain_server_t::send_zap_request (const std::string &username,
msg
.
set_flags
(
msg_t
::
more
);
msg
.
set_flags
(
msg_t
::
more
);
rc
=
session
->
write_zap_msg
(
&
msg
);
rc
=
session
->
write_zap_msg
(
&
msg
);
if
(
rc
!=
0
)
if
(
rc
!=
0
)
return
send_failure
(
&
msg
);
return
close_and_return
(
&
msg
,
-
1
);
// Domain frame
// Domain frame
rc
=
msg
.
init_size
(
options
.
zap_domain
.
length
());
rc
=
msg
.
init_size
(
options
.
zap_domain
.
length
());
...
@@ -316,7 +316,7 @@ int zmq::plain_server_t::send_zap_request (const std::string &username,
...
@@ -316,7 +316,7 @@ int zmq::plain_server_t::send_zap_request (const std::string &username,
msg
.
set_flags
(
msg_t
::
more
);
msg
.
set_flags
(
msg_t
::
more
);
rc
=
session
->
write_zap_msg
(
&
msg
);
rc
=
session
->
write_zap_msg
(
&
msg
);
if
(
rc
!=
0
)
if
(
rc
!=
0
)
return
send_failure
(
&
msg
);
return
close_and_return
(
&
msg
,
-
1
);
// Address frame
// Address frame
rc
=
msg
.
init_size
(
peer_address
.
length
());
rc
=
msg
.
init_size
(
peer_address
.
length
());
...
@@ -325,7 +325,7 @@ int zmq::plain_server_t::send_zap_request (const std::string &username,
...
@@ -325,7 +325,7 @@ int zmq::plain_server_t::send_zap_request (const std::string &username,
msg
.
set_flags
(
msg_t
::
more
);
msg
.
set_flags
(
msg_t
::
more
);
rc
=
session
->
write_zap_msg
(
&
msg
);
rc
=
session
->
write_zap_msg
(
&
msg
);
if
(
rc
!=
0
)
if
(
rc
!=
0
)
return
send_failure
(
&
msg
);
return
close_and_return
(
&
msg
,
-
1
);
// Identity frame
// Identity frame
rc
=
msg
.
init_size
(
options
.
identity_size
);
rc
=
msg
.
init_size
(
options
.
identity_size
);
...
@@ -334,7 +334,7 @@ int zmq::plain_server_t::send_zap_request (const std::string &username,
...
@@ -334,7 +334,7 @@ int zmq::plain_server_t::send_zap_request (const std::string &username,
msg
.
set_flags
(
msg_t
::
more
);
msg
.
set_flags
(
msg_t
::
more
);
rc
=
session
->
write_zap_msg
(
&
msg
);
rc
=
session
->
write_zap_msg
(
&
msg
);
if
(
rc
!=
0
)
if
(
rc
!=
0
)
return
send_failure
(
&
msg
);
return
close_and_return
(
&
msg
,
-
1
);
// Mechanism frame
// Mechanism frame
rc
=
msg
.
init_size
(
5
);
rc
=
msg
.
init_size
(
5
);
...
@@ -343,7 +343,7 @@ int zmq::plain_server_t::send_zap_request (const std::string &username,
...
@@ -343,7 +343,7 @@ int zmq::plain_server_t::send_zap_request (const std::string &username,
msg
.
set_flags
(
msg_t
::
more
);
msg
.
set_flags
(
msg_t
::
more
);
rc
=
session
->
write_zap_msg
(
&
msg
);
rc
=
session
->
write_zap_msg
(
&
msg
);
if
(
rc
!=
0
)
if
(
rc
!=
0
)
return
send_failure
(
&
msg
);
return
close_and_return
(
&
msg
,
-
1
);
// Username frame
// Username frame
rc
=
msg
.
init_size
(
username
.
length
());
rc
=
msg
.
init_size
(
username
.
length
());
...
@@ -352,7 +352,7 @@ int zmq::plain_server_t::send_zap_request (const std::string &username,
...
@@ -352,7 +352,7 @@ int zmq::plain_server_t::send_zap_request (const std::string &username,
msg
.
set_flags
(
msg_t
::
more
);
msg
.
set_flags
(
msg_t
::
more
);
rc
=
session
->
write_zap_msg
(
&
msg
);
rc
=
session
->
write_zap_msg
(
&
msg
);
if
(
rc
!=
0
)
if
(
rc
!=
0
)
return
send_failure
(
&
msg
);
return
close_and_return
(
&
msg
,
-
1
);
// Password frame
// Password frame
rc
=
msg
.
init_size
(
password
.
length
());
rc
=
msg
.
init_size
(
password
.
length
());
...
@@ -360,7 +360,7 @@ int zmq::plain_server_t::send_zap_request (const std::string &username,
...
@@ -360,7 +360,7 @@ int zmq::plain_server_t::send_zap_request (const std::string &username,
memcpy
(
msg
.
data
(),
password
.
c_str
(),
password
.
length
());
memcpy
(
msg
.
data
(),
password
.
c_str
(),
password
.
length
());
rc
=
session
->
write_zap_msg
(
&
msg
);
rc
=
session
->
write_zap_msg
(
&
msg
);
if
(
rc
!=
0
)
if
(
rc
!=
0
)
return
send_failure
(
&
msg
);
return
close_and_return
(
&
msg
,
-
1
);
return
0
;
return
0
;
}
}
...
@@ -379,12 +379,12 @@ int zmq::plain_server_t::receive_and_process_zap_reply ()
...
@@ -379,12 +379,12 @@ int zmq::plain_server_t::receive_and_process_zap_reply ()
for
(
int
i
=
0
;
i
<
7
;
i
++
)
{
for
(
int
i
=
0
;
i
<
7
;
i
++
)
{
rc
=
session
->
read_zap_msg
(
&
msg
[
i
]);
rc
=
session
->
read_zap_msg
(
&
msg
[
i
]);
if
(
rc
==
-
1
)
if
(
rc
==
-
1
)
return
send_failure
(
msg
);
return
close_and_return
(
msg
,
-
1
);
if
((
msg
[
i
].
flags
()
&
msg_t
::
more
)
==
(
i
<
6
?
0
:
msg_t
::
more
))
{
if
((
msg
[
i
].
flags
()
&
msg_t
::
more
)
==
(
i
<
6
?
0
:
msg_t
::
more
))
{
// Temporary support for security debugging
// Temporary support for security debugging
puts
(
"PLAIN I: ZAP handler sent incomplete reply message"
);
puts
(
"PLAIN I: ZAP handler sent incomplete reply message"
);
errno
=
EPROTO
;
errno
=
EPROTO
;
return
send_failure
(
msg
);
return
close_and_return
(
msg
,
-
1
);
}
}
}
}
...
@@ -393,7 +393,7 @@ int zmq::plain_server_t::receive_and_process_zap_reply ()
...
@@ -393,7 +393,7 @@ int zmq::plain_server_t::receive_and_process_zap_reply ()
// Temporary support for security debugging
// Temporary support for security debugging
puts
(
"PLAIN I: ZAP handler sent malformed reply message"
);
puts
(
"PLAIN I: ZAP handler sent malformed reply message"
);
errno
=
EPROTO
;
errno
=
EPROTO
;
return
send_failure
(
msg
);
return
close_and_return
(
msg
,
-
1
);
}
}
// Version frame
// Version frame
...
@@ -401,7 +401,7 @@ int zmq::plain_server_t::receive_and_process_zap_reply ()
...
@@ -401,7 +401,7 @@ int zmq::plain_server_t::receive_and_process_zap_reply ()
// Temporary support for security debugging
// Temporary support for security debugging
puts
(
"PLAIN I: ZAP handler sent bad version number"
);
puts
(
"PLAIN I: ZAP handler sent bad version number"
);
errno
=
EPROTO
;
errno
=
EPROTO
;
return
send_failure
(
msg
);
return
close_and_return
(
msg
,
-
1
);
}
}
// Request id frame
// Request id frame
...
@@ -409,7 +409,7 @@ int zmq::plain_server_t::receive_and_process_zap_reply ()
...
@@ -409,7 +409,7 @@ int zmq::plain_server_t::receive_and_process_zap_reply ()
// Temporary support for security debugging
// Temporary support for security debugging
puts
(
"PLAIN I: ZAP handler sent bad request ID"
);
puts
(
"PLAIN I: ZAP handler sent bad request ID"
);
errno
=
EPROTO
;
errno
=
EPROTO
;
return
send_failure
(
msg
);
return
close_and_return
(
msg
,
-
1
);
}
}
// Status code frame
// Status code frame
...
@@ -417,7 +417,7 @@ int zmq::plain_server_t::receive_and_process_zap_reply ()
...
@@ -417,7 +417,7 @@ int zmq::plain_server_t::receive_and_process_zap_reply ()
// Temporary support for security debugging
// Temporary support for security debugging
puts
(
"PLAIN I: ZAP handler rejected client authentication"
);
puts
(
"PLAIN I: ZAP handler rejected client authentication"
);
errno
=
EACCES
;
errno
=
EACCES
;
return
send_failure
(
msg
);
return
close_and_return
(
msg
,
-
1
);
}
}
// Save status code
// Save status code
...
@@ -431,7 +431,7 @@ int zmq::plain_server_t::receive_and_process_zap_reply ()
...
@@ -431,7 +431,7 @@ int zmq::plain_server_t::receive_and_process_zap_reply ()
msg
[
6
].
size
(),
true
);
msg
[
6
].
size
(),
true
);
if
(
rc
!=
0
)
if
(
rc
!=
0
)
return
send_failure
(
msg
);
return
close_and_return
(
msg
,
-
1
);
// Close all reply frames
// Close all reply frames
for
(
int
i
=
0
;
i
<
7
;
i
++
)
{
for
(
int
i
=
0
;
i
<
7
;
i
++
)
{
...
...
src/proxy.cpp
View file @
c5acd1bd
...
@@ -143,7 +143,7 @@ int zmq::proxy (
...
@@ -143,7 +143,7 @@ int zmq::proxy (
// Wait while there are either requests or replies to process.
// Wait while there are either requests or replies to process.
rc
=
zmq_poll
(
&
items
[
0
],
qt_poll_items
,
-
1
);
rc
=
zmq_poll
(
&
items
[
0
],
qt_poll_items
,
-
1
);
if
(
unlikely
(
rc
<
0
))
if
(
unlikely
(
rc
<
0
))
return
-
1
;
return
close_and_return
(
&
msg
,
-
1
)
;
// Get the pollout separately because when combining this with pollin it maxes the CPU
// Get the pollout separately because when combining this with pollin it maxes the CPU
// because pollout shall most of the time return directly.
// because pollout shall most of the time return directly.
...
@@ -151,7 +151,7 @@ int zmq::proxy (
...
@@ -151,7 +151,7 @@ int zmq::proxy (
if
(
frontend_
!=
backend_
)
{
if
(
frontend_
!=
backend_
)
{
rc
=
zmq_poll
(
&
itemsout
[
0
],
2
,
0
);
rc
=
zmq_poll
(
&
itemsout
[
0
],
2
,
0
);
if
(
unlikely
(
rc
<
0
))
{
if
(
unlikely
(
rc
<
0
))
{
return
-
1
;
return
close_and_return
(
&
msg
,
-
1
)
;
}
}
}
}
...
@@ -159,17 +159,17 @@ int zmq::proxy (
...
@@ -159,17 +159,17 @@ int zmq::proxy (
if
(
control_
&&
items
[
2
].
revents
&
ZMQ_POLLIN
)
{
if
(
control_
&&
items
[
2
].
revents
&
ZMQ_POLLIN
)
{
rc
=
control_
->
recv
(
&
msg
,
0
);
rc
=
control_
->
recv
(
&
msg
,
0
);
if
(
unlikely
(
rc
<
0
))
if
(
unlikely
(
rc
<
0
))
return
-
1
;
return
close_and_return
(
&
msg
,
-
1
)
;
moresz
=
sizeof
more
;
moresz
=
sizeof
more
;
rc
=
control_
->
getsockopt
(
ZMQ_RCVMORE
,
&
more
,
&
moresz
);
rc
=
control_
->
getsockopt
(
ZMQ_RCVMORE
,
&
more
,
&
moresz
);
if
(
unlikely
(
rc
<
0
)
||
more
)
if
(
unlikely
(
rc
<
0
)
||
more
)
return
-
1
;
return
close_and_return
(
&
msg
,
-
1
)
;
// Copy message to capture socket if any
// Copy message to capture socket if any
rc
=
capture
(
capture_
,
msg
);
rc
=
capture
(
capture_
,
msg
);
if
(
unlikely
(
rc
<
0
))
if
(
unlikely
(
rc
<
0
))
return
-
1
;
return
close_and_return
(
&
msg
,
-
1
)
;
if
(
msg
.
size
()
==
5
&&
memcmp
(
msg
.
data
(),
"PAUSE"
,
5
)
==
0
)
if
(
msg
.
size
()
==
5
&&
memcmp
(
msg
.
data
(),
"PAUSE"
,
5
)
==
0
)
state
=
paused
;
state
=
paused
;
...
@@ -180,7 +180,7 @@ int zmq::proxy (
...
@@ -180,7 +180,7 @@ int zmq::proxy (
if
(
msg
.
size
()
==
9
&&
memcmp
(
msg
.
data
(),
"TERMINATE"
,
9
)
==
0
)
if
(
msg
.
size
()
==
9
&&
memcmp
(
msg
.
data
(),
"TERMINATE"
,
9
)
==
0
)
state
=
terminated
;
state
=
terminated
;
else
{
else
{
// This is an API error,
we should
assert
// This is an API error,
so we
assert
puts
(
"E: invalid command sent to proxy"
);
puts
(
"E: invalid command sent to proxy"
);
zmq_assert
(
false
);
zmq_assert
(
false
);
}
}
...
@@ -189,19 +189,20 @@ int zmq::proxy (
...
@@ -189,19 +189,20 @@ int zmq::proxy (
if
(
state
==
active
if
(
state
==
active
&&
items
[
0
].
revents
&
ZMQ_POLLIN
&&
items
[
0
].
revents
&
ZMQ_POLLIN
&&
(
frontend_
==
backend_
||
itemsout
[
1
].
revents
&
ZMQ_POLLOUT
))
{
&&
(
frontend_
==
backend_
||
itemsout
[
1
].
revents
&
ZMQ_POLLOUT
))
{
rc
=
forward
(
frontend_
,
backend_
,
capture_
,
msg
);
rc
=
forward
(
frontend_
,
backend_
,
capture_
,
msg
);
if
(
unlikely
(
rc
<
0
))
if
(
unlikely
(
rc
<
0
))
return
-
1
;
return
close_and_return
(
&
msg
,
-
1
)
;
}
}
// Process a reply
// Process a reply
if
(
state
==
active
if
(
state
==
active
&&
frontend_
!=
backend_
&&
frontend_
!=
backend_
&&
items
[
1
].
revents
&
ZMQ_POLLIN
&&
items
[
1
].
revents
&
ZMQ_POLLIN
&&
itemsout
[
0
].
revents
&
ZMQ_POLLOUT
)
{
&&
itemsout
[
0
].
revents
&
ZMQ_POLLOUT
)
{
rc
=
forward
(
backend_
,
frontend_
,
capture_
,
msg
);
rc
=
forward
(
backend_
,
frontend_
,
capture_
,
msg
);
if
(
unlikely
(
rc
<
0
))
if
(
unlikely
(
rc
<
0
))
return
-
1
;
return
close_and_return
(
&
msg
,
-
1
)
;
}
}
}
}
return
0
;
return
close_and_return
(
&
msg
,
0
);
}
}
src/sub.cpp
View file @
c5acd1bd
...
@@ -69,15 +69,8 @@ int zmq::sub_t::xsetsockopt (int option_, const void *optval_,
...
@@ -69,15 +69,8 @@ int zmq::sub_t::xsetsockopt (int option_, const void *optval_,
memcpy
(
data
+
1
,
optval_
,
optvallen_
);
memcpy
(
data
+
1
,
optval_
,
optvallen_
);
}
}
// Pass it further on in the stack.
// Pass it further on in the stack.
int
err
=
0
;
rc
=
xsub_t
::
xsend
(
&
msg
);
rc
=
xsub_t
::
xsend
(
&
msg
);
if
(
rc
!=
0
)
return
close_and_return
(
&
msg
,
rc
);
err
=
errno
;
int
rc2
=
msg
.
close
();
errno_assert
(
rc2
==
0
);
if
(
rc
!=
0
)
errno
=
err
;
return
rc
;
}
}
int
zmq
::
sub_t
::
xsend
(
msg_t
*
)
int
zmq
::
sub_t
::
xsend
(
msg_t
*
)
...
...
src/xpub.cpp
View file @
c5acd1bd
...
@@ -41,18 +41,18 @@ zmq::xpub_t::xpub_t (class ctx_t *parent_, uint32_t tid_, int sid_) :
...
@@ -41,18 +41,18 @@ zmq::xpub_t::xpub_t (class ctx_t *parent_, uint32_t tid_, int sid_) :
verbose_unsubs
(
false
),
verbose_unsubs
(
false
),
more
(
false
),
more
(
false
),
lossy
(
true
),
lossy
(
true
),
manual
(
false
),
manual
(
false
),
pending_pipes
(),
pending_pipes
(),
welcome_msg
()
welcome_msg
()
{
{
last_pipe
=
NULL
;
last_pipe
=
NULL
;
options
.
type
=
ZMQ_XPUB
;
options
.
type
=
ZMQ_XPUB
;
welcome_msg
.
init
();
welcome_msg
.
init
();
}
}
zmq
::
xpub_t
::~
xpub_t
()
zmq
::
xpub_t
::~
xpub_t
()
{
{
welcome_msg
.
close
();
welcome_msg
.
close
();
}
}
void
zmq
::
xpub_t
::
xattach_pipe
(
pipe_t
*
pipe_
,
bool
subscribe_to_all_
)
void
zmq
::
xpub_t
::
xattach_pipe
(
pipe_t
*
pipe_
,
bool
subscribe_to_all_
)
...
@@ -65,15 +65,16 @@ void zmq::xpub_t::xattach_pipe (pipe_t *pipe_, bool subscribe_to_all_)
...
@@ -65,15 +65,16 @@ void zmq::xpub_t::xattach_pipe (pipe_t *pipe_, bool subscribe_to_all_)
if
(
subscribe_to_all_
)
if
(
subscribe_to_all_
)
subscriptions
.
add
(
NULL
,
0
,
pipe_
);
subscriptions
.
add
(
NULL
,
0
,
pipe_
);
// if welcome message exist
// if welcome message exist
s, send a copy of it
if
(
welcome_msg
.
size
()
>
0
)
if
(
welcome_msg
.
size
()
>
0
)
{
{
msg_t
copy
;
msg_t
copy
;
copy
.
init
();
copy
.
init
();
copy
.
copy
(
welcome_msg
);
int
rc
=
copy
.
copy
(
welcome_msg
);
errno_assert
(
rc
==
0
);
pipe_
->
write
(
&
copy
);
bool
ok
=
pipe_
->
write
(
&
copy
);
pipe_
->
flush
();
zmq_assert
(
ok
);
pipe_
->
flush
();
}
}
// The pipe is active when attached. Let's read the subscriptions from
// The pipe is active when attached. Let's read the subscriptions from
...
@@ -95,35 +96,35 @@ void zmq::xpub_t::xread_activated (pipe_t *pipe_)
...
@@ -95,35 +96,35 @@ void zmq::xpub_t::xread_activated (pipe_t *pipe_)
{
{
// Store manual subscription to use on termination
// Store manual subscription to use on termination
if
(
*
data
==
0
)
if
(
*
data
==
0
)
manual_subscriptions
.
rm
(
data
+
1
,
size
-
1
,
pipe_
);
manual_subscriptions
.
rm
(
data
+
1
,
size
-
1
,
pipe_
);
else
else
manual_subscriptions
.
add
(
data
+
1
,
size
-
1
,
pipe_
);
manual_subscriptions
.
add
(
data
+
1
,
size
-
1
,
pipe_
);
pending_pipes
.
push_back
(
pipe_
);
pending_pipes
.
push_back
(
pipe_
);
pending_data
.
push_back
(
blob_t
(
data
,
size
));
pending_data
.
push_back
(
blob_t
(
data
,
size
));
if
(
metadata
)
if
(
metadata
)
metadata
->
add_ref
();
metadata
->
add_ref
();
pending_metadata
.
push_back
(
metadata
);
pending_metadata
.
push_back
(
metadata
);
pending_flags
.
push_back
(
0
);
pending_flags
.
push_back
(
0
);
}
}
else
else
{
{
bool
unique
;
bool
unique
;
if
(
*
data
==
0
)
if
(
*
data
==
0
)
unique
=
subscriptions
.
rm
(
data
+
1
,
size
-
1
,
pipe_
);
unique
=
subscriptions
.
rm
(
data
+
1
,
size
-
1
,
pipe_
);
else
else
unique
=
subscriptions
.
add
(
data
+
1
,
size
-
1
,
pipe_
);
unique
=
subscriptions
.
add
(
data
+
1
,
size
-
1
,
pipe_
);
// If the (un)subscription is not a duplicate store it so that it can be
// If the (un)subscription is not a duplicate store it so that it can be
// passed to the user on next recv call unless verbose mode is enabled
// passed to the user on next recv call unless verbose mode is enabled
// which makes to pass always these messages.
// which makes to pass always these messages.
if
(
options
.
type
==
ZMQ_XPUB
&&
(
unique
||
(
*
data
==
1
&&
verbose_subs
)
||
if
(
options
.
type
==
ZMQ_XPUB
&&
(
unique
||
(
*
data
==
1
&&
verbose_subs
)
||
(
*
data
==
0
&&
verbose_unsubs
&&
verbose_subs
)))
{
(
*
data
==
0
&&
verbose_unsubs
&&
verbose_subs
)))
{
pending_data
.
push_back
(
blob_t
(
data
,
size
));
pending_data
.
push_back
(
blob_t
(
data
,
size
));
if
(
metadata
)
if
(
metadata
)
metadata
->
add_ref
();
metadata
->
add_ref
();
pending_metadata
.
push_back
(
metadata
);
pending_metadata
.
push_back
(
metadata
);
pending_flags
.
push_back
(
0
);
pending_flags
.
push_back
(
0
);
}
}
}
}
}
}
...
@@ -131,7 +132,7 @@ void zmq::xpub_t::xread_activated (pipe_t *pipe_)
...
@@ -131,7 +132,7 @@ void zmq::xpub_t::xread_activated (pipe_t *pipe_)
// Process user message coming upstream from xsub socket
// Process user message coming upstream from xsub socket
pending_data
.
push_back
(
blob_t
(
data
,
size
));
pending_data
.
push_back
(
blob_t
(
data
,
size
));
if
(
metadata
)
if
(
metadata
)
metadata
->
add_ref
();
metadata
->
add_ref
();
pending_metadata
.
push_back
(
metadata
);
pending_metadata
.
push_back
(
metadata
);
pending_flags
.
push_back
(
sub
.
flags
());
pending_flags
.
push_back
(
sub
.
flags
());
}
}
...
@@ -151,7 +152,7 @@ int zmq::xpub_t::xsetsockopt (int option_, const void *optval_,
...
@@ -151,7 +152,7 @@ int zmq::xpub_t::xsetsockopt (int option_, const void *optval_,
||
option_
==
ZMQ_XPUB_VERBOSER
||
option_
==
ZMQ_XPUB_VERBOSER
||
option_
==
ZMQ_XPUB_NODROP
||
option_
==
ZMQ_XPUB_NODROP
||
option_
==
ZMQ_XPUB_MANUAL
)
{
||
option_
==
ZMQ_XPUB_MANUAL
)
{
if
(
optvallen_
!=
sizeof
(
int
)
||
*
static_cast
<
const
int
*>
(
optval_
)
<
0
)
{
if
(
optvallen_
!=
sizeof
(
int
)
||
*
static_cast
<
const
int
*>
(
optval_
)
<
0
)
{
errno
=
EINVAL
;
errno
=
EINVAL
;
return
-
1
;
return
-
1
;
}
}
...
@@ -174,26 +175,26 @@ int zmq::xpub_t::xsetsockopt (int option_, const void *optval_,
...
@@ -174,26 +175,26 @@ int zmq::xpub_t::xsetsockopt (int option_, const void *optval_,
else
else
if
(
option_
==
ZMQ_SUBSCRIBE
&&
manual
)
{
if
(
option_
==
ZMQ_SUBSCRIBE
&&
manual
)
{
if
(
last_pipe
!=
NULL
)
if
(
last_pipe
!=
NULL
)
subscriptions
.
add
((
unsigned
char
*
)
optval_
,
optvallen_
,
last_pipe
);
subscriptions
.
add
((
unsigned
char
*
)
optval_
,
optvallen_
,
last_pipe
);
}
}
else
else
if
(
option_
==
ZMQ_UNSUBSCRIBE
&&
manual
)
{
if
(
option_
==
ZMQ_UNSUBSCRIBE
&&
manual
)
{
if
(
last_pipe
!=
NULL
)
if
(
last_pipe
!=
NULL
)
subscriptions
.
rm
((
unsigned
char
*
)
optval_
,
optvallen_
,
last_pipe
);
subscriptions
.
rm
((
unsigned
char
*
)
optval_
,
optvallen_
,
last_pipe
);
}
}
else
else
if
(
option_
==
ZMQ_XPUB_WELCOME_MSG
)
{
if
(
option_
==
ZMQ_XPUB_WELCOME_MSG
)
{
welcome_msg
.
close
();
welcome_msg
.
close
();
if
(
optvallen_
>
0
)
{
if
(
optvallen_
>
0
)
{
int
rc
=
welcome_msg
.
init_size
(
optvallen_
);
int
rc
=
welcome_msg
.
init_size
(
optvallen_
);
errno_assert
(
rc
==
0
);
errno_assert
(
rc
==
0
);
unsigned
char
*
data
=
(
unsigned
char
*
)
welcome_msg
.
data
();
unsigned
char
*
data
=
(
unsigned
char
*
)
welcome_msg
.
data
();
memcpy
(
data
,
optval_
,
optvallen_
);
memcpy
(
data
,
optval_
,
optvallen_
);
}
}
else
else
welcome_msg
.
init
();
welcome_msg
.
init
();
}
}
else
{
else
{
errno
=
EINVAL
;
errno
=
EINVAL
;
...
...
tests/test_xpub_welcome_msg.cpp
View file @
c5acd1bd
...
@@ -31,7 +31,7 @@
...
@@ -31,7 +31,7 @@
int
main
(
void
)
int
main
(
void
)
{
{
setup_test_environment
();
setup_test_environment
();
void
*
ctx
=
zmq_ctx_new
();
void
*
ctx
=
zmq_ctx_new
();
assert
(
ctx
);
assert
(
ctx
);
...
@@ -42,15 +42,15 @@ int main (void)
...
@@ -42,15 +42,15 @@ int main (void)
assert
(
rc
==
0
);
assert
(
rc
==
0
);
// set pub socket options
// set pub socket options
rc
=
zmq_setsockopt
(
pub
,
ZMQ_XPUB_WELCOME_MSG
,
"W"
,
1
);
rc
=
zmq_setsockopt
(
pub
,
ZMQ_XPUB_WELCOME_MSG
,
"W"
,
1
);
assert
(
rc
==
0
);
assert
(
rc
==
0
);
// Create a subscriber
// Create a subscriber
void
*
sub
=
zmq_socket
(
ctx
,
ZMQ_SUB
);
void
*
sub
=
zmq_socket
(
ctx
,
ZMQ_SUB
);
// Subscribe to the welcome message
// Subscribe to the welcome message
rc
=
zmq_setsockopt
(
sub
,
ZMQ_SUBSCRIBE
,
"W"
,
1
);
rc
=
zmq_setsockopt
(
sub
,
ZMQ_SUBSCRIBE
,
"W"
,
1
);
assert
(
rc
==
0
);
assert
(
rc
==
0
);
assert
(
sub
);
assert
(
sub
);
rc
=
zmq_connect
(
sub
,
"inproc://soname"
);
rc
=
zmq_connect
(
sub
,
"inproc://soname"
);
...
@@ -60,14 +60,14 @@ int main (void)
...
@@ -60,14 +60,14 @@ int main (void)
// Receive the welcome subscription
// Receive the welcome subscription
rc
=
zmq_recv
(
pub
,
buffer
,
2
,
0
);
rc
=
zmq_recv
(
pub
,
buffer
,
2
,
0
);
assert
(
rc
==
2
);
assert
(
rc
==
2
);
assert
(
buffer
[
0
]
==
1
);
assert
(
buffer
[
0
]
==
1
);
assert
(
buffer
[
1
]
==
'W'
);
assert
(
buffer
[
1
]
==
'W'
);
// Receive the welcome message
// Receive the welcome message
rc
=
zmq_recv
(
sub
,
buffer
,
1
,
0
);
rc
=
zmq_recv
(
sub
,
buffer
,
1
,
0
);
assert
(
rc
==
1
);
assert
(
rc
==
1
);
assert
(
buffer
[
0
]
==
'W'
);
assert
(
buffer
[
0
]
==
'W'
);
// Clean up.
// Clean up.
rc
=
zmq_close
(
pub
);
rc
=
zmq_close
(
pub
);
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment