Wallet/src/js/services/glideraService.js

423 lines
14 KiB
JavaScript
Raw Normal View History

2015-08-28 18:23:24 -03:00
'use strict';
angular.module('copayApp.services').factory('glideraService', function($http, $log, $window, $filter, platformInfo, storageService, buyAndSellService, lodash, configService, txFormatService) {
2015-08-28 18:23:24 -03:00
var root = {};
var credentials = {};
var isCordova = platformInfo.isCordova;
2017-01-30 18:04:17 -03:00
var isWindowsPhoneApp = platformInfo.isWP && platformInfo.isCordova;
2015-09-07 18:48:47 -03:00
2017-01-30 18:04:17 -03:00
var setCredentials = function() {
2016-09-01 16:51:29 -03:00
if (!$window.externalServices || !$window.externalServices.glidera) {
return;
}
var glidera = $window.externalServices.glidera;
2016-08-24 11:33:43 -03:00
/*
* Development: 'testnet'
* Production: 'livenet'
*/
2016-12-05 11:57:13 -03:00
credentials.NETWORK = 'livenet';
2017-01-31 14:52:52 -03:00
//credentials.NETWORK = 'testnet';
2016-08-24 11:33:43 -03:00
if (credentials.NETWORK == 'testnet') {
2016-09-01 16:51:29 -03:00
credentials.HOST = glidera.sandbox.host;
if (isCordova) {
2016-09-01 16:51:29 -03:00
credentials.REDIRECT_URI = glidera.sandbox.mobile.redirect_uri;
credentials.CLIENT_ID = glidera.sandbox.mobile.client_id;
credentials.CLIENT_SECRET = glidera.sandbox.mobile.client_secret;
2016-08-19 23:45:44 -03:00
} else {
2016-09-01 16:51:29 -03:00
credentials.REDIRECT_URI = glidera.sandbox.desktop.redirect_uri;
credentials.CLIENT_ID = glidera.sandbox.desktop.client_id;
credentials.CLIENT_SECRET = glidera.sandbox.desktop.client_secret;
}
2016-08-19 23:45:44 -03:00
} else {
2016-09-01 16:51:29 -03:00
credentials.HOST = glidera.production.host;
2015-09-22 14:11:54 -03:00
if (isCordova) {
2016-09-01 16:51:29 -03:00
credentials.REDIRECT_URI = glidera.production.mobile.redirect_uri;
credentials.CLIENT_ID = glidera.production.mobile.client_id;
credentials.CLIENT_SECRET = glidera.production.mobile.client_secret;
2016-08-19 23:45:44 -03:00
} else {
2016-09-01 16:51:29 -03:00
credentials.REDIRECT_URI = glidera.production.desktop.redirect_uri;
credentials.CLIENT_ID = glidera.production.desktop.client_id;
credentials.CLIENT_SECRET = glidera.production.desktop.client_secret;
2015-09-22 14:11:54 -03:00
}
};
2015-09-07 18:48:47 -03:00
};
2015-08-28 18:23:24 -03:00
2017-02-14 12:36:28 -03:00
root.getNetwork = function() {
2016-08-24 11:33:43 -03:00
return credentials.NETWORK;
};
root.getCurrency = function() {
return 'USD';
};
root.parseAmount = function(amount, currency) {
var config = configService.getSync().wallet.settings;
var satToBtc = 1 / 100000000;
var unitToSatoshi = config.unitToSatoshi;
var amountUnitStr;
// IF 'USD'
if (currency) {
amountUnitStr = $filter('formatFiatAmount')(amount) + ' ' + currency;
} else {
var amountSat = parseInt((amount * unitToSatoshi).toFixed(0));
amountUnitStr = txFormatService.formatAmountStr(amountSat);
// convert unit to BTC
amount = (amountSat * satToBtc).toFixed(8);
currency = 'BTC';
}
return {
amount: amount,
currency: currency,
amountUnitStr: amountUnitStr
};
};
root.getSignupUrl = function() {
return credentials.HOST + '/register';
}
root.getSupportUrl = function() {
return 'https://twitter.com/GlideraInc';
}
2015-08-28 18:23:24 -03:00
root.getOauthCodeUrl = function() {
2016-08-19 23:45:44 -03:00
return credentials.HOST + '/oauth2/auth?response_type=code&client_id=' + credentials.CLIENT_ID + '&redirect_uri=' + credentials.REDIRECT_URI;
2015-08-28 18:23:24 -03:00
};
2017-02-14 12:36:28 -03:00
root.remove = function(cb) {
2016-08-24 11:33:43 -03:00
storageService.removeGlideraToken(credentials.NETWORK, function() {
2017-02-14 12:36:28 -03:00
storageService.removeGlideraPermissions(credentials.NETWORK, function() {
storageService.removeGlideraStatus(credentials.NETWORK, function() {
buyAndSellService.updateLink('glidera', false);
return cb();
});
});
2016-08-24 11:33:43 -03:00
});
};
2015-08-28 18:23:24 -03:00
root.getToken = function(code, cb) {
var req = {
method: 'POST',
url: credentials.HOST + '/api/v1/oauth/token',
2015-08-28 18:23:24 -03:00
headers: {
'Content-Type': 'application/json',
'Accept': 'application/json'
},
2016-08-19 23:45:44 -03:00
data: {
grant_type: 'authorization_code',
2015-08-28 18:23:24 -03:00
code: code,
2016-08-19 23:45:44 -03:00
client_id: credentials.CLIENT_ID,
client_secret: credentials.CLIENT_SECRET,
redirect_uri: credentials.REDIRECT_URI
2015-08-28 18:23:24 -03:00
}
2015-08-31 18:12:04 -03:00
};
2015-08-28 18:23:24 -03:00
$http(req).then(function(data) {
2015-08-31 18:12:04 -03:00
$log.info('Glidera Authorization Access Token: SUCCESS');
2016-08-19 23:45:44 -03:00
return cb(null, data.data);
2015-08-28 18:23:24 -03:00
}, function(data) {
2015-08-31 18:12:04 -03:00
$log.error('Glidera Authorization Access Token: ERROR ' + data.statusText);
2015-09-08 10:17:59 -03:00
return cb('Glidera Authorization Access Token: ERROR ' + data.statusText);
2015-08-28 18:23:24 -03:00
});
};
2017-02-14 12:36:28 -03:00
root.authorize = function(code, cb) {
root.getToken(code, function(err, data) {
if (err) return cb(err);
if (data && !data.access_token) return cb('No access token');
var accessToken = data.access_token;
root.getAccessTokenPermissions(accessToken, function(err, p) {
if (err) return cb(err);
root.getStatus(accessToken, function(err, status) {
if (err) $log.error(err);
storageService.setGlideraToken(credentials.NETWORK, accessToken, function() {
storageService.setGlideraPermissions(credentials.NETWORK, JSON.stringify(p), function() {
storageService.setGlideraStatus(credentials.NETWORK, JSON.stringify(status), function() {
return cb(null, {
token: accessToken,
permissions: p,
status: status
});
});
});
});
});
});
});
};
2015-08-28 18:23:24 -03:00
var _get = function(endpoint, token) {
return {
method: 'GET',
url: credentials.HOST + '/api/v1' + endpoint,
2015-08-28 18:23:24 -03:00
headers: {
'Content-Type': 'application/json',
2015-08-31 18:12:04 -03:00
'Accept': 'application/json',
'Authorization': 'Bearer ' + token
2015-08-28 18:23:24 -03:00
}
};
};
2015-09-05 14:30:02 -03:00
root.getAccessTokenPermissions = function(token, cb) {
2015-08-28 18:23:24 -03:00
if (!token) return cb('Invalid Token');
$http(_get('/oauth/token', token)).then(function(data) {
2015-08-31 18:12:04 -03:00
$log.info('Glidera Access Token Permissions: SUCCESS');
2015-08-28 18:23:24 -03:00
return cb(null, data.data);
}, function(data) {
2015-08-31 18:12:04 -03:00
$log.error('Glidera Access Token Permissions: ERROR ' + data.statusText);
2015-09-08 10:17:59 -03:00
return cb('Glidera Access Token Permissions: ERROR ' + data.statusText);
2015-08-28 18:23:24 -03:00
});
};
root.getEmail = function(token, cb) {
if (!token) return cb('Invalid Token');
$http(_get('/user/email', token)).then(function(data) {
2015-08-31 18:12:04 -03:00
$log.info('Glidera Get Email: SUCCESS');
2015-08-28 18:23:24 -03:00
return cb(null, data.data);
}, function(data) {
2015-08-31 18:12:04 -03:00
$log.error('Glidera Get Email: ERROR ' + data.statusText);
2015-09-08 10:17:59 -03:00
return cb('Glidera Get Email: ERROR ' + data.statusText);
2015-08-28 18:23:24 -03:00
});
};
root.getPersonalInfo = function(token, cb) {
if (!token) return cb('Invalid Token');
$http(_get('/user/personalinfo', token)).then(function(data) {
2015-08-31 18:12:04 -03:00
$log.info('Glidera Get Personal Info: SUCCESS');
2015-08-28 18:23:24 -03:00
return cb(null, data.data);
}, function(data) {
2015-08-31 18:12:04 -03:00
$log.error('Glidera Get Personal Info: ERROR ' + data.statusText);
2015-09-08 10:17:59 -03:00
return cb('Glidera Get Personal Info: ERROR ' + data.statusText);
2015-08-28 18:23:24 -03:00
});
};
root.getStatus = function(token, cb) {
if (!token) return cb('Invalid Token');
$http(_get('/user/status', token)).then(function(data) {
2015-08-31 18:12:04 -03:00
$log.info('Glidera User Status: SUCCESS');
2015-08-28 18:23:24 -03:00
return cb(null, data.data);
}, function(data) {
2015-08-31 18:12:04 -03:00
$log.error('Glidera User Status: ERROR ' + data.statusText);
2015-09-08 10:17:59 -03:00
return cb('Glidera User Status: ERROR ' + data.statusText);
2015-08-28 18:23:24 -03:00
});
};
root.getLimits = function(token, cb) {
if (!token) return cb('Invalid Token');
$http(_get('/user/limits', token)).then(function(data) {
2015-08-31 18:12:04 -03:00
$log.info('Glidera Transaction Limits: SUCCESS');
return cb(null, data.data);
}, function(data) {
$log.error('Glidera Transaction Limits: ERROR ' + data.statusText);
2015-09-08 10:17:59 -03:00
return cb('Glidera Transaction Limits: ERROR ' + data.statusText);
2015-08-31 18:12:04 -03:00
});
};
root.getTransactions = function(token, cb) {
if (!token) return cb('Invalid Token');
$http(_get('/transaction', token)).then(function(data) {
2015-09-02 16:02:40 -03:00
$log.info('Glidera Transactions: SUCCESS');
2015-09-01 18:53:47 -03:00
return cb(null, data.data.transactions);
2015-09-02 16:02:40 -03:00
}, function(data) {
$log.error('Glidera Transactions: ERROR ' + data.statusText);
2015-09-08 10:17:59 -03:00
return cb('Glidera Transactions: ERROR ' + data.statusText);
2015-09-02 16:02:40 -03:00
});
};
root.getTransaction = function(token, txid, cb) {
if (!token) return cb('Invalid Token');
if (!txid) return cb('TxId required');
$http(_get('/transaction/' + txid, token)).then(function(data) {
$log.info('Glidera Transaction: SUCCESS');
return cb(null, data.data);
2015-08-28 18:23:24 -03:00
}, function(data) {
2015-08-31 18:12:04 -03:00
$log.error('Glidera Transaction: ERROR ' + data.statusText);
2015-09-08 10:17:59 -03:00
return cb('Glidera Transaction: ERROR ' + data.statusText);
2015-08-31 18:12:04 -03:00
});
};
root.getSellAddress = function(token, cb) {
if (!token) return cb('Invalid Token');
$http(_get('/user/create_sell_address', token)).then(function(data) {
$log.info('Glidera Create Sell Address: SUCCESS');
2015-09-03 02:50:59 -03:00
return cb(null, data.data.sellAddress);
2015-08-31 18:12:04 -03:00
}, function(data) {
$log.error('Glidera Create Sell Address: ERROR ' + data.statusText);
2015-09-08 10:17:59 -03:00
return cb('Glidera Create Sell Address: ERROR ' + data.statusText);
2015-08-31 18:12:04 -03:00
});
};
2015-09-01 18:53:47 -03:00
root.get2faCode = function(token, cb) {
if (!token) return cb('Invalid Token');
2015-09-01 18:53:47 -03:00
$http(_get('/authentication/get2faCode', token)).then(function(data) {
$log.info('Glidera 2FA code: SUCCESS');
return cb(null, data.data);
2015-09-01 18:53:47 -03:00
}, function(data) {
$log.error('Glidera 2FA code: ERROR ' + data.statusText);
return cb('Glidera 2FA code: ERROR ' + data.statusText);
2015-09-01 18:53:47 -03:00
});
};
var _post = function(endpoint, token, twoFaCode, data) {
2015-08-31 18:12:04 -03:00
return {
method: 'POST',
url: credentials.HOST + '/api/v1' + endpoint,
2015-08-31 18:12:04 -03:00
headers: {
'Content-Type': 'application/json',
'Accept': 'application/json',
2015-09-01 18:53:47 -03:00
'Authorization': 'Bearer ' + token,
'X-2FA-CODE': twoFaCode
2015-08-31 18:12:04 -03:00
},
data: data
};
};
root.sellPrice = function(token, price, cb) {
var data = {
qty: price.qty,
fiat: price.fiat
};
2015-09-01 18:53:47 -03:00
$http(_post('/prices/sell', token, null, data)).then(function(data) {
2015-08-31 18:12:04 -03:00
$log.info('Glidera Sell Price: SUCCESS');
2016-08-19 23:45:44 -03:00
return cb(null, data.data);
2015-08-31 18:12:04 -03:00
}, function(data) {
$log.error('Glidera Sell Price: ERROR ' + data.statusText);
2015-09-08 10:17:59 -03:00
return cb('Glidera Sell Price: ERROR ' + data.statusText);
2015-08-31 18:12:04 -03:00
});
2016-08-19 23:45:44 -03:00
};
2015-08-31 18:12:04 -03:00
2015-09-01 18:53:47 -03:00
root.sell = function(token, twoFaCode, data, cb) {
2015-08-31 18:12:04 -03:00
var data = {
refundAddress: data.refundAddress,
signedTransaction: data.signedTransaction,
priceUuid: data.priceUuid,
useCurrentPrice: data.useCurrentPrice,
ip: data.ip
};
2015-09-01 18:53:47 -03:00
$http(_post('/sell', token, twoFaCode, data)).then(function(data) {
$log.info('Glidera Sell: SUCCESS');
2016-08-19 23:45:44 -03:00
return cb(null, data.data);
2015-08-31 18:12:04 -03:00
}, function(data) {
2015-09-08 10:17:59 -03:00
$log.error('Glidera Sell Request: ERROR ' + data.statusText);
return cb('Glidera Sell Request: ERROR ' + data.statusText);
2015-08-31 18:12:04 -03:00
});
};
root.buyPrice = function(token, price, cb) {
var data = {
qty: price.qty,
fiat: price.fiat
};
2015-09-01 18:53:47 -03:00
$http(_post('/prices/buy', token, null, data)).then(function(data) {
2015-08-31 18:12:04 -03:00
$log.info('Glidera Buy Price: SUCCESS');
2016-08-19 23:45:44 -03:00
return cb(null, data.data);
2015-08-31 18:12:04 -03:00
}, function(data) {
$log.error('Glidera Buy Price: ERROR ' + data.statusText);
2015-09-08 10:17:59 -03:00
return cb('Glidera Buy Price: ERROR ' + data.statusText);
2015-08-31 18:12:04 -03:00
});
};
2015-09-01 18:53:47 -03:00
root.buy = function(token, twoFaCode, data, cb) {
2015-08-31 18:12:04 -03:00
var data = {
destinationAddress: data.destinationAddress,
qty: data.qty,
priceUuid: data.priceUuid,
useCurrentPrice: data.useCurrentPrice,
ip: data.ip
};
2015-09-01 18:53:47 -03:00
$http(_post('/buy', token, twoFaCode, data)).then(function(data) {
console.log('[glideraService.js:333]',data); //TODO
2015-08-31 18:12:04 -03:00
$log.info('Glidera Buy: SUCCESS');
2016-08-19 23:45:44 -03:00
return cb(null, data.data);
2015-08-31 18:12:04 -03:00
}, function(data) {
2015-09-08 10:17:59 -03:00
$log.error('Glidera Buy Request: ERROR ' + data.statusText);
return cb('Glidera Buy Request: ERROR ' + data.statusText);
2015-08-28 18:23:24 -03:00
});
};
2017-02-14 12:36:28 -03:00
root.init = function(cb) {
if (lodash.isEmpty(credentials.CLIENT_ID)) {
return cb('Glidera is Disabled');
2016-08-24 11:33:43 -03:00
}
2017-02-14 12:36:28 -03:00
$log.debug('Trying to initialise Glidera...');
storageService.getGlideraToken(credentials.NETWORK, function(err, accessToken) {
if (err || lodash.isEmpty(accessToken)) return cb();
storageService.getGlideraPermissions(credentials.NETWORK, function(err, permissions) {
if (lodash.isString(permissions)) permissions = JSON.parse(permissions);
storageService.getGlideraStatus(credentials.NETWORK, function(err, status) {
if (lodash.isString(status)) status = JSON.parse(status);
buyAndSellService.updateLink('glidera', true);
return cb(null, {
token: accessToken,
permissions: permissions,
status: status
});
2016-08-19 23:40:28 -03:00
});
2017-02-14 12:36:28 -03:00
});
2016-08-19 23:40:28 -03:00
});
};
2017-02-14 12:36:28 -03:00
root.updateStatus = function(data) {
storageService.getGlideraToken(credentials.NETWORK, function(err, accessToken) {
if (err) return;
root.getAccessTokenPermissions(accessToken, function(err, permissions) {
if (err) return;
storageService.setGlideraPermissions(credentials.NETWORK, JSON.stringify(permissions), function() {});
data.permissions = permissions;
root.getStatus(accessToken, function(err, status) {
data.status = status;
storageService.setGlideraStatus(credentials.NETWORK, JSON.stringify(status), function() {});
root.getLimits(accessToken, function(err, limits) {
data.limits = limits;
if (permissions.transaction_history) {
root.getTransactions(accessToken, function(err, txs) {
data.txs = txs;
});
}
if (permissions.view_email_address) {
root.getEmail(accessToken, function(err, email) {
data.email = email;
});
}
if (permissions.personal_info) {
root.getPersonalInfo(accessToken, function(err, info) {
data.personalInfo = info;
});
}
});
});
});
});
};
2015-08-28 18:23:24 -03:00
2017-01-30 18:04:17 -03:00
var register = function() {
if (isWindowsPhoneApp) return;
storageService.getGlideraToken(credentials.NETWORK, function(err, token) {
if (err) return cb(err);
2017-01-30 19:38:52 -03:00
buyAndSellService.register({
name: 'glidera',
2017-01-30 18:04:17 -03:00
logo: 'img/glidera-logo.png',
location: 'US Only',
2017-01-30 18:04:17 -03:00
sref: 'tabs.buyandsell.glidera',
2017-01-30 19:38:52 -03:00
configSref: 'tabs.preferences.glidera',
2017-01-30 18:04:17 -03:00
linked: !!token,
2017-01-30 19:38:52 -03:00
});
2017-01-30 18:04:17 -03:00
});
};
setCredentials();
register();
return root;
2015-08-28 18:23:24 -03:00
});