You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

77 lines
1.7 KiB

10 years ago
'use strict';
var $ = require('preconditions').singleton();
10 years ago
var _ = require('lodash');
var util = require('util');
var Bitcore = require('bitcore');
var HDPublicKey = Bitcore.HDPublicKey;
10 years ago
var Uuid = require('uuid');
var AddressManager = require('./addressmanager');
10 years ago
var Utils = require('../walletutils');
10 years ago
var RO_SIGNING_PATH = "m/1/0";
var RW_SIGNING_PATH = "m/1/1";
10 years ago
function Copayer() {
this.version = '1.0.0';
};
Copayer.create = function(opts) {
$.checkArgument(opts && opts.xPubKey, 'need to provide an xPubKey');
10 years ago
opts.copayerIndex = opts.copayerIndex || 0;
10 years ago
var x = new Copayer();
x.createdOn = Math.floor(Date.now() / 1000);
x.xPubKey = opts.xPubKey;
x.id = Utils.xPubToCopayerId(x.xPubKey);
x.name = opts.name;
x.xPubKeySignature = opts.xPubKeySignature; // So third parties can check independently
10 years ago
x.roPubKey = x.getROPubKey();
x.rwPubKey = x.getRWPubKey();
x.addressManager = AddressManager.create({
copayerIndex: opts.copayerIndex
});
return x;
10 years ago
};
10 years ago
Copayer.fromObj = function(obj) {
var x = new Copayer();
10 years ago
x.createdOn = obj.createdOn;
x.id = obj.id;
x.name = obj.name;
x.xPubKey = obj.xPubKey;
x.xPubKeySignature = obj.xPubKeySignature;
10 years ago
x.roPubKey = obj.roPubKey;
x.rwPubKey = obj.rwPubKey;
x.addressManager = AddressManager.fromObj(obj.addressManager);
10 years ago
return x;
};
10 years ago
Copayer.prototype.getPublicKey = function(path) {
return HDPublicKey
.fromString(this.xPubKey)
.derive(path)
.publicKey
.toString();
};
10 years ago
Copayer.prototype.getROPubKey = function() {
return this.getPublicKey(RO_SIGNING_PATH);
};
10 years ago
Copayer.prototype.getRWPubKey = function() {
return this.getPublicKey(RW_SIGNING_PATH);
};
10 years ago
module.exports = Copayer;