|
|
|
import axios from 'axios'
|
|
|
|
|
|
|
|
// When running in development/hot mode we load the renderer js code via webpack dev server, and it is from there that
|
|
|
|
// we ultimately initate requests to these remote resources. The end result is that the electron browser window makes a
|
|
|
|
// request to localhost (to webpack dev server), which in turn makes a request to the remote resource. If the remote
|
|
|
|
// resource in question has a restrictive `Access-Control-Allow-Origin` header, this may cause the electron browser
|
|
|
|
// window to not allow loading the remote content.
|
|
|
|
//
|
|
|
|
// See https://enable-cors.org/
|
|
|
|
//
|
|
|
|
// In order to mitigate the CORS issue, we instead access these remote resources through a local proxy that we have
|
|
|
|
// defined on the webpack dev server.
|
|
|
|
const scheme = process.env.HOT ? '/proxy/' : 'https://'
|
|
|
|
|
|
|
|
export function requestTicker() {
|
|
|
|
const BASE_URL = `${scheme}blockchain.info/ticker`
|
|
|
|
return axios({
|
|
|
|
method: 'get',
|
|
|
|
url: BASE_URL
|
|
|
|
}).then(response => response.data)
|
|
|
|
}
|
|
|
|
|
|
|
|
export function requestTickers(ids) {
|
|
|
|
return axios
|
|
|
|
.all(ids.map(id => requestTicker(id)))
|
|
|
|
.then(
|
|
|
|
axios.spread((btcTicker, ltcTicker) => ({ btcTicker: btcTicker[0], ltcTicker: ltcTicker[0] }))
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
export function requestSuggestedNodes() {
|
|
|
|
const BASE_URL = `${scheme}zap.jackmallers.com/suggested-peers`
|
|
|
|
return axios({
|
|
|
|
method: 'get',
|
|
|
|
url: BASE_URL
|
|
|
|
}).then(response => response.data)
|
|
|
|
}
|
|
|
|
|
|
|
|
export function requestFees() {
|
|
|
|
const BASE_URL = 'https://bitcoinfees.earn.com/api/v1/fees/recommended'
|
|
|
|
return axios({
|
|
|
|
method: 'get',
|
|
|
|
url: BASE_URL
|
|
|
|
}).then(response => response.data)
|
|
|
|
}
|