You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

109 lines
2.7 KiB

6 years ago
/*!
* scripts/patches/translate-hd-accounts.js
* Copyright © 2019 Katana Cryptographic Ltd. All Rights Reserved.
*/
'use strict'
const mysql = require('mysql')
const bitcoin = require('bitcoinjs-lib')
const bs58check = require('bs58check')
const bs58 = require('bs58')
const db = require('../../lib/db/mysql-db-wrapper')
const hdaHelper = require('../../lib/bitcoin/hd-accounts-helper')
/**
* Translate a xpub into a ypub or zpub
*/
function xlatXPUB(xpub, targetType) {
const decoded = bs58check.decode(xpub)
const ver = decoded.readInt32BE()
let xlatVer = 0
if (ver == hdaHelper.MAGIC_XPUB) {
if (targetType == hdaHelper.BIP49)
xlatVer = hdaHelper.MAGIC_YPUB
else if (targetType == hdaHelper.BIP84)
xlatVer = hdaHelper.MAGIC_ZPUB
} else if (ver == hdaHelper.MAGIC_TPUB) {
if (targetType == hdaHelper.BIP49)
xlatVer = hdaHelper.MAGIC_UPUB
else if (targetType == hdaHelper.BIP84)
xlatVer = hdaHelper.MAGIC_VPUB
}
let b = Buffer.alloc(4)
b.writeInt32BE(xlatVer)
decoded.writeInt32BE(xlatVer, 0)
const checksum = bitcoin.crypto.hash256(decoded).slice(0, 4)
const xlatXpub = Buffer.alloc(decoded.length + checksum.length)
decoded.copy(xlatXpub, 0, 0, decoded.length)
checksum.copy(xlatXpub, xlatXpub.length - 4, 0, checksum.length)
const encoded = bs58.encode(xlatXpub)
return encoded
}
/**
* Retrieve hd accounts from db
*/
async function getHdAccounts() {
const sqlQuery = 'SELECT `hdID`, `hdXpub`, `hdType` FROM `hd`'
const query = mysql.format(sqlQuery)
return db._query(query)
}
/**
* Update the xpub of a hdaccount
*/
async function updateHdAccount(hdId, xpub) {
const sqlQuery = 'UPDATE `hd` SET `hdXpub` = ? WHERE `hdID` = ?'
const params = [xpub, hdId]
const query = mysql.format(sqlQuery, params)
return db._query(query)
}
/**
* Script translating when needed
* xpubs stored in db into ypub and zpub
*/
async function run() {
try {
const hdAccounts = await getHdAccounts()
for (let account of hdAccounts) {
const hdId = account.hdID
const xpub = account.hdXpub
const info = hdaHelper.classify(account.hdType)
const scheme = info.type
if ((scheme == hdaHelper.BIP49) || (scheme == hdaHelper.BIP84)) {
const xlatedXpub = xlatXPUB(xpub, scheme)
await updateHdAccount(hdId, xlatedXpub)
console.log(`Updated ${hdId} (${xpub} => ${xlatedXpub})`)
}
}
} catch(e) {
console.log('A problem was met')
console.log(e)
}
}
/**
* Launch the script
*/
console.log('Start processing')
const startupTimeout = setTimeout(async function() {
return run().then(() => {
console.log('Process completed')
})
}, 1500)