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(id) { const BASE_URL = `${scheme}api.coinbase.com/v2/exchange-rates?currency=${id}` 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.data.rates, ltcTicker: ltcTicker.data.rates })) ) } 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) }