Wallet/src/js/services/incomingData.js

198 lines
5.7 KiB
JavaScript
Raw Normal View History

2016-08-25 11:18:10 -03:00
'use strict';
2016-10-19 16:52:55 -04:00
angular.module('copayApp.services').factory('incomingData', function($log, $state, $window, $timeout, bitcore, profileService, popupService, ongoingProcess, platformInfo, gettextCatalog, $rootScope) {
2016-08-25 11:18:10 -03:00
var root = {};
root.showMenu = function(data) {
$rootScope.$broadcast('incomingDataMenu.showMenu', data);
};
root.redir = function(data) {
$log.debug('Processing incoming data: ' + data);
2016-08-25 11:18:10 -03:00
function sanitizeUri(data) {
// Fixes when a region uses comma to separate decimals
var regex = /[\?\&]amount=(\d+([\,\.]\d+)?)/i;
var match = regex.exec(data);
if (!match || match.length === 0) {
return data;
}
var value = match[0].replace(',', '.');
var newUri = data.replace(regex, value);
// mobile devices, uris like copay://glidera
newUri.replace('://', ':');
return newUri;
}
2016-08-25 11:18:10 -03:00
2016-10-06 19:23:39 -03:00
function getParameterByName(name, url) {
if (!url) return;
name = name.replace(/[\[\]]/g, "\\$&");
var regex = new RegExp("[?&]" + name + "(=([^&#]*)|&|#|$)"),
results = regex.exec(url);
if (!results) return null;
if (!results[2]) return '';
return decodeURIComponent(results[2].replace(/\+/g, " "));
}
2016-08-25 11:18:10 -03:00
// data extensions for Payment Protocol with non-backwards-compatible request
if ((/^bitcoin:\?r=[\w+]/).exec(data)) {
data = decodeURIComponent(data.replace('bitcoin:?r=', ''));
2016-10-12 09:38:41 -03:00
$state.go('tabs.send').then(function() {
$state.transitionTo('tabs.send.confirm', {paypro: data});
2016-10-12 09:38:41 -03:00
});
return true;
2016-08-25 11:18:10 -03:00
}
data = sanitizeUri(data);
//data = 'msEVvmpiFEtXv3MdsFLUYMbnNLeNYrqBEA';
2016-08-25 11:18:10 -03:00
// BIP21
2016-08-25 11:18:10 -03:00
if (bitcore.URI.isValid(data)) {
var parsed = new bitcore.URI(data);
var addr = parsed.address ? parsed.address.toString() : '';
var message = parsed.message;
var amount = parsed.amount ? parsed.amount : '';
2016-10-20 18:04:45 -04:00
if (parsed.r) {
getPayProDetails(parsed.r, function(err, details) {
handlePayPro(details);
});
} else {
$state.go('tabs.send');
// Timeout is required to enable the "Back" button
$timeout(function() {
if (amount) {
$state.transitionTo('tabs.send.confirm', {toAmount: amount, toAddress: addr, description:message});
} else {
$state.transitionTo('tabs.send.amount', {toAddress: addr});
}
2016-10-20 18:04:45 -04:00
});
}
2016-08-25 11:18:10 -03:00
return true;
// Plain URL
} else if (/^https?:\/\//.test(data)) {
2016-08-25 11:18:10 -03:00
2016-10-13 18:29:03 -04:00
getPayProDetails(data, function(err, details) {
if(err) {
root.showMenu({data: data, type: 'url'});
2016-10-13 18:29:03 -04:00
return;
}
handlePayPro(details);
2016-10-13 18:29:03 -04:00
return true;
});
// Plain Address
} else if (bitcore.Address.isValid(data, 'livenet') || bitcore.Address.isValid(data, 'testnet')) {
if($state.includes('tabs.scan')) {
root.showMenu({data: data, type: 'bitcoinAddress'});
} else {
goToAmountPage(data);
}
} else if (data && data.indexOf($window.appConfig.name + '://glidera') === 0) {
return $state.go('uriglidera', {url: data});
2016-10-19 16:45:29 -04:00
} else if (data && data.indexOf($window.appConfig.name + '://coinbase') === 0) {
return $state.go('uricoinbase', {url: data});
// BitPayCard Authentication
} else if (data && data.indexOf($window.appConfig.name + '://') === 0) {
var secret = getParameterByName('secret', data);
var email = getParameterByName('email', data);
var otp = getParameterByName('otp', data);
$state.go('tabs.home').then(function() {
$state.transitionTo('tabs.bitpayCardIntro', {
secret: secret,
email: email,
otp: otp
});
2016-10-06 19:23:39 -03:00
});
return true;
2016-10-06 19:23:39 -03:00
2016-08-25 11:18:10 -03:00
// Join
2016-09-22 19:27:59 -03:00
} else if (data && data.match(/^copay:[0-9A-HJ-NP-Za-km-z]{70,80}$/)) {
2016-10-12 09:38:41 -03:00
$state.go('tabs.home').then(function() {
$state.transitionTo('tabs.add.join', {url: data});
2016-10-12 09:38:41 -03:00
});
return true;
2016-08-25 11:18:10 -03:00
// Old join
2016-09-22 19:27:59 -03:00
} else if (data && data.match(/^[0-9A-HJ-NP-Za-km-z]{70,80}$/)) {
2016-10-12 09:38:41 -03:00
$state.go('tabs.home').then(function() {
$state.transitionTo('tabs.add.join', {url: data});
2016-10-12 09:38:41 -03:00
});
return true;
2016-10-19 13:53:18 -04:00
} else {
if($state.includes('tabs.scan')) {
root.showMenu({data: data, type: 'text'});
}
2016-08-25 11:18:10 -03:00
}
return false;
};
2016-10-13 18:29:03 -04:00
function getPayProDetails(uri, cb) {
if (!cb) cb = function() {};
var wallet = profileService.getWallets({
onlyComplete: true
})[0];
if (!wallet) return cb();
if (platformInfo.isChromeApp) {
popupService.showAlert(gettextCatalog.getString('Payment Protocol not supported on Chrome App'));
return cb(true);
}
$log.debug('Fetch PayPro Request...', uri);
ongoingProcess.set('fetchingPayPro', true);
2016-10-19 16:45:29 -04:00
2016-10-13 18:29:03 -04:00
wallet.fetchPayPro({
payProUrl: uri,
}, function(err, paypro) {
ongoingProcess.set('fetchingPayPro', false);
2016-10-13 18:29:03 -04:00
if (err) {
return cb(true);
}
if (!paypro.verified) {
$log.warn('Failed to verify payment protocol signatures');
popupService.showAlert(gettextCatalog.getString('Payment Protocol Invalid'));
return cb(true);
}
cb(null, paypro);
2016-10-13 18:29:03 -04:00
});
}
2016-10-13 18:29:03 -04:00
function goToAmountPage(toAddress) {
$state.go('tabs.send');
$timeout(function() {
$state.transitionTo('tabs.send.amount', {toAddress: toAddress});
}, 100);
}
function handlePayPro(payProDetails){
var stateParams = {
toAmount: payProDetails.amount,
toAddress: payProDetails.toAddress,
description: payProDetails.memo,
paypro: payProDetails
};
$state.go('tabs.send').then(function() {
$timeout(function() {
$state.transitionTo('tabs.send.confirm', stateParams);
});
});
}
2016-08-25 11:18:10 -03:00
return root;
});