2016-05-13 11:48:48 -03:00
|
|
|
'use strict';
|
|
|
|
|
|
2016-07-13 14:00:21 -03:00
|
|
|
angular.module('copayApp.controllers').controller('buyAmazonController',
|
2016-07-21 11:18:48 -03:00
|
|
|
function($rootScope, $scope, $ionicModal, $log, $timeout, $state, lodash, profileService, bwcError, configService, walletService, fingerprintService, amazonService, ongoingProcess) {
|
2016-07-13 14:00:21 -03:00
|
|
|
|
2016-05-13 11:48:48 -03:00
|
|
|
var self = this;
|
2016-06-13 15:00:17 -03:00
|
|
|
var client;
|
2016-05-13 11:48:48 -03:00
|
|
|
|
|
|
|
|
var handleEncryptedWallet = function(client, cb) {
|
|
|
|
|
if (!walletService.isEncrypted(client)) return cb();
|
|
|
|
|
$rootScope.$emit('Local/NeedsPassword', false, function(err, password) {
|
|
|
|
|
if (err) return cb(err);
|
|
|
|
|
return cb(walletService.unlock(client, password));
|
|
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
this.init = function() {
|
|
|
|
|
var network = configService.getSync().amazon.testnet ? 'testnet' : 'livenet';
|
|
|
|
|
amazonService.setCredentials(network);
|
2016-06-13 15:00:17 -03:00
|
|
|
self.allWallets = profileService.getWallets(network, 1);
|
|
|
|
|
client = profileService.focusedClient;
|
2016-07-21 11:18:48 -03:00
|
|
|
if (client && client.credentials.m == 1 && client.credentials.network == network) {
|
2016-06-13 15:00:17 -03:00
|
|
|
$timeout(function() {
|
|
|
|
|
self.selectedWalletId = client.credentials.walletId;
|
|
|
|
|
self.selectedWalletName = client.credentials.walletName;
|
|
|
|
|
$scope.$apply();
|
|
|
|
|
}, 100);
|
|
|
|
|
}
|
2016-05-13 11:48:48 -03:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
$scope.openWalletsModal = function(wallets) {
|
|
|
|
|
self.error = null;
|
|
|
|
|
|
2016-06-13 15:00:17 -03:00
|
|
|
$scope.type = 'SELL';
|
|
|
|
|
$scope.wallets = wallets;
|
2016-07-14 11:54:01 -03:00
|
|
|
$scope.self = self;
|
2016-05-13 11:48:48 -03:00
|
|
|
|
2016-06-13 15:00:17 -03:00
|
|
|
$ionicModal.fromTemplateUrl('views/modals/wallets.html', {
|
2016-07-14 11:54:01 -03:00
|
|
|
scope: $scope,
|
|
|
|
|
animation: 'slide-in-up'
|
2016-06-13 15:00:17 -03:00
|
|
|
}).then(function(modal) {
|
|
|
|
|
$scope.walletsModal = modal;
|
|
|
|
|
$scope.walletsModal.show();
|
2016-05-13 11:48:48 -03:00
|
|
|
});
|
|
|
|
|
|
2016-07-14 11:54:01 -03:00
|
|
|
$scope.$on('walletSelected', function(ev, walletId) {
|
2016-05-13 11:48:48 -03:00
|
|
|
$timeout(function() {
|
2016-07-14 11:54:01 -03:00
|
|
|
client = profileService.getClient(walletId);
|
|
|
|
|
self.selectedWalletId = walletId;
|
|
|
|
|
self.selectedWalletName = client.credentials.walletName;
|
2016-05-13 11:48:48 -03:00
|
|
|
$scope.$apply();
|
|
|
|
|
}, 100);
|
2016-06-13 15:00:17 -03:00
|
|
|
$scope.walletsModal.hide();
|
2016-05-13 11:48:48 -03:00
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
this.createTx = function() {
|
|
|
|
|
self.error = null;
|
2016-05-19 17:29:24 -03:00
|
|
|
self.errorInfo = null;
|
2016-05-13 11:48:48 -03:00
|
|
|
|
2016-05-19 01:18:15 -03:00
|
|
|
var currency_code = configService.getSync().amazon.testnet ? window.amazon_sandbox_currency_code : window.amazon_currency_code;
|
2016-07-13 14:00:21 -03:00
|
|
|
var dataSrc = {
|
2016-06-06 15:51:15 -03:00
|
|
|
currency: currency_code,
|
2016-07-21 11:18:48 -03:00
|
|
|
amount: $scope.fiat
|
2016-05-13 11:48:48 -03:00
|
|
|
};
|
|
|
|
|
var outputs = [];
|
|
|
|
|
var config = configService.getSync();
|
|
|
|
|
var configWallet = config.wallet;
|
|
|
|
|
var walletSettings = configWallet.settings;
|
|
|
|
|
|
|
|
|
|
|
2016-06-14 11:44:44 -03:00
|
|
|
ongoingProcess.set('Processing Transaction...', true);
|
2016-05-13 11:48:48 -03:00
|
|
|
$timeout(function() {
|
2016-07-21 11:18:48 -03:00
|
|
|
amazonService.createBitPayInvoice(dataSrc, function(err, dataInvoice) {
|
2016-05-13 11:48:48 -03:00
|
|
|
if (err) {
|
2016-06-14 11:44:44 -03:00
|
|
|
ongoingProcess.set('Processing Transaction...', false);
|
2016-07-13 14:00:21 -03:00
|
|
|
self.error = bwcError.msg(err);
|
2016-06-14 11:44:44 -03:00
|
|
|
$timeout(function() {
|
|
|
|
|
$scope.$digest();
|
|
|
|
|
});
|
2016-05-13 11:48:48 -03:00
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
2016-07-21 11:18:48 -03:00
|
|
|
amazonService.getBitPayInvoice(dataInvoice.invoiceId, function(err, invoice) {
|
2016-05-13 11:48:48 -03:00
|
|
|
if (err) {
|
2016-07-21 11:18:48 -03:00
|
|
|
ongoingProcess.set('Processing Transaction...', false);
|
2016-07-13 14:00:21 -03:00
|
|
|
self.error = bwcError.msg(err);
|
2016-06-14 11:44:44 -03:00
|
|
|
$timeout(function() {
|
|
|
|
|
$scope.$digest();
|
|
|
|
|
});
|
2016-05-13 11:48:48 -03:00
|
|
|
return;
|
|
|
|
|
}
|
2016-07-21 11:18:48 -03:00
|
|
|
|
|
|
|
|
var address, comment, amount;
|
|
|
|
|
|
|
|
|
|
address = invoice.bitcoinAddress;
|
|
|
|
|
amount = parseInt((invoice.btcPrice * 100000000).toFixed(0));
|
|
|
|
|
comment = 'Amazon.com Gift Card';
|
|
|
|
|
|
|
|
|
|
outputs.push({
|
|
|
|
|
'toAddress': address,
|
|
|
|
|
'amount': amount,
|
|
|
|
|
'message': comment
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
var txp = {
|
|
|
|
|
toAddress: address,
|
|
|
|
|
amount: amount,
|
|
|
|
|
outputs: outputs,
|
|
|
|
|
message: comment,
|
|
|
|
|
payProUrl: null,
|
|
|
|
|
excludeUnconfirmedUtxos: configWallet.spendUnconfirmed ? false : true,
|
|
|
|
|
feeLevel: walletSettings.feeLevel || 'normal'
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
walletService.createTx(client, txp, function(err, createdTxp) {
|
|
|
|
|
ongoingProcess.set('Processing Transaction...', false);
|
|
|
|
|
if (err) {
|
|
|
|
|
self.error = bwcError.msg(err);
|
|
|
|
|
$timeout(function() {
|
|
|
|
|
$scope.$digest();
|
|
|
|
|
});
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
$scope.$emit('Local/NeedsConfirmation', createdTxp, function(accept) {
|
|
|
|
|
if (accept) {
|
|
|
|
|
self.confirmTx(createdTxp, function(err, tx) {
|
2016-07-13 14:00:21 -03:00
|
|
|
if (err) {
|
2016-07-21 11:18:48 -03:00
|
|
|
ongoingProcess.set('Processing Transaction...', false);
|
2016-07-13 14:00:21 -03:00
|
|
|
self.error = bwcError.msg(err);
|
2016-06-14 11:44:44 -03:00
|
|
|
$timeout(function() {
|
|
|
|
|
$scope.$digest();
|
|
|
|
|
});
|
2016-05-13 11:48:48 -03:00
|
|
|
return;
|
|
|
|
|
}
|
2016-07-21 11:18:48 -03:00
|
|
|
var count = 0;
|
|
|
|
|
ongoingProcess.set('Processing Transaction...', true);
|
|
|
|
|
|
|
|
|
|
dataSrc.accessKey = dataInvoice.accessKey;
|
|
|
|
|
dataSrc.invoiceId = invoice.id;
|
|
|
|
|
dataSrc.invoiceUrl = invoice.url;
|
|
|
|
|
dataSrc.invoiceTime = invoice.invoiceTime;
|
|
|
|
|
|
|
|
|
|
self.debounceCreate(count, dataSrc);
|
2016-05-13 11:48:48 -03:00
|
|
|
});
|
2016-07-21 11:18:48 -03:00
|
|
|
}
|
|
|
|
|
});
|
2016-05-13 11:48:48 -03:00
|
|
|
});
|
|
|
|
|
});
|
|
|
|
|
});
|
|
|
|
|
}, 100);
|
|
|
|
|
};
|
|
|
|
|
|
2016-07-21 11:18:48 -03:00
|
|
|
self.debounceCreate = lodash.throttle(function(count, dataSrc) {
|
|
|
|
|
self.debounceCreateGiftCard(count, dataSrc);
|
|
|
|
|
}, 8000, {
|
|
|
|
|
'leading': true
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
self.debounceCreateGiftCard = function(count, dataSrc) {
|
|
|
|
|
|
|
|
|
|
amazonService.createGiftCard(dataSrc, function(err, giftCard) {
|
|
|
|
|
$log.debug("creating gift card " + count);
|
|
|
|
|
if (err) {
|
|
|
|
|
ongoingProcess.set('Processing Transaction...', false);
|
|
|
|
|
self.error = bwcError.msg(err);
|
|
|
|
|
self.errorInfo = dataSrc;
|
|
|
|
|
$timeout(function() {
|
|
|
|
|
$scope.$digest();
|
|
|
|
|
});
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
if (giftCard.status == 'PENDING' && count < 3) {
|
|
|
|
|
$log.debug("pending gift card not available yet");
|
|
|
|
|
self.debounceCreate(count + 1, dataSrc, dataSrc);
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var now = moment().unix();
|
|
|
|
|
|
|
|
|
|
var newData = giftCard;
|
|
|
|
|
newData['invoiceId'] = dataSrc.invoiceId;
|
|
|
|
|
newData['accessKey'] = dataSrc.accessKey;
|
|
|
|
|
newData['invoiceUrl'] = dataSrc.invoiceUrl;
|
|
|
|
|
newData['amount'] = dataSrc.amount;
|
|
|
|
|
newData['date'] = dataSrc.invoiceTime || now;
|
|
|
|
|
|
|
|
|
|
if (newData.status == 'expired') {
|
|
|
|
|
amazonService.savePendingGiftCard(newData, {
|
|
|
|
|
remove: true
|
|
|
|
|
}, function(err) {
|
|
|
|
|
return;
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
amazonService.savePendingGiftCard(newData, null, function(err) {
|
|
|
|
|
ongoingProcess.set('Processing Transaction...', false);
|
|
|
|
|
$log.debug("Saving new gift card with status: " + newData.status);
|
|
|
|
|
|
|
|
|
|
self.giftCard = newData;
|
|
|
|
|
if (newData.status == 'PENDING') $state.transitionTo('amazon');
|
|
|
|
|
$timeout(function() {
|
|
|
|
|
$scope.$digest();
|
|
|
|
|
});
|
|
|
|
|
});
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
2016-05-13 11:48:48 -03:00
|
|
|
this.confirmTx = function(txp, cb) {
|
|
|
|
|
|
2016-06-13 15:00:17 -03:00
|
|
|
fingerprintService.check(client, function(err) {
|
2016-05-13 11:48:48 -03:00
|
|
|
if (err) {
|
|
|
|
|
$log.debug(err);
|
|
|
|
|
return cb(err);
|
|
|
|
|
}
|
|
|
|
|
|
2016-06-13 15:00:17 -03:00
|
|
|
handleEncryptedWallet(client, function(err) {
|
2016-05-13 11:48:48 -03:00
|
|
|
if (err) {
|
|
|
|
|
$log.debug(err);
|
2016-07-13 14:00:21 -03:00
|
|
|
return bwcError.cb(err, null, cb);
|
2016-05-13 11:48:48 -03:00
|
|
|
}
|
|
|
|
|
|
2016-06-14 11:44:44 -03:00
|
|
|
ongoingProcess.set('Processing Transaction...', true);
|
2016-06-13 15:00:17 -03:00
|
|
|
walletService.publishTx(client, txp, function(err, publishedTxp) {
|
2016-05-13 11:48:48 -03:00
|
|
|
if (err) {
|
|
|
|
|
$log.debug(err);
|
2016-07-13 14:00:21 -03:00
|
|
|
return bwcError.cb(err, null, cb);
|
2016-05-13 11:48:48 -03:00
|
|
|
}
|
|
|
|
|
|
2016-06-13 15:00:17 -03:00
|
|
|
walletService.signTx(client, publishedTxp, function(err, signedTxp) {
|
|
|
|
|
walletService.lock(client);
|
2016-05-13 11:48:48 -03:00
|
|
|
if (err) {
|
|
|
|
|
$log.debug(err);
|
2016-06-13 15:00:17 -03:00
|
|
|
walletService.removeTx(client, signedTxp, function(err) {
|
2016-05-13 11:48:48 -03:00
|
|
|
if (err) $log.debug(err);
|
|
|
|
|
});
|
2016-07-13 14:00:21 -03:00
|
|
|
return bwcError.cb(err, null, cb);
|
2016-05-13 11:48:48 -03:00
|
|
|
}
|
|
|
|
|
|
2016-06-13 15:00:17 -03:00
|
|
|
walletService.broadcastTx(client, signedTxp, function(err, broadcastedTxp) {
|
2016-05-13 11:48:48 -03:00
|
|
|
if (err) {
|
|
|
|
|
$log.debug(err);
|
2016-06-13 15:00:17 -03:00
|
|
|
walletService.removeTx(client, broadcastedTxp, function(err) {
|
2016-05-13 11:48:48 -03:00
|
|
|
if (err) $log.debug(err);
|
|
|
|
|
});
|
2016-07-13 14:00:21 -03:00
|
|
|
return bwcError.cb(err, null, cb);
|
2016-05-13 11:48:48 -03:00
|
|
|
}
|
|
|
|
|
$timeout(function() {
|
|
|
|
|
return cb(null, broadcastedTxp);
|
|
|
|
|
}, 5000);
|
|
|
|
|
});
|
|
|
|
|
});
|
|
|
|
|
});
|
|
|
|
|
});
|
|
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
});
|