|
@ -18,24 +18,51 @@ module.exports = (shepherd) => { |
|
|
shepherd.getTransaction = (txid, network, ecl) => { |
|
|
shepherd.getTransaction = (txid, network, ecl) => { |
|
|
return new shepherd.Promise((resolve, reject) => { |
|
|
return new shepherd.Promise((resolve, reject) => { |
|
|
if (!shepherd.electrumCache[network]) { |
|
|
if (!shepherd.electrumCache[network]) { |
|
|
shepherd.electrumCache[network] = { |
|
|
shepherd.electrumCache[network] = {}; |
|
|
tx: {}, |
|
|
} |
|
|
blocksHeaders: {}, |
|
|
if (!shepherd.electrumCache[network].tx) { |
|
|
}; |
|
|
shepherd.electrumCache[network]['tx'] = {}; |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
if (!shepherd.electrumCache[network].tx[txid]) { |
|
|
if (!shepherd.electrumCache[network].tx[txid]) { |
|
|
|
|
|
shepherd.log(`electrum raw input tx ${txid}`, true); |
|
|
|
|
|
|
|
|
ecl.blockchainTransactionGet(txid) |
|
|
ecl.blockchainTransactionGet(txid) |
|
|
.then((_rawtxJSON) => { |
|
|
.then((_rawtxJSON) => { |
|
|
shepherd.electrumCache[network].tx[txid] = _rawtxJSON; |
|
|
shepherd.electrumCache[network].tx[txid] = _rawtxJSON; |
|
|
resolve(_rawtxJSON); |
|
|
resolve(_rawtxJSON); |
|
|
}); |
|
|
}); |
|
|
} else { |
|
|
} else { |
|
|
|
|
|
shepherd.log(`electrum cached raw input tx ${txid}`, true); |
|
|
resolve(shepherd.electrumCache[network].tx[txid]); |
|
|
resolve(shepherd.electrumCache[network].tx[txid]); |
|
|
} |
|
|
} |
|
|
}); |
|
|
}); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
shepherd.getBlockHeader = (height, network, ecl) => { |
|
|
|
|
|
return new shepherd.Promise((resolve, reject) => { |
|
|
|
|
|
if (!shepherd.electrumCache[network]) { |
|
|
|
|
|
shepherd.electrumCache[network] = {}; |
|
|
|
|
|
} |
|
|
|
|
|
if (!shepherd.electrumCache[network].blockHeader) { |
|
|
|
|
|
shepherd.electrumCache[network]['blockHeader'] = {}; |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
if (!shepherd.electrumCache[network].blockHeader[height]) { |
|
|
|
|
|
shepherd.log(`electrum raw block ${height}`, true); |
|
|
|
|
|
|
|
|
|
|
|
ecl.blockchainBlockGetHeader(height) |
|
|
|
|
|
.then((_rawtxJSON) => { |
|
|
|
|
|
shepherd.electrumCache[network].blockHeader[height] = _rawtxJSON; |
|
|
|
|
|
resolve(_rawtxJSON); |
|
|
|
|
|
}); |
|
|
|
|
|
} else { |
|
|
|
|
|
shepherd.log(`electrum cached raw block ${height}`, true); |
|
|
|
|
|
resolve(shepherd.electrumCache[network].blockHeader[height]); |
|
|
|
|
|
} |
|
|
|
|
|
}); |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
shepherd.get('/electrum/listtransactions', (req, res, next) => { |
|
|
shepherd.get('/electrum/listtransactions', (req, res, next) => { |
|
|
if (shepherd.checkToken(req.query.token)) { |
|
|
if (shepherd.checkToken(req.query.token)) { |
|
|
const network = req.query.network || shepherd.findNetworkObj(req.query.coin); |
|
|
const network = req.query.network || shepherd.findNetworkObj(req.query.coin); |
|
@ -82,7 +109,7 @@ module.exports = (shepherd) => { |
|
|
let index = 0; |
|
|
let index = 0; |
|
|
|
|
|
|
|
|
async.eachOfSeries(json, (transaction, ind, callback) => { |
|
|
async.eachOfSeries(json, (transaction, ind, callback) => { |
|
|
ecl.blockchainBlockGetHeader(transaction.height) |
|
|
shepherd.getBlockHeader(transaction.height, network, ecl) |
|
|
.then((blockInfo) => { |
|
|
.then((blockInfo) => { |
|
|
if (blockInfo && |
|
|
if (blockInfo && |
|
|
blockInfo.timestamp) { |
|
|
blockInfo.timestamp) { |
|
@ -175,8 +202,6 @@ module.exports = (shepherd) => { |
|
|
.then((rawInput) => { |
|
|
.then((rawInput) => { |
|
|
const decodedVinVout = shepherd.electrumJSTxDecoder(rawInput, network, _network); |
|
|
const decodedVinVout = shepherd.electrumJSTxDecoder(rawInput, network, _network); |
|
|
|
|
|
|
|
|
shepherd.log(`electrum raw input tx ${_decodedInput.txid} ==>`, true); |
|
|
|
|
|
|
|
|
|
|
|
if (decodedVinVout) { |
|
|
if (decodedVinVout) { |
|
|
shepherd.log(decodedVinVout.outputs[_decodedInput.n], true); |
|
|
shepherd.log(decodedVinVout.outputs[_decodedInput.n], true); |
|
|
txInputs.push(decodedVinVout.outputs[_decodedInput.n]); |
|
|
txInputs.push(decodedVinVout.outputs[_decodedInput.n]); |
|
|