7#ifndef BOTAN_PBKDF_BCRYPT_H_ 
    8#define BOTAN_PBKDF_BCRYPT_H_ 
   10#include <botan/pwdhash.h> 
   32                      size_t salt_len) 
const override;
 
   36      size_t iterations()
 const override { 
return m_iterations; }
 
 
   52      std::string 
name() 
const override;
 
   54      std::unique_ptr<PasswordHash> 
tune(
size_t output_length,
 
   55                                         std::chrono::milliseconds msec,
 
   57                                         std::chrono::milliseconds tune_msec) 
const override;
 
   61      std::unique_ptr<PasswordHash> 
from_iterations(
size_t iterations) 
const override;
 
   63      std::unique_ptr<PasswordHash> 
from_params(
size_t iterations, 
size_t , 
size_t ) 
const override;
 
 
   79   auto pwdhash = pwdhash_fam->from_params(rounds);
 
   80   pwdhash->derive_key(output, output_len, password, password_len, salt, salt_len);
 
 
#define BOTAN_PUBLIC_API(maj, min)
 
#define BOTAN_FUTURE_INTERNAL_HEADER(hdr)
 
#define BOTAN_DEPRECATED(msg)
 
#define BOTAN_FUTURE_EXPLICIT
 
std::unique_ptr< PasswordHash > from_iterations(size_t iterations) const override
 
Bcrypt_PBKDF_Family()=default
 
std::unique_ptr< PasswordHash > from_params(size_t iterations, size_t, size_t) const override
 
std::unique_ptr< PasswordHash > default_params() const override
 
std::unique_ptr< PasswordHash > tune(size_t output_length, std::chrono::milliseconds msec, size_t max_memory, std::chrono::milliseconds tune_msec) const override
 
std::string name() const override
 
size_t iterations() const override
 
size_t total_memory_usage() const override
 
size_t parallelism() const override
 
size_t memory_param() const override
 
BOTAN_FUTURE_EXPLICIT Bcrypt_PBKDF(size_t iterations)
 
static std::unique_ptr< PasswordHashFamily > create_or_throw(std::string_view algo_spec, std::string_view provider="")
 
virtual void derive_key(uint8_t out[], size_t out_len, const char *password, size_t password_len, const uint8_t salt[], size_t salt_len) const =0
 
virtual std::string to_string() const =0
 
void bcrypt_pbkdf(uint8_t output[], size_t output_len, const char *password, size_t password_len, const uint8_t salt[], size_t salt_len, size_t rounds)