blob: b496af78286ab1cf17e3dd22bb72d440366868a3 [file] [log] [blame] [edit]
// Copyright (c) 2012 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "base/base64.h"
#include "third_party/modp_b64/modp_b64.h"
namespace base {
bool Base64Encode(const StringPiece& input, std::string* output) {
std::string temp;
temp.resize(modp_b64_encode_len(input.size())); // makes room for null byte
// null terminates result since result is base64 text!
int input_size = static_cast<int>(input.size());
// modp_b64_encode_len() returns at least 1, so temp[0] is safe to use.
int output_size = modp_b64_encode(&(temp[0]), input.data(), input_size);
if (output_size < 0)
return false;
temp.resize(output_size); // strips off null byte
output->swap(temp);
return true;
}
template <class Container>
bool Base64DecodeInternal(const StringPiece& input, Container* output) {
Container temp;
temp.resize(modp_b64_decode_len(input.size()));
int input_size = static_cast<int>(input.size());
// When using this template for a new type, make sure its content is unsigned
// char or char.
static_assert(sizeof(typename Container::value_type) == 1,
"Input type should be char or equivalent.");
int output_size = modp_b64_decode(reinterpret_cast<char*>(&(temp[0])),
input.data(), input_size);
if (output_size < 0)
return false;
temp.resize(output_size);
output->swap(temp);
return true;
}
bool Base64Decode(const StringPiece& input, std::string* output) {
return Base64DecodeInternal(input, output);
}
bool Base64Decode(const StringPiece& input, std::vector<uint8_t>* output) {
return Base64DecodeInternal(input, output);
}
} // namespace base