aboutsummaryrefslogtreecommitdiffstats
path: root/framework/src/suricata/src/app-layer-ssh.h
diff options
context:
space:
mode:
authorAshlee Young <ashlee@onosfw.com>2015-09-09 22:21:41 -0700
committerAshlee Young <ashlee@onosfw.com>2015-09-09 22:21:41 -0700
commit8879b125d26e8db1a5633de5a9c692eb2d1c4f83 (patch)
treec7259d85a991b83dfa85ab2e339360669fc1f58e /framework/src/suricata/src/app-layer-ssh.h
parent13d05bc8458758ee39cb829098241e89616717ee (diff)
suricata checkin based on commit id a4bce14770beee46a537eda3c3f6e8e8565d5d0a
Change-Id: I9a214fa0ee95e58fc640e50bd604dac7f42db48f
Diffstat (limited to 'framework/src/suricata/src/app-layer-ssh.h')
-rw-r--r--framework/src/suricata/src/app-layer-ssh.h77
1 files changed, 77 insertions, 0 deletions
diff --git a/framework/src/suricata/src/app-layer-ssh.h b/framework/src/suricata/src/app-layer-ssh.h
new file mode 100644
index 00000000..7a6a9b72
--- /dev/null
+++ b/framework/src/suricata/src/app-layer-ssh.h
@@ -0,0 +1,77 @@
+/* Copyright (C) 2007-2014 Open Information Security Foundation
+ *
+ * You can copy, redistribute or modify this Program under the terms of
+ * the GNU General Public License version 2 as published by the Free
+ * Software Foundation.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * version 2 along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
+ * 02110-1301, USA.
+ */
+
+/**
+ * \file
+ *
+ * \author Pablo Rincon <pablo.rincon.crespo@gmail.com>
+ * \author Victor Julien <victor@inliniac.net>
+ */
+
+#ifndef __APP_LAYER_SSH_H__
+#define __APP_LAYER_SSH_H__
+
+/* header flag */
+#define SSH_FLAG_VERSION_PARSED 0x01
+
+/* This flags indicate that the rest of the communication
+ * must be ciphered, so the parsing finish here */
+#define SSH_FLAG_PARSER_DONE 0x02
+
+#define SSH_FLAG_STATE_LOGGED 0x04
+
+/* MSG_CODE */
+#define SSH_MSG_NEWKEYS 21
+
+/** From SSH-TRANSP rfc
+
+ SSH Bunary packet structure:
+ uint32 packet_length
+ byte padding_length
+ byte[n1] payload; n1 = packet_length - padding_length - 1
+ byte[n2] random padding; n2 = padding_length
+ byte[m] mac (Message Authentication Code - MAC); m = mac_length
+
+ So we are going to do a header struct to store
+ the lenghts and msg_code (inside payload, if any)
+*/
+
+typedef struct SshHeader_ {
+ uint32_t pkt_len;
+ uint8_t padding_len;
+ uint8_t msg_code;
+ uint8_t buf[6];
+ uint8_t buf_offset;
+ uint8_t flags;
+ uint32_t record_left;
+ uint8_t *proto_version;
+ uint8_t *software_version;
+ uint8_t *banner_buffer;
+ uint16_t banner_len;
+} SshHeader;
+
+/** structure to store the SSH state values */
+typedef struct SshState_ {
+ SshHeader srv_hdr;
+ SshHeader cli_hdr;
+} SshState;
+
+void RegisterSSHParsers(void);
+void SSHParserRegisterTests(void);
+
+#endif /* __APP_LAYER_SSH_H__ */
+