'use strict'; angular.module('copayApp.services').factory('glideraService', function($http, $log, platformInfo, storageService, configService, $rootScope) { var root = {}; var credentials = {}; var isCordova = platformInfo.isCordova; // // root.setCredentials = function(network) { if (network == 'testnet') { credentials.HOST = 'https://sandbox.glidera.io'; if (isCordova) { credentials.REDIRECT_URI = 'copay://glidera'; credentials.CLIENT_ID = '6163427a2f37d1b2022ececd6d6c9cdd'; credentials.CLIENT_SECRET = '599cc3af26108c6fece8ab17c3f35867'; } else { credentials.REDIRECT_URI = 'urn:ietf:wg:oauth:2.0:oob'; credentials.CLIENT_ID = 'c402f4a753755456e8c384fb65b7be1d'; credentials.CLIENT_SECRET = '3ce826198e3618d0b8ed341ab91fe4e5'; } } else { credentials.HOST = 'https://glidera.io'; if (isCordova) { credentials.REDIRECT_URI = 'copay://glidera'; credentials.CLIENT_ID = '9c8023f0ac0128235b7b27a6f2610c83'; credentials.CLIENT_SECRET = '30431511407b47f25a83bffd72881d55'; } else { credentials.REDIRECT_URI = 'urn:ietf:wg:oauth:2.0:oob'; credentials.CLIENT_ID = '8a9e8a9cf155db430c1ea6c7889afed1'; credentials.CLIENT_SECRET = '24ddec578f38d5488bfe13601933c05f'; } }; }; 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); }); }; root.init = function(accessToken) { root.glideraEnabled = configService.getSync().glidera.enabled; root.glideraTestnet = configService.getSync().glidera.testnet; var network = root.glideraTestnet ? 'testnet' : 'livenet'; root.glideraToken = null; root.glideraError = null; root.glideraPermissions = null; root.glideraEmail = null; root.glideraPersonalInfo = null; root.glideraTxs = null; root.glideraStatus = null; if (!root.glideraEnabled) return; root.setCredentials(network); var getToken = function(cb) { if (accessToken) { cb(null, accessToken); } else { storageService.getGlideraToken(network, cb); } }; getToken(function(err, accessToken) { if (err || !accessToken) return; else { root.getAccessTokenPermissions(accessToken, function(err, p) { if (err) { root.glideraError = err; } else { root.glideraToken = accessToken; root.glideraPermissions = p; root.update({ fullUpdate: true }); } }); } }); }; root.update = function(opts) { if (!root.glideraToken || !root.glideraPermissions) return; var accessToken = root.glideraToken; var permissions = root.glideraPermissions; opts = opts || {}; root.getStatus(accessToken, function(err, data) { root.glideraStatus = data; }); root.getLimits(accessToken, function(err, limits) { root.glideraLimits = limits; }); if (permissions.transaction_history) { root.getTransactions(accessToken, function(err, data) { root.glideraTxs = data; }); } if (permissions.view_email_address && opts.fullUpdate) { root.getEmail(accessToken, function(err, data) { root.glideraEmail = data.email; }); } if (permissions.personal_info && opts.fullUpdate) { root.getPersonalInfo(accessToken, function(err, data) { root.glideraPersonalInfo = data; }); } }; configService.whenAvailable(function() { $log.debug('Init Glidera Service...'); root.init(); }); $rootScope.$on('NewBlock', function() {     root.update();    }); return root; });