Botan 3.6.1
Crypto and TLS for C&
Botan::TOTP Class Referencefinal

#include <otp.h>

Public Member Functions

uint32_t generate_totp (std::chrono::system_clock::time_point time_point)
 
uint32_t generate_totp (uint64_t unix_time)
 
 TOTP (const SymmetricKey &key, std::string_view hash_algo="SHA-1", size_t digits=6, size_t time_step=30)
 
 TOTP (const uint8_t key[], size_t key_len, std::string_view hash_algo="SHA-1", size_t digits=6, size_t time_step=30)
 
bool verify_totp (uint32_t otp, std::chrono::system_clock::time_point time, size_t clock_drift_accepted=0)
 
bool verify_totp (uint32_t otp, uint64_t unix_time, size_t clock_drift_accepted=0)
 

Detailed Description

TOTP (time based) one time passwords (RFC 6238)

Definition at line 63 of file otp.h.

Constructor & Destructor Documentation

◆ TOTP() [1/2]

Botan::TOTP::TOTP ( const SymmetricKey & key,
std::string_view hash_algo = "SHA-1",
size_t digits = 6,
size_t time_step = 30 )
inline
Parameters
keythe secret key shared between client and server
hash_algothe hash algorithm to use, should be SHA-1, SHA-256 or SHA-512
digitsthe number of digits in the OTP (must be 6, 7, or 8)
time_stepgranularity of OTP in seconds

Definition at line 71 of file otp.h.

71 :
72 TOTP(key.begin(), key.size(), hash_algo, digits, time_step) {}
TOTP(const SymmetricKey &key, std::string_view hash_algo="SHA-1", size_t digits=6, size_t time_step=30)
Definition otp.h:71

◆ TOTP() [2/2]

Botan::TOTP::TOTP ( const uint8_t key[],
size_t key_len,
std::string_view hash_algo = "SHA-1",
size_t digits = 6,
size_t time_step = 30 )
Parameters
keythe secret key shared between client and server
key_lenlength of key
hash_algothe hash algorithm to use, should be SHA-1, SHA-256 or SHA-512
digitsthe number of digits in the OTP (must be 6, 7, or 8)
time_stepgranularity of OTP in seconds

Definition at line 14 of file totp.cpp.

14 :
15 m_hotp(key, key_len, hash_algo, digits),
16 m_time_step(time_step),
17 m_unix_epoch(calendar_point(1970, 1, 1, 0, 0, 0).to_std_timepoint()) {
18 /*
19 * Technically any time step except 0 is valid, but 30 is typical
20 * and over 5 minutes seems unlikely.
21 */
22 BOTAN_ARG_CHECK(m_time_step > 0 && m_time_step < 300, "Invalid TOTP time step");
23}
#define BOTAN_ARG_CHECK(expr, msg)
Definition assert.h:29

References BOTAN_ARG_CHECK.

Member Function Documentation

◆ generate_totp() [1/2]

uint32_t Botan::TOTP::generate_totp ( std::chrono::system_clock::time_point time_point)

Convert the provided time_point to a Unix timestamp and call generate_totp

Definition at line 25 of file totp.cpp.

25 {
26 const uint64_t unix_time = std::chrono::duration_cast<std::chrono::seconds>(current_time - m_unix_epoch).count();
27 return this->generate_totp(unix_time);
28}
uint32_t generate_totp(std::chrono::system_clock::time_point time_point)
Definition totp.cpp:25

References generate_totp().

Referenced by generate_totp().

◆ generate_totp() [2/2]

uint32_t Botan::TOTP::generate_totp ( uint64_t unix_time)

Generate the OTP corresponding the the provided "Unix timestamp" (ie number of seconds since midnight Jan 1, 1970)

Definition at line 30 of file totp.cpp.

30 {
31 return m_hotp.generate_hotp(unix_time / m_time_step);
32}
uint32_t generate_hotp(uint64_t counter)
Definition hotp.cpp:43

References Botan::HOTP::generate_hotp().

◆ verify_totp() [1/2]

bool Botan::TOTP::verify_totp ( uint32_t otp,
std::chrono::system_clock::time_point time,
size_t clock_drift_accepted = 0 )

Definition at line 34 of file totp.cpp.

34 {
35 const uint64_t unix_time = std::chrono::duration_cast<std::chrono::seconds>(current_time - m_unix_epoch).count();
36 return verify_totp(otp, unix_time, clock_drift_accepted);
37}
bool verify_totp(uint32_t otp, std::chrono::system_clock::time_point time, size_t clock_drift_accepted=0)
Definition totp.cpp:34

References verify_totp().

Referenced by verify_totp().

◆ verify_totp() [2/2]

bool Botan::TOTP::verify_totp ( uint32_t otp,
uint64_t unix_time,
size_t clock_drift_accepted = 0 )

Definition at line 39 of file totp.cpp.

39 {
40 uint64_t t = unix_time / m_time_step;
41
42 for(size_t i = 0; i <= clock_drift_accepted; ++i) {
43 if(m_hotp.generate_hotp(t - i) == otp) {
44 return true;
45 }
46 }
47
48 return false;
49}

References Botan::HOTP::generate_hotp().


The documentation for this class was generated from the following files: