aboutsummaryrefslogtreecommitdiff
path: root/node_modules/pbkdf2/index.js
diff options
context:
space:
mode:
Diffstat (limited to 'node_modules/pbkdf2/index.js')
-rw-r--r--node_modules/pbkdf2/index.js32
1 files changed, 27 insertions, 5 deletions
diff --git a/node_modules/pbkdf2/index.js b/node_modules/pbkdf2/index.js
index 205abf08f..fc2f8d96f 100644
--- a/node_modules/pbkdf2/index.js
+++ b/node_modules/pbkdf2/index.js
@@ -1,9 +1,31 @@
-var crypto = require('crypto')
+var checkParameters = require('./lib/precondition')
+var native = require('crypto')
+
+function nativePBKDF2 (password, salt, iterations, keylen, digest, callback) {
+ checkParameters(password, salt, iterations, keylen)
+
+ if (typeof digest === 'function') {
+ callback = digest
+ digest = 'sha1'
+ }
+ if (typeof callback !== 'function') throw new Error('No callback provided to pbkdf2')
+
+ return native.pbkdf2(password, salt, iterations, keylen, digest, callback)
+}
+
+function nativePBKDF2Sync (password, salt, iterations, keylen, digest) {
+ checkParameters(password, salt, iterations, keylen)
+ digest = digest || 'sha1'
+ return native.pbkdf2Sync(password, salt, iterations, keylen, digest)
+}
+
/* istanbul ignore next */
-if (crypto && (!crypto.pbkdf2Sync || crypto.pbkdf2Sync.toString().indexOf('keylen, digest') === -1)) {
- exports.pbkdf2 = require('./lib/async')
+if (!native.pbkdf2Sync || native.pbkdf2Sync.toString().indexOf('keylen, digest') === -1) {
exports.pbkdf2Sync = require('./lib/sync')
+ exports.pbkdf2 = require('./lib/async')
+
+// native
} else {
- exports.pbkdf2Sync = crypto.pbkdf2Sync
- exports.pbkdf2 = crypto.pbkdf2
+ exports.pbkdf2Sync = nativePBKDF2Sync
+ exports.pbkdf2 = nativePBKDF2
}