Merge pull request #3145 from cmgustavo/feat/glidera-integration
Feat/glidera integration
This commit is contained in:
commit
a9a49f5007
33 changed files with 1856 additions and 249 deletions
253
src/js/services/glideraService.js
Normal file
253
src/js/services/glideraService.js
Normal file
|
|
@ -0,0 +1,253 @@
|
|||
'use strict';
|
||||
|
||||
angular.module('copayApp.services').factory('glideraService', function($http, $log, isCordova) {
|
||||
var root = {};
|
||||
var credentials = {};
|
||||
|
||||
root.setCredentials = function(network) {
|
||||
if (network == 'testnet') {
|
||||
credentials.HOST = 'https://sandbox.glidera.io';
|
||||
if (isCordova) {
|
||||
credentials.REDIRECT_URI = 'bitcoin://glidera';
|
||||
credentials.CLIENT_ID = 'dfc56e4336e32bb8ba46dde34f3d7d6d';
|
||||
credentials.CLIENT_SECRET = '5eb679058f6c7eb81123162323d4fba5';
|
||||
}
|
||||
else {
|
||||
credentials.REDIRECT_URI = 'urn:ietf:wg:oauth:2.0:oob';
|
||||
credentials.CLIENT_ID = '9915b6ffa6dc3baffb87135ed3873d49';
|
||||
credentials.CLIENT_SECRET = 'd74eda05b9c6a228fd5c85cfbd0eb7eb';
|
||||
}
|
||||
}
|
||||
else {
|
||||
credentials.HOST = 'https://glidera.io';
|
||||
credentials.REDIRECT_URI = 'urn:ietf:wg:oauth:2.0:oob';
|
||||
credentials.CLIENT_ID = '';
|
||||
credentials.CLIENT_SECRET = '';
|
||||
};
|
||||
};
|
||||
|
||||
root.getOauthCodeUrl = function() {
|
||||
return credentials.HOST
|
||||
+ '/oauth2/auth?response_type=code&client_id='
|
||||
+ credentials.CLIENT_ID
|
||||
+ '&redirect_uri='
|
||||
+ credentials.REDIRECT_URI;
|
||||
};
|
||||
|
||||
root.getToken = function(code, cb) {
|
||||
var req = {
|
||||
method: 'POST',
|
||||
url: credentials.HOST + '/api/v1/oauth/token',
|
||||
headers: {
|
||||
'Content-Type': 'application/json',
|
||||
'Accept': 'application/json'
|
||||
},
|
||||
data: {
|
||||
grant_type : 'authorization_code',
|
||||
code: code,
|
||||
client_id : credentials.CLIENT_ID,
|
||||
client_secret: credentials.CLIENT_SECRET,
|
||||
redirect_uri: credentials.REDIRECT_URI
|
||||
}
|
||||
};
|
||||
|
||||
$http(req).then(function(data) {
|
||||
$log.info('Glidera Authorization Access Token: SUCCESS');
|
||||
return cb(null, data.data);
|
||||
}, function(data) {
|
||||
$log.error('Glidera Authorization Access Token: ERROR ' + data.statusText);
|
||||
return cb('Glidera Authorization Access Token: ERROR ' + data.statusText);
|
||||
});
|
||||
};
|
||||
|
||||
var _get = function(endpoint, token) {
|
||||
return {
|
||||
method: 'GET',
|
||||
url: credentials.HOST + '/api/v1' + endpoint,
|
||||
headers: {
|
||||
'Content-Type': 'application/json',
|
||||
'Accept': 'application/json',
|
||||
'Authorization': 'Bearer ' + token
|
||||
}
|
||||
};
|
||||
};
|
||||
|
||||
root.getAccessTokenPermissions = function(token, cb) {
|
||||
if (!token) return cb('Invalid Token');
|
||||
$http(_get('/oauth/token', token)).then(function(data) {
|
||||
$log.info('Glidera Access Token Permissions: SUCCESS');
|
||||
return cb(null, data.data);
|
||||
}, function(data) {
|
||||
$log.error('Glidera Access Token Permissions: ERROR ' + data.statusText);
|
||||
return cb('Glidera Access Token Permissions: ERROR ' + data.statusText);
|
||||
});
|
||||
};
|
||||
|
||||
root.getEmail = function(token, cb) {
|
||||
if (!token) return cb('Invalid Token');
|
||||
$http(_get('/user/email', token)).then(function(data) {
|
||||
$log.info('Glidera Get Email: SUCCESS');
|
||||
return cb(null, data.data);
|
||||
}, function(data) {
|
||||
$log.error('Glidera Get Email: ERROR ' + data.statusText);
|
||||
return cb('Glidera Get Email: ERROR ' + data.statusText);
|
||||
});
|
||||
};
|
||||
|
||||
root.getPersonalInfo = function(token, cb) {
|
||||
if (!token) return cb('Invalid Token');
|
||||
$http(_get('/user/personalinfo', token)).then(function(data) {
|
||||
$log.info('Glidera Get Personal Info: SUCCESS');
|
||||
return cb(null, data.data);
|
||||
}, function(data) {
|
||||
$log.error('Glidera Get Personal Info: ERROR ' + data.statusText);
|
||||
return cb('Glidera Get Personal Info: ERROR ' + data.statusText);
|
||||
});
|
||||
};
|
||||
|
||||
root.getStatus = function(token, cb) {
|
||||
if (!token) return cb('Invalid Token');
|
||||
$http(_get('/user/status', token)).then(function(data) {
|
||||
$log.info('Glidera User Status: SUCCESS');
|
||||
return cb(null, data.data);
|
||||
}, function(data) {
|
||||
$log.error('Glidera User Status: ERROR ' + data.statusText);
|
||||
return cb('Glidera User Status: ERROR ' + data.statusText);
|
||||
});
|
||||
};
|
||||
|
||||
root.getLimits = function(token, cb) {
|
||||
if (!token) return cb('Invalid Token');
|
||||
$http(_get('/user/limits', token)).then(function(data) {
|
||||
$log.info('Glidera Transaction Limits: SUCCESS');
|
||||
return cb(null, data.data);
|
||||
}, function(data) {
|
||||
$log.error('Glidera Transaction Limits: ERROR ' + data.statusText);
|
||||
return cb('Glidera Transaction Limits: ERROR ' + data.statusText);
|
||||
});
|
||||
};
|
||||
|
||||
root.getTransactions = function(token, cb) {
|
||||
if (!token) return cb('Invalid Token');
|
||||
$http(_get('/transaction', token)).then(function(data) {
|
||||
$log.info('Glidera Transactions: SUCCESS');
|
||||
return cb(null, data.data.transactions);
|
||||
}, function(data) {
|
||||
$log.error('Glidera Transactions: ERROR ' + data.statusText);
|
||||
return cb('Glidera Transactions: ERROR ' + data.statusText);
|
||||
});
|
||||
};
|
||||
|
||||
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);
|
||||
}, function(data) {
|
||||
$log.error('Glidera Transaction: ERROR ' + data.statusText);
|
||||
return cb('Glidera Transaction: ERROR ' + data.statusText);
|
||||
});
|
||||
};
|
||||
|
||||
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');
|
||||
return cb(null, data.data.sellAddress);
|
||||
}, function(data) {
|
||||
$log.error('Glidera Create Sell Address: ERROR ' + data.statusText);
|
||||
return cb('Glidera Create Sell Address: ERROR ' + data.statusText);
|
||||
});
|
||||
};
|
||||
|
||||
root.get2faCode = function(token, cb) {
|
||||
if (!token) return cb('Invalid Token');
|
||||
$http(_get('/authentication/get2faCode', token)).then(function(data) {
|
||||
$log.info('Glidera Sent 2FA code by SMS: SUCCESS');
|
||||
return cb(null, data.status == 200 ? true : false);
|
||||
}, function(data) {
|
||||
$log.error('Glidera Sent 2FA code by SMS: ERROR ' + data.statusText);
|
||||
return cb('Glidera Sent 2FA code by SMS: ERROR ' + data.statusText);
|
||||
});
|
||||
};
|
||||
|
||||
var _post = function(endpoint, token, twoFaCode, data) {
|
||||
return {
|
||||
method: 'POST',
|
||||
url: credentials.HOST + '/api/v1' + endpoint,
|
||||
headers: {
|
||||
'Content-Type': 'application/json',
|
||||
'Accept': 'application/json',
|
||||
'Authorization': 'Bearer ' + token,
|
||||
'2FA_CODE': twoFaCode
|
||||
},
|
||||
data: data
|
||||
};
|
||||
};
|
||||
|
||||
root.sellPrice = function(token, price, cb) {
|
||||
var data = {
|
||||
qty: price.qty,
|
||||
fiat: price.fiat
|
||||
};
|
||||
$http(_post('/prices/sell', token, null, data)).then(function(data) {
|
||||
$log.info('Glidera Sell Price: SUCCESS');
|
||||
return cb(null, data.data);
|
||||
}, function(data) {
|
||||
$log.error('Glidera Sell Price: ERROR ' + data.statusText);
|
||||
return cb('Glidera Sell Price: ERROR ' + data.statusText);
|
||||
});
|
||||
};
|
||||
|
||||
root.sell = function(token, twoFaCode, data, cb) {
|
||||
var data = {
|
||||
refundAddress: data.refundAddress,
|
||||
signedTransaction: data.signedTransaction,
|
||||
priceUuid: data.priceUuid,
|
||||
useCurrentPrice: data.useCurrentPrice,
|
||||
ip: data.ip
|
||||
};
|
||||
$http(_post('/sell', token, twoFaCode, data)).then(function(data) {
|
||||
$log.info('Glidera Sell: SUCCESS');
|
||||
return cb(null, data.data);
|
||||
}, function(data) {
|
||||
$log.error('Glidera Sell Request: ERROR ' + data.statusText);
|
||||
return cb('Glidera Sell Request: ERROR ' + data.statusText);
|
||||
});
|
||||
};
|
||||
|
||||
root.buyPrice = function(token, price, cb) {
|
||||
var data = {
|
||||
qty: price.qty,
|
||||
fiat: price.fiat
|
||||
};
|
||||
$http(_post('/prices/buy', token, null, data)).then(function(data) {
|
||||
$log.info('Glidera Buy Price: SUCCESS');
|
||||
return cb(null, data.data);
|
||||
}, function(data) {
|
||||
$log.error('Glidera Buy Price: ERROR ' + data.statusText);
|
||||
return cb('Glidera Buy Price: ERROR ' + data.statusText);
|
||||
});
|
||||
};
|
||||
|
||||
root.buy = function(token, twoFaCode, data, cb) {
|
||||
var data = {
|
||||
destinationAddress: data.destinationAddress,
|
||||
qty: data.qty,
|
||||
priceUuid: data.priceUuid,
|
||||
useCurrentPrice: data.useCurrentPrice,
|
||||
ip: data.ip
|
||||
};
|
||||
$http(_post('/buy', token, twoFaCode, data)).then(function(data) {
|
||||
$log.info('Glidera Buy: SUCCESS');
|
||||
return cb(null, data.data);
|
||||
}, function(data) {
|
||||
$log.error('Glidera Buy Request: ERROR ' + data.statusText);
|
||||
return cb('Glidera Buy Request: ERROR ' + data.statusText);
|
||||
});
|
||||
};
|
||||
|
||||
return root;
|
||||
|
||||
});
|
||||
|
|
@ -29,12 +29,13 @@ angular.module('copayApp.services').factory('go', function($window, $rootScope,
|
|||
}
|
||||
};
|
||||
|
||||
root.openExternalLink = function(url) {
|
||||
root.openExternalLink = function(url, target) {
|
||||
if (nodeWebkit.isDefined()) {
|
||||
nodeWebkit.openExternalLink(url);
|
||||
}
|
||||
else {
|
||||
var ref = window.open(url, '_blank', 'location=no');
|
||||
target = target || '_blank';
|
||||
var ref = window.open(url, target, 'location=no');
|
||||
}
|
||||
};
|
||||
|
||||
|
|
@ -89,8 +90,8 @@ angular.module('copayApp.services').factory('go', function($window, $rootScope,
|
|||
root.path(path);
|
||||
};
|
||||
|
||||
$rootScope.openExternalLink = function(url) {
|
||||
root.openExternalLink(url);
|
||||
$rootScope.openExternalLink = function(url, target) {
|
||||
root.openExternalLink(url, target);
|
||||
};
|
||||
|
||||
|
||||
|
|
|
|||
|
|
@ -192,5 +192,17 @@ angular.module('copayApp.services')
|
|||
storage.get('remotePrefStored', cb);
|
||||
};
|
||||
|
||||
root.setGlideraToken = function(network, token, cb) {
|
||||
storage.set('glideraToken-' + network, token, cb);
|
||||
};
|
||||
|
||||
root.getGlideraToken = function(network, cb) {
|
||||
storage.get('glideraToken-' + network, cb);
|
||||
};
|
||||
|
||||
root.removeGlideraToken = function(network, cb) {
|
||||
storage.remove('glideraToken-' + network, cb);
|
||||
};
|
||||
|
||||
return root;
|
||||
});
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue