diff --git a/public/views/paperWallet.html b/public/views/paperWallet.html index 120aadc81..e147a4bcd 100644 --- a/public/views/paperWallet.html +++ b/public/views/paperWallet.html @@ -43,7 +43,7 @@ ng-disabled="paperWallet.scanning || !paperWallet.scannedKey" ng-style="{'background-color':index.backgroundColor}" class="button black round expand" - ng-click="paperWallet.createTx(inputData, passphrase)" + ng-click="paperWallet.scanFunds()" translate>Scan Wallet Funds @@ -62,7 +62,7 @@ ng-disabled="paperWallet.sending" ng-style="{'background-color':index.backgroundColor}" class="button black round expand" - ng-click="paperWallet.transaction()" + ng-click="paperWallet.sweepWallet()" translate>Sweep Wallet
diff --git a/src/js/controllers/paperWallet.js b/src/js/controllers/paperWallet.js index 3ca58a778..33cb066a8 100644 --- a/src/js/controllers/paperWallet.js +++ b/src/js/controllers/paperWallet.js @@ -1,5 +1,5 @@ angular.module('copayApp.controllers').controller('paperWalletController', - function($scope, $http, $timeout, configService, profileService, go, addressService, bitcore) { + function($scope, $http, $timeout, $log, configService, profileService, go, addressService, bitcore) { self = this; var fc = profileService.focusedClient; var rawTx; @@ -10,99 +10,104 @@ angular.module('copayApp.controllers').controller('paperWalletController', } self.onData = function(data) { + self.error = ''; self.scannedKey = data; self.isPkEncrypted = (data.charAt(0) == '6'); } - self.createTx = function(privateKey, passphrase) { - if (privateKey.charAt(0) != '6') { - var isValidKey = self.checkPrivateKey(privateKey); + self.scanFunds = function() { + function getPrivateKey(scannedKey, isPkEncrypted, passphrase, cb) { + if (!isPkEncrypted) return cb(null, scannedKey); + fc.decryptBIP38PrivateKey(scannedKey, passphrase, null, cb); + }; - if (!isValidKey) return; + function getBalance(privateKey, cb) { + fc.getBalanceFromPrivateKey(privateKey, cb); + }; + + function checkPrivateKey(privateKey) { + try { + new bitcore.PrivateKey(privateKey, 'livenet'); + } catch (err) { + return false; + } + return true; } - var config = configService.getSync().wallet.settings; - self.error = null; self.scanning = true; + self.privateKey = ''; + self.error = ''; $timeout(function() { - self.getRawTx(privateKey, passphrase, function(err, rawtx, balance) { - self.scanning = false; - - if (err) - self.error = err.toString(); - else { - self.balance = profileService.formatAmount(balance) + ' ' + config.unitName; - rawTx = rawtx; + getPrivateKey(self.scannedKey, self.isPkEncrypted, $scope.passphrase, function(err, privateKey) { + if (err) { + $log.error(err); + self.error = 'Could not get private key'; + self.scanning = false; + return; } + if (!checkPrivateKey(privateKey)) { + self.error = 'Invalid private key'; + self.scanning = false; + return; + } + self.privateKey = privateKey; - $timeout(function() { - $scope.$apply(); - }, 1); - }); - }, 100); - }; - - self.checkPrivateKey = function(privateKey) { - try { - new bitcore.PrivateKey(privateKey, 'livenet'); - } catch (err) { - self.error = err.toString(); - return false; - } - return true; - } - - self.getRawTx = function(scannedKey, passphrase, cb) { - function buildTx(privateKey, cb) { - fc.getBalanceFromPrivateKey(privateKey, function(err, balance) { - if (err) return cb(err) - - addressService.getAddress(fc.credentials.walletId, true, function(err, destinationAddress) { - if (err) return cb(err); - - fc.buildTxFromPrivateKey(privateKey, destinationAddress, null, function(err, tx) { - if (err) return cb(err); - return cb(null, tx.serialize(), balance); - }); - }); - }); - } - - if (scannedKey.charAt(0) == '6') { - fc.decryptBIP38PrivateKey(scannedKey, passphrase, null, function(err, privateKey) { - if (err) return cb(err); - buildTx(privateKey, cb); - }); - } else { - buildTx(scannedKey, cb); - } - }; - - self.transaction = function() { - self.error = null; - self.sending = true; - $timeout(function() { - self.doTransaction(rawTx).then(function(err, response) { - self.sending = false; - self.goHome(); - }, - function(err) { - self.sending = false; - self.error = err.toString(); + getBalance(privateKey, function(err, balance) { + self.scanning = false; + if (err) { + $log.error(err); + self.error = 'Could not get balance'; + self.scanning = false; + return; + } + var config = configService.getSync().wallet.settings; + self.balance = profileService.formatAmount(balance) + ' ' + config.unitName; $timeout(function() { $scope.$apply(); }, 1); }); + }); + }, 100); + } + + self.sweepWallet = function() { + self.sending = true; + self.error = ''; + $timeout(function() { + addressService.getAddress(fc.credentials.walletId, true, function(err, destinationAddress) { + if (err) { + $log.error(err); + self.error = 'Could not get destination address'; + self.sending = false; + return; + } + + fc.buildTxFromPrivateKey(self.privateKey, destinationAddress, null, function(err, tx) { + if (err) { + $log.error(err); + self.error = 'Could not build transaction'; + self.sending = false; + return; + } + + fc.broadcastRawTx({ + rawTx: tx.serialize(), + network: 'livenet' + }, function(err, txid) { + if (err) { + $log.error(err); + self.error = 'Could not broadcast transaction'; + self.sending = false; + return; + } + + $timeout(function() { + $scope.$apply(); + }, 1); + go.walletHome(); + }); + }); + }); }, 100); }; - - self.goHome = function() { - go.walletHome(); - }; - - self.doTransaction = function(rawTx) { - return $http.post('https://insight.bitpay.com/api/tx/send', { - rawtx: rawTx - }); - }; });