family-friendly-diceware

1.2.0 • Public • Published

A simple diceware module

CircleCI

family-friendly-diceware generates easily sharable ids using the the EFF's family friendly diceware list.

This package intended for creation of easy to distribute UUID's, so we provide some backwards functionality (phrase to integer index).

As this is meant to be use with user input, attempts to normalize and correct obvious errors are made. For example, phrase_to_id begins with a simple case and spacing normalization, then proceeds to call upon an optional fixer function (implemented for example via levenshein distance) to correct for more complex errors.

npm install family-friendly-diceware
diceware = require('family-friendly-diceware');
 
diceware.make_phrase_with_id()
> { phrase: 'turtle astride porous', id: '286370444755' }
 
diceware.clean_phrase('turtle astride porous')
> 'turtle astride porous'
 
diceware.clean_phrase('  turtle AStride  porous  ')
> 'turtle astride porous'
 
diceware.clean_phrase('turtal astride porous', function fixer(str) {
  if (str == 'turtal') return Promise.resolve('turtle'); // a real fixer should follow same convention of returning closest string
}).then(val => console.log(val));
> 'turtle astride porous'

Example fixer (assume words is a table containing all words of a give diceware wordlist):

CREATE OR REPLACE FUNCTION closest_diceware(input_str text) RETURNS text AS
$$
SELECT * FROM words WHERE levenshtein(input_str, word) < 3
                    ORDER BY levenshtein(input_str, word)
                    LIMIT 1;
$$ LANGUAGE SQL;

Dependencies (0)

    Dev Dependencies (2)

    Package Sidebar

    Install

    npm i family-friendly-diceware

    Weekly Downloads

    0

    Version

    1.2.0

    License

    none

    Last publish

    Collaborators

    • jkearl