Skip to content

Latest commit

 

History

History
21 lines (12 loc) · 2.23 KB

README.md

File metadata and controls

21 lines (12 loc) · 2.23 KB

mpw-js

mpw-js is a JavaScript + Web Crypto implementation of the Master Password App (Lyndir/MasterPassword) algorithm (http://masterpasswordapp.com/algorithm.html).

mpw-js relies on window.crypto.subtle when it is avaliable on modern browser but will fallback to using crypto-js. It is written in ES6 JS but is transpiled to ES5 JS for browsers that do not yet support ES6 JS. It is purely intended as a proof-of-concept.

The MPW constructor constructor(name, password) accepts two mandatory arguments; .name is set to the argument name and both name and password are subsequently passed to calculateKey, .key being set to the result.

The MPW class implements static calculateKey(name, password) which is an implementation of step 1 of the algorithm, Calculate the master key from a user's name and master password, it accepts two mandatory arguments, the users full name and the users master password; calculateKey is invoked automatically by the constructor.

MPW also implements calculateSeed(site, counter = 0), an implementation of step 2 of the algorithm, Calculate the template seed from the site's name and counter, it accepts two arguments, the name of the site -- potentially it's FQDN -- and a counter -- This is an integer that can be incremented when the user needs a new password for the site; calculateSeed is invoked automatically by generate.

MPW implements generate(site, counter = 0, template = "long") which is an implementation of step 3 of the algorithm, Encode a site password using the site's type template, it accepts three arguments, the name of the site -- potentially it's FQDN -- and a counter -- This is an integer that can be incremented when the user needs a new password for the site. -- which are passed to calculateSeed, and template which refers to any of the 'Password Type Templates' supported by the algorithm -- maximum, long, medium, short, basic or pin.

MPW finally implements invalidate() which sets .key to a Promise.reject, preventing further access to the non-exportable key.

Dependencies

npm install -g traceur