Browse Source

txproposal with type=multiple-outputs needs an array of outputs

activeAddress
Gregg Zigler 10 years ago
parent
commit
6f43888176
  1. 20
      lib/model/txproposal.js
  2. 38
      test/models/txproposal.js

20
lib/model/txproposal.js

@ -9,21 +9,31 @@ var Address = Bitcore.Address;
var TxProposalAction = require('./txproposalaction'); var TxProposalAction = require('./txproposalaction');
function TxProposal() { function TxProposal() {
this.version = '1.0.0'; this.version = '1.0.1';
}; };
TxProposal.create = function(opts) { TxProposal.create = function(opts) {
opts = opts || {}; opts = opts || {};
var x = new TxProposal(); var x = new TxProposal();
x.type = opts.type;
var now = Date.now(); var now = Date.now();
x.createdOn = Math.floor(now / 1000); x.createdOn = Math.floor(now / 1000);
x.id = _.padLeft(now, 14, '0') + Uuid.v4(); x.id = _.padLeft(now, 14, '0') + Uuid.v4();
x.walletId = opts.walletId; x.walletId = opts.walletId;
x.creatorId = opts.creatorId; x.creatorId = opts.creatorId;
if (x.type == 'multiple-outputs' && opts.outputs) {
x.outputs = opts.outputs;
} else if (x.type == 'multiple-outputs') {
x.outputs = [{
toAddress: opts.toAddress,
amount: opts.amount
}];
} else {
x.toAddress = opts.toAddress; x.toAddress = opts.toAddress;
x.amount = opts.amount; x.amount = opts.amount;
}
x.message = opts.message; x.message = opts.message;
x.payProUrl = opts.payProUrl; x.payProUrl = opts.payProUrl;
x.proposalSignature = opts.proposalSignature; x.proposalSignature = opts.proposalSignature;
@ -34,9 +44,11 @@ TxProposal.create = function(opts) {
x.requiredRejections = opts.requiredRejections; x.requiredRejections = opts.requiredRejections;
x.status = 'pending'; x.status = 'pending';
x.actions = []; x.actions = [];
x.outputOrder = _.shuffle(_.range(2)); var outputCount = x.outputs ? x.outputs.length + 1 : 2;
x.outputOrder = _.shuffle(_.range(outputCount));
x.fee = null; x.fee = null;
x.network = Bitcore.Address(x.toAddress).toObject().network; var toAddress = x.outputs ? x.outputs[0].toAddress : x.toAddress;
x.network = Bitcore.Address(toAddress).toObject().network;
x.feePerKb = opts.feePerKb; x.feePerKb = opts.feePerKb;
return x; return x;
@ -46,10 +58,12 @@ TxProposal.fromObj = function(obj) {
var x = new TxProposal(); var x = new TxProposal();
x.version = obj.version; x.version = obj.version;
x.type = obj.type;
x.createdOn = obj.createdOn; x.createdOn = obj.createdOn;
x.id = obj.id; x.id = obj.id;
x.walletId = obj.walletId; x.walletId = obj.walletId;
x.creatorId = obj.creatorId; x.creatorId = obj.creatorId;
x.outputs = obj.outputs;
x.toAddress = obj.toAddress; x.toAddress = obj.toAddress;
x.amount = obj.amount; x.amount = obj.amount;
x.message = obj.message; x.message = obj.message;

38
test/models/txproposal.js

@ -15,14 +15,19 @@ describe('TXProposal', function() {
var txp = TXP.fromObj(aTXP()); var txp = TXP.fromObj(aTXP());
should.exist(txp); should.exist(txp);
}); });
it('should create a multiple-outputs TXP', function() {
var txp = TXP.fromObj(aTXP('multiple-outputs'));
should.exist(txp);
});
}); });
describe('#_getBitcoreTx', function() {
describe('#getBitcoreTx', function() {
it('should create a valid bitcore TX', function() { it('should create a valid bitcore TX', function() {
var txp = TXP.fromObj(aTXP()); var txp = TXP.fromObj(aTXP());
var t = txp.getBitcoreTx(); var t = txp.getBitcoreTx();
should.exist(t); should.exist(t);
}); });
it('should order ouputs as specified by outputOrder', function() { it('should order outputs as specified by outputOrder', function() {
var txp = TXP.fromObj(aTXP()); var txp = TXP.fromObj(aTXP());
txp.outputOrder = [0, 1]; txp.outputOrder = [0, 1];
@ -33,6 +38,12 @@ describe('TXProposal', function() {
var t = txp.getBitcoreTx(); var t = txp.getBitcoreTx();
t.getChangeOutput().should.deep.equal(t.outputs[0]); t.getChangeOutput().should.deep.equal(t.outputs[0]);
}); });
it('should create a bitcore TX with multiple outputs', function() {
var txp = TXP.fromObj(aTXP('multiple-outputs'));
txp.outputOrder = [0, 1, 2];
var t = txp.getBitcoreTx();
t.getChangeOutput().should.deep.equal(t.outputs[2]);
});
}); });
@ -86,8 +97,8 @@ var theXPriv = 'xprv9s21ZrQH143K2rMHbXTJmWTuFx6ssqn1vyRoZqPkCXYchBSkp5ey8kMJe84s
var theXPub = 'xpub661MyMwAqRbcFLRkhYzK8eQdoywNHJVsJCMQNDoMks5bZymuMcyDgYfnVQYq2Q9npnVmdTAthYGc3N3uxm5sEdnTpSqBc4YYTAhNnoSxCm9'; var theXPub = 'xpub661MyMwAqRbcFLRkhYzK8eQdoywNHJVsJCMQNDoMks5bZymuMcyDgYfnVQYq2Q9npnVmdTAthYGc3N3uxm5sEdnTpSqBc4YYTAhNnoSxCm9';
var theSignatures = ['3045022100896aeb8db75fec22fddb5facf791927a996eb3aee23ee6deaa15471ea46047de02204c0c33f42a9d3ff93d62738712a8c8a5ecd21b45393fdd144e7b01b5a186f1f9']; var theSignatures = ['3045022100896aeb8db75fec22fddb5facf791927a996eb3aee23ee6deaa15471ea46047de02204c0c33f42a9d3ff93d62738712a8c8a5ecd21b45393fdd144e7b01b5a186f1f9'];
var aTXP = function() { var aTXP = function(type) {
return { var txp = {
"version": "1.0.0", "version": "1.0.0",
"createdOn": 1423146231, "createdOn": 1423146231,
"id": "75c34f49-1ed6-255f-e9fd-0c71ae75ed1e", "id": "75c34f49-1ed6-255f-e9fd-0c71ae75ed1e",
@ -123,5 +134,24 @@ var aTXP = function() {
"status": "pending", "status": "pending",
"actions": [], "actions": [],
"outputOrder": [0, 1], "outputOrder": [0, 1],
};
if (type == 'multiple-outputs') {
txp.type = type;
txp.outputs = [
{
toAddress: "18PzpUFkFZE8zKWUPvfykkTxmB9oMR8qP7",
amount: 10000000,
message: "first message"
},
{
toAddress: "18PzpUFkFZE8zKWUPvfykkTxmB9oMR8qP7",
amount: 20000000,
message: "second message"
},
];
txp.outputOrder = [0, 1, 2];
delete txp.toAddress;
delete txp.amount;
} }
return txp;
}; };

Loading…
Cancel
Save