X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=src%2Fjs%2Fjsbip39.js;h=025f6258d7d8462427c993b84d94aed9d1483f0c;hb=ab1bd64d52e347000eab584c3a18e107e1cc7f8e;hp=455615a907c26807d842cf7514435b2482fca11e;hpb=7772c641c7f2537246ff268bee725debe52edfd9;p=perso%2FImmae%2FProjets%2FCryptomonnaies%2FBIP39.git diff --git a/src/js/jsbip39.js b/src/js/jsbip39.js index 455615a..025f625 100644 --- a/src/js/jsbip39.js +++ b/src/js/jsbip39.js @@ -93,12 +93,12 @@ var Mnemonic = function(language) { var idx = parseInt(b.substring(i * 11, (i + 1) * 11), 2); result.push(wordlist[idx]); } - return result.join(' '); + return self.joinWords(result); } self.check = function(mnemonic) { - var mnemonic = mnemonic.split(' ') - if (mnemonic.length % 3 > 0) { + var mnemonic = self.splitWords(mnemonic); + if (mnemonic.length == 0 || mnemonic.length % 3 > 0) { return false } // idx = map(lambda x: bin(self.wordlist.index(x))[2:].zfill(11), mnemonic) @@ -130,16 +130,31 @@ var Mnemonic = function(language) { self.toSeed = function(mnemonic, passphrase) { passphrase = passphrase || ''; - mnemonic = self.normalizeString(mnemonic).split(' ').filter(function(x) { return x.length; }).join(' '); + mnemonic = self.joinWords(self.splitWords(mnemonic)); // removes duplicate blanks + var mnemonicNormalized = self.normalizeString(mnemonic); passphrase = self.normalizeString(passphrase) passphrase = "mnemonic" + passphrase; - var mnemonicBits = sjcl.codec.utf8String.toBits(mnemonic); + var mnemonicBits = sjcl.codec.utf8String.toBits(mnemonicNormalized); var passphraseBits = sjcl.codec.utf8String.toBits(passphrase); var result = sjcl.misc.pbkdf2(mnemonicBits, passphraseBits, PBKDF2_ROUNDS, 512, hmacSHA512); var hashHex = sjcl.codec.hex.fromBits(result); return hashHex; } + self.splitWords = function(mnemonic) { + return mnemonic.split(/\s/g).filter(function(x) { return x.length; }); + } + + self.joinWords = function(words) { + // Set space correctly depending on the language + // see https://github.com/bitcoin/bips/blob/master/bip-0039/bip-0039-wordlists.md#japanese + var space = " "; + if (language == "japanese") { + space = "\u3000"; // ideographic space + } + return words.join(space); + } + self.normalizeString = function(str) { if (typeof str.normalize == "function") { return str.normalize("NFKD");