feat: fallback to BitPay ticker
This commit is contained in:
parent
418bd9b649
commit
0e980693af
1 changed files with 24 additions and 18 deletions
|
|
@ -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))
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue