UNPKG

icewallet

Version:

Cold storage enabled command line bitcoin wallet based on bitpay's bitcore

186 lines 17.4 kB
"use strict"; var bitcore = require('bitcore-lib'); const async = require('async'); const InsightService_1 = require('../Services/InsightService'); const PublicWalletInfo_1 = require('../Models/PublicWalletInfo'); const WalletService_1 = require('./WalletService'); const cerialize_1 = require('cerialize'); class PublicWalletService extends WalletService_1.default { constructor(info, password) { super(info, password); this.insightService = new InsightService_1.InsightService('https://insight.bitpay.com/api/'); this.changeAddresses = []; this.externalAddresses = []; } static openWallet(password, encryptedInfo, callback) { this.cryptoService.decrypt(password, encryptedInfo, (err, decrypted) => { if (err) { return callback(err, null, null); } else if (decrypted.startsWith('xpub')) { let error = 'This version of Icewallet is not compatable with your wallet\n'; error += 'Please create a new wallet with your public key\n'; error += decrypted + '\n'; error += 'Then use the "Next Unused Address Indexes" option to update your private wallet'; return callback(error, null, null); } try { var json = JSON.parse(decrypted); var walletInfo = cerialize_1.Deserialize(json, PublicWalletInfo_1.PublicWalletInfo); var wallet = new PublicWalletService(walletInfo, password); } catch (err) { return callback('Could not create wallet, check your xpub or password', decrypted, null); } return callback(null, decrypted, wallet); }); } get balance() { var changeBalance = 0; var externalBalance = 0; if (this.changeAddresses.length > 0) { changeBalance = this.changeAddresses.map((addr) => addr.balanceSat).reduce((p, c) => c + p); } if (this.externalAddresses.length > 0) { externalBalance = this.externalAddresses.map((addr) => addr.balanceSat).reduce((p, c) => c + p); } return changeBalance + externalBalance; } getAddressInfo(index, change, callback) { var address = this.address(index, change); this.insightService.getAddressInfo(address, (err, resp, body) => { if (err) { return callback(err, null); } return callback(null, JSON.parse(body)); }); } switchAccount(accountName, callback) { this.selectedAccount = this.walletInfo.accounts.find(account => account.name == accountName); console.log('updating wallet account...'); return this.update(callback); } getTransactions(change, callback) { var startingAddress = 0; var addrs = this.addressRange(startingAddress, startingAddress + 19, change); var transactions = []; var self = this; function combine(err, resp, body) { if (err) { return callback(err, null); } var transactionBatch = JSON.parse(body).items; transactionBatch.forEach((utxo) => transactions.push(utxo)); if (transactionBatch.length > 0) { startingAddress += 20; addrs = self.addressRange(startingAddress, startingAddress + 19, change); self.insightService.getTransactions(addrs, combine); } else { return callback(err, transactions); } } this.insightService.getTransactions(addrs, combine); } getAddresses(change, callback) { var maxConcurrency = 3; var maxUnusedAddresses = 5; var index = 0; var emptyAddressCount = 0; var addresses = []; var errors = []; function taskCallback(error) { if (error) { return errors.push(error); } } var q = async.queue((task, callback) => { this.getAddressInfo(task.index, change, (err, address) => { if (err) { return callback(err); } if (address.txApperances == 0) { emptyAddressCount++; } else { addresses[task.index] = address; } if (emptyAddressCount < maxUnusedAddresses) { q.push({ index: index }, taskCallback); } index++; return callback(); }); }, maxConcurrency); for (index = 0; index < maxConcurrency; index++) { q.push({ index: index }, taskCallback); } q.drain = () => { return callback(errors.length > 0 ? errors : null, addresses); }; } update(callback) { async.series([ (cb) => this.getAddresses(false, cb), (cb) => this.getAddresses(true, cb), ], (err, results) => { if (err) { return callback(err, null); } this.externalAddresses = results[0]; this.changeAddresses = results[1]; return callback(null, this); }); } createTransaction(to, amount, callback) { var addrs = []; var total = 0; var standardFee = 15000; var addrsWithBalance = this.externalAddresses.concat(this.changeAddresses) .filter((addr) => addr.balanceSat > 0); addrsWithBalance.forEach((addr) => { if (total < amount + standardFee) { addrs.push(addr.addrStr); total += addr.balanceSat; } }); if (total < amount + standardFee) { return callback('you dont have enough coins for this transaction plus a fee', null); } this.insightService.getUtxos(addrs, (err, utxos) => { if (err) { return callback(err, null); } var utxosForTransaction = utxos.map((utxo) => { return { address: utxo.address, txId: utxo.txid, outputIndex: utxo.vout, script: utxo.scriptPubKey, satoshis: utxo.satoshis }; }); var transaction = new bitcore.Transaction() .from(utxosForTransaction) .to(to, amount); return callback(null, JSON.stringify(transaction.toObject())); }); } broadcastTransaction(serializedTransaction, callback) { var transaction = new bitcore.Transaction(JSON.parse(serializedTransaction)); this.insightService.broadcastTransaction(transaction.serialize(), callback); } exportInfo(callback) { PublicWalletService.cryptoService.deriveKey(this.password, (err, key) => { if (err) { return callback(err, null); } var serialized = cerialize_1.Serialize(this.walletInfo); var stringified = JSON.stringify(serialized); let encrypted = PublicWalletService.cryptoService.encrypt(key, stringified); return callback(null, encrypted); }); } } exports.PublicWalletService = PublicWalletService; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"PublicWalletService.js","sourceRoot":"","sources":["../../../src/Services/PublicWalletService.ts"],"names":[],"mappings":"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"}