2021-07-08 22:42:19 +02:00
|
|
|
import { DataProviderService } from '@ghostfolio/api/services/data-provider.service';
|
2021-07-01 23:11:41 +02:00
|
|
|
import { ExchangeRateDataService } from '@ghostfolio/api/services/exchange-rate-data.service';
|
2021-07-09 21:35:54 +02:00
|
|
|
import { resetHours } from '@ghostfolio/common/helper';
|
2021-07-03 16:37:33 +02:00
|
|
|
import { Injectable } from '@nestjs/common';
|
|
|
|
import { Currency } from '@prisma/client';
|
2021-07-08 22:42:19 +02:00
|
|
|
import { isToday } from 'date-fns';
|
2021-07-01 23:11:41 +02:00
|
|
|
|
2021-07-03 16:37:33 +02:00
|
|
|
import { MarketDataService } from './market-data.service';
|
2021-07-01 23:11:41 +02:00
|
|
|
|
2021-07-03 16:37:33 +02:00
|
|
|
@Injectable()
|
|
|
|
export class CurrentRateService {
|
2021-07-01 23:11:41 +02:00
|
|
|
public constructor(
|
2021-07-08 22:42:19 +02:00
|
|
|
private readonly dataProviderService: DataProviderService,
|
2021-07-01 23:11:41 +02:00
|
|
|
private readonly exchangeRateDataService: ExchangeRateDataService,
|
2021-07-03 16:37:33 +02:00
|
|
|
private readonly marketDataService: MarketDataService
|
2021-07-01 23:11:41 +02:00
|
|
|
) {}
|
|
|
|
|
2021-07-03 16:37:33 +02:00
|
|
|
public async getValue({
|
|
|
|
currency,
|
|
|
|
date,
|
|
|
|
symbol,
|
|
|
|
userCurrency
|
2021-07-09 21:35:54 +02:00
|
|
|
}: GetValueParams): Promise<GetValueObject> {
|
2021-07-08 22:42:19 +02:00
|
|
|
if (isToday(date)) {
|
|
|
|
const dataProviderResult = await this.dataProviderService.get([symbol]);
|
2021-07-09 21:35:54 +02:00
|
|
|
return {
|
|
|
|
date: resetHours(date),
|
2021-07-20 21:07:17 +02:00
|
|
|
marketPrice: dataProviderResult?.[symbol]?.marketPrice ?? 0,
|
|
|
|
symbol: symbol
|
2021-07-09 21:35:54 +02:00
|
|
|
};
|
2021-07-08 22:42:19 +02:00
|
|
|
}
|
|
|
|
|
2021-07-03 16:37:33 +02:00
|
|
|
const marketData = await this.marketDataService.get({
|
|
|
|
date,
|
|
|
|
symbol
|
2021-07-01 23:11:41 +02:00
|
|
|
});
|
|
|
|
|
2021-07-03 16:37:33 +02:00
|
|
|
if (marketData) {
|
2021-07-09 21:35:54 +02:00
|
|
|
return {
|
|
|
|
date: marketData.date,
|
2021-07-20 21:07:17 +02:00
|
|
|
symbol: marketData.symbol,
|
2021-07-09 21:35:54 +02:00
|
|
|
marketPrice: this.exchangeRateDataService.toCurrency(
|
|
|
|
marketData.marketPrice,
|
|
|
|
currency,
|
|
|
|
userCurrency
|
|
|
|
)
|
|
|
|
};
|
2021-07-03 16:37:33 +02:00
|
|
|
}
|
2021-07-01 23:11:41 +02:00
|
|
|
|
2021-07-09 21:35:54 +02:00
|
|
|
throw new Error(`Value not found for ${symbol} at ${resetHours(date)}`);
|
|
|
|
}
|
|
|
|
|
|
|
|
public async getValues({
|
2021-07-20 20:42:56 +02:00
|
|
|
currencies,
|
2021-07-09 21:35:54 +02:00
|
|
|
dateRangeEnd,
|
|
|
|
dateRangeStart,
|
2021-07-20 20:42:56 +02:00
|
|
|
symbols,
|
2021-07-09 21:35:54 +02:00
|
|
|
userCurrency
|
|
|
|
}: GetValuesParams): Promise<GetValueObject[]> {
|
|
|
|
const marketData = await this.marketDataService.getRange({
|
|
|
|
dateRangeEnd,
|
|
|
|
dateRangeStart,
|
2021-07-20 20:42:56 +02:00
|
|
|
symbols
|
2021-07-09 21:35:54 +02:00
|
|
|
});
|
|
|
|
|
|
|
|
if (marketData) {
|
|
|
|
return marketData.map((marketDataItem) => {
|
|
|
|
return {
|
|
|
|
date: marketDataItem.date,
|
2021-07-20 21:07:17 +02:00
|
|
|
symbol: marketDataItem.symbol,
|
2021-07-09 21:35:54 +02:00
|
|
|
marketPrice: this.exchangeRateDataService.toCurrency(
|
|
|
|
marketDataItem.marketPrice,
|
2021-07-20 20:42:56 +02:00
|
|
|
currencies[marketDataItem.symbol],
|
2021-07-09 21:35:54 +02:00
|
|
|
userCurrency
|
|
|
|
)
|
|
|
|
};
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
throw new Error(
|
2021-07-20 20:42:56 +02:00
|
|
|
`Values not found for symbols ${symbols.join(', ')} from ${resetHours(
|
2021-07-09 21:35:54 +02:00
|
|
|
dateRangeStart
|
|
|
|
)} to ${resetHours(dateRangeEnd)}`
|
|
|
|
);
|
2021-07-01 23:11:41 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface GetValueParams {
|
|
|
|
date: Date;
|
|
|
|
symbol: string;
|
|
|
|
currency: Currency;
|
|
|
|
userCurrency: Currency;
|
|
|
|
}
|
2021-07-09 21:35:54 +02:00
|
|
|
|
|
|
|
export interface GetValuesParams {
|
|
|
|
dateRangeEnd: Date;
|
|
|
|
dateRangeStart: Date;
|
2021-07-20 20:42:56 +02:00
|
|
|
symbols: string[];
|
|
|
|
currencies: { [symbol: string]: Currency };
|
2021-07-09 21:35:54 +02:00
|
|
|
userCurrency: Currency;
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface GetValueObject {
|
|
|
|
date: Date;
|
2021-07-20 21:07:17 +02:00
|
|
|
symbol: string;
|
2021-07-09 21:35:54 +02:00
|
|
|
marketPrice: number;
|
|
|
|
}
|