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
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)
|