2015-07-24 12:11:07 -03:00
|
|
|
'use strict';
|
|
|
|
|
|
2016-04-13 17:46:25 +02:00
|
|
|
angular.module('copayApp.services').factory('feeService', function($log, bwcService, profileService, configService, gettextCatalog, lodash) {
|
2015-07-24 12:11:07 -03:00
|
|
|
var root = {};
|
|
|
|
|
|
2015-07-29 13:07:35 -03:00
|
|
|
// Constant fee options to translate
|
2015-07-30 15:26:16 -03:00
|
|
|
root.feeOpts = {
|
|
|
|
|
priority: gettextCatalog.getString('Priority'),
|
|
|
|
|
normal: gettextCatalog.getString('Normal'),
|
|
|
|
|
economy: gettextCatalog.getString('Economy')
|
|
|
|
|
};
|
2015-07-29 13:07:35 -03:00
|
|
|
|
2016-02-22 19:56:53 -03:00
|
|
|
root.getCurrentFeeLevel = function() {
|
|
|
|
|
return configService.getSync().wallet.settings.feeLevel || 'normal';
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
root.getCurrentFeeValue = function(cb) {
|
2015-07-24 12:11:07 -03:00
|
|
|
var fc = profileService.focusedClient;
|
2016-02-22 19:56:53 -03:00
|
|
|
var feeLevel = root.getCurrentFeeLevel();
|
2016-03-04 10:44:13 -03:00
|
|
|
|
2015-07-24 12:11:07 -03:00
|
|
|
fc.getFeeLevels(fc.credentials.network, function(err, levels) {
|
2016-04-13 17:46:25 +02:00
|
|
|
if (err)
|
|
|
|
|
return cb({
|
|
|
|
|
message: 'Could not get dynamic fee'
|
|
|
|
|
});
|
2016-03-04 10:44:13 -03:00
|
|
|
|
2016-04-13 17:46:25 +02:00
|
|
|
var feeLevelValue = lodash.find(levels, {
|
|
|
|
|
level: feeLevel
|
|
|
|
|
});
|
|
|
|
|
if (!feeLevelValue || !feeLevelValue.feePerKB)
|
|
|
|
|
return cb({
|
|
|
|
|
message: 'Could not get dynamic fee for level: ' + feeLevel
|
|
|
|
|
});
|
2016-03-04 10:44:13 -03:00
|
|
|
|
2016-03-04 18:36:40 -03:00
|
|
|
var fee = feeLevelValue.feePerKB;
|
2016-04-13 17:46:25 +02:00
|
|
|
$log.debug('Dynamic fee: ' + feeLevel + ' ' + fee + ' SAT');
|
|
|
|
|
return cb(null, fee);
|
2015-07-24 12:11:07 -03:00
|
|
|
});
|
2016-04-13 17:46:25 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
root.getFeeLevels = function(cb) {
|
|
|
|
|
var walletClient = bwcService.getClient();
|
2015-07-24 12:11:07 -03:00
|
|
|
|
2016-02-22 19:56:53 -03:00
|
|
|
var unitName = configService.getSync().wallet.settings.unitName;
|
2015-07-24 12:11:07 -03:00
|
|
|
|
2016-04-13 17:46:25 +02:00
|
|
|
walletClient.getFeeLevels('livenet', function(errLivenet, levelsLivenet) {
|
|
|
|
|
walletClient.getFeeLevels('testnet', function(errTestnet, levelsTestnet) {
|
2015-07-27 12:33:37 -03:00
|
|
|
if (errLivenet || errTestnet) $log.debug('Could not get dynamic fee');
|
|
|
|
|
else {
|
|
|
|
|
for (var i = 0; i < 3; i++) {
|
|
|
|
|
levelsLivenet[i]['feePerKBUnit'] = profileService.formatAmount(levelsLivenet[i].feePerKB) + ' ' + unitName;
|
|
|
|
|
levelsTestnet[i]['feePerKBUnit'] = profileService.formatAmount(levelsTestnet[i].feePerKB) + ' ' + unitName;
|
|
|
|
|
}
|
2015-07-24 12:23:30 -03:00
|
|
|
}
|
2015-07-24 12:11:07 -03:00
|
|
|
|
2015-07-24 12:23:30 -03:00
|
|
|
return cb({
|
|
|
|
|
'livenet': levelsLivenet,
|
|
|
|
|
'testnet': levelsTestnet
|
|
|
|
|
});
|
2015-07-24 12:11:07 -03:00
|
|
|
});
|
|
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
return root;
|
|
|
|
|
});
|