mail/src/js/crypto/pbkdf2.js

25 lines
745 B
JavaScript
Raw Normal View History

2013-04-02 09:02:57 -04:00
/**
2013-05-14 06:01:51 -04:00
* A Wrapper for Forge's PBKDF2 function
2013-04-02 09:02:57 -04:00
*/
2014-06-05 09:26:19 -04:00
define(['forge'], function(forge) {
'use strict';
2013-03-13 11:58:46 -04:00
var self = {};
2013-06-10 17:07:29 -04:00
/**
* PBKDF2-HMAC-SHA256 key derivation with a random salt and 10000 iterations
2014-06-05 09:26:19 -04:00
* @param {String} password The password in UTF8
* @param {String} salt The base64 encoded salt
* @param {String} keySize The key size in bits
* @return {String} The base64 encoded key
*/
self.getKey = function(password, salt, keySize) {
2014-06-05 09:26:19 -04:00
var saltUtf8 = forge.util.decode64(salt);
var md = forge.md.sha256.create();
var key = forge.pkcs5.pbkdf2(password, saltUtf8, 10000, keySize / 8, md);
2014-06-05 09:26:19 -04:00
return forge.util.encode64(key);
};
return self;
2014-06-05 09:26:19 -04:00
});