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
0750303b
Commit
0750303b
authored
May 15, 2014
by
Martin Hurton
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
CURVE: Implement client-side ERROR handling
parent
0975be6e
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
64 additions
and
40 deletions
+64
-40
curve_client.cpp
src/curve_client.cpp
+60
-38
curve_client.hpp
src/curve_client.hpp
+4
-2
No files found.
src/curve_client.cpp
View file @
0750303b
...
@@ -82,30 +82,31 @@ int zmq::curve_client_t::next_handshake_command (msg_t *msg_)
...
@@ -82,30 +82,31 @@ int zmq::curve_client_t::next_handshake_command (msg_t *msg_)
int
zmq
::
curve_client_t
::
process_handshake_command
(
msg_t
*
msg_
)
int
zmq
::
curve_client_t
::
process_handshake_command
(
msg_t
*
msg_
)
{
{
int
rc
=
0
;
const
unsigned
char
*
msg_data
=
static_cast
<
unsigned
char
*>
(
msg_
->
data
());
const
size_t
msg_size
=
msg_
->
size
();
switch
(
state
)
{
int
rc
=
0
;
case
expect_welcome
:
if
(
msg_size
>=
8
&&
!
memcmp
(
msg_data
,
"
\7
WELCOME"
,
8
))
rc
=
process_welcome
(
msg_
);
rc
=
process_welcome
(
msg_data
,
msg_size
);
if
(
rc
==
0
)
else
state
=
send_initiate
;
if
(
msg_size
>=
6
&&
!
memcmp
(
msg_data
,
"
\5
READY"
,
6
))
break
;
rc
=
process_ready
(
msg_data
,
msg_size
);
case
expect_ready
:
else
rc
=
process_ready
(
msg_
);
if
(
msg_size
>=
6
&&
!
memcmp
(
msg_data
,
"
\5
ERROR"
,
6
))
if
(
rc
==
0
)
rc
=
process_error
(
msg_data
,
msg_size
);
state
=
connected
;
else
{
break
;
errno
=
EPROTO
;
default
:
rc
=
-
1
;
errno
=
EPROTO
;
rc
=
-
1
;
break
;
}
}
if
(
rc
==
0
)
{
if
(
rc
==
0
)
{
rc
=
msg_
->
close
();
rc
=
msg_
->
close
();
errno_assert
(
rc
==
0
);
errno_assert
(
rc
==
0
);
rc
=
msg_
->
init
();
rc
=
msg_
->
init
();
errno_assert
(
rc
==
0
);
errno_assert
(
rc
==
0
);
}
}
return
rc
;
return
rc
;
}
}
...
@@ -218,7 +219,13 @@ int zmq::curve_client_t::decode (msg_t *msg_)
...
@@ -218,7 +219,13 @@ int zmq::curve_client_t::decode (msg_t *msg_)
zmq
::
mechanism_t
::
status_t
zmq
::
curve_client_t
::
status
()
const
zmq
::
mechanism_t
::
status_t
zmq
::
curve_client_t
::
status
()
const
{
{
return
state
==
connected
?
mechanism_t
::
ready
:
mechanism_t
::
handshaking
;
if
(
state
==
connected
)
return
mechanism_t
::
ready
;
else
if
(
state
==
error_received
)
return
mechanism_t
::
error
;
else
return
mechanism_t
::
handshaking
;
}
}
int
zmq
::
curve_client_t
::
produce_hello
(
msg_t
*
msg_
)
int
zmq
::
curve_client_t
::
produce_hello
(
msg_t
*
msg_
)
...
@@ -260,15 +267,10 @@ int zmq::curve_client_t::produce_hello (msg_t *msg_)
...
@@ -260,15 +267,10 @@ int zmq::curve_client_t::produce_hello (msg_t *msg_)
return
0
;
return
0
;
}
}
int
zmq
::
curve_client_t
::
process_welcome
(
msg_t
*
msg_
)
int
zmq
::
curve_client_t
::
process_welcome
(
const
uint8_t
*
msg_data
,
size_t
msg_size
)
{
{
if
(
msg_
->
size
()
!=
168
)
{
if
(
msg_size
!=
168
)
{
errno
=
EPROTO
;
return
-
1
;
}
const
uint8_t
*
welcome
=
static_cast
<
uint8_t
*>
(
msg_
->
data
());
if
(
memcmp
(
welcome
,
"
\x07
WELCOME"
,
8
))
{
errno
=
EPROTO
;
errno
=
EPROTO
;
return
-
1
;
return
-
1
;
}
}
...
@@ -279,10 +281,10 @@ int zmq::curve_client_t::process_welcome (msg_t *msg_)
...
@@ -279,10 +281,10 @@ int zmq::curve_client_t::process_welcome (msg_t *msg_)
// Open Box [S' + cookie](C'->S)
// Open Box [S' + cookie](C'->S)
memset
(
welcome_box
,
0
,
crypto_box_BOXZEROBYTES
);
memset
(
welcome_box
,
0
,
crypto_box_BOXZEROBYTES
);
memcpy
(
welcome_box
+
crypto_box_BOXZEROBYTES
,
welcome
+
24
,
144
);
memcpy
(
welcome_box
+
crypto_box_BOXZEROBYTES
,
msg_data
+
24
,
144
);
memcpy
(
welcome_nonce
,
"WELCOME-"
,
8
);
memcpy
(
welcome_nonce
,
"WELCOME-"
,
8
);
memcpy
(
welcome_nonce
+
8
,
welcome
+
8
,
16
);
memcpy
(
welcome_nonce
+
8
,
msg_data
+
8
,
16
);
int
rc
=
crypto_box_open
(
welcome_plaintext
,
welcome_box
,
int
rc
=
crypto_box_open
(
welcome_plaintext
,
welcome_box
,
sizeof
welcome_box
,
sizeof
welcome_box
,
...
@@ -299,6 +301,8 @@ int zmq::curve_client_t::process_welcome (msg_t *msg_)
...
@@ -299,6 +301,8 @@ int zmq::curve_client_t::process_welcome (msg_t *msg_)
rc
=
crypto_box_beforenm
(
cn_precom
,
cn_server
,
cn_secret
);
rc
=
crypto_box_beforenm
(
cn_precom
,
cn_server
,
cn_secret
);
zmq_assert
(
rc
==
0
);
zmq_assert
(
rc
==
0
);
state
=
send_initiate
;
return
0
;
return
0
;
}
}
...
@@ -375,20 +379,15 @@ int zmq::curve_client_t::produce_initiate (msg_t *msg_)
...
@@ -375,20 +379,15 @@ int zmq::curve_client_t::produce_initiate (msg_t *msg_)
return
0
;
return
0
;
}
}
int
zmq
::
curve_client_t
::
process_ready
(
msg_t
*
msg_
)
int
zmq
::
curve_client_t
::
process_ready
(
const
uint8_t
*
msg_data
,
size_t
msg_size
)
{
{
if
(
msg_
->
size
()
<
30
)
{
if
(
msg_size
<
30
)
{
errno
=
EPROTO
;
return
-
1
;
}
const
uint8_t
*
ready
=
static_cast
<
uint8_t
*>
(
msg_
->
data
());
if
(
memcmp
(
ready
,
"
\x05
READY"
,
6
))
{
errno
=
EPROTO
;
errno
=
EPROTO
;
return
-
1
;
return
-
1
;
}
}
const
size_t
clen
=
(
msg_
->
size
()
-
14
)
+
crypto_box_BOXZEROBYTES
;
const
size_t
clen
=
(
msg_
size
-
14
)
+
crypto_box_BOXZEROBYTES
;
uint8_t
ready_nonce
[
crypto_box_NONCEBYTES
];
uint8_t
ready_nonce
[
crypto_box_NONCEBYTES
];
uint8_t
ready_plaintext
[
crypto_box_ZEROBYTES
+
256
];
uint8_t
ready_plaintext
[
crypto_box_ZEROBYTES
+
256
];
...
@@ -396,10 +395,10 @@ int zmq::curve_client_t::process_ready (msg_t *msg_)
...
@@ -396,10 +395,10 @@ int zmq::curve_client_t::process_ready (msg_t *msg_)
memset
(
ready_box
,
0
,
crypto_box_BOXZEROBYTES
);
memset
(
ready_box
,
0
,
crypto_box_BOXZEROBYTES
);
memcpy
(
ready_box
+
crypto_box_BOXZEROBYTES
,
memcpy
(
ready_box
+
crypto_box_BOXZEROBYTES
,
ready
+
14
,
clen
-
crypto_box_BOXZEROBYTES
);
msg_data
+
14
,
clen
-
crypto_box_BOXZEROBYTES
);
memcpy
(
ready_nonce
,
"CurveZMQREADY---"
,
16
);
memcpy
(
ready_nonce
,
"CurveZMQREADY---"
,
16
);
memcpy
(
ready_nonce
+
16
,
ready
+
6
,
8
);
memcpy
(
ready_nonce
+
16
,
msg_data
+
6
,
8
);
int
rc
=
crypto_box_open_afternm
(
ready_plaintext
,
ready_box
,
int
rc
=
crypto_box_open_afternm
(
ready_plaintext
,
ready_box
,
clen
,
ready_nonce
,
cn_precom
);
clen
,
ready_nonce
,
cn_precom
);
...
@@ -411,7 +410,30 @@ int zmq::curve_client_t::process_ready (msg_t *msg_)
...
@@ -411,7 +410,30 @@ int zmq::curve_client_t::process_ready (msg_t *msg_)
rc
=
parse_metadata
(
ready_plaintext
+
crypto_box_ZEROBYTES
,
rc
=
parse_metadata
(
ready_plaintext
+
crypto_box_ZEROBYTES
,
clen
-
crypto_box_ZEROBYTES
);
clen
-
crypto_box_ZEROBYTES
);
if
(
rc
==
0
)
state
=
connected
;
return
rc
;
return
rc
;
}
}
int
zmq
::
curve_client_t
::
process_error
(
const
uint8_t
*
msg_data
,
size_t
msg_size
)
{
if
(
state
!=
expect_welcome
&&
state
!=
expect_ready
)
{
errno
=
EPROTO
;
return
-
1
;
}
if
(
msg_size
<
7
)
{
errno
=
EPROTO
;
return
-
1
;
}
const
size_t
error_reason_len
=
static_cast
<
size_t
>
(
msg_data
[
6
]);
if
(
error_reason_len
>
msg_size
-
7
)
{
errno
=
EPROTO
;
return
-
1
;
}
state
=
error_received
;
return
0
;
}
#endif
#endif
src/curve_client.hpp
View file @
0750303b
...
@@ -69,6 +69,7 @@ namespace zmq
...
@@ -69,6 +69,7 @@ namespace zmq
expect_welcome
,
expect_welcome
,
send_initiate
,
send_initiate
,
expect_ready
,
expect_ready
,
error_received
,
connected
connected
};
};
...
@@ -103,9 +104,10 @@ namespace zmq
...
@@ -103,9 +104,10 @@ namespace zmq
uint64_t
cn_nonce
;
uint64_t
cn_nonce
;
int
produce_hello
(
msg_t
*
msg_
);
int
produce_hello
(
msg_t
*
msg_
);
int
process_welcome
(
msg_t
*
msg_
);
int
process_welcome
(
const
uint8_t
*
cmd_data
,
size_t
data_size
);
int
produce_initiate
(
msg_t
*
msg_
);
int
produce_initiate
(
msg_t
*
msg_
);
int
process_ready
(
msg_t
*
msg_
);
int
process_ready
(
const
uint8_t
*
cmd_data
,
size_t
data_size
);
int
process_error
(
const
uint8_t
*
cmd_data
,
size_t
data_size
);
mutex_t
sync
;
mutex_t
sync
;
};
};
...
...
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