blob: 42999c39bb279f5d13a5a2cf110ac80e70b6b966 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
|
/* Icinga 2 | (c) 2012 Icinga GmbH | GPLv2+ */
#include "base/base64.hpp"
#include <openssl/bio.h>
#include <openssl/evp.h>
#include <openssl/buffer.h>
#include <sstream>
using namespace icinga;
String Base64::Encode(const String& input)
{
BIO *biomem = BIO_new(BIO_s_mem());
BIO *bio64 = BIO_new(BIO_f_base64());
BIO_push(bio64, biomem);
BIO_set_flags(bio64, BIO_FLAGS_BASE64_NO_NL);
BIO_write(bio64, input.CStr(), input.GetLength());
(void) BIO_flush(bio64);
char *outbuf;
long len = BIO_get_mem_data(biomem, &outbuf);
String ret = String(outbuf, outbuf + len);
BIO_free_all(bio64);
return ret;
}
String Base64::Decode(const String& input)
{
BIO *biomem = BIO_new_mem_buf(
const_cast<char*>(input.CStr()), input.GetLength());
BIO *bio64 = BIO_new(BIO_f_base64());
BIO_push(bio64, biomem);
BIO_set_flags(bio64, BIO_FLAGS_BASE64_NO_NL);
auto *outbuf = new char[input.GetLength()];
size_t len = 0;
int rc;
while ((rc = BIO_read(bio64, outbuf + len, input.GetLength() - len)) > 0)
len += rc;
String ret = String(outbuf, outbuf + len);
BIO_free_all(bio64);
delete [] outbuf;
if (ret.IsEmpty() && !input.IsEmpty())
throw std::invalid_argument("Not a valid base64 string");
return ret;
}
|