56 lines
1.7 KiB
JavaScript
56 lines
1.7 KiB
JavaScript
/**
|
|
* This script finds an address given an account extended public key
|
|
* Usage: edit these fields below and run it like `node find-address.js`
|
|
*/
|
|
|
|
const assert = require('node:assert/strict');
|
|
const HDPublicKey = require('hsd/lib/hd/public');
|
|
const Address = require('hsd/lib/primitives/address');
|
|
|
|
// **********
|
|
// FILL THESE
|
|
// **********
|
|
const NETWORK = 'main';
|
|
const ACCOUNT_XPUB = 'xpub6BvF6DnLZRV6my62FuQ8nw5TRebL8qr9Wa7u2tE1aEedHWBt4XAfSaNTmP1SM2nXErGWSzxRAHVwqstPzRrsXtA2vn1a4KzLwAVEgLNmfca'; // should start with: xpub, rpub, etc.
|
|
const SEARCH_ADDRESS = 'hs1q3tlnmk9sp2luxdvkdcyvtj8ucj5pa4hwvr8ql6';
|
|
|
|
const [START, END] = [0, 0x7fffffff];
|
|
// const [START, END] = [0, 100];
|
|
|
|
(() => {
|
|
const account = HDPublicKey.fromBase58(ACCOUNT_XPUB, NETWORK);
|
|
console.log('[*] Using account public key:', account.xpubkey(NETWORK));
|
|
|
|
const expectedAddr = new Address(SEARCH_ADDRESS, NETWORK);
|
|
console.log('[*] Searching for address:', expectedAddr.toString(NETWORK));
|
|
|
|
const len = END - START;
|
|
assert((len >>> 0) > 0);
|
|
|
|
for (let i = START; i <= END; i++) {
|
|
if (i % 1e3 === 0) {
|
|
console.log(`[${i}/${len}] searching...`);
|
|
}
|
|
|
|
/** @type {Buffer[]} */
|
|
const keys = [
|
|
account.derive(0).derive(i).publicKey, // receive
|
|
account.derive(1).derive(i).publicKey, // change
|
|
];
|
|
|
|
for (const [branch, key] of keys.entries()) {
|
|
const addr = Address.fromPubkey(key);
|
|
if (expectedAddr.equals(addr)) {
|
|
console.log('Found address', {
|
|
address: addr,
|
|
branch: branch,
|
|
index: i,
|
|
publicKey: key.toString('hex'),
|
|
});
|
|
return;
|
|
}
|
|
}
|
|
}
|
|
|
|
console.log(`Searched index from ${START} to ${END}. Address not found.`);
|
|
})(); |