new TOTP()
Classe que agrupa funções de geração e verificação de senhas de uso único baseadas em tempo TOTP (Time-based One-Time Password), conforme RFC 6238.
As chaves informadas nos métodos desta classe devem ser uma sequência de bytes aleatórios ou devem ser geradas por algoritmos de derivação de chaves para fins criptográficos. Elas devem ter um tamanho adequado para o algoritmo de hash adotado e devem ser mantidas em segredo, devendo ser compartilhadas apenas com o gerador e o verificador de senhas.
Esta classe trata as strings como se fossem uma sequência de bytes no formato conhecido
como "Binary String", onde cada caractere da string representa um byte do conteúdo binário. É
importante observar que a codificação adotada pode ser diferente em outras plataformas, como o
Node.js. Para garantir compatibilidade com as senhas geradas por outras plataformas, prefira
sempre informar valores do tipo Uint8Array
ou ArrayBuffer
, evitando a codificação
implícita das strings.
Example
const TOTP = require('@nginstack/engine/lib/otp/TOTP.js'); const Crypto = require('@nginstack/engine/lib/crypto/Crypto.js'); const secret = Crypto.randomBytes(20, 'uint8array'); const token = TOTP.generate(secret); TOTP.verify(token, secret); // >= true
Methods
-
<static> formatKeyUri(key, userName, issuer [, options])
-
Formata a chave (segredo compartilhado) em uma URI utilizando o esquema otpauth.
Essa URI pode ser codificada em um QRCode para que possa ser aberta por aplicativos autenticadores, como o Google Authenticator ou o Microsoft Authenticator, permitindo que esses aplicativos possam ser utilizados para gerar as senhas de uso único associadas à chave informada.
Parameters:
Name Type Argument Description key
string | Uint8Array | ArrayBuffer Chave única que deve ser mantida em segredo e será utilizada pelo algoritmo HMAC para gerar a senha de uso único.
userName
string Nome do usuário que será autenticado.
issuer
string Identificação do sistema. Caso a chave seja utilizada para autenticar usuários do sistema, é recomendado que o nome da base de dados faça parte da identificação do sistema, pois é comum que um usuário se conecte a mais de uma base de dados, como as de produção, homologação e desenvolvimento.
options
TOTPOptions <optional>
Parâmetros opcionais do algoritmo TOTP.
-
<static> generate(key [, options])
-
Cria uma senha de uso único que pode ser verificada pelo método #verify ou por outros aplicativos que implementem o algoritmo TOTP.
Parameters:
Name Type Argument Description key
string | Uint8Array | ArrayBuffer Chave única que deve ser mantida em segredo e será utilizada pelo algoritmo HMAC para gerar a senha de uso único.
options
TOTPOptions <optional>
Parâmetros opcionais do algoritmo TOTP.
Returns:
Senha de utilização única.
- Type
- string
-
<static> verify(otp, key [, options])
-
Verifica se uma senha de uso único é válida.
É importante garantir que uma senha de uso único verificada por este método não seja reutilizada em mais de uma autenticação, sendo necessário forçar o usuário a aguardar a geração de uma nova senha para realizar uma nova autenticação.
Parameters:
Name Type Argument Description otp
string Senha de uso único que deverá ser verificada.
key
string | Uint8Array | ArrayBuffer Chave única que deve ser mantida em segredo e será utilizada pelo algoritmo HMAC para gerar a senha de uso único.
options
TOTPOptions <optional>
Parâmetros opcionais do algoritmo TOTP.
Returns:
True se a senha informada for válida.
- Type
- boolean