Move Base32_encode from packet-fc00.c to wsutil (as ws_base32_decode)
authorMichael Mann <mmann78@netscape.net>
Mon, 31 Oct 2016 05:10:56 +0000 (01:10 -0400)
committerAnders Broman <a.broman58@gmail.com>
Wed, 2 Nov 2016 04:34:44 +0000 (04:34 +0000)
There could be some reuse out of it, so but it with the rest of the
general utilities.

Change-Id: I404c135b933660a82678510b9ca2701985c5632a
Reviewed-on: https://code.wireshark.org/review/18589
Reviewed-by: Michael Mann <mmann78@netscape.net>
Petri-Dish: Michael Mann <mmann78@netscape.net>
Tested-by: Petri Dish Buildbot <buildbot-no-reply@wireshark.org>
Reviewed-by: Anders Broman <a.broman58@gmail.com>
debian/libwsutil0.symbols
epan/dissectors/packet-fc00.c
wsutil/CMakeLists.txt
wsutil/Makefile.am
wsutil/base32.c [new file with mode: 0644]
wsutil/base32.h [new file with mode: 0644]

index 3f908b6c7b8cd478ba5fa25bdf3da945754bb750..1a42ae7d024c1182405067371c5e6f8782ff5d33 100644 (file)
@@ -169,6 +169,7 @@ libwsutil.so.0 libwsutil0 #MINVER#
  ws_add_crash_info@Base 1.10.0
  ws_ascii_strnatcasecmp@Base 1.99.1
  ws_ascii_strnatcmp@Base 1.99.1
+ ws_base32_decode@Base 2.3.0
  ws_base64_decode_inplace@Base 1.12.0~rc1
  ws_buffer_append@Base 1.99.0
  ws_buffer_assure_space@Base 1.99.0
index d40c1a3c299a5f55a2047cf0fac00cbfd3612d2c..5ea01b9d8cc09f807692260fd8c218de1f22acdd 100644 (file)
@@ -31,6 +31,7 @@
 
 #include <epan/expert.h>
 #include <epan/packet.h>
+#include <wsutil/base32.h>
 
 /* Prototypes */
 /* (Required to prevent [-Wmissing-prototypes] warnings */
@@ -86,50 +87,6 @@ static const value_string session_states[] = {
     { 0, NULL }
 };
 
-/*
- * Cjdns style base32 encoding
- */
-
-/** Returned by Base32_decode() if the input is not valid base32. */
-#define Base32_BAD_INPUT -1
-/** Returned by Base32_decode() or Base32_encode() if the output buffer is too small. */
-#define Base32_TOO_BIG -2
-
-static inline int Base32_encode(guint8* output,
-                                const guint32 outputLength,
-                                const guint8* in,
-                                const guint32 inputLength)
-{
-    guint32 outIndex = 0;
-    guint32 inIndex = 0;
-    guint32 work = 0;
-    guint32 bits = 0;
-    static const guint8* kChars = (guint8*) "0123456789bcdfghjklmnpqrstuvwxyz";
-    while (inIndex < inputLength) {
-        work |= ((unsigned) in[inIndex++]) << bits;
-        bits += 8;
-        while (bits >= 5) {
-            if (outIndex >= outputLength) {
-                return Base32_TOO_BIG;
-            }
-            output[outIndex++] = kChars[work & 31];
-            bits -= 5;
-            work >>= 5;
-        }
-    }
-    if (bits) {
-        if (outIndex >= outputLength) {
-            return Base32_TOO_BIG;
-        }
-        output[outIndex++] = kChars[work & 31];
-    }
-    if (outIndex < outputLength) {
-        output[outIndex] = '\0';
-    }
-    return outIndex;
-}
-
-
 /* Code to actually dissect the packets */
 static int
 dissect_cryptoauth(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, void *data _U_)
