341 lines
11 KiB
JavaScript
341 lines
11 KiB
JavaScript
'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;
|
||
|
||
});
|