1
0
Fork 0
management/front/dkha-web-sz-main/node_modules/pbkdf2/lib/async.js

119 lines
2.9 KiB
JavaScript
Raw Normal View History

2024-01-16 21:26:16 +08:00
var Buffer = require('safe-buffer').Buffer
2023-12-18 13:12:25 +08:00
var checkParameters = require('./precondition')
var defaultEncoding = require('./default-encoding')
var sync = require('./sync')
2024-01-16 21:26:16 +08:00
var toBuffer = require('./to-buffer')
2023-12-18 13:12:25 +08:00
var ZERO_BUF
var subtle = global.crypto && global.crypto.subtle
var toBrowser = {
2024-01-16 21:26:16 +08:00
sha: 'SHA-1',
2023-12-18 13:12:25 +08:00
'sha-1': 'SHA-1',
2024-01-16 21:26:16 +08:00
sha1: 'SHA-1',
sha256: 'SHA-256',
2023-12-18 13:12:25 +08:00
'sha-256': 'SHA-256',
2024-01-16 21:26:16 +08:00
sha384: 'SHA-384',
2023-12-18 13:12:25 +08:00
'sha-384': 'SHA-384',
'sha-512': 'SHA-512',
2024-01-16 21:26:16 +08:00
sha512: 'SHA-512'
2023-12-18 13:12:25 +08:00
}
var checks = []
function checkNative (algo) {
if (global.process && !global.process.browser) {
return Promise.resolve(false)
}
if (!subtle || !subtle.importKey || !subtle.deriveBits) {
return Promise.resolve(false)
}
if (checks[algo] !== undefined) {
return checks[algo]
}
ZERO_BUF = ZERO_BUF || Buffer.alloc(8)
var prom = browserPbkdf2(ZERO_BUF, ZERO_BUF, 10, 128, algo)
.then(function () {
return true
}).catch(function () {
return false
})
checks[algo] = prom
return prom
}
2024-01-16 21:26:16 +08:00
var nextTick
function getNextTick () {
if (nextTick) {
return nextTick
}
if (global.process && global.process.nextTick) {
nextTick = global.process.nextTick
} else if (global.queueMicrotask) {
nextTick = global.queueMicrotask
} else if (global.setImmediate) {
nextTick = global.setImmediate
} else {
nextTick = global.setTimeout
}
return nextTick
}
2023-12-18 13:12:25 +08:00
function browserPbkdf2 (password, salt, iterations, length, algo) {
return subtle.importKey(
2024-01-16 21:26:16 +08:00
'raw', password, { name: 'PBKDF2' }, false, ['deriveBits']
2023-12-18 13:12:25 +08:00
).then(function (key) {
return subtle.deriveBits({
name: 'PBKDF2',
salt: salt,
iterations: iterations,
hash: {
name: algo
}
}, key, length << 3)
}).then(function (res) {
return Buffer.from(res)
})
}
function resolvePromise (promise, callback) {
promise.then(function (out) {
2024-01-16 21:26:16 +08:00
getNextTick()(function () {
2023-12-18 13:12:25 +08:00
callback(null, out)
})
}, function (e) {
2024-01-16 21:26:16 +08:00
getNextTick()(function () {
2023-12-18 13:12:25 +08:00
callback(e)
})
})
}
module.exports = function (password, salt, iterations, keylen, digest, callback) {
if (typeof digest === 'function') {
callback = digest
digest = undefined
}
digest = digest || 'sha1'
var algo = toBrowser[digest.toLowerCase()]
if (!algo || typeof global.Promise !== 'function') {
2024-01-16 21:26:16 +08:00
getNextTick()(function () {
2023-12-18 13:12:25 +08:00
var out
try {
out = sync(password, salt, iterations, keylen, digest)
} catch (e) {
return callback(e)
}
callback(null, out)
})
2024-01-16 21:26:16 +08:00
return
2023-12-18 13:12:25 +08:00
}
2024-01-16 21:26:16 +08:00
checkParameters(iterations, keylen)
password = toBuffer(password, defaultEncoding, 'Password')
salt = toBuffer(salt, defaultEncoding, 'Salt')
2023-12-18 13:12:25 +08:00
if (typeof callback !== 'function') throw new Error('No callback provided to pbkdf2')
resolvePromise(checkNative(algo).then(function (resp) {
if (resp) return browserPbkdf2(password, salt, iterations, keylen, algo)
return sync(password, salt, iterations, keylen, digest)
}), callback)
}