PHP WebShell

Текущая директория: /usr/lib/node_modules/bitgo/node_modules/@bitgo/abstract-utxo/dist/src/recovery

Просмотр файла: coingeckoApi.js

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.CoingeckoApi = void 0;
const baseApi_1 = require("./baseApi");
const familyNamesToCoinGeckoIds = new Map()
    .set('BTC', 'bitcoin')
    .set('LTC', 'litecoin')
    .set('BCH', 'bitcoin-cash')
    .set('ZEC', 'zcash')
    .set('DASH', 'dash')
    // note: we don't have a source for price data of BCHA and BSV, but we will use BCH as a proxy. We will substitute
    // it out for a better source when it becomes available.  TODO BG-26359.
    .set('BCHA', 'bitcoin-cash')
    .set('BSV', 'bitcoin-cash');
class CoingeckoApi extends baseApi_1.BaseApi {
    constructor() {
        super('https://api.coingecko.com/api/v3');
    }
    async getUSDPrice(coinFamily) {
        const coinGeckoId = familyNamesToCoinGeckoIds.get(coinFamily.toUpperCase());
        if (!coinGeckoId) {
            throw new Error(`There is no CoinGecko id for family name ${coinFamily.toUpperCase()}.`);
        }
        const coinGeckoUrl = `/simple/price?ids=${coinGeckoId}&vs_currencies=USD`;
        const res = await this.get(coinGeckoUrl, { retry: 2 });
        return res.map((body) => {
            // An example of response
            // {
            //   "ethereum": {
            //     "usd": 220.64
            //   }
            // }
            if (!body) {
                throw new Error('Unable to reach Coin Gecko API for price data');
            }
            if (!body[coinGeckoId]['usd'] || typeof body[coinGeckoId]['usd'] !== 'number') {
                throw new Error('Unexpected response from Coin Gecko API for price data');
            }
            return body[coinGeckoId]['usd'];
        });
    }
}
exports.CoingeckoApi = CoingeckoApi;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29pbmdlY2tvQXBpLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3JlY292ZXJ5L2NvaW5nZWNrb0FwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSx1Q0FBb0M7QUFFcEMsTUFBTSx5QkFBeUIsR0FBRyxJQUFJLEdBQUcsRUFBRTtLQUN4QyxHQUFHLENBQUMsS0FBSyxFQUFFLFNBQVMsQ0FBQztLQUNyQixHQUFHLENBQUMsS0FBSyxFQUFFLFVBQVUsQ0FBQztLQUN0QixHQUFHLENBQUMsS0FBSyxFQUFFLGNBQWMsQ0FBQztLQUMxQixHQUFHLENBQUMsS0FBSyxFQUFFLE9BQU8sQ0FBQztLQUNuQixHQUFHLENBQUMsTUFBTSxFQUFFLE1BQU0sQ0FBQztJQUNwQixrSEFBa0g7SUFDbEgsd0VBQXdFO0tBQ3ZFLEdBQUcsQ0FBQyxNQUFNLEVBQUUsY0FBYyxDQUFDO0tBQzNCLEdBQUcsQ0FBQyxLQUFLLEVBQUUsY0FBYyxDQUFDLENBQUM7QUFFOUIsTUFBYSxZQUFhLFNBQVEsaUJBQU87SUFDdkM7UUFDRSxLQUFLLENBQUMsa0NBQWtDLENBQUMsQ0FBQztJQUM1QyxDQUFDO0lBRUQsS0FBSyxDQUFDLFdBQVcsQ0FBQyxVQUFrQjtRQUNsQyxNQUFNLFdBQVcsR0FBRyx5QkFBeUIsQ0FBQyxHQUFHLENBQUMsVUFBVSxDQUFDLFdBQVcsRUFBRSxDQUFDLENBQUM7UUFDNUUsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO1lBQ2pCLE1BQU0sSUFBSSxLQUFLLENBQUMsNENBQTRDLFVBQVUsQ0FBQyxXQUFXLEVBQUUsR0FBRyxDQUFDLENBQUM7UUFDM0YsQ0FBQztRQUNELE1BQU0sWUFBWSxHQUFHLHFCQUFxQixXQUFXLG9CQUFvQixDQUFDO1FBQzFFLE1BQU0sR0FBRyxHQUFHLE1BQU0sSUFBSSxDQUFDLEdBQUcsQ0FBTSxZQUFZLEVBQUUsRUFBRSxLQUFLLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQztRQUM1RCxPQUFPLEdBQUcsQ0FBQyxHQUFHLENBQUMsQ0FBQyxJQUFJLEVBQUUsRUFBRTtZQUN0Qix5QkFBeUI7WUFDekIsSUFBSTtZQUNKLGtCQUFrQjtZQUNsQixvQkFBb0I7WUFDcEIsTUFBTTtZQUNOLElBQUk7WUFDSixJQUFJLENBQUMsSUFBSSxFQUFFLENBQUM7Z0JBQ1YsTUFBTSxJQUFJLEtBQUssQ0FBQywrQ0FBK0MsQ0FBQyxDQUFDO1lBQ25FLENBQUM7WUFDRCxJQUFJLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDLEtBQUssQ0FBQyxJQUFJLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDLEtBQUssQ0FBQyxLQUFLLFFBQVEsRUFBRSxDQUFDO2dCQUM5RSxNQUFNLElBQUksS0FBSyxDQUFDLHdEQUF3RCxDQUFDLENBQUM7WUFDNUUsQ0FBQztZQUVELE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ2xDLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztDQUNGO0FBN0JELG9DQTZCQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEJhc2VBcGkgfSBmcm9tICcuL2Jhc2VBcGknO1xuXG5jb25zdCBmYW1pbHlOYW1lc1RvQ29pbkdlY2tvSWRzID0gbmV3IE1hcCgpXG4gIC5zZXQoJ0JUQycsICdiaXRjb2luJylcbiAgLnNldCgnTFRDJywgJ2xpdGVjb2luJylcbiAgLnNldCgnQkNIJywgJ2JpdGNvaW4tY2FzaCcpXG4gIC5zZXQoJ1pFQycsICd6Y2FzaCcpXG4gIC5zZXQoJ0RBU0gnLCAnZGFzaCcpXG4gIC8vIG5vdGU6IHdlIGRvbid0IGhhdmUgYSBzb3VyY2UgZm9yIHByaWNlIGRhdGEgb2YgQkNIQSBhbmQgQlNWLCBidXQgd2Ugd2lsbCB1c2UgQkNIIGFzIGEgcHJveHkuIFdlIHdpbGwgc3Vic3RpdHV0ZVxuICAvLyBpdCBvdXQgZm9yIGEgYmV0dGVyIHNvdXJjZSB3aGVuIGl0IGJlY29tZXMgYXZhaWxhYmxlLiAgVE9ETyBCRy0yNjM1OS5cbiAgLnNldCgnQkNIQScsICdiaXRjb2luLWNhc2gnKVxuICAuc2V0KCdCU1YnLCAnYml0Y29pbi1jYXNoJyk7XG5cbmV4cG9ydCBjbGFzcyBDb2luZ2Vja29BcGkgZXh0ZW5kcyBCYXNlQXBpIHtcbiAgY29uc3RydWN0b3IoKSB7XG4gICAgc3VwZXIoJ2h0dHBzOi8vYXBpLmNvaW5nZWNrby5jb20vYXBpL3YzJyk7XG4gIH1cblxuICBhc3luYyBnZXRVU0RQcmljZShjb2luRmFtaWx5OiBzdHJpbmcpOiBQcm9taXNlPG51bWJlcj4ge1xuICAgIGNvbnN0IGNvaW5HZWNrb0lkID0gZmFtaWx5TmFtZXNUb0NvaW5HZWNrb0lkcy5nZXQoY29pbkZhbWlseS50b1VwcGVyQ2FzZSgpKTtcbiAgICBpZiAoIWNvaW5HZWNrb0lkKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYFRoZXJlIGlzIG5vIENvaW5HZWNrbyBpZCBmb3IgZmFtaWx5IG5hbWUgJHtjb2luRmFtaWx5LnRvVXBwZXJDYXNlKCl9LmApO1xuICAgIH1cbiAgICBjb25zdCBjb2luR2Vja29VcmwgPSBgL3NpbXBsZS9wcmljZT9pZHM9JHtjb2luR2Vja29JZH0mdnNfY3VycmVuY2llcz1VU0RgO1xuICAgIGNvbnN0IHJlcyA9IGF3YWl0IHRoaXMuZ2V0PGFueT4oY29pbkdlY2tvVXJsLCB7IHJldHJ5OiAyIH0pO1xuICAgIHJldHVybiByZXMubWFwKChib2R5KSA9PiB7XG4gICAgICAvLyBBbiBleGFtcGxlIG9mIHJlc3BvbnNlXG4gICAgICAvLyB7XG4gICAgICAvLyAgIFwiZXRoZXJldW1cIjoge1xuICAgICAgLy8gICAgIFwidXNkXCI6IDIyMC42NFxuICAgICAgLy8gICB9XG4gICAgICAvLyB9XG4gICAgICBpZiAoIWJvZHkpIHtcbiAgICAgICAgdGhyb3cgbmV3IEVycm9yKCdVbmFibGUgdG8gcmVhY2ggQ29pbiBHZWNrbyBBUEkgZm9yIHByaWNlIGRhdGEnKTtcbiAgICAgIH1cbiAgICAgIGlmICghYm9keVtjb2luR2Vja29JZF1bJ3VzZCddIHx8IHR5cGVvZiBib2R5W2NvaW5HZWNrb0lkXVsndXNkJ10gIT09ICdudW1iZXInKSB7XG4gICAgICAgIHRocm93IG5ldyBFcnJvcignVW5leHBlY3RlZCByZXNwb25zZSBmcm9tIENvaW4gR2Vja28gQVBJIGZvciBwcmljZSBkYXRhJyk7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiBib2R5W2NvaW5HZWNrb0lkXVsndXNkJ107XG4gICAgfSk7XG4gIH1cbn1cbiJdfQ==

Выполнить команду


Для локальной разработки. Не используйте в интернете!