Skip to content

Test code to get an OPAQUE login system working in Typescript using the libsodium-sumo library

License

Notifications You must be signed in to change notification settings

backupbrain/opaque-libsodium-sumo-typescript

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

12 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

OPAQUE-KE Tests in Typescript and Libsodium

OPAQUE is a way for users to type their username and password to log into a website, but then log in without sending their password across the Internet.

It uses a key-derivation function to facilitate a secure key-exchange between the client and server.

How it works

Registration

When you register, the server generates and sends a public key to the client. This acts as a pseudo-random number.

On the client side, the user's password is combined with the public key and the generated public key to derive an encryption private key.

This private key then encrypts some session data that will become important for login. The encrypted data is sent to the server for safe keeping.

The server generates information required to set up it's half of a key exchange that will be used to talk to create a secure communication channel with the client.

Login

When the client logs in, the server sends the same public key to the client. The client uses this and the password to generate the encryption private key.

The server sends the encrypted data from the registration and the user decrypts it using the derived private key.

The descrypted packet contains the other half of the session keys used to create a secure channel with the server.

Setup

Install modules

$ npm install -g jest ts-node
$ npm install

Running

$ npm run demo

This runs the src/demo.ts script, which runs a series of registration and login tests, including:

  • Register (OPAQUE)
  • Successful login (key exchange)
  • Unauthorized login attempt

Running Tests

$ npm test

This runs the tests/opaque.test.ts script, which runs a series of registration and login tests.

More information

OPAQUE: An Asymmetric PAKE Protocol Secure Against Pre-Computation Attacks

The OPAQUE Asymmetric PAKE Protocol (draft-irtf-cfrg-opaque-09)

WASM / Typescript Impelementation

About

Test code to get an OPAQUE login system working in Typescript using the libsodium-sumo library

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published