totp-generator
Version:
Generate TOTP tokens from key
67 lines (45 loc) • 2.43 kB
Markdown
# totp-generator
[](https://github.com/bellstrand/totp-generator/actions?query=workflow%3ATest)
[](https://www.npmjs.com/package/totp-generator)
totp-generator lets you generate TOTP tokens from a TOTP key
## How to use
```javascript
import { TOTP } from "totp-generator"
// Keys provided must be base32 strings, ie. only containing characters matching (A-Z, 2-7, =).
const { otp, expires } = await TOTP.generate("JBSWY3DPEHPK3PXP")
console.log(otp) // prints a 6-digit time-based token based on provided key and current time
```
## Default token settings
- SHA-1
- 30-second epoch interval
- 6-digit tokens
## Custom token settings
Settings can be provided as an optional second parameter:
```javascript
import { TOTP } from "totp-generator"
const { otp } = await TOTP.generate("JBSWY3DPEHPK3PXP", { digits: 8 })
console.log(otp) // prints an 8-digit token
const { otp } = await TOTP.generate("JBSWY3DPEHPK3PXP", { digits: 8, explicitZeroPad: true })
console.log(otp) // prints an 8-digit token (with explicit zero padding to always be 8 digits long)
const { otp } = await TOTP.generate("JBSWY3DPEHPK3PXP", { algorithm: "SHA-512" })
console.log(otp) // prints a token created using a different algorithm
const { otp } = await TOTP.generate("JBSWY3DPEHPK3PXP", { period: 60 })
console.log(otp) // prints a token using a 60-second epoch interval
const { otp } = await TOTP.generate("JBSWY3DPEHPK3PXP", { timestamp: 1465324707000 })
console.log(otp) // prints a token for given time
const { otp } = await TOTP.generate("JBSWY3DPEHPK3PXP", {
digits: 8,
algorithm: "SHA-512",
period: 60,
timestamp: 1465324707000,
})
console.log(otp) // prints a token using all custom settings combined
```
## What do I use this library for?
- TOTP generation
- E2E tests (where you need to login with 2-factor authentication)
## 💥 Breaking Changes in v2.0.0
The generate() method has been refactored to be asynchronous. This was done by replacing the external jssha library with the native Web Crypto API, which is more secure and performant.
| Before (v1.x.x) | After (v2.0.0) |
| --------------------------------- | --------------------------------------- |
| `const token = generate(secret);` | `const token = await generate(secret);` |