oath_totp_validate - Man Page

API function

Synopsis

#include <oath.h>

int oath_totp_validate(const char * secret, size_t secret_length, time_t now, unsigned time_step_size, time_t start_offset, size_t window, const char * otp);

Arguments

const char * secret

the shared secret string

size_t secret_length

length of secret

time_t now

Unix time value to validate TOTP for

unsigned time_step_size

time step system parameter (typically 30)

time_t start_offset

Unix time of when to start counting time steps (typically 0)

size_t window

how many OTPs after/before start OTP to test

const char * otp

the OTP to validate.

Description

Validate an OTP according to OATH TOTP algorithm per RFC 6238.

Currently only OTP lengths of 6, 7 or 8 digits are supported.  This restrictions may be lifted in future versions, although some limitations are inherent in the protocol.

Returns

Returns absolute value of position in OTP window (zero is first position), or OATH_INVALID_OTP if no OTP was found in OTP window, or an error code.

Since

1.6.0

Reporting Bugs

Report bugs to <oath-toolkit-help@nongnu.org>. liboath home page: https://www.nongnu.org/oath-toolkit/ General help using GNU software: http://www.gnu.org/gethelp/

Info

2.6.11 liboath