Browse Source

one test passes

patch-2
Manuel Araoz 11 years ago
parent
commit
837658034a
  1. 15
      lib/Address.js
  2. 6
      lib/NetworkMonitor.js
  3. 11
      lib/Transaction.js
  4. 35
      test/test.NetworkMonitor.js

15
lib/Address.js

@ -186,6 +186,21 @@ Address.fromPubkeyHashScriptSig = function(scriptSig, network) {
return Address.fromPubKey(scriptSig.chunks[1], network); return Address.fromPubKey(scriptSig.chunks[1], network);
}; };
//extract an address from scriptSig
Address.fromScriptSig = function(scriptSig, network) {
if (typeof scriptSig === 'string') {
scriptSig = new Script(new Buffer(scriptSig, 'hex'));
}
if (!network)
network = 'livenet';
var payload = scriptSig.chunks;
if (scriptSig.chunks.length === 2)
return Address.fromPubkeyHashScriptSig(scriptSig, network);
// TODO: support other scriptSig types
return null;
};
Address.getScriptPubKeyFor = function(s) { Address.getScriptPubKeyFor = function(s) {
return new Address(s).getScriptPubKey(); return new Address(s).getScriptPubKey();
}; };

6
lib/NetworkMonitor.js

@ -10,13 +10,13 @@ var preconditions = require('preconditions').singleton();
var NetworkMonitor = function(peerman) { var NetworkMonitor = function(peerman) {
preconditions.checkArgument(peerman); preconditions.checkArgument(peerman);
this.peerman = peerman; this.peerman = peerman;
this.networkName = peerman.config.network;
this.init(); this.init();
} }
util.inherits(NetworkMonitor, EventEmitter); util.inherits(NetworkMonitor, EventEmitter);
NetworkMonitor.create = function(config) { NetworkMonitor.create = function(config) {
this.config = config;
var peerman = new PeerManager({ var peerman = new PeerManager({
network: config.networkName network: config.networkName
}); });
@ -39,12 +39,12 @@ NetworkMonitor.prototype.init = function() {
var handleTx = function(info) { var handleTx = function(info) {
var tx = info.message.tx; var tx = info.message.tx;
var from = tx.getSendingAddresses(self.config.networkName); var from = tx.getSendingAddresses(self.networkName);
for (var i = 0; i < from.length; i++) { for (var i = 0; i < from.length; i++) {
var addr = from[i]; var addr = from[i];
self.emit('out:'+addr, tx); self.emit('out:'+addr, tx);
} }
var to = tx.getReceivingAddresses(self.config.networkName); var to = tx.getReceivingAddresses(self.networkName);
for (var i = 0; i < to.length; i++) { for (var i = 0; i < to.length; i++) {
var addr = to[i]; var addr = to[i];
self.emit('in:'+addr, tx); self.emit('in:'+addr, tx);

11
lib/Transaction.js

@ -634,10 +634,13 @@ Transaction.prototype.getSendingAddresses = function(networkName) {
var ret = []; var ret = [];
if (!networkName) networkName = 'livenet'; if (!networkName) networkName = 'livenet';
for (var i = 0; i<this.ins.length; i++) { for (var i = 0; i<this.ins.length; i++) {
var o = this.ins[i]; var input = this.ins[i];
var scriptSig = o.getScript(); var scriptSig = input.getScript();
if (scriptSig.getBuffer().length === 0) continue; if (scriptSig.getBuffer().length === 0) {
var addr = Address.fromPubkeyHashScriptSig(o.getScript(), networkName).toString(); ret.push(null);
continue;
}
var addr = Address.fromScriptSig(scriptSig, networkName).toString();
ret.push(addr); ret.push(addr);
} }
return ret; return ret;

35
test/test.NetworkMonitor.js

@ -2,6 +2,7 @@
var chai = chai || require('chai'); var chai = chai || require('chai');
var bitcore = bitcore || require('../bitcore'); var bitcore = bitcore || require('../bitcore');
var Transaction = bitcore.Transaction;
var NetworkMonitor = bitcore.NetworkMonitor; var NetworkMonitor = bitcore.NetworkMonitor;
var EventEmitter = require('events').EventEmitter; var EventEmitter = require('events').EventEmitter;
@ -17,6 +18,9 @@ describe('NetworkMonitor', function() {
}; };
var fakePM = {}; var fakePM = {};
fakePM.on = nop; fakePM.on = nop;
fakePM.config = {
network: config.networkName
};
it('should initialze the main object', function() { it('should initialze the main object', function() {
should.exist(NetworkMonitor); should.exist(NetworkMonitor);
}); });
@ -71,27 +75,42 @@ describe('NetworkMonitor', function() {
}); });
}); });
}); });
var observedAddress = '2NFYBLfabKgLbgoTALYrtBQhbLjEKUcs9Go';
describe('incoming tx event', function() { describe('incoming tx event', function() {
it('should be called on incoming transactions', function(done) { it('should be called on incoming transactions', function(done) {
var nm = createConnectedNM(); var nm = createConnectedNM();
nm.incoming('n2tTCgsJPJBZZEKLiJx9KoU4idJQB37j9E', function(tx) { nm.incoming(observedAddress, function(tx) {
should.exist(tx); should.exist(tx);
done(); done();
}); });
var fakeTX = null; var tx = new Transaction();
var raw = '01000000012732117ef4663b4a7a455ff37c3af26deca57dc43f5d8e7e5440b22c11cefc8b010000006a47304402201ca8b1b33e9f7a515829b887b264b812ab499a08e0002a0fb32629bdbfbc005e0220567adbec3befee04e810e1d34bf31614e1cd397d7a6e3184f219c89562cac7a3012102f1bc222f40a7dd4348e4c2b1e88812179686305f1b56374aae891aa21929ad14ffffffff02809698000000000017a914f487a0aeae655268e2636207abe75228bfcf5631874f219800000000001976a914361d24071123fb9fd88685c877b014ff8543c24488ac00000000';
tx.parse(new Buffer(raw, 'hex'));
nm.connection.emit('tx', { nm.connection.emit('tx', {
message: { message: {
tx: fakeTX tx: tx
} }
}); });
}); });
it('should not be called on outgoing transactions', function() { it('should not be called on unrelated transactions', function(done) {
var nm = createConnectedNM();
nm.incoming(observedAddress, function(tx) {
should.exist(tx);
done();
});
var raw = '010000000114bae675546f758e0dbab95aa88d4db0c63e26f8fd6cbbce3a4827446d4937cf00000000700048304502201da760691f18a0ab140de1437e4bd29767b74add8cca8e38d46a2f37d9a8188f022100cbf4e121d97b4db846d236957da7fc17fd706ad47b41ae63adf953982e34f70901255121022f58491a833933a9bea80d8e820e66bee91bd8c71bfa972fe70482360b48129951aeffffffff01706f9800000000001976a91400a26ff8123593e10d0a9eba2a74db33cd69299288ac00000000';
var tx = new Transaction();
tx.parse(new Buffer(raw, 'hex'));
nm.connection.emit('tx', {
message: {
tx: tx
}
});
}); });
}); });
describe('outgoing tx event', function() { describe('outgoing tx event', function() {
it('should be called on outgoing transactions', function() { it('should be called on outgoing transactions', function() {});
}); it('should not be called on incoming transactions', function() {});
it('should not be called on incoming transactions', function() {
});
}); });
}); });

Loading…
Cancel
Save