@@ -191,7 +148,7 @@ dissect_cryptoauth(tvbuff_t *tvb, packet_info *pinfo, proto_tree *tree, void *da
 
         tvb_memcpy(tvb, raw_key, PUBLIC_KEY_OFF, PUBLIC_KEY_LEN);
 
-        Base32_encode((guint8*)encoded_key, 53, raw_key, PUBLIC_KEY_LEN);
+        ws_base32_decode((guint8*)encoded_key, 53, raw_key, PUBLIC_KEY_LEN);
 
         g_checksum_update(hash, (guchar*)raw_key, PUBLIC_KEY_LEN);
         g_checksum_get_digest(hash, ip_buf, &digest_len);
index 438bc42cbb9f0cbc339a8a00ce2753662b714459..8b9cf011d83972b277478a78fd2192258c0403ff 100644 (file)
@@ -25,6 +25,7 @@ set(WSUTIL_COMMON_FILES
        adler32.c
        aes.c
        airpdcap_wep.c
+       base32.c
        base64.c
        bitswap.c
        buffer.c
index cf5da9f926e6b9c33870a2d1849daa6e838efd91..a8642d4e10a3b6ad0d02ecdf516eda343aa4ceb5 100644 (file)
@@ -40,6 +40,7 @@ endif
 libwsutil_nonrepl_INCLUDES = \
        adler32.h               \
        aes.h                   \
+       base32.h                \
        base64.h                \
        bits_count_ones.h       \
        bits_ctz.h              \
@@ -118,6 +119,7 @@ libwsutil_la_SOURCES = \
        adler32.c               \
        aes.c                   \
        airpdcap_wep.c          \
+       base32.c                \
        base64.c                \
        bitswap.c               \
        buffer.c                \
diff --git a/wsutil/base32.c b/wsutil/base32.c
new file mode 100644 (file)
index 0000000..6bb1b61
--- /dev/null
@@ -0,0 +1,82 @@
+/* base32.c
+ * Base-32 conversion
+ *
+ * Wireshark - Network traffic analyzer
+ * By Gerald Combs <gerald@wireshark.org>
+ * Copyright 1998 Gerald Combs
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License
+ * as published by the Free Software Foundation; either version 2
+ * of the License, or (at your option) any later version.
+ *
+ * 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
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
+ */
+
+#include "config.h"
+
+#include <glib.h>
+
+#include <string.h>
+#include "base32.h"
+
+/*
+ * Cjdns style base32 encoding
+ */
+
+/** Returned by ws_base32_encode() if the input is not valid base32. */
+#define Base32_BAD_INPUT -1
+/** Returned by ws_base32_encode() if the output buffer is too small. */
+#define Base32_TOO_BIG -2
+
+int ws_base32_decode(guint8* output, const guint32 outputLength,
+                                               const guint8* in, const guint32 inputLength)
+{
+       guint32 outIndex = 0;
+       guint32 inIndex = 0;
+       guint32 work = 0;
+       guint32 bits = 0;
+       static const guint8* kChars = (guint8*) "0123456789bcdfghjklmnpqrstuvwxyz";
+       while (inIndex < inputLength) {
+               work |= ((unsigned) in[inIndex++]) << bits;
+               bits += 8;
+               while (bits >= 5) {
+                       if (outIndex >= outputLength) {
+                               return Base32_TOO_BIG;
+                       }
+                       output[outIndex++] = kChars[work & 31];
+                       bits -= 5;
+                       work >>= 5;
+               }
+       }
+       if (bits) {
+               if (outIndex >= outputLength) {
+                       return Base32_TOO_BIG;
+               }
+               output[outIndex++] = kChars[work & 31];
+       }
+       if (outIndex < outputLength) {
+               output[outIndex] = '\0';
+       }
+       return outIndex;
+}
+
+/*
+ * Editor modelines  -  http://www.wireshark.org/tools/modelines.html
+ *
+ * Local variables:
+ * c-basic-offset: 8
+ * tab-width: 8
+ * indent-tabs-mode: t
+ * End:
+ *
+ * vi: set shiftwidth=8 tabstop=8 noexpandtab:
+ * :indentSize=8:tabSize=8:noTabs=false:
+ */
diff --git a/wsutil/base32.h b/wsutil/base32.h
new file mode 100644 (file)
index 0000000..626f643
--- /dev/null
@@ -0,0 +1,58 @@
+/* base32.h
+ * Base-32 conversion
+ *
+ * Wireshark - Network traffic analyzer
+ * By Gerald Combs <gerald@wireshark.org>
+ * Copyright 1998 Gerald Combs
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License
+ * as published by the Free Software Foundation; either version 2
+ * of the License, or (at your option) any later version.
+ *
+ * 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
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
+ */
+#ifndef __BASE32_H__
+#define __BASE32_H__
+
+#include "ws_symbol_export.h"
+
+#ifdef __cplusplus
+extern "C" {
+#endif /* __cplusplus */
+
+/** Returned by base32_decode() if the input is not valid base32. */
+#define Base32_BAD_INPUT -1
+/** Returned by base32_decode() if the output buffer is too small. */
+#define Base32_TOO_BIG -2
+
+/* Encoding of a base32 byte array */
+WS_DLL_PUBLIC
+int ws_base32_decode(guint8* output, const guint32 outputLength,
+                                               const guint8* in, const guint32 inputLength);
+
+#ifdef __cplusplus
+}
+#endif /* __cplusplus */
+
+#endif /* __BASE32_H__ */
+
+/*
+ * Editor modelines  -  https://www.wireshark.org/tools/modelines.html
+ *
+ * Local variables:
+ * c-basic-offset: 4
+ * tab-width: 8
+ * indent-tabs-mode: nil
+ * End:
+ *
+ * vi: set shiftwidth=4 tabstop=8 expandtab:
+ * :indentSize=4:tabSize=8:noTabs=true:
+ */