4
1
mirror of https://github.com/Qortal/qortal-ui.git synced 2025-02-11 17:55:51 +00:00

51 lines
1.5 KiB
JavaScript
Raw Normal View History

import { store } from '../api_deps'
import { stateAwait } from './utils/stateAwait'
import { Sha512 } from 'asmcrypto.js'
import utils from '../api/deps/utils'
import { get, registerTranslateConfig } from '../../core/translate'
2023-06-27 16:21:06 +02:00
registerTranslateConfig({
loader: lang => fetch(`/language/${lang}.json`).then(res => res.json())
2023-06-27 16:21:06 +02:00
})
2021-12-25 14:39:47 +01:00
export const kdf = async (seed, salt, status = () => { }) => {
const state = store.getState()
const config = state.config
const workers = state.app.workers.workers
2023-06-27 16:21:06 +02:00
const kst1 = get("login.lp17")
status(kst1)
await stateAwait(state => state.app.workers.ready)
2023-06-27 16:21:06 +02:00
const kst2 = get("login.lp18")
status(kst2)
salt = new Uint8Array(salt)
const seedParts = await Promise.all(workers.map((worker, index) => {
const nonce = index
return worker.request('kdf', {
key: seed,
salt,
nonce,
staticSalt: config.crypto.staticSalt,
staticBcryptSalt: config.crypto.staticBcryptSalt
}).then(data => {
let jsonData
try {
jsonData = JSON.parse(data)
data = jsonData
} catch (e) {
// ...
}
2023-06-27 16:21:06 +02:00
const kst3 = get("login.lp19")
if (seed !== data.key) throw new Error(kst3 + seed + ' !== ' + data.key)
const kst4 = get("login.lp20")
if (nonce !== data.nonce) throw new Error(kst4)
return data.result
})
}))
2023-06-27 16:21:06 +02:00
const kst5 = get("login.lp21")
status(kst5)
const result = new Sha512().process(utils.stringtoUTF8Array(config.crypto.staticSalt + seedParts.reduce((a, c) => a + c))).finish().result
2023-06-27 16:21:06 +02:00
const kst6 = get("login.lp22")
status(kst6)
return result
2021-12-25 14:39:47 +01:00
}