// file      : butl/base64 -*- C++ -*-
// copyright : Copyright (c) 2014-2017 Code Synthesis Ltd
// license   : MIT; see accompanying LICENSE file

#ifndef BUTL_BASE64
#define BUTL_BASE64

#include <iosfwd>
#include <string>
#include <vector>

#include <butl/export>

namespace butl
{
  // Base64-encode a stream or a buffer. Split the output into 76 char-long
  // lines (new line is the 77th). If reading from a stream, check if it has
  // badbit, failbit, or eofbit set and throw invalid_argument if that's the
  // case. Otherwise, set eofbit on completion. If writing to a stream, check
  // if it has badbit, failbit, or eofbit set and throw invalid_argument if
  // that's the case. Otherwise set badbit if the write operation fails.
  //
  LIBBUTL_EXPORT void
  base64_encode (std::ostream&, std::istream&);

  LIBBUTL_EXPORT std::string
  base64_encode (std::istream&);

  LIBBUTL_EXPORT std::string
  base64_encode (const std::vector<char>&);

  // Base64-decode a stream or a string. Throw invalid_argument if the input
  // is not a valid base64 representation. If reading from a stream, check if
  // it has badbit, failbit, or eofbit set and throw invalid_argument if
  // that's the case. Otherwise, set eofbit on completion. If writing to a
  // stream, check if it has badbit, failbit, or eofbit set and throw
  // invalid_argument if that's the case. Otherwise set badbit if the write
  // operation fails.
  //
  LIBBUTL_EXPORT void
  base64_decode (std::ostream&, std::istream&);

  LIBBUTL_EXPORT void
  base64_decode (std::ostream&, const std::string&);

  LIBBUTL_EXPORT std::vector<char>
  base64_decode (const std::string&);
};

#endif // BUTL_BASE64