/** * Gives the caller a url at which the user can acquire eth, depending on the network they are in * * @param {Object} opts - Options required to determine the correct url * @param {string} opts.network The network for which to return a url * @param {string} opts.address The address the bought ETH should be sent to. Only relevant if network === '1'. * @returns {string|undefined} - The url at which the user can access ETH, while in the given network. If the passed * network does not match any of the specified cases, or if no network is given, returns undefined. * */ export default function getBuyEthUrl({ network, address, service }) { // default service by network if not specified if (!service) { // eslint-disable-next-line no-param-reassign service = getDefaultServiceForNetwork(network) } switch (service) { case 'wyre': return `https://pay.sendwyre.com/purchase?dest=ethereum:${address}&destCurrency=ETH&accountId=AC-7AG3W4XH4N2&paymentMethod=debit-card` case 'coinswitch': return `https://metamask.coinswitch.co/?address=${address}&to=eth` case 'metamask-faucet': return 'https://faucet.metamask.io/' case 'rinkeby-faucet': return 'https://www.rinkeby.io/' case 'kovan-faucet': return 'https://github.com/kovan-testnet/faucet' case 'goerli-faucet': return 'https://goerli-faucet.slock.it/' default: throw new Error(`Unknown cryptocurrency exchange or faucet: "${service}"`) } } function getDefaultServiceForNetwork(network) { switch (network) { case '1': return 'wyre' case '3': return 'metamask-faucet' case '4': return 'rinkeby-faucet' case '42': return 'kovan-faucet' case '5': return 'goerli-faucet' default: throw new Error( `No default cryptocurrency exchange or faucet for networkId: "${network}"`, ) } }