7 #ifndef BOTAN_PBKDF_BCRYPT_H_
8 #define BOTAN_PBKDF_BCRYPT_H_
10 #include <botan/pwdhash.h>
31 const char* password,
size_t password_len,
32 const uint8_t salt[],
size_t salt_len)
const override;
36 size_t iterations()
const override {
return m_iterations; }
53 std::string
name()
const override;
55 std::unique_ptr<PasswordHash>
tune(
size_t output_length,
56 std::chrono::milliseconds msec,
57 size_t max_memory)
const override;
61 std::unique_ptr<PasswordHash>
from_iterations(
size_t iter)
const override;
64 size_t i,
size_t,
size_t)
const override;
71 const char* pass,
size_t pass_len,
72 const uint8_t salt[],
size_t salt_len,
#define BOTAN_UNSTABLE_API
virtual std::unique_ptr< PasswordHash > tune(size_t output_length, std::chrono::milliseconds msec, size_t max_memory_usage_mb=0) const =0
void bcrypt_pbkdf(uint8_t output[], size_t output_len, const char *pass, size_t pass_len, const uint8_t salt[], size_t salt_len, size_t rounds)
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
size_t parallelism() const override
int(* final)(unsigned char *, CTX *)
#define BOTAN_PUBLIC_API(maj, min)
size_t total_memory_usage() const override
size_t iterations() const override
virtual std::unique_ptr< PasswordHash > from_iterations(size_t iterations) const =0
Bcrypt_PBKDF(size_t iterations)
virtual std::string to_string() const =0
size_t memory_param() const override
virtual std::unique_ptr< PasswordHash > default_params() const =0
virtual std::string name() const =0
#define BOTAN_FUTURE_INTERNAL_HEADER(hdr)
virtual std::unique_ptr< PasswordHash > from_params(size_t i1, size_t i2=0, size_t i3=0) const =0