feat: fallback to BitPay ticker

This commit is contained in:
siiky 2023-11-24 18:26:46 +00:00
parent bb57a599e0
commit 0168fe4994

View file

@ -14,26 +14,32 @@ const FETCH_INTERVAL = 58000
const PEGGED_FIAT_CURRENCIES = { NAD: 'ZAR' } const PEGGED_FIAT_CURRENCIES = { NAD: 'ZAR' }
function _getRates (settings, fiatCode, cryptoCode) { const FALLBACK_TICKER = 'bitpay'
return Promise.resolve()
.then(() => {
const config = settings.config
const tickerName = configManager.getWalletSettings(cryptoCode, config).ticker
const market = [cryptoCode, fiatCode].join('-')
return buildTicker(fiatCode, cryptoCode, tickerName) const hasRatesOrReject = r => _.get(['rates'], r) ?
.then(r => { r :
return lastRate[market] = { Promise.reject(new Error("Failed to get ticker rates"))
rates: r.rates,
timestamp: Date.now() const get1 = (market, fiatCode, cryptoCode, ticker) =>
} buildTicker(fiatCode, cryptoCode, ticker)
.then(hasRatesOrReject)
.then(({ rates }) => {
return lastRate[market] = { rates, timestamp: Date.now() }
}) })
const _getRates = (settings, fiatCode, cryptoCode) => Promise.resolve()
.then(() => {
const ticker = configManager.getWalletSettings(cryptoCode, settings.config).ticker
const market = [cryptoCode, fiatCode].join('-')
return get1(market, fiatCode, cryptoCode, ticker)
.catch(err => { .catch(err => {
logger.error(err) logger.error(err)
return lastRate[market] return ticker === FALLBACK_TICKER ?
lastRate[market] :
get1(market, fiatCode, cryptoCode, FALLBACK_TICKER)
}) })
.then(hasRatesOrReject)
}) })
}
function buildTicker (fiatCode, cryptoCode, tickerName) { function buildTicker (fiatCode, cryptoCode, tickerName) {
fiatCode = _.defaultTo(fiatCode, _.get([fiatCode], PEGGED_FIAT_CURRENCIES)) fiatCode = _.defaultTo(fiatCode, _.get([fiatCode], PEGGED_FIAT_CURRENCIES))