aboutsummaryrefslogtreecommitdiff
path: root/nDPId.c
diff options
context:
space:
mode:
authorToni Uhlig <matzeton@googlemail.com>2023-08-24 22:51:03 +0200
committerToni Uhlig <matzeton@googlemail.com>2023-08-24 22:51:57 +0200
commitcc60e819e802b8f5b36377d95ecb33db71d1d14b (patch)
tree2fa14061d774b45eb6b1d789412740e475839ce1 /nDPId.c
parent5234f4621b5a7c5764a6f53921f9af0ba9f4c762 (diff)
Fixed invalid base64 encoding in some rare cases.
* nDPId-test may also verify the correct encoding/decoding Signed-off-by: Toni Uhlig <matzeton@googlemail.com>
Diffstat (limited to 'nDPId.c')
-rw-r--r--nDPId.c67
1 files changed, 33 insertions, 34 deletions
diff --git a/nDPId.c b/nDPId.c
index 644b4a507..f3dfe6366 100644
--- a/nDPId.c
+++ b/nDPId.c
@@ -589,10 +589,12 @@ static int set_collector_nonblock(struct nDPId_reader_thread * const reader_thre
int current_flags;
while ((current_flags = fcntl(reader_thread->collector_sockfd, F_GETFL, 0)) == -1 && errno == EINTR) {}
- if (current_flags == -1) {
- }
+ if (current_flags == -1) {}
- while ((current_flags = fcntl(reader_thread->collector_sockfd, F_SETFL, current_flags | O_NONBLOCK)) == -1 && errno == EINTR) {}
+ while ((current_flags = fcntl(reader_thread->collector_sockfd, F_SETFL, current_flags | O_NONBLOCK)) == -1 &&
+ errno == EINTR)
+ {
+ }
if (current_flags == -1)
{
reader_thread->collector_sock_last_errno = errno;
@@ -2425,12 +2427,12 @@ static void serialize_and_send(struct nDPId_reader_thread * const reader_thread)
}
/* Slightly modified code from: https://en.wikibooks.org/wiki/Algorithm_Implementation/Miscellaneous/Base64 */
-static void base64encode(uint8_t const * const data_buf,
+static int base64_encode(uint8_t const * const data_buf,
size_t dataLength,
char * const result,
size_t * const resultSize)
{
- const char base64chars[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
+ static const char base64chars[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
const uint8_t * data = (const uint8_t *)data_buf;
size_t resultIndex = 0;
size_t x;
@@ -2446,15 +2448,11 @@ static void base64encode(uint8_t const * const data_buf,
// conversion to uint32_t, resulting to 0
if ((x + 1) < dataLength)
- {
n += ((uint32_t)data[x + 1]) << 8; // parenthesis needed, compiler depending on flags can do the shifting
// before conversion to uint32_t, resulting to 0
- }
if ((x + 2) < dataLength)
- {
n += data[x + 2];
- }
/* this 24-bit number gets separated into four 6-bit numbers */
n0 = (uint8_t)(n >> 18) & 63;
@@ -2466,11 +2464,11 @@ static void base64encode(uint8_t const * const data_buf,
* if we have one byte available, then its encoding is spread
* out over two characters
*/
- if (resultIndex + 2 >= *resultSize - (3 - padCount))
- {
- break;
- }
+ if (resultIndex >= *resultSize)
+ return 1; /* indicate failure: buffer too small */
result[resultIndex++] = base64chars[n0];
+ if (resultIndex >= *resultSize)
+ return 1; /* indicate failure: buffer too small */
result[resultIndex++] = base64chars[n1];
/*
@@ -2479,10 +2477,8 @@ static void base64encode(uint8_t const * const data_buf,
*/
if ((x + 1) < dataLength)
{
- if (resultIndex + 1 >= *resultSize - (3 - padCount))
- {
- break;
- }
+ if (resultIndex >= *resultSize)
+ return 1; /* indicate failure: buffer too small */
result[resultIndex++] = base64chars[n2];
}
@@ -2492,10 +2488,8 @@ static void base64encode(uint8_t const * const data_buf,
*/
if ((x + 2) < dataLength)
{
- if (resultIndex + 1 >= *resultSize - (3 - padCount))
- {
- break;
- }
+ if (resultIndex >= *resultSize)
+ return 1; /* indicate failure: buffer too small */
result[resultIndex++] = base64chars[n3];
}
}
@@ -2508,12 +2502,16 @@ static void base64encode(uint8_t const * const data_buf,
{
for (; padCount < 3; padCount++)
{
+ if (resultIndex >= *resultSize)
+ return 1; /* indicate failure: buffer too small */
result[resultIndex++] = '=';
}
}
-
- result[resultIndex] = '\0';
+ if (resultIndex >= *resultSize)
+ return 1; /* indicate failure: buffer too small */
+ result[resultIndex] = 0;
*resultSize = resultIndex;
+ return 0; /* indicate success */
}
static void jsonize_data_analysis(struct nDPId_reader_thread * const reader_thread,
@@ -2666,11 +2664,19 @@ static void jsonize_packet_event(struct nDPId_reader_thread * const reader_threa
ndpi_serialize_string_uint32(&workflow->ndpi_serializer, "pkt_l4_len", pkt_l4_len);
ndpi_serialize_string_uint64(&workflow->ndpi_serializer, "thread_ts_usec", workflow->last_thread_time);
- char base64_data[nDPId_PACKETS_PLEN_MAX];
+ char base64_data[nDPId_PACKETS_PLEN_MAX * 4];
size_t base64_data_len = sizeof(base64_data);
- base64encode(packet, header->caplen, base64_data, &base64_data_len);
-
- if (base64_data_len > 0)
+ if (base64_encode(packet,
+ (header->caplen > nDPId_PACKETS_PLEN_MAX ? nDPId_PACKETS_PLEN_MAX : header->caplen),
+ base64_data,
+ &base64_data_len) != 0)
+ {
+ logger(1,
+ "[%8llu, %zu] Base64 encoding failed.",
+ reader_thread->workflow->packets_captured,
+ reader_thread->array_index);
+ }
+ else if (base64_data_len > 0)
{
if (ndpi_serialize_string_binary(&workflow->ndpi_serializer, "pkt", base64_data, base64_data_len) != 0)
{
@@ -2680,13 +2686,6 @@ static void jsonize_packet_event(struct nDPId_reader_thread * const reader_threa
reader_thread->array_index);
}
}
- else
- {
- logger(1,
- "[%8llu, %zu] Base64 encoding failed.",
- reader_thread->workflow->packets_captured,
- reader_thread->array_index);
- }
serialize_and_send(reader_thread);
}