|
|
@ -18,7 +18,6 @@ import {
|
|
|
|
|
|
|
|
|
|
|
|
import { ConfigurationService } from './configuration.service';
|
|
|
|
import { ConfigurationService } from './configuration.service';
|
|
|
|
import { DataProviderService } from './data-provider/data-provider.service';
|
|
|
|
import { DataProviderService } from './data-provider/data-provider.service';
|
|
|
|
import { GhostfolioScraperApiService } from './data-provider/ghostfolio-scraper-api/ghostfolio-scraper-api.service';
|
|
|
|
|
|
|
|
import { DataEnhancerInterface } from './data-provider/interfaces/data-enhancer.interface';
|
|
|
|
import { DataEnhancerInterface } from './data-provider/interfaces/data-enhancer.interface';
|
|
|
|
import { ExchangeRateDataService } from './exchange-rate-data.service';
|
|
|
|
import { ExchangeRateDataService } from './exchange-rate-data.service';
|
|
|
|
import { IDataGatheringItem } from './interfaces/interfaces';
|
|
|
|
import { IDataGatheringItem } from './interfaces/interfaces';
|
|
|
@ -26,13 +25,14 @@ import { PrismaService } from './prisma.service';
|
|
|
|
|
|
|
|
|
|
|
|
@Injectable()
|
|
|
|
@Injectable()
|
|
|
|
export class DataGatheringService {
|
|
|
|
export class DataGatheringService {
|
|
|
|
|
|
|
|
private dataGatheringProgress: number;
|
|
|
|
|
|
|
|
|
|
|
|
public constructor(
|
|
|
|
public constructor(
|
|
|
|
private readonly configurationService: ConfigurationService,
|
|
|
|
private readonly configurationService: ConfigurationService,
|
|
|
|
@Inject('DataEnhancers')
|
|
|
|
@Inject('DataEnhancers')
|
|
|
|
private readonly dataEnhancers: DataEnhancerInterface[],
|
|
|
|
private readonly dataEnhancers: DataEnhancerInterface[],
|
|
|
|
private readonly dataProviderService: DataProviderService,
|
|
|
|
private readonly dataProviderService: DataProviderService,
|
|
|
|
private readonly exchangeRateDataService: ExchangeRateDataService,
|
|
|
|
private readonly exchangeRateDataService: ExchangeRateDataService,
|
|
|
|
private readonly ghostfolioScraperApi: GhostfolioScraperApiService,
|
|
|
|
|
|
|
|
private readonly prismaService: PrismaService,
|
|
|
|
private readonly prismaService: PrismaService,
|
|
|
|
private readonly symbolProfileService: SymbolProfileService
|
|
|
|
private readonly symbolProfileService: SymbolProfileService
|
|
|
|
) {}
|
|
|
|
) {}
|
|
|
@ -204,8 +204,11 @@ export class DataGatheringService {
|
|
|
|
|
|
|
|
|
|
|
|
public async gatherSymbols(aSymbolsWithStartDate: IDataGatheringItem[]) {
|
|
|
|
public async gatherSymbols(aSymbolsWithStartDate: IDataGatheringItem[]) {
|
|
|
|
let hasError = false;
|
|
|
|
let hasError = false;
|
|
|
|
|
|
|
|
let symbolCounter = 0;
|
|
|
|
|
|
|
|
|
|
|
|
for (const { dataSource, date, symbol } of aSymbolsWithStartDate) {
|
|
|
|
for (const { dataSource, date, symbol } of aSymbolsWithStartDate) {
|
|
|
|
|
|
|
|
this.dataGatheringProgress = symbolCounter / aSymbolsWithStartDate.length;
|
|
|
|
|
|
|
|
|
|
|
|
try {
|
|
|
|
try {
|
|
|
|
const historicalData = await this.dataProviderService.getHistoricalRaw(
|
|
|
|
const historicalData = await this.dataProviderService.getHistoricalRaw(
|
|
|
|
[{ dataSource, symbol }],
|
|
|
|
[{ dataSource, symbol }],
|
|
|
@ -263,6 +266,16 @@ export class DataGatheringService {
|
|
|
|
hasError = true;
|
|
|
|
hasError = true;
|
|
|
|
Logger.error(error);
|
|
|
|
Logger.error(error);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (symbolCounter > 0 && symbolCounter % 100 === 0) {
|
|
|
|
|
|
|
|
Logger.log(
|
|
|
|
|
|
|
|
`Data gathering progress: ${(
|
|
|
|
|
|
|
|
this.dataGatheringProgress * 100
|
|
|
|
|
|
|
|
).toFixed(2)}%`
|
|
|
|
|
|
|
|
);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
symbolCounter += 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
await this.exchangeRateDataService.initialize();
|
|
|
|
await this.exchangeRateDataService.initialize();
|
|
|
@ -272,6 +285,16 @@ export class DataGatheringService {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public async getDataGatheringProgress() {
|
|
|
|
|
|
|
|
const isInProgress = await this.getIsInProgress();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (isInProgress) {
|
|
|
|
|
|
|
|
return this.dataGatheringProgress;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return undefined;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public async getIsInProgress() {
|
|
|
|
public async getIsInProgress() {
|
|
|
|
return await this.prismaService.property.findUnique({
|
|
|
|
return await this.prismaService.property.findUnique({
|
|
|
|
where: { key: 'LOCKED_DATA_GATHERING' }
|
|
|
|
where: { key: 'LOCKED_DATA_GATHERING' }
|
|
|
|