From 266db38fa4df77f545394345fdd382633deb9565 Mon Sep 17 00:00:00 2001 From: Ivan Socolsky Date: Fri, 20 Feb 2015 15:21:19 -0300 Subject: [PATCH] if decrypted, txp.message contains cleartext and txp.encryptedMessage contains cyphertext --- bit-wallet/bit-status | 2 +- lib/client/api.js | 3 ++- lib/client/verifier.js | 8 ++++---- test/integration/clientApi.js | 26 +++++++++++++------------- 4 files changed, 20 insertions(+), 19 deletions(-) diff --git a/bit-wallet/bit-status b/bit-wallet/bit-status index 0e0b642..5d15a1f 100755 --- a/bit-wallet/bit-status +++ b/bit-wallet/bit-status @@ -30,7 +30,7 @@ client.getStatus(function(err, res) { if (!_.isEmpty(res.pendingTxps)) { console.log("* TX Proposals:") _.each(res.pendingTxps, function(x) { - console.log("\t%s [%s by %s] %dSAT => %s", utils.shortID(x.id), x.decryptedMessage, x.creatorName, x.amount, x.toAddress); + console.log("\t%s [%s by %s] %dSAT => %s", utils.shortID(x.id), x.message, x.creatorName, x.amount, x.toAddress); if (!_.isEmpty(x.actions)) { console.log('\t\t * Actions'); diff --git a/lib/client/api.js b/lib/client/api.js index fc1ee62..8d73cfa 100644 --- a/lib/client/api.js +++ b/lib/client/api.js @@ -33,7 +33,8 @@ function _decryptMessage(message, encryptingKey) { function _processTxps(txps, encryptingKey) { _.each([].concat(txps), function(txp) { - txp.decryptedMessage = _decryptMessage(txp.message, encryptingKey); + txp.encryptedMessage = txp.message; + txp.message = _decryptMessage(txp.message, encryptingKey); _.each(txp.actions, function(action) { action.comment = _decryptMessage(action.comment, encryptingKey); }); diff --git a/lib/client/verifier.js b/lib/client/verifier.js index cb891b6..2b3bb0b 100644 --- a/lib/client/verifier.js +++ b/lib/client/verifier.js @@ -35,8 +35,8 @@ Verifier.checkCopayers = function(copayers, walletPrivKey, myXPrivKey, n) { } // Not signed pub keys - if (!copayer.xPubKey || !copayer.xPubKeySignature || - !WalletUtils.verifyMessage(copayer.xPubKey, copayer.xPubKeySignature, walletPubKey)) { + if (!copayer.xPubKey || !copayer.xPubKeySignature || + !WalletUtils.verifyMessage(copayer.xPubKey, copayer.xPubKeySignature, walletPubKey)) { log.error('Invalid signatures in server response'); error = true; } @@ -62,9 +62,9 @@ Verifier.checkTxProposal = function(data, txp) { if (!creatorXPubKey) return false; var creatorSigningPubKey = (new Bitcore.HDPublicKey(creatorXPubKey)).derive('m/1/0').publicKey.toString(); - var hash = WalletUtils.getProposalHash(txp.toAddress, txp.amount, txp.message); + var hash = WalletUtils.getProposalHash(txp.toAddress, txp.amount, txp.encryptedMessage || txp.message); log.debug('Regenerating & verifying tx proposal hash -> Hash: ', hash, ' Signature: ', txp.proposalSignature); - if (!WalletUtils.verifyMessage(hash, txp.proposalSignature, creatorSigningPubKey)) + if (!WalletUtils.verifyMessage(hash, txp.proposalSignature, creatorSigningPubKey)) return false; return Verifier.checkAddress(data, txp.changeAddress); diff --git a/test/integration/clientApi.js b/test/integration/clientApi.js index 727429e..7cdd9b7 100644 --- a/test/integration/clientApi.js +++ b/test/integration/clientApi.js @@ -425,7 +425,7 @@ describe('client API ', function() { var opts = { amount: 120000000, toAddress: 'n2TBMPzPECGUfcT2EByiTJ12TPZkhN2mN5', - message: 'hola 1-1', + message: 'hello 1-1', }; clients[0].sendTxProposal(opts, function(err, x) { should.not.exist(err); @@ -462,7 +462,7 @@ describe('client API ', function() { should.not.exist(err); clients[2].getTxProposals({}, function(err, txs) { should.not.exist(err); - txs[0].decryptedMessage.should.equal('some message'); + txs[0].message.should.equal('some message'); txs[0].actions[0].comment.should.equal('rejection comment'); done(); }); @@ -523,7 +523,7 @@ describe('client API ', function() { var opts = { amount: 10000, toAddress: 'n2TBMPzPECGUfcT2EByiTJ12TPZkhN2mN5', - message: 'hola', + message: 'hello', }; clients[0].sendTxProposal(opts, function(err, x) { should.not.exist(err); @@ -562,7 +562,7 @@ describe('client API ', function() { var opts = { amount: 10000, toAddress: 'n2TBMPzPECGUfcT2EByiTJ12TPZkhN2mN5', - message: 'hola', + message: 'hello', }; clients[0].sendTxProposal(opts, function(err, x) { should.not.exist(err); @@ -601,7 +601,7 @@ describe('client API ', function() { var opts = { amount: 10000, toAddress: 'n2TBMPzPECGUfcT2EByiTJ12TPZkhN2mN5', - message: 'hola', + message: 'hello', }; clients[0].sendTxProposal(opts, function(err, x) { should.not.exist(err); @@ -643,7 +643,7 @@ describe('client API ', function() { var opts = { amount: 10000000, toAddress: 'n2TBMPzPECGUfcT2EByiTJ12TPZkhN2mN5', - message: 'hola 1-1', + message: 'hello 1-1', }; clients[0].sendTxProposal(opts, function(err, x) { should.not.exist(err); @@ -670,7 +670,7 @@ describe('client API ', function() { var opts = { amount: 10000, toAddress: 'n2TBMPzPECGUfcT2EByiTJ12TPZkhN2mN5', - message: 'hola 1-1', + message: 'hello 1-1', }; clients[0].sendTxProposal(opts, function(err, x) { should.not.exist(err); @@ -701,14 +701,14 @@ describe('client API ', function() { var opts = { amount: 10000, toAddress: 'n2TBMPzPECGUfcT2EByiTJ12TPZkhN2mN5', - message: 'hola 1-1', + message: 'hello 1-1', }; clients[0].sendTxProposal(opts, function(err, x) { should.not.exist(err); x.status.should.equal('pending'); x.requiredRejections.should.equal(2); x.requiredSignatures.should.equal(2); - clients[0].rejectTxProposal(x, 'no me gusto', function(err, tx) { + clients[0].rejectTxProposal(x, 'wont sign', function(err, tx) { should.not.exist(err, err); tx.status.should.equal('pending'); clients[1].signTxProposal(x, function(err, tx) { @@ -735,7 +735,7 @@ describe('client API ', function() { var opts = { amount: 10000, toAddress: 'n2TBMPzPECGUfcT2EByiTJ12TPZkhN2mN5', - message: 'hola 1-1', + message: 'hello 1-1', }; clients[0].sendTxProposal(opts, function(err, x) { should.not.exist(err); @@ -743,13 +743,13 @@ describe('client API ', function() { x.requiredRejections.should.equal(2); x.requiredSignatures.should.equal(3); - clients[0].rejectTxProposal(x, 'no me gusto', function(err, tx) { + clients[0].rejectTxProposal(x, 'wont sign', function(err, tx) { should.not.exist(err, err); tx.status.should.equal('pending'); clients[1].signTxProposal(x, function(err, tx) { should.not.exist(err); tx.status.should.equal('pending'); - clients[2].rejectTxProposal(x, 'tampoco me gusto', function(err, tx) { + clients[2].rejectTxProposal(x, 'me neither', function(err, tx) { should.not.exist(err); tx.status.should.equal('rejected'); done(); @@ -770,7 +770,7 @@ describe('client API ', function() { var opts = { amount: 10000, toAddress: 'n2TBMPzPECGUfcT2EByiTJ12TPZkhN2mN5', - message: 'hola 1-1', + message: 'hello 1-1', }; clients[0].sendTxProposal(opts, function(err, x) { should.not.exist(err);