aboutsummaryrefslogtreecommitdiff
path: root/src/ecdh.c
diff options
context:
space:
mode:
authorAris Adamantiadis <aris@0xbadc0de.be>2018-10-27 21:27:00 +0200
committerAndreas Schneider <asn@cryptomilk.org>2019-01-24 09:11:30 +0100
commit602a1defea06f0f63d8c6bdd5b164b86dbfdb971 (patch)
tree082cf1dba7d772e29027ac123c70ebaa07801b6b /src/ecdh.c
parentfd5770973f17f884317e70fddd743bf718227af0 (diff)
downloadlibssh-602a1defea06f0f63d8c6bdd5b164b86dbfdb971.tar.gz
libssh-602a1defea06f0f63d8c6bdd5b164b86dbfdb971.tar.xz
libssh-602a1defea06f0f63d8c6bdd5b164b86dbfdb971.zip
kex: use runtime callbacks (client)
Signed-off-by: Aris Adamantiadis <aris@0xbadc0de.be> Reviewed-by: Jakub Jelen <jjelen@redhat.com> Reviewed-by: Andreas Schneider <asn@cryptomilk.org>
Diffstat (limited to 'src/ecdh.c')
-rw-r--r--src/ecdh.c30
1 files changed, 27 insertions, 3 deletions
diff --git a/src/ecdh.c b/src/ecdh.c
index f7fcaf13..71779da9 100644
--- a/src/ecdh.c
+++ b/src/ecdh.c
@@ -30,16 +30,32 @@
#ifdef HAVE_ECDH
+static SSH_PACKET_CALLBACK(ssh_packet_client_ecdh_reply);
+
+static ssh_packet_callback ecdh_client_callbacks[]= {
+ ssh_packet_client_ecdh_reply
+};
+
+struct ssh_packet_callbacks_struct ssh_ecdh_client_callbacks = {
+ .start = SSH2_MSG_KEX_ECDH_REPLY,
+ .n_callbacks = 1,
+ .callbacks = ecdh_client_callbacks,
+ .user = NULL
+};
+
/** @internal
* @brief parses a SSH_MSG_KEX_ECDH_REPLY packet and sends back
* a SSH_MSG_NEWKEYS
*/
-int ssh_client_ecdh_reply(ssh_session session, ssh_buffer packet){
+SSH_PACKET_CALLBACK(ssh_packet_client_ecdh_reply){
ssh_string q_s_string = NULL;
ssh_string pubkey_blob = NULL;
ssh_string signature = NULL;
int rc;
+ (void)type;
+ (void)user;
+ ssh_packet_remove_callbacks(session, &ssh_ecdh_client_callbacks);
pubkey_blob = ssh_buffer_get_ssh_string(packet);
if (pubkey_blob == NULL) {
ssh_set_error(session,SSH_FATAL, "No public key in packet");
@@ -77,10 +93,18 @@ int ssh_client_ecdh_reply(ssh_session session, ssh_buffer packet){
}
rc=ssh_packet_send(session);
+ if (rc == SSH_ERROR) {
+ goto error;
+ }
+
SSH_LOG(SSH_LOG_PROTOCOL, "SSH_MSG_NEWKEYS sent");
- return rc;
+ session->dh_handshake_state = DH_STATE_NEWKEYS_SENT;
+
+ return SSH_PACKET_USED;
+
error:
- return SSH_ERROR;
+ session->session_state=SSH_SESSION_STATE_ERROR;
+ return SSH_PACKET_USED;
}
#endif /* HAVE_ECDH */