mirror of https://github.com/BTCPrivate/copay.git
initial work replacing symmetric shared secret with ECIES
This commit is contained in:
parent
a535d93b6f
commit
31d601b2a6
|
@ -20,11 +20,23 @@ function PrivateKey(opts) {
|
||||||
|
|
||||||
PrivateKey.prototype.getId = function() {
|
PrivateKey.prototype.getId = function() {
|
||||||
if (!this.id) {
|
if (!this.id) {
|
||||||
|
this.cacheId();
|
||||||
|
}
|
||||||
|
return this.id;
|
||||||
|
};
|
||||||
|
|
||||||
|
PrivateKey.prototype.getIdPriv = function() {
|
||||||
|
if (!this.idpriv) {
|
||||||
|
this.cacheId();
|
||||||
|
}
|
||||||
|
return this.idpriv;
|
||||||
|
};
|
||||||
|
|
||||||
|
PrivateKey.prototype.cacheId = function() {
|
||||||
var path = Structure.IdFullBranch;
|
var path = Structure.IdFullBranch;
|
||||||
var idhk = this.bip.derive(path);
|
var idhk = this.bip.derive(path);
|
||||||
this.id = idhk.eckey.public.toString('hex');
|
this.id = idhk.eckey.public.toString('hex');
|
||||||
}
|
this.idpriv = idhk.eckey.private.toString('hex');
|
||||||
return this.id;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
PrivateKey.prototype.deriveBIP45Branch = function() {
|
PrivateKey.prototype.deriveBIP45Branch = function() {
|
||||||
|
|
|
@ -38,7 +38,7 @@ function Wallet(opts) {
|
||||||
|
|
||||||
this.id = opts.id || Wallet.getRandomId();
|
this.id = opts.id || Wallet.getRandomId();
|
||||||
this.name = opts.name;
|
this.name = opts.name;
|
||||||
this.netKey = opts.netKey || SecureRandom.getRandomBuffer(8).toString('base64');
|
//this.netKey = opts.netKey || SecureRandom.getRandomBuffer(8).toString('base64');
|
||||||
|
|
||||||
// Renew token every 24hs
|
// Renew token every 24hs
|
||||||
if (opts.tokenTime && new Date().getTime() - opts.tokenTime < 86400000) {
|
if (opts.tokenTime && new Date().getTime() - opts.tokenTime < 86400000) {
|
||||||
|
@ -216,7 +216,7 @@ Wallet.prototype._optsToObj = function() {
|
||||||
requiredCopayers: this.requiredCopayers,
|
requiredCopayers: this.requiredCopayers,
|
||||||
totalCopayers: this.totalCopayers,
|
totalCopayers: this.totalCopayers,
|
||||||
name: this.name,
|
name: this.name,
|
||||||
netKey: this.netKey,
|
//netKey: this.netKey,
|
||||||
version: this.version,
|
version: this.version,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -240,21 +240,21 @@ Wallet.prototype.getMyCopayerId = function() {
|
||||||
|
|
||||||
|
|
||||||
Wallet.prototype.getSecret = function() {
|
Wallet.prototype.getSecret = function() {
|
||||||
var i = new Buffer(this.getMyCopayerId(), 'hex');
|
var pubkeybuf = new Buffer(this.getMyCopayerId(), 'hex');
|
||||||
var k = new Buffer(this.netKey, 'base64');
|
//var k = new Buffer(this.netKey, 'base64');
|
||||||
var b = Buffer.concat([i, k]);
|
//var b = Buffer.concat([i, k]);
|
||||||
var str = Base58Check.encode(b);
|
var str = Base58Check.encode(pubkeybuf);
|
||||||
return str;
|
return str;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
Wallet.decodeSecret = function(secretB) {
|
Wallet.decodeSecret = function(secretB) {
|
||||||
var secret = Base58Check.decode(secretB);
|
var secret = Base58Check.decode(secretB);
|
||||||
var netKeyBuf = secret.slice(-8);
|
//var netKeyBuf = secret.slice(-8);
|
||||||
var pubKeyBuf = secret.slice(0, 33);
|
var pubKeyBuf = secret.slice(0, 33);
|
||||||
return {
|
return {
|
||||||
pubKey: pubKeyBuf.toString('hex'),
|
pubKey: pubKeyBuf.toString('hex')//,
|
||||||
netKey: netKeyBuf.toString('base64'),
|
//netKey: netKeyBuf.toString('base64'),
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -280,8 +280,8 @@ Wallet.prototype.netStart = function() {
|
||||||
var startOpts = {
|
var startOpts = {
|
||||||
copayerId: myId,
|
copayerId: myId,
|
||||||
token: self.token,
|
token: self.token,
|
||||||
maxPeers: self.totalCopayers,
|
maxPeers: self.totalCopayers//,
|
||||||
netKey: this.netKey,
|
//netKey: this.netKey,
|
||||||
};
|
};
|
||||||
|
|
||||||
if (this.publicKeyRing.isComplete()) {
|
if (this.publicKeyRing.isComplete()) {
|
||||||
|
|
|
@ -220,7 +220,8 @@ WalletFactory.prototype.joinCreateSession = function(secret, nickname, passphras
|
||||||
this.log('\t### PrivateKey Initialized');
|
this.log('\t### PrivateKey Initialized');
|
||||||
var opts = {
|
var opts = {
|
||||||
copayerId: privateKey.getId(),
|
copayerId: privateKey.getId(),
|
||||||
netKey: s.netKey,
|
//netKey: s.netKey,
|
||||||
|
privkey: privateKey.getIdPriv()
|
||||||
};
|
};
|
||||||
self.network.cleanUp();
|
self.network.cleanUp();
|
||||||
self.network.start(opts, function() {
|
self.network.start(opts, function() {
|
||||||
|
|
|
@ -43,7 +43,8 @@ Network.prototype.cleanUp = function() {
|
||||||
this.started = false;
|
this.started = false;
|
||||||
this.connectedPeers = [];
|
this.connectedPeers = [];
|
||||||
this.peerId = null;
|
this.peerId = null;
|
||||||
this.netKey = null;
|
//this.netKey = null;
|
||||||
|
this.privkey = null; //TODO: hide privkey in a closure
|
||||||
this.copayerId = null;
|
this.copayerId = null;
|
||||||
this.signingKey = null;
|
this.signingKey = null;
|
||||||
this.allowedCopayerIds=null;
|
this.allowedCopayerIds=null;
|
||||||
|
@ -150,11 +151,14 @@ Network.prototype._addConnectedCopayer = function(copayerId, isInbound) {
|
||||||
this.emit('connect', copayerId);
|
this.emit('connect', copayerId);
|
||||||
};
|
};
|
||||||
|
|
||||||
Network.prototype._onData = function(encStr, isInbound, peerId) {
|
Network.prototype._onData = function(enchex, isInbound, peerId) {
|
||||||
var sig, payload;
|
var sig, payload;
|
||||||
|
var encbuf = new Buffer(enchex, 'hex');
|
||||||
|
|
||||||
|
var privkey = this.privkey;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
var data = this._decrypt(encStr);
|
var data = this._decrypt(privkey, encbuf);
|
||||||
payload= JSON.parse(data);
|
payload= JSON.parse(data);
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
this._deletePeer(peerId);
|
this._deletePeer(peerId);
|
||||||
|
@ -300,7 +304,8 @@ Network.prototype.start = function(opts, openCallback) {
|
||||||
|
|
||||||
if (this.started) return openCallback();
|
if (this.started) return openCallback();
|
||||||
|
|
||||||
this.netKey = opts.netKey;
|
//this.netKey = opts.netKey;
|
||||||
|
this.privkey = opts.privkey;
|
||||||
this.maxPeers = opts.maxPeers || this.maxPeers;
|
this.maxPeers = opts.maxPeers || this.maxPeers;
|
||||||
|
|
||||||
if (opts.token)
|
if (opts.token)
|
||||||
|
@ -344,7 +349,11 @@ Network.prototype.getPeer = function() {
|
||||||
return this.peer;
|
return this.peer;
|
||||||
};
|
};
|
||||||
|
|
||||||
Network.prototype._encrypt = function(payloadStr) {
|
Network.prototype._encrypt = function(pubkey, payload) {
|
||||||
|
var encrypted = bitcore.ECIES.encrypt(pubkey, payload);
|
||||||
|
return encrypted;
|
||||||
|
|
||||||
|
/*
|
||||||
var plainText = sjcl.codec.utf8String.toBits(payloadStr);
|
var plainText = sjcl.codec.utf8String.toBits(payloadStr);
|
||||||
var p = this.sjclParams;
|
var p = this.sjclParams;
|
||||||
ct = sjcl.encrypt(this.netKey, plainText, p);//,p, rp);
|
ct = sjcl.encrypt(this.netKey, plainText, p);//,p, rp);
|
||||||
|
@ -354,10 +363,15 @@ Network.prototype._encrypt = function(payloadStr) {
|
||||||
ct: c.ct,
|
ct: c.ct,
|
||||||
};
|
};
|
||||||
return JSON.stringify(toSend);
|
return JSON.stringify(toSend);
|
||||||
|
*/
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
Network.prototype._decrypt = function(encStr) {
|
Network.prototype._decrypt = function(privkey, encrypted) {
|
||||||
|
var decrypted = bitcore.ECIES.decrypt(privkey, encrypted);
|
||||||
|
return decrypted;
|
||||||
|
|
||||||
|
/*
|
||||||
var i = JSON.parse(encStr);
|
var i = JSON.parse(encStr);
|
||||||
for (var k in this.sjclParams) {
|
for (var k in this.sjclParams) {
|
||||||
i[k] = this.sjclParams[k];
|
i[k] = this.sjclParams[k];
|
||||||
|
@ -365,6 +379,7 @@ Network.prototype._decrypt = function(encStr) {
|
||||||
var str= JSON.stringify(i);
|
var str= JSON.stringify(i);
|
||||||
var pt = sjcl.decrypt(this.netKey, str);
|
var pt = sjcl.decrypt(this.netKey, str);
|
||||||
return pt;
|
return pt;
|
||||||
|
*/
|
||||||
};
|
};
|
||||||
|
|
||||||
Network.prototype._sendToOne = function(copayerId, payload, sig, cb) {
|
Network.prototype._sendToOne = function(copayerId, payload, sig, cb) {
|
||||||
|
@ -379,7 +394,8 @@ Network.prototype._sendToOne = function(copayerId, payload, sig, cb) {
|
||||||
};
|
};
|
||||||
|
|
||||||
Network.prototype.send = function(copayerIds, payload, cb) {
|
Network.prototype.send = function(copayerIds, payload, cb) {
|
||||||
if (!payload || !this.netKey) return cb();
|
//if (!payload || !this.netKey) return cb();
|
||||||
|
if (!payload) return cb();
|
||||||
|
|
||||||
var self=this;
|
var self=this;
|
||||||
if (!copayerIds) {
|
if (!copayerIds) {
|
||||||
|
@ -389,11 +405,14 @@ Network.prototype.send = function(copayerIds, payload, cb) {
|
||||||
|
|
||||||
var sig;
|
var sig;
|
||||||
var payloadStr = JSON.stringify(payload);
|
var payloadStr = JSON.stringify(payload);
|
||||||
var encPayload = this._encrypt(payloadStr);
|
var payloadBuf = new Buffer(payloadStr);
|
||||||
|
//var encPayload = this._encrypt(payloadStr);
|
||||||
if (Array.isArray(copayerIds)) {
|
if (Array.isArray(copayerIds)) {
|
||||||
var l = copayerIds.length;
|
var l = copayerIds.length;
|
||||||
var i = 0;
|
var i = 0;
|
||||||
copayerIds.forEach(function(copayerId) {
|
copayerIds.forEach(function(copayerId) {
|
||||||
|
var copayerIdBuf = new Buffer(copayerId, 'hex');
|
||||||
|
var encPayload = self._encrypt(copayerIdBuf, payloadBuf);
|
||||||
self._sendToOne(copayerId, encPayload, sig, function () {
|
self._sendToOne(copayerId, encPayload, sig, function () {
|
||||||
if (++i === l && typeof cb === 'function') cb();
|
if (++i === l && typeof cb === 'function') cb();
|
||||||
});
|
});
|
||||||
|
|
Loading…
Reference in New Issue