one-time-password

module
v0.0.1 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Feb 22, 2021 License: MIT

README

one-time-password

Provides the following features

  • Generate otpauth URI
  • HMAC-based One-time Password (HOTP) (RFC4226)
  • Time-based One-time Password (TOTP) (RFC6238)
  • Generate recovery codes

Usage

Generate otpauth URI

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
//  
HMAC-based One-time Password (HOTP)

simple use case

func main() {
    secret := "RGUIO25EXLPPMEBDHND67342HNY6UJRD"
    counter := 1

    otp, err := hotp.GeneratePasscode(secret, counter)
    if err != nil {
        panic(err)
    }
    
    fmt.Println(otp)
}

// 728019
Time-based One-time Password (TOTP)

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
Generate recovery codes

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

License

MIT

Directories

Path Synopsis
sample

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL