- Generate
otpauth
URI - HMAC-based One-time Password (HOTP) (RFC4226)
- Time-based One-time Password (TOTP) (RFC6238)
- Generate recovery codes
simple use case
func main() {
issuer := "butter_company"
accountName := "butter@example.com"
host := otpauth.HostTOTP
oa, err := otpauth.GenerateOtpAuth(issuer, accountName, host)
if err != nil {
panic(err)
}
fmt.Println(oa.URL())
fmt.Println(oa.QRCode())
}
// otpauth://hotp/butter_company:butter@example.com?algorithm=SHA1&digits=6&issuer=butter_company&period=30&secret=RGUIO25EXLPPMEBDHND67342HNY6UJRD
// 
simple use case
func main() {
secret := "RGUIO25EXLPPMEBDHND67342HNY6UJRD"
counter := 1
otp, err := hotp.GeneratePasscode(secret, counter)
if err != nil {
panic(err)
}
fmt.Println(otp)
}
// 728019
simple use case
func main() {
passcode := "123456"
secret := "RGUIO25EXLPPMEBDHND67342HNY6UJRD"
now := time.Now()
ok, err := totp.Validate(passcode, secret, now)
if err != nil {
panic(err)
}
fmt.Println(ok)
}
// false
simple use case
func main() {
codes, err := recovery.GenerateRecoveryCodes()
if err != nil {
panic(err)
}
for _, code := range codes {
fmt.Println(code)
}
}
// zFXfrWdZ
// djyHvDve
// hxGRMHtt
// cPv0C0WR