lambroslambrou@chromium.org | 0d2c4aa | 2012-05-18 03:34:59 +0900 | [diff] [blame] | 1 | // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
hayato@chromium.org | 268ac3a | 2009-11-24 15:21:53 +0900 | [diff] [blame] | 2 | // Use of this source code is governed by a BSD-style license that can be |
| 3 | // found in the LICENSE file. |
| 4 | |
| 5 | #include "base/base64.h" |
| 6 | |
| 7 | #include "third_party/modp_b64/modp_b64.h" |
| 8 | |
| 9 | namespace base { |
| 10 | |
vadimt@chromium.org | 528238b | 2013-12-11 10:48:50 +0900 | [diff] [blame] | 11 | void Base64Encode(const StringPiece& input, std::string* output) { |
hayato@chromium.org | 268ac3a | 2009-11-24 15:21:53 +0900 | [diff] [blame] | 12 | std::string temp; |
| 13 | temp.resize(modp_b64_encode_len(input.size())); // makes room for null byte |
| 14 | |
lambroslambrou@chromium.org | 0d2c4aa | 2012-05-18 03:34:59 +0900 | [diff] [blame] | 15 | // modp_b64_encode_len() returns at least 1, so temp[0] is safe to use. |
vadimt@chromium.org | 528238b | 2013-12-11 10:48:50 +0900 | [diff] [blame] | 16 | size_t output_size = modp_b64_encode(&(temp[0]), input.data(), input.size()); |
hayato@chromium.org | 268ac3a | 2009-11-24 15:21:53 +0900 | [diff] [blame] | 17 | |
| 18 | temp.resize(output_size); // strips off null byte |
| 19 | output->swap(temp); |
hayato@chromium.org | 268ac3a | 2009-11-24 15:21:53 +0900 | [diff] [blame] | 20 | } |
| 21 | |
joth@chromium.org | 42544c8 | 2011-07-22 22:22:23 +0900 | [diff] [blame] | 22 | bool Base64Decode(const StringPiece& input, std::string* output) { |
hayato@chromium.org | 268ac3a | 2009-11-24 15:21:53 +0900 | [diff] [blame] | 23 | std::string temp; |
| 24 | temp.resize(modp_b64_decode_len(input.size())); |
| 25 | |
| 26 | // does not null terminate result since result is binary data! |
jschuh@chromium.org | 98976a6 | 2012-12-28 07:01:58 +0900 | [diff] [blame] | 27 | size_t input_size = input.size(); |
| 28 | size_t output_size = modp_b64_decode(&(temp[0]), input.data(), input_size); |
| 29 | if (output_size == MODP_B64_ERROR) |
hayato@chromium.org | 268ac3a | 2009-11-24 15:21:53 +0900 | [diff] [blame] | 30 | return false; |
| 31 | |
| 32 | temp.resize(output_size); |
| 33 | output->swap(temp); |
| 34 | return true; |
| 35 | } |
| 36 | |
| 37 | } // namespace base |