-
Notifications
You must be signed in to change notification settings - Fork 17
/
Copy pathcotp.h
115 lines (88 loc) · 2.84 KB
/
cotp.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
#pragma once
#include <stdlib.h>
#include <stdint.h>
// OTPRESULT can either be 1 (success) or 0 (error)
typedef int COTPRESULT;
#define OTP_OK ((COTPRESULT) 1)
#define OTP_ERROR ((COTPRESULT) 0)
/*
Default characters used in BASE32 digests.
For use with otp_random_base32()
*/
static const char OTP_DEFAULT_BASE32_CHARS[32] =
{
'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J',
'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T',
'U', 'V', 'W', 'X', 'Y', 'Z', '2', '3', '4', '5',
'6', '7'
};
/*
Used for differentiation on which
method you are using. Necessary
when you go to generate a URI.
*/
typedef enum OTPType
{
OTP, TOTP, HOTP
} OTPType;
const char* OTPType_asString(OTPType type);
/*
Must compute HMAC using passed arguments,
output as char array through output.
key is base32 secret key.
input is input number as string.
output is an output char buffer of the resulting HMAC operation.
Must return 0 if error, or the length in bytes of the HMAC operation.
*/
typedef int (*COTP_ALGO)(const char* key, int key_length, const char* input, char* output);
/*
Must return the current time in seconds.
*/
typedef uint64_t (*COTP_TIME)();
/*
Holds data for use by the cotp module.
If you know what you are doing,
feel free to initialize this yourself.
*/
typedef struct OTPData
{
uint32_t digits;
uint32_t interval; // TOTP exclusive
uint64_t count;
OTPType method;
COTP_ALGO algo;
COTP_TIME time;
const char* base32_secret;
} OTPData;
/*
Struct initialization functions
*/
OTPData* otp_new(OTPData* data, const char* base32_secret, COTP_ALGO algo, uint32_t digits);
OTPData* totp_new(OTPData* data, const char* base32_secret, COTP_ALGO algo, COTP_TIME time, uint32_t digits, uint32_t interval);
OTPData* hotp_new(OTPData* data, const char* base32_secret, COTP_ALGO algo, uint32_t digits, uint64_t count);
/*
OTP free function
*/
void otp_free(OTPData* data);
/*
OTP functions
*/
COTPRESULT otp_generate(OTPData* data, uint64_t input, char* out_str);
COTPRESULT otp_byte_secret(OTPData* data, char* out_str);
COTPRESULT otp_num_to_bytestring(uint64_t integer, char* out_str);
COTPRESULT otp_random_base32(size_t len, char* out_str);
/*
TOTP functions
*/
COTPRESULT totp_compare(OTPData* data, const char* key, int64_t offset, uint64_t for_time);
COTPRESULT totp_at(OTPData* data, uint64_t for_time, int64_t offset, char* out_str);
COTPRESULT totp_now(OTPData* data, char* out_str);
COTPRESULT totp_verify(OTPData* data, const char* key, uint64_t for_time, int64_t valid_window);
uint64_t totp_valid_until(OTPData* data, uint64_t for_time, int64_t valid_window);
uint64_t totp_timecode(OTPData* data, uint64_t for_time);
/*
HOTP functions
*/
COTPRESULT hotp_compare(OTPData* data, const char* key, uint64_t counter);
COTPRESULT hotp_at(OTPData* data, uint64_t counter, char* out_str);
COTPRESULT hotp_next(OTPData* data, char* out_str);