Merge pull request #44 from maraoz/add/reporters

add transaction reporters
This commit is contained in:
Esteban Ordano 2015-03-19 12:39:23 -03:00
commit 2b309baeb2
6 changed files with 48 additions and 20 deletions

View File

@ -3,6 +3,7 @@ BitcoreNode:
network: livenet
host: localhost
port: 8333
Reporter: simple # none, simple, matrix
LevelUp: ./db
RPC:
username: username

View File

@ -1,7 +1,7 @@
'use strict';
var BitcoreNode = require('./lib/node');
var reporters = require('./lib/reporters');
if (require.main === module) {
var config = require('config');
@ -11,9 +11,17 @@ if (require.main === module) {
if (err.code === 'ECONNREFUSED') {
console.log('Connection to bitcoind failed');
} else {
console.log('Unrecognized error: ', err);
console.log('Error: ', err);
}
});
var reporterName = config.get('Reporter');
var reporter = reporters[reporterName];
if (!reporter) {
throw new Error('Unrecognized network reporter: ' + reporterName +
'. Available: ' + Object.keys(reporters));
}
node.on('Transaction', reporter);
}

View File

@ -8,7 +8,7 @@ var Networks = bitcore.Networks;
var $ = bitcore.util.preconditions;
var p2p = require('bitcore-p2p');
var Peer = p2p.Peer;
var Messages = p2p.Messages;
var messages = new p2p.Messages();
function NetworkMonitor(eventBus, peer) {
$.checkArgument(eventBus);
@ -36,7 +36,7 @@ NetworkMonitor.prototype.setupPeer = function(peer) {
});
peer.on('inv', function(m) {
// TODO only ask for data if tx or block is unknown
peer.sendMessage(new Messages.GetData(m.inventory));
peer.sendMessage(messages.GetData(m.inventory));
});
peer.on('tx', function(m) {
self.bus.process(m.transaction);

View File

@ -4,7 +4,6 @@ var util = require('util');
var EventEmitter = require('eventemitter2').EventEmitter2;
var bitcore = require('bitcore');
var Unit = bitcore.Unit;
var $ = bitcore.util.preconditions;
var NetworkMonitor = require('./networkmonitor');
@ -17,16 +16,6 @@ var BitcoreNode = function(bus, nm) {
this.bus = bus;
this.nm = nm;
this.bus.register(bitcore.Transaction, function(tx) {
var tout = Unit.fromSatoshis(tx.outputAmount).toBTC();
console.log('Transaction:', tx.id);
console.log('\ttotal_out:', tout, 'BTC');
});
this.bus.register(bitcore.Block, function(block) {
console.log('Block:', block.id);
});
this.bus.onAny(function(value) {
self.emit(this.event, value);
});

35
lib/reporters.js Normal file
View File

@ -0,0 +1,35 @@
'use strict';
var bitcore = require('bitcore');
var Unit = bitcore.Unit;
var reporters = {};
reporters.none = function() {
// do nothing
};
reporters.matrix = function(tx) {
var s = tx.toString();
for (var i = 0; i < s.length; i++) {
var slice = s.slice(4 * i, 4 * (i + 1));
if (slice.length < 4) {
continue;
}
var c = JSON.parse('"\\u' + slice + '"');
process.stdout.write(c);
}
};
reporters.simple = function(tx) {
var tout = Unit.fromSatoshis(tx.outputAmount).toBTC();
console.log('Transaction:', tx.id);
console.log('\ttotal_out:', tout, 'BTC');
console.log('\tinput addresses:');
tx.inputs.forEach(function(inp) {
console.log('\t\t' + inp.script.toAddress());
});
console.log('\toutput addresses:');
tx.outputs.forEach(function(out) {
console.log('\t\t' + out.script.toAddress());
});
};
module.exports = reporters;

View File

@ -51,11 +51,6 @@ describe('NetworkMonitor', function() {
});
it('instantiates correctly from create with opts', function() {
var opts = {
network: Networks.livenet,
host: '8.8.8.8',
port: 3001
};
var nm = NetworkMonitor.create(busMock);
should.exist(nm);
});