* Oauth2 and first view * Connect with Coinbase using mobile * Buy and Sell through Coinbase * Fix buy * Receive and send bitcoin to Coinbase account * Receive bitcoin from Coinbase to Copay * Complete user and account information. Connection errors * Improves error handler * Removes console.log * Coinbase background color. Send to Coinbase form validation * Fix send from different wallet * Send and receive using Coinbase * Pagination activity * Fix Buy and Sell * One option in the sidebar to Buy and Sell * Native balance on Coinbase homepage * Rename receive and send * Auto-close window after authenticate * Reorder * Get payment methods * Fix when token expired * Fix token expired * Integration: sell and send to Coinbase * Store pending transaction before sell * Sell flow completed * Removing files * Fix sell * Fix sell * Fix sell * Sell completed * Buy bitcoin through coinbase * Buy auto * Currency set to USD * Select payment methods. Limits * Removes payment methods from preferences * Fix signs. Tx ordered by updated. Minor fixes * Removes console.log * Improving ux-language things * Fix selectedpaymentmethod if not verified * Set error if tx not found * Price sensitivity. Minor fixes * Adds coinbase api key to gitignore * Coinbase production ready * Fix sell in usd * Bug fixes * New Sensitivity step * Refresh token with a simple click * Refresh token * Refactor * Fix auto reconnect if token expired Signed-off-by: Gustavo Maximiliano Cortez <cmgustavo83@gmail.com> * Fix calls if token expired
101 lines
3 KiB
JavaScript
101 lines
3 KiB
JavaScript
'use strict';
|
|
|
|
angular.module('copayApp.controllers').controller('preferencesController',
|
|
function($scope, $rootScope, $timeout, $log, configService, profileService, txService) {
|
|
|
|
var fc = profileService.focusedClient;
|
|
$scope.deleted = false;
|
|
if (fc.credentials && !fc.credentials.mnemonicEncrypted && !fc.credentials.mnemonic) {
|
|
$scope.deleted = true;
|
|
}
|
|
|
|
this.init = function() {
|
|
var config = configService.getSync();
|
|
var fc = profileService.focusedClient;
|
|
if (fc) {
|
|
$scope.encrypt = fc.hasPrivKeyEncrypted();
|
|
this.externalSource = fc.getPrivKeyExternalSourceName() == 'ledger' ? "Ledger" : null;
|
|
// TODO externalAccount
|
|
//this.externalIndex = fc.getExternalIndex();
|
|
}
|
|
|
|
if (window.touchidAvailable) {
|
|
var walletId = fc.credentials.walletId;
|
|
this.touchidAvailable = true;
|
|
config.touchIdFor = config.touchIdFor || {};
|
|
$scope.touchid = config.touchIdFor[walletId];
|
|
}
|
|
};
|
|
|
|
var unwatchEncrypt = $scope.$watch('encrypt', function(val) {
|
|
var fc = profileService.focusedClient;
|
|
if (!fc) return;
|
|
|
|
if (val && !fc.hasPrivKeyEncrypted()) {
|
|
$rootScope.$emit('Local/NeedsPassword', true, function(err, password) {
|
|
if (err || !password) {
|
|
$scope.encrypt = false;
|
|
return;
|
|
}
|
|
profileService.setPrivateKeyEncryptionFC(password, function() {
|
|
$rootScope.$emit('Local/NewEncryptionSetting');
|
|
$scope.encrypt = true;
|
|
});
|
|
});
|
|
} else {
|
|
if (!val && fc.hasPrivKeyEncrypted()) {
|
|
profileService.unlockFC({}, function(err) {
|
|
if (err) {
|
|
$scope.encrypt = true;
|
|
return;
|
|
}
|
|
profileService.disablePrivateKeyEncryptionFC(function(err) {
|
|
$rootScope.$emit('Local/NewEncryptionSetting');
|
|
if (err) {
|
|
$scope.encrypt = true;
|
|
$log.error(err);
|
|
return;
|
|
}
|
|
$scope.encrypt = false;
|
|
});
|
|
});
|
|
}
|
|
}
|
|
});
|
|
|
|
var unwatchRequestTouchid = $scope.$watch('touchid', function(newVal, oldVal) {
|
|
if (newVal == oldVal || $scope.touchidError) {
|
|
$scope.touchidError = false;
|
|
return;
|
|
}
|
|
var walletId = profileService.focusedClient.credentials.walletId;
|
|
|
|
var opts = {
|
|
touchIdFor: {}
|
|
};
|
|
opts.touchIdFor[walletId] = newVal;
|
|
|
|
txService.setTouchId(function(err) {
|
|
if (err) {
|
|
$log.debug(err);
|
|
$timeout(function() {
|
|
$scope.touchidError = true;
|
|
$scope.touchid = oldVal;
|
|
}, 100);
|
|
} else {
|
|
configService.set(opts, function(err) {
|
|
if (err) {
|
|
$log.debug(err);
|
|
$scope.touchidError = true;
|
|
$scope.touchid = oldVal;
|
|
}
|
|
});
|
|
}
|
|
});
|
|
});
|
|
|
|
$scope.$on('$destroy', function() {
|
|
unwatchEncrypt();
|
|
unwatchRequestTouchid();
|
|
});
|
|
});
|