Issue #8 - Added 'betterrand' key generator which bases the key around the current time rather than a series of random values
This commit is contained in:
parent
6c31389327
commit
8b112cc257
|
@ -0,0 +1,53 @@
|
||||||
|
/*
|
||||||
|
The current timestamp is sha1 hashed, then that hash value is converted
|
||||||
|
into a number system represented by a 'legible' alphabet.
|
||||||
|
|
||||||
|
This provides several enhancements over the default random keygen.
|
||||||
|
1) Keys are unlikely to collide due to using timestamp as seed
|
||||||
|
2) Keys will display more entropy due to sha1-hashing
|
||||||
|
3) Similar-looking letters have been removed from alphabet
|
||||||
|
*/
|
||||||
|
|
||||||
|
var crypto = require('crypto');
|
||||||
|
|
||||||
|
// the alphabet is separated this way so when we convert hex to this system,
|
||||||
|
// we can have some manner of style, like upper case, followed by 2 lower case, etc.
|
||||||
|
var code = ['ABCDEFGHJKMNPRSTWXYZ',
|
||||||
|
'abcdefhkmnprstwxyz',
|
||||||
|
/*'abcdefhkmnprstwxyz',
|
||||||
|
'0123456789'*/];
|
||||||
|
|
||||||
|
function sha1(str) {
|
||||||
|
var hash = crypto.createHash('sha1');
|
||||||
|
hash.update(str);
|
||||||
|
return hash.digest('hex');
|
||||||
|
}
|
||||||
|
|
||||||
|
function convertNumberToLegible(n) {
|
||||||
|
var legible = '';
|
||||||
|
var codeIndex = 0;
|
||||||
|
var alphabet = code[codeIndex];
|
||||||
|
while (n > 0) {
|
||||||
|
var c = n % alphabet.length;
|
||||||
|
n = Math.floor(n / alphabet.length);
|
||||||
|
legible += alphabet.charAt(c);
|
||||||
|
codeIndex = (codeIndex+1) % code.length;
|
||||||
|
alphabet = code[codeIndex];
|
||||||
|
}
|
||||||
|
return legible;
|
||||||
|
}
|
||||||
|
|
||||||
|
function createKey(keyLength) {
|
||||||
|
// process.hrtime() gives more precision (nanoseconds?) than new Date().getTime() (milliseconds)
|
||||||
|
var time = process.hrtime().join('');
|
||||||
|
var sha1Hex= sha1(time).substring(0, 8);
|
||||||
|
var key = convertNumberToLegible(parseInt(sha1Hex, 16));
|
||||||
|
if (key.length > keyLength) {
|
||||||
|
return key.substring(0, keyLength);
|
||||||
|
}
|
||||||
|
return key;
|
||||||
|
};
|
||||||
|
|
||||||
|
var UniqueRandomKeyGenerator = function() {};
|
||||||
|
UniqueRandomKeyGenerator.prototype.createKey = createKey;
|
||||||
|
module.exports = UniqueRandomKeyGenerator;
|
Loading…
Reference in New Issue