|
@ -11,12 +11,26 @@ var Storage = require('./storage'); |
|
|
var Wallet = require('./model/wallet'); |
|
|
var Wallet = require('./model/wallet'); |
|
|
var Copayer = require('./model/copayer'); |
|
|
var Copayer = require('./model/copayer'); |
|
|
|
|
|
|
|
|
|
|
|
/** |
|
|
|
|
|
* Creates an instance of the Copay server. |
|
|
|
|
|
* @constructor |
|
|
|
|
|
*/ |
|
|
function CopayServer(opts) { |
|
|
function CopayServer(opts) { |
|
|
opts = opts || {}; |
|
|
opts = opts || {}; |
|
|
this.storage = new Storage(opts); |
|
|
this.storage = new Storage(opts); |
|
|
}; |
|
|
}; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/** |
|
|
|
|
|
* Creates a new wallet. |
|
|
|
|
|
* @param {object} opts |
|
|
|
|
|
* @param {string} opts.id - The wallet id. |
|
|
|
|
|
* @param {string} opts.name - The wallet name. |
|
|
|
|
|
* @param {number} opts.m - Required copayers. |
|
|
|
|
|
* @param {number} opts.n - Total copayers. |
|
|
|
|
|
* @param {string} opts.pubKey - Public key to verify copayers joining have access to the wallet secret. |
|
|
|
|
|
* @param {string} [opts.network = 'livenet'] - The Bitcoin network for this wallet. |
|
|
|
|
|
*/ |
|
|
CopayServer.prototype.createWallet = function (opts, cb) { |
|
|
CopayServer.prototype.createWallet = function (opts, cb) { |
|
|
var self = this; |
|
|
var self = this; |
|
|
|
|
|
|
|
@ -37,6 +51,13 @@ CopayServer.prototype.createWallet = function (opts, cb) { |
|
|
}); |
|
|
}); |
|
|
}; |
|
|
}; |
|
|
|
|
|
|
|
|
|
|
|
/** |
|
|
|
|
|
* Retrieves a wallet from storage. |
|
|
|
|
|
* @param {object} opts |
|
|
|
|
|
* @param {string} opts.id - The wallet id. |
|
|
|
|
|
* @param {truthy} opts.includeCopayers - Fetch wallet along with list of copayers. |
|
|
|
|
|
* @returns {Object} wallet |
|
|
|
|
|
*/ |
|
|
CopayServer.prototype.getWallet = function (opts, cb) { |
|
|
CopayServer.prototype.getWallet = function (opts, cb) { |
|
|
var self = this; |
|
|
var self = this; |
|
|
|
|
|
|
|
@ -54,7 +75,15 @@ CopayServer.prototype.getWallet = function (opts, cb) { |
|
|
}); |
|
|
}); |
|
|
}; |
|
|
}; |
|
|
|
|
|
|
|
|
|
|
|
/** |
|
|
|
|
|
* Joins a wallet in creation. |
|
|
|
|
|
* @param {object} opts |
|
|
|
|
|
* @param {string} opts.walletId - The wallet id. |
|
|
|
|
|
* @param {string} opts.id - The copayer id. |
|
|
|
|
|
* @param {string} opts.name - The copayer name. |
|
|
|
|
|
* @param {number} opts.xPubKey - Extended Public Key for this copayer. |
|
|
|
|
|
* @param {number} opts.xPubKeySignature - Signature of xPubKey using the wallet pubKey. |
|
|
|
|
|
*/ |
|
|
CopayServer.prototype.joinWallet = function (opts, cb) { |
|
|
CopayServer.prototype.joinWallet = function (opts, cb) { |
|
|
var self = this; |
|
|
var self = this; |
|
|
|
|
|
|
|
@ -169,14 +198,6 @@ CopayServer.prototype._doCreateTx = function (opts, cb) { |
|
|
return tx; |
|
|
return tx; |
|
|
}; |
|
|
}; |
|
|
|
|
|
|
|
|
// opts = {
|
|
|
|
|
|
// copayerId,
|
|
|
|
|
|
// walletId,
|
|
|
|
|
|
// toAddress,
|
|
|
|
|
|
// amount, // in Satoshi
|
|
|
|
|
|
// message,
|
|
|
|
|
|
// otToken, // one time random token generated by the client and signed to avoid replay attacks
|
|
|
|
|
|
// utxos: [], // optional (not yet implemented)
|
|
|
|
|
|
// requestSignature, // S(toAddress + amount + otToken) using this copayers privKey
|
|
|
// requestSignature, // S(toAddress + amount + otToken) using this copayers privKey
|
|
|
// // using this signature, the server can
|
|
|
// // using this signature, the server can
|
|
|
// };
|
|
|
// };
|
|
@ -185,7 +206,20 @@ CopayServer.prototype._doCreateTx = function (opts, cb) { |
|
|
// ntxid,
|
|
|
// ntxid,
|
|
|
// rawTx,
|
|
|
// rawTx,
|
|
|
// };
|
|
|
// };
|
|
|
|
|
|
/** |
|
|
|
|
|
* Creates a new transaction proposal. |
|
|
|
|
|
* @param {object} opts |
|
|
|
|
|
* @param {string} opts.walletId - The wallet id. |
|
|
|
|
|
* @param {string} opts.copayerId - The wallet id. |
|
|
|
|
|
* @param {truthy} opts.otToken - A one-time token used to avoid reply attacks. |
|
|
|
|
|
* @param {string} opts.toAddress - Destination address. |
|
|
|
|
|
* @param {number} opts.amount - Amount to transfer in satoshi. |
|
|
|
|
|
* @param {string} opts.message - A message to attach to this transaction. |
|
|
|
|
|
* @param {string} opts.requestSignature - Signature of the request (toAddress + amount + otToken). |
|
|
|
|
|
* @returns {Object} result |
|
|
|
|
|
* @returns {Object} result.ntxid - Id of the transaction proposal. |
|
|
|
|
|
* @returns {Object} result.rawTx - Raw transaction. |
|
|
|
|
|
*/ |
|
|
CopayServer.prototype.createTx = function (opts, cb) { |
|
|
CopayServer.prototype.createTx = function (opts, cb) { |
|
|
// Client generates a unique token and signs toAddress + amount + token.
|
|
|
// Client generates a unique token and signs toAddress + amount + token.
|
|
|
// This way we authenticate + avoid replay attacks.
|
|
|
// This way we authenticate + avoid replay attacks.
|
|
|