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) {
|
2013-10-09 10:40:36 -04:00
|
|
|
'use strict';
|
2013-03-13 11:58:46 -04:00
|
|
|
|
2013-10-09 10:40:36 -04:00
|
|
|
var self = {};
|
2013-06-10 17:07:29 -04:00
|
|
|
|
2013-10-09 10:40:36 -04:00
|
|
|
/**
|
2014-06-13 06:33:30 -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
|
2013-10-09 10:40:36 -04:00
|
|
|
*/
|
|
|
|
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);
|
2013-04-01 18:12:15 -04:00
|
|
|
|
2014-06-05 09:26:19 -04:00
|
|
|
return forge.util.encode64(key);
|
2013-10-09 10:40:36 -04:00
|
|
|
};
|
2013-04-01 18:12:15 -04:00
|
|
|
|
2013-10-09 10:40:36 -04:00
|
|
|
return self;
|
2014-06-05 09:26:19 -04:00
|
|
|
});
|