address summary finished
This commit is contained in:
parent
17acbdda6d
commit
a3e4e19a9d
@ -1,5 +1,7 @@
|
|||||||
const Block = require('../../models/block.js');
|
const Block = require('../../models/block.js');
|
||||||
const logger = require('../logger');
|
const logger = require('../logger');
|
||||||
|
const request = require('request');
|
||||||
|
const config = require('../../config');
|
||||||
|
|
||||||
const MAX_BLOCKS = 200;
|
const MAX_BLOCKS = 200;
|
||||||
|
|
||||||
@ -23,19 +25,60 @@ function getBlock(params, options, limit, cb) {
|
|||||||
|
|
||||||
module.exports = function AddressAPI(router) {
|
module.exports = function AddressAPI(router) {
|
||||||
router.get('/addr/:addr', (req, res) => {
|
router.get('/addr/:addr', (req, res) => {
|
||||||
res.json({
|
getBlock(
|
||||||
addrStr: req.params.addr,
|
{},
|
||||||
balance: 0,
|
{ height: 1 },
|
||||||
balanceSat: 0,
|
1,
|
||||||
totalReceived: 0,
|
(err, block) => {
|
||||||
totalReceivedSat: 0,
|
if (err) {
|
||||||
totalSent: 0,
|
res.status(501).send();
|
||||||
totalSentSat: 0,
|
logger.log('err', err);
|
||||||
unconfirmedBalance: 0,
|
}
|
||||||
unconfirmedBalanceSat: 0,
|
if (block[0]) {
|
||||||
unconfirmedTxApperances: 0,
|
const height = block[0].height;
|
||||||
txApperances: 5,
|
request(`http://${config.bcoin_http}:${config.bcoin['http-port']}/tx/address/${req.params.addr}`, (err, localRes, body) => {
|
||||||
});
|
if (err) {
|
||||||
|
logger.log('error',
|
||||||
|
`${err}`);
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
body = JSON.parse(body);
|
||||||
|
} catch (e) {
|
||||||
|
logger.log('error',
|
||||||
|
`${err}`);
|
||||||
|
}
|
||||||
|
const totalSpent = body.reduce((sum, tx) => sum + tx.outputs.reduce((sum, output) => {
|
||||||
|
if (output.address === req.params.addr) {
|
||||||
|
return sum + output.value;
|
||||||
|
}
|
||||||
|
return sum;
|
||||||
|
}, 0), 0);
|
||||||
|
|
||||||
|
const totalReceived = body.reduce((sum, tx) => sum + tx.inputs.reduce((sum, input) => {
|
||||||
|
if (input.coin && input.coin.address === req.params.addr) {
|
||||||
|
return sum + input.coin.value;
|
||||||
|
}
|
||||||
|
return sum;
|
||||||
|
}, 0), 0);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
res.json({
|
||||||
|
addrStr: req.params.addr,
|
||||||
|
balance: totalReceived - totalSpent,
|
||||||
|
balanceSat: totalReceived - totalSpent,
|
||||||
|
totalReceived: totalReceived / 1e8,
|
||||||
|
totalReceivedSat: totalReceived,
|
||||||
|
totalSent: totalSpent / 1e8,
|
||||||
|
totalSentSat: totalSpent,
|
||||||
|
unconfirmedBalance: 0,
|
||||||
|
unconfirmedBalanceSat: 0,
|
||||||
|
unconfirmedTxApperances: 0,
|
||||||
|
txApperances: body.length,
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
router.get('/addr/:addr/utxo', (req, res) => {
|
router.get('/addr/:addr/utxo', (req, res) => {
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user