summaryrefslogtreecommitdiffstats
path: root/plugins
diff options
context:
space:
mode:
authorThomas Guyot-Sionnest <dermoth@users.sourceforge.net>2007-11-09 21:17:03 +0000
committerThomas Guyot-Sionnest <dermoth@users.sourceforge.net>2007-11-09 21:17:03 +0000
commit7a05ad0166ac11d4206d934825728b56a58d8edd (patch)
tree771b5f856eaa9e38ed4ef525ecefcf1b72e85949 /plugins
parent29471dda5ae9e750809e7a25b93d6bf6a2913bc2 (diff)
downloadmonitoring-plugins-7a05ad0166ac11d4206d934825728b56a58d8edd.tar.gz
Moved base64 function to /lib.
git-svn-id: https://nagiosplug.svn.sourceforge.net/svnroot/nagiosplug/nagiosplug/trunk@1817 f882894a-f735-0410-b71e-b25c423dba1c
Diffstat (limited to 'plugins')
-rw-r--r--plugins/check_http.c45
-rw-r--r--plugins/check_smtp.c42
2 files changed, 3 insertions, 84 deletions
diff --git a/plugins/check_http.c b/plugins/check_http.c
index 901f6b66..36374233 100644
--- a/plugins/check_http.c
+++ b/plugins/check_http.c
@@ -48,6 +48,7 @@ const char *email = "nagiosplug-devel@lists.sourceforge.net";
48#include "common.h" 48#include "common.h"
49#include "netutils.h" 49#include "netutils.h"
50#include "utils.h" 50#include "utils.h"
51#include "base64.h"
51 52
52#define INPUT_DELIMITER ";" 53#define INPUT_DELIMITER ";"
53 54
@@ -125,7 +126,6 @@ char *http_content_type;
125char buffer[MAX_INPUT_BUFFER]; 126char buffer[MAX_INPUT_BUFFER];
126 127
127int process_arguments (int, char **); 128int process_arguments (int, char **);
128static char *base64 (const char *bin, size_t len);
129int check_http (void); 129int check_http (void);
130void redir (char *pos, char *status_line); 130void redir (char *pos, char *status_line);
131int server_type_check(const char *type); 131int server_type_check(const char *type);
@@ -455,49 +455,6 @@ process_arguments (int argc, char **argv)
455 455
456 456
457 457
458/* written by lauri alanko */
459static char *
460base64 (const char *bin, size_t len)
461{
462
463 char *buf = (char *) malloc ((len + 2) / 3 * 4 + 1);
464 size_t i = 0, j = 0;
465
466 char BASE64_END = '=';
467 char base64_table[64];
468 strncpy (base64_table, "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", 64);
469
470 while (j < len - 2) {
471 buf[i++] = base64_table[bin[j] >> 2];
472 buf[i++] = base64_table[((bin[j] & 3) << 4) | (bin[j + 1] >> 4)];
473 buf[i++] = base64_table[((bin[j + 1] & 15) << 2) | (bin[j + 2] >> 6)];
474 buf[i++] = base64_table[bin[j + 2] & 63];
475 j += 3;
476 }
477
478 switch (len - j) {
479 case 1:
480 buf[i++] = base64_table[bin[j] >> 2];
481 buf[i++] = base64_table[(bin[j] & 3) << 4];
482 buf[i++] = BASE64_END;
483 buf[i++] = BASE64_END;
484 break;
485 case 2:
486 buf[i++] = base64_table[bin[j] >> 2];
487 buf[i++] = base64_table[((bin[j] & 3) << 4) | (bin[j + 1] >> 4)];
488 buf[i++] = base64_table[(bin[j + 1] & 15) << 2];
489 buf[i++] = BASE64_END;
490 break;
491 case 0:
492 break;
493 }
494
495 buf[i] = '\0';
496 return buf;
497}
498
499
500
501/* Returns 1 if we're done processing the document body; 0 to keep going */ 458/* Returns 1 if we're done processing the document body; 0 to keep going */
502static int 459static int
503document_headers_done (char *full_page) 460document_headers_done (char *full_page)
diff --git a/plugins/check_smtp.c b/plugins/check_smtp.c
index 79c7cd35..f44e5331 100644
--- a/plugins/check_smtp.c
+++ b/plugins/check_smtp.c
@@ -45,6 +45,7 @@ const char *email = "nagiosplug-devel@lists.sourceforge.net";
45#include "common.h" 45#include "common.h"
46#include "netutils.h" 46#include "netutils.h"
47#include "utils.h" 47#include "utils.h"
48#include "base64.h"
48 49
49#ifdef HAVE_SSL 50#ifdef HAVE_SSL
50int check_cert = FALSE; 51int check_cert = FALSE;
@@ -122,46 +123,6 @@ enum {
122 UDP_PROTOCOL = 2, 123 UDP_PROTOCOL = 2,
123}; 124};
124 125
125/* written by lauri alanko */
126static char *
127base64 (const char *bin, size_t len)
128{
129
130 char *buf = (char *) malloc ((len + 2) / 3 * 4 + 1);
131 size_t i = 0, j = 0;
132
133 char BASE64_END = '=';
134 char base64_table[64];
135 strncpy (base64_table, "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", 64);
136
137 while (j < len - 2) {
138 buf[i++] = base64_table[bin[j] >> 2];
139 buf[i++] = base64_table[((bin[j] & 3) << 4) | (bin[j + 1] >> 4)];
140 buf[i++] = base64_table[((bin[j + 1] & 15) << 2) | (bin[j + 2] >> 6)];
141 buf[i++] = base64_table[bin[j + 2] & 63];
142 j += 3;
143 }
144
145 switch (len - j) {
146 case 1:
147 buf[i++] = base64_table[bin[j] >> 2];
148 buf[i++] = base64_table[(bin[j] & 3) << 4];
149 buf[i++] = BASE64_END;
150 buf[i++] = BASE64_END;
151 break;
152 case 2:
153 buf[i++] = base64_table[bin[j] >> 2];
154 buf[i++] = base64_table[((bin[j] & 3) << 4) | (bin[j + 1] >> 4)];
155 buf[i++] = base64_table[(bin[j + 1] & 15) << 2];
156 buf[i++] = BASE64_END;
157 break;
158 case 0:
159 break;
160 }
161
162 buf[i] = '\0';
163 return buf;
164}
165 126
166int 127int
167main (int argc, char **argv) 128main (int argc, char **argv)
@@ -567,6 +528,7 @@ process_arguments (int argc, char **argv)
567 break; 528 break;
568 case 'A': 529 case 'A':
569 authtype = optarg; 530 authtype = optarg;
531 use_ehlo = TRUE;
570 break; 532 break;
571 case 'U': 533 case 'U':
572 authuser = optarg; 534 authuser = optarg;