23#ifndef NODESET_BASE64_H
24#define NODESET_BASE64_H
30static const char *b64 =
31 "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
34static const unsigned char unb64[] = {
35 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
36 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
37 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
38 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
39 0, 0, 0, 62, 0, 0, 0, 63, 52, 53,
40 54, 55, 56, 57, 58, 59, 60, 61, 0, 0,
41 0, 0, 0, 0, 0, 0, 1, 2, 3, 4,
42 5, 6, 7, 8, 9, 10, 11, 12, 13, 14,
43 15, 16, 17, 18, 19, 20, 21, 22, 23, 24,
44 25, 0, 0, 0, 0, 0, 0, 26, 27, 28,
45 29, 30, 31, 32, 33, 34, 35, 36, 37, 38,
46 39, 40, 41, 42, 43, 44, 45, 46, 47, 48,
47 49, 50, 51, 0, 0, 0, 0, 0, 0, 0,
48 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
49 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
50 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
51 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
52 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
53 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
54 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
55 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
56 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
57 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
58 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
59 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
66char *
base64(
const void *binaryData,
int len,
int *flen);
67char *
base64(
const void *binaryData,
int len,
int *flen)
69 const unsigned char *bin = (
const unsigned char *)binaryData;
75 int modulusLen = len % 3;
77 ((modulusLen & 1) << 1) +
78 ((modulusLen & 2) >> 1);
80 *flen = 4 * (len + pad) / 3;
81 res = (
char *)malloc((
size_t)(*flen + 1));
84 puts(
"ERROR: base64 could not allocate enough memory.");
85 puts(
"I must stop because I could not get enough");
89 for (byteNo = 0; byteNo <= len - 3; byteNo += 3)
91 unsigned char BYTE0 = bin[byteNo];
92 unsigned char BYTE1 = bin[byteNo + 1];
93 unsigned char BYTE2 = bin[byteNo + 2];
94 res[rc++] = b64[BYTE0 >> 2];
95 res[rc++] = b64[((0x3 & BYTE0) << 4) + (BYTE1 >> 4)];
96 res[rc++] = b64[((0x0f & BYTE1) << 2) + (BYTE2 >> 6)];
97 res[rc++] = b64[0x3f & BYTE2];
102 res[rc++] = b64[bin[byteNo] >> 2];
103 res[rc++] = b64[(0x3 & bin[byteNo]) << 4];
109 res[rc++] = b64[bin[byteNo] >> 2];
110 res[rc++] = b64[((0x3 & bin[byteNo]) << 4) + (bin[byteNo + 1] >> 4)];
111 res[rc++] = b64[(0x0f & bin[byteNo + 1]) << 2];
118unsigned char *
unbase64(
const char *ascii,
int len,
int *flen);
120unsigned char *
unbase64(
const char *ascii,
int len,
int *flen)
122 unsigned char *safeAsciiPtr;
128 safeAsciiPtr = (
unsigned char *)malloc((
size_t)len);
131 puts(
"ERROR: unbase64 could not allocate enough memory.");
132 puts(
"I must stop because I could not get enough");
136 for (charNo = 0; charNo < len; charNo++)
139 if (!isspace(ascii[charNo]))
141 if (((ascii[charNo] >=
'0') &&
142 (ascii[charNo] <=
'9')) ||
143 ((ascii[charNo] >=
'A') &&
144 (ascii[charNo] <=
'Z')) ||
145 ((ascii[charNo] >=
'a') &&
146 (ascii[charNo] <=
'z')) ||
147 (ascii[charNo] ==
'+') ||
148 (ascii[charNo] ==
'/') ||
149 (ascii[charNo] ==
'='))
151 safeAsciiPtr[cb++] = (
unsigned char)ascii[charNo];
155 puts(
"ERROR: You passed an invalid base64 string (illegal character). "
156 "You get NULL back.");
168 puts(
"ERROR: You passed an invalid base64 string (too short). You get "
174 if (safeAsciiPtr[len - 1] ==
'=')
176 if (safeAsciiPtr[len - 2] ==
'=')
179 *flen = 3 * len / 4 - pad;
180 bin = (
unsigned char *)malloc((
size_t)*flen);
183 puts(
"ERROR: unbase64 could not allocate enough memory.");
184 puts(
"I must stop because I could not get enough");
190 for (charNo = 0; charNo <= len - 4 - pad; charNo += 4)
192 unsigned char A = unb64[safeAsciiPtr[charNo]];
193 unsigned char B = unb64[safeAsciiPtr[charNo + 1]];
194 unsigned char C = unb64[safeAsciiPtr[charNo + 2]];
195 unsigned char D = unb64[safeAsciiPtr[charNo + 3]];
197 bin[cb++] = (
unsigned char)(A << 2) | (B >> 4);
198 bin[cb++] = (
unsigned char)(B << 4) | (C >> 2);
199 bin[cb++] = (
unsigned char)(C << 6) | (D);
202 if (pad == 1 && (charNo + 2) < len)
204 unsigned char A = unb64[safeAsciiPtr[charNo]];
205 unsigned char B = unb64[safeAsciiPtr[charNo + 1]];
206 unsigned char C = unb64[safeAsciiPtr[charNo + 2]];
208 bin[cb++] = (
unsigned char)(A << 2) | (B >> 4);
209 bin[cb++] = (
unsigned char)(B << 4) | (C >> 2);
211 else if (pad == 2 && (charNo + 1) < len)
213 unsigned char A = (
unsigned char)unb64[safeAsciiPtr[charNo]];
214 unsigned char B = (
unsigned char)unb64[safeAsciiPtr[charNo + 1]];
216 bin[cb++] = (
unsigned char)(A << 2) | (B >> 4);
unsigned char * unbase64(const char *ascii, int len, int *flen)
char * base64(const void *binaryData, int len, int *flen)