Package Exports
- otpauth
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (otpauth) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
OTPAuth
One Time Password (HOTP/TOTP) library for Node.js and browser.
Installation
Install the module via npm
.
$ npm install otpauth
Usage
Node.js
const OTPAuth = require('otpauth');
let totp = new OTPAuth.TOTP({
'issuer': 'ACME',
'label': 'AzureDiamond',
'algorithm': 'SHA1',
'digits': 6,
'period': 30,
'secret': OTPAuth.Secret.fromB32('NB2W45DFOIZA')
});
// Generate TOTP token
let token = totp.generate();
// Validate TOTP token
let delta = totp.validate({
'token': token,
'window': 10
});
// Convert to Google Authenticator key URI
// otpauth://totp/ACME:AzureDiamond?issuer=ACME&secret=NB2W45DFOIZA&algorithm=SHA1&digits=6&period=30
let uri = totp.toString();
Browser
<script src="otpauth.min.js"></script>
<script>
// Same as above...
</script>
Supported hashing algorithms
In Node.js, the same algorithms as Crypto.createHmac
function are supported, since it is used internally.
In browsers, the SHA1
, SHA256
and SHA512
algorithms are supported by using the Stanford Javascript Crypto Library.
Documentation
See the documentation page.