Browse Source

Merge edd8099b78 into 81f874bbc2

pull/4073/merge
Devin A. Conley 8 months ago
committed by GitHub
parent
commit
a2b23e2583
No known key found for this signature in database GPG Key ID: B5690EEEBB952194
  1. 80
      apps/api/src/services/data-provider/coingecko/coingecko.service.ts
  2. 1
      prisma/schema.prisma

80
apps/api/src/services/data-provider/coingecko/coingecko.service.ts

@ -75,7 +75,13 @@ export class CoinGeckoService implements DataProviderInterface {
abortController.abort();
}, this.configurationService.get('REQUEST_TIMEOUT'));
const { name } = await got(`${this.apiUrl}/coins/${symbol}`, {
let url = `${this.apiUrl}/coins/${symbol}`;
if (symbol.startsWith('nft:')) {
response.assetSubClass = AssetSubClass.NFT;
url = `${this.apiUrl}/nfts/${symbol.replace('nft:', '')}`;
}
const { name } = await got(url, {
headers: this.headers,
// @ts-ignore
signal: abortController.signal
@ -124,18 +130,22 @@ export class CoinGeckoService implements DataProviderInterface {
abortController.abort();
}, requestTimeout);
const { prices } = await got(
`${
this.apiUrl
}/coins/${symbol}/market_chart/range?vs_currency=${DEFAULT_CURRENCY.toLowerCase()}&from=${getUnixTime(
from
)}&to=${getUnixTime(to)}`,
{
let url = `${this.apiUrl}/coins/${symbol}/market_chart/range?vs_currency=${DEFAULT_CURRENCY.toLowerCase()}&from=${getUnixTime(from)}&to=${getUnixTime(to)}`;
let field = 'prices';
if (symbol.startsWith('nft:')) {
// note: pro only
url = `${this.apiUrl}/nfts/${symbol.replace('nft:', '')}/market_chart?days=max`;
field = 'floor_prices_usd';
}
console.log(url);
const res = await got(url, {
headers: this.headers,
// @ts-ignore
signal: abortController.signal
}
).json<any>();
}).json<any>();
const prices = res[field];
const result: {
[symbol: string]: { [date: string]: IDataProviderHistoricalResponse };
@ -185,10 +195,12 @@ export class CoinGeckoService implements DataProviderInterface {
abortController.abort();
}, requestTimeout);
// note: simple price endpoint currently does not support list of nfts
// (submitted a ticket with this request)
const quotes = await got(
`${this.apiUrl}/simple/price?ids=${symbols.join(
','
)}&vs_currencies=${DEFAULT_CURRENCY.toLowerCase()}`,
`${this.apiUrl}/simple/price?ids=${symbols
.filter((s) => !s.startsWith('nft:'))
.join(',')}&vs_currencies=${DEFAULT_CURRENCY.toLowerCase()}`,
{
headers: this.headers,
// @ts-ignore
@ -205,6 +217,24 @@ export class CoinGeckoService implements DataProviderInterface {
marketState: 'open'
};
}
// nfts
for (const symbol of symbols.filter((s) => s.startsWith('nft:'))) {
const s = symbol.replace('nft:', '');
const { floor_price } = await got(`${this.apiUrl}/nfts/${s}`, {
headers: this.headers,
// @ts-ignore
signal: abortController.signal
}).json<any>();
console.log(floor_price);
response[symbol] = {
currency: DEFAULT_CURRENCY,
dataProviderInfo: this.getDataProviderInfo(),
dataSource: DataSource.COINGECKO,
marketPrice: floor_price[DEFAULT_CURRENCY.toLowerCase()],
marketState: 'open'
};
}
} catch (error) {
let message = error;
@ -216,7 +246,7 @@ export class CoinGeckoService implements DataProviderInterface {
Logger.error(message, 'CoinGeckoService');
}
console.log(response);
return response;
}
@ -234,13 +264,17 @@ export class CoinGeckoService implements DataProviderInterface {
abortController.abort();
}, this.configurationService.get('REQUEST_TIMEOUT'));
const { coins } = await got(`${this.apiUrl}/search?query=${query}`, {
// note: this search does return nfts in a separate array
const { coins, nfts } = await got(
`${this.apiUrl}/search?query=${query}`,
{
headers: this.headers,
// @ts-ignore
signal: abortController.signal
}).json<any>();
}
).json<any>();
items = coins.map(({ id: symbol, name }) => {
let itemsCoins = coins.map(({ id: symbol, name }) => {
return {
name,
symbol,
@ -251,6 +285,18 @@ export class CoinGeckoService implements DataProviderInterface {
dataSource: this.getName()
};
});
let itemsNfts = nfts.map(({ id: symbol, name }) => {
return {
name,
symbol: `nft:${symbol}`,
assetClass: AssetClass.LIQUIDITY,
assetSubClass: AssetSubClass.NFT,
currency: DEFAULT_CURRENCY,
dataProviderInfo: this.getDataProviderInfo(),
dataSource: this.getName()
};
});
items = itemsCoins.concat(itemsNfts);
} catch (error) {
let message = error;

1
prisma/schema.prisma

@ -284,6 +284,7 @@ enum AssetSubClass {
CASH
COMMODITY
CRYPTOCURRENCY
NFT
ETF
MUTUALFUND
PRECIOUS_METAL

Loading…
Cancel
Save