mirror of
https://github.com/Qortal/qortal-ui.git
synced 2025-03-14 19:52:31 +00:00
22 lines
861 B
JavaScript
22 lines
861 B
JavaScript
import { Epml, EpmlReadyPlugin, EpmlWorkerPlugin, RequestPlugin } from 'epml'
|
|
import { bytes_to_base64 as bytesToBase64, Sha512 } from 'asmcrypto.js'
|
|
import bcrypt from 'bcryptjs'
|
|
import utils from './cryptoUtils'
|
|
|
|
Epml.registerPlugin(RequestPlugin)
|
|
Epml.registerPlugin(EpmlReadyPlugin)
|
|
Epml.registerPlugin(EpmlWorkerPlugin)
|
|
|
|
const parentEpml = new Epml({ type: 'WORKER', source: self })
|
|
|
|
parentEpml.route('kdf', async req => {
|
|
const { salt, key, nonce, staticSalt, staticBcryptSalt } = req.data
|
|
const combinedBytes = utils.appendBuffer(salt, utils.stringtoUTF8Array(staticSalt + key + nonce))
|
|
const sha512Hash = new Sha512().process(combinedBytes).finish().result
|
|
const sha512HashBase64 = bytesToBase64(sha512Hash)
|
|
const result = bcrypt.hashSync(sha512HashBase64.substring(0, 72), staticBcryptSalt)
|
|
|
|
return { key, nonce, result }
|
|
})
|
|
|
|
parentEpml.imReady() |