#include <utils/sha1.hpp>

#include <biboumi.h>

#ifdef BOTAN_FOUND
# include <botan/version.h>
# include <botan/hash.h>
# include <botan/hex.h>
# include <botan/exceptn.h>
#endif
#ifdef GCRYPT_FOUND
# include <gcrypt.h>
# include <vector>
# include <iomanip>
# include <sstream>
#endif

std::string sha1(const std::string& input)
{
#ifdef BOTAN_FOUND
  auto sha1 = Botan::HashFunction::create_or_throw("SHA-1");
  sha1->update(input);
  return Botan::hex_encode(sha1->final(), false);
#endif
#ifdef GCRYPT_FOUND
  const auto hash_length = gcry_md_get_algo_dlen(GCRY_MD_SHA1);
  std::vector<uint8_t> output(hash_length, {});
  gcry_md_hash_buffer(GCRY_MD_SHA1, output.data(), input.data(), input.size());
  std::ostringstream digest;
  for (std::size_t i = 0; i < hash_length; i++)
    digest << std::hex << std::setfill('0') << std::setw(2) << static_cast<int>(output[i]);
  return digest.str();
#endif
}