Browse Source

add export to text and qr

activeAddress
Matias Alejo Garcia 10 years ago
parent
commit
705773aa37
  1. 1
      bit-wallet/bit
  2. 28
      bit-wallet/bit-export
  3. 83
      lib/client/api.js
  4. 1
      package.json

1
bit-wallet/bit

@ -15,6 +15,7 @@ program
.command('reject <txpId> [reason]', 'reject a transaction proposal') .command('reject <txpId> [reason]', 'reject a transaction proposal')
.command('broadcast <txpId>', 'broadcast a transaction proposal to the Bitcoin network') .command('broadcast <txpId>', 'broadcast a transaction proposal to the Bitcoin network')
.command('rm <txpId>', 'remove a transaction proposal') .command('rm <txpId>', 'remove a transaction proposal')
.command('export', 'export wallet critical data')
.parse(process.argv); .parse(process.argv);

28
bit-wallet/bit-export

@ -0,0 +1,28 @@
#!/usr/bin/env node
var program = require('commander');
var qr = require('qr-image');
var Client = require('../lib/client');
var utils = require('./cli-utils');
program
.version('0.0.1')
.option('-c, --config [file]', 'Wallet config filename')
.option('-v, --verbose', 'be verbose')
.option('-q, --qr')
.parse(process.argv);
var args = program.args;
var client = utils.getClient(program);
client.export(function(err, x) {
utils.die(err);
if (program.qr) {
var filename = program.config + '.svg';
var qr_svg = qr.image(x, { type: 'svg' });
qr_svg.pipe(require('fs').createWriteStream(filename));
} else {
console.log('Wallet Critical Data:\n', x);
}
});

83
lib/client/api.js

@ -309,66 +309,73 @@ API.prototype.getBalance = function(cb) {
}); });
}; };
API.prototype.export = function(cb) {
API.prototype.getTxProposals = function(opts, cb) {
var self = this; var self = this;
this._loadAndCheck( this._loadAndCheck( function(err, data) {
function(err, data) {
if (err) return cb(err); if (err) return cb(err);
var url = '/v1/txproposals/'; var x = _.pick(data,['publicKeyRing','xPrivKey', 'copayerId', 'signingPrivKey'])
self._doGetRequest(url, data, cb); return cb(null, JSON.stringify(x));
}); });
}
API.prototype.getTxProposals = function(opts, cb) {
var self = this;
this._loadAndCheck(function(err, data) {
if (err) return cb(err);
var url = '/v1/txproposals/';
self._doGetRequest(url, data, cb);
});
}; };
API.prototype.signTxProposal = function(txp, cb) { API.prototype.signTxProposal = function(txp, cb) {
var self = this; var self = this;
this._loadAndCheck( this._loadAndCheck(function(err, data) {
function(err, data) { if (err) return cb(err);
if (err) return cb(err);
if (!Verifier.checkTxProposal(data, txp)) { if (!Verifier.checkTxProposal(data, txp)) {
return cb(new ServerCompromisedError('Server sent fake transaction proposal')); return cb(new ServerCompromisedError('Server sent fake transaction proposal'));
} }
//Derive proper key to sign, for each input //Derive proper key to sign, for each input
var privs = [], var privs = [],
derived = {}; derived = {};
var network = new Bitcore.Address(txp.toAddress).network.name; var network = new Bitcore.Address(txp.toAddress).network.name;
var xpriv = new Bitcore.HDPrivateKey(data.xPrivKey, network); var xpriv = new Bitcore.HDPrivateKey(data.xPrivKey, network);
_.each(txp.inputs, function(i) { _.each(txp.inputs, function(i) {
if (!derived[i.path]) { if (!derived[i.path]) {
derived[i.path] = xpriv.derive(i.path).privateKey; derived[i.path] = xpriv.derive(i.path).privateKey;
} }
privs.push(derived[i.path]); privs.push(derived[i.path]);
}); });
var t = new Bitcore.Transaction(); var t = new Bitcore.Transaction();
_.each(txp.inputs, function(i) { _.each(txp.inputs, function(i) {
t.from(i, i.publicKeys, txp.requiredSignatures); t.from(i, i.publicKeys, txp.requiredSignatures);
}); });
t.to(txp.toAddress, txp.amount) t.to(txp.toAddress, txp.amount)
.change(txp.changeAddress) .change(txp.changeAddress)
.sign(privs); .sign(privs);
var signatures = []; var signatures = [];
_.each(privs, function(p) { _.each(privs, function(p) {
var s = t.getSignatures(p)[0].signature.toDER().toString('hex'); var s = t.getSignatures(p)[0].signature.toDER().toString('hex');
signatures.push(s); signatures.push(s);
}); });
var url = '/v1/txproposals/' + txp.id + '/signatures/'; var url = '/v1/txproposals/' + txp.id + '/signatures/';
var args = { var args = {
signatures: signatures signatures: signatures
}; };
self._doPostRequest(url, args, data, cb); self._doPostRequest(url, args, data, cb);
}); });
}; };
API.prototype.rejectTxProposal = function(txp, reason, cb) { API.prototype.rejectTxProposal = function(txp, reason, cb) {

1
package.json

@ -31,6 +31,7 @@
"npmlog": "^0.1.1", "npmlog": "^0.1.1",
"preconditions": "^1.0.7", "preconditions": "^1.0.7",
"request": "^2.53.0", "request": "^2.53.0",
"qr-image": "*",
"uuid": "*" "uuid": "*"
}, },
"devDependencies": { "devDependencies": {

Loading…
Cancel
Save