Browse Source
Merge pull request #535 from mrfelton/feat/redundent-block-explorers
Fetch block height from multiple block explorers incase one is unavailable
renovate/lint-staged-8.x
Ben Woosley
7 years ago
committed by
GitHub
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with
42 additions and
8 deletions
-
app/api/index.js
-
app/reducers/lnd.js
-
webpack.config.renderer.dev.js
-
webpack.config.renderer.prod.js
|
@ -29,11 +29,33 @@ export function requestTickers(ids) { |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
export function requestBlockHeight() { |
|
|
export function requestBlockHeight() { |
|
|
const BASE_URL = `${scheme}testnet-api.smartbit.com.au/v1/blockchain/blocks?limit=1` |
|
|
const sources = [ |
|
|
|
|
|
{ |
|
|
|
|
|
baseUrl: `${scheme}testnet-api.smartbit.com.au/v1/blockchain/blocks?limit=1`, |
|
|
|
|
|
path: 'blocks[0].height' |
|
|
|
|
|
}, |
|
|
|
|
|
{ |
|
|
|
|
|
baseUrl: `${scheme}tchain.api.btc.com/v3/block/latest`, |
|
|
|
|
|
path: 'data.height' |
|
|
|
|
|
}, |
|
|
|
|
|
{ |
|
|
|
|
|
baseUrl: `${scheme}api.blockcypher.com/v1/btc/test3`, |
|
|
|
|
|
path: 'height' |
|
|
|
|
|
} |
|
|
|
|
|
] |
|
|
|
|
|
const fetchData = (baseUrl, path) => { |
|
|
return axios({ |
|
|
return axios({ |
|
|
method: 'get', |
|
|
method: 'get', |
|
|
url: BASE_URL |
|
|
timeout: 5000, |
|
|
}).then(response => response.data) |
|
|
url: baseUrl |
|
|
|
|
|
}) |
|
|
|
|
|
.then(response => path.split('.').reduce((a, b) => a[b], response.data)) |
|
|
|
|
|
.catch(() => null) |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
const promises = [] |
|
|
|
|
|
sources.forEach(source => promises.push(fetchData(source.baseUrl, source.path))) |
|
|
|
|
|
return Promise.race(promises) |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
export function requestSuggestedNodes() { |
|
|
export function requestSuggestedNodes() { |
|
|
|
@ -84,8 +84,8 @@ export function receiveBlockHeight(blockHeight) { |
|
|
// Fetch current block height
|
|
|
// Fetch current block height
|
|
|
export const fetchBlockHeight = () => async dispatch => { |
|
|
export const fetchBlockHeight = () => async dispatch => { |
|
|
dispatch(getBlockHeight()) |
|
|
dispatch(getBlockHeight()) |
|
|
const blockData = await requestBlockHeight() |
|
|
const blockHeight = await requestBlockHeight() |
|
|
dispatch(receiveBlockHeight(blockData.blocks[0].height)) |
|
|
dispatch(receiveBlockHeight(blockHeight)) |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
// ------------------------------------
|
|
|
// ------------------------------------
|
|
|
|
@ -298,6 +298,16 @@ export default merge.smart(baseConfig, { |
|
|
target: 'https://testnet-api.smartbit.com.au', |
|
|
target: 'https://testnet-api.smartbit.com.au', |
|
|
pathRewrite: { '^/proxy/testnet-api.smartbit.com.au': '' }, |
|
|
pathRewrite: { '^/proxy/testnet-api.smartbit.com.au': '' }, |
|
|
changeOrigin: true |
|
|
changeOrigin: true |
|
|
|
|
|
}, |
|
|
|
|
|
'/proxy/tchain.api.btc.com': { |
|
|
|
|
|
target: 'https://tchain.api.btc.com', |
|
|
|
|
|
pathRewrite: { '^/proxy/tchain.api.btc.com': '' }, |
|
|
|
|
|
changeOrigin: true |
|
|
|
|
|
}, |
|
|
|
|
|
'/proxy/api.blockcypher.com': { |
|
|
|
|
|
target: 'https://api.blockcypher.com', |
|
|
|
|
|
pathRewrite: { '^/proxy/api.blockcypher.com': '' }, |
|
|
|
|
|
changeOrigin: true |
|
|
} |
|
|
} |
|
|
}, |
|
|
}, |
|
|
historyApiFallback: { |
|
|
historyApiFallback: { |
|
|
|
@ -159,7 +159,9 @@ export default merge.smart(baseConfig, { |
|
|
"'self'", |
|
|
"'self'", |
|
|
'https://api.coinmarketcap.com', |
|
|
'https://api.coinmarketcap.com', |
|
|
'https://zap.jackmallers.com', |
|
|
'https://zap.jackmallers.com', |
|
|
'https://testnet-api.smartbit.com.au' |
|
|
'https://testnet-api.smartbit.com.au', |
|
|
|
|
|
'https://tchain.api.btc.com', |
|
|
|
|
|
'https://api.blockcypher.com' |
|
|
], |
|
|
], |
|
|
'script-src': ["'self'"], |
|
|
'script-src': ["'self'"], |
|
|
'font-src': [ |
|
|
'font-src': [ |
|
|