[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH] packet: log disconnect code in host byte order
[Thread Prev] | [Thread Next]
- Subject: [PATCH] packet: log disconnect code in host byte order
- From: Jon Simons <jon@xxxxxxxxxxxxx>
- Reply-to: libssh@xxxxxxxxxx
- Date: Tue, 11 Feb 2014 17:22:26 -0800
- To: libssh@xxxxxxxxxx
Hi, Attached is a minor patch which logs disconnect codes in host byte order (this makes it easier to map them to the values as laid out in the RFC). While here I converted hardtabs to spaces for this function. -Jon
From b69c386cc56b68e0679a45b3c5a6c35629f48ee3 Mon Sep 17 00:00:00 2001
From: Jon Simons <jon@xxxxxxxxxxxxx>
Date: Mon, 10 Feb 2014 17:43:54 -0800
Subject: [PATCH] packet: log disconnect code in host byte order
---
src/packet_cb.c | 32 +++++++++++++++++++-------------
1 file changed, 19 insertions(+), 13 deletions(-)
diff --git a/src/packet_cb.c b/src/packet_cb.c
index f5d4f05..a10dd1a 100644
--- a/src/packet_cb.c
+++ b/src/packet_cb.c
@@ -43,29 +43,35 @@
* @brief Handle a SSH_DISCONNECT packet.
*/
SSH_PACKET_CALLBACK(ssh_packet_disconnect_callback){
- uint32_t code;
- char *error=NULL;
- ssh_string error_s;
- (void)user;
- (void)type;
- buffer_get_u32(packet, &code);
+ int rc;
+ uint32_t code = 0;
+ char *error = NULL;
+ ssh_string error_s;
+ (void)user;
+ (void)type;
+
+ rc = buffer_get_u32(packet, &code);
+ if (rc != 0) {
+ code = ntohl(code);
+ }
+
error_s = buffer_get_ssh_string(packet);
if (error_s != NULL) {
error = ssh_string_to_char(error_s);
ssh_string_free(error_s);
}
- SSH_LOG(SSH_LOG_PACKET, "Received SSH_MSG_DISCONNECT %d:%s",code,
- error != NULL ? error : "no error");
+ SSH_LOG(SSH_LOG_PACKET, "Received SSH_MSG_DISCONNECT %d:%s",
+ code, error != NULL ? error : "no error");
ssh_set_error(session, SSH_FATAL,
- "Received SSH_MSG_DISCONNECT: %d:%s",code,
- error != NULL ? error : "no error");
+ "Received SSH_MSG_DISCONNECT: %d:%s",
+ code, error != NULL ? error : "no error");
SAFE_FREE(error);
ssh_socket_close(session->socket);
session->alive = 0;
- session->session_state= SSH_SESSION_STATE_ERROR;
- /* TODO: handle a graceful disconnect */
- return SSH_PACKET_USED;
+ session->session_state = SSH_SESSION_STATE_ERROR;
+ /* TODO: handle a graceful disconnect */
+ return SSH_PACKET_USED;
}
/**
--
1.8.4.21.g992c386
Archive administrator: postmaster@lists.cynapses.org