|
@ -40,7 +40,7 @@ export class DataGatheringService { |
|
|
const isDataGatheringNeeded = await this.isDataGatheringNeeded(); |
|
|
const isDataGatheringNeeded = await this.isDataGatheringNeeded(); |
|
|
|
|
|
|
|
|
if (isDataGatheringNeeded) { |
|
|
if (isDataGatheringNeeded) { |
|
|
Logger.log('7d data gathering has been started.'); |
|
|
Logger.log('7d data gathering has been started.', 'DataGatheringService'); |
|
|
console.time('data-gathering-7d'); |
|
|
console.time('data-gathering-7d'); |
|
|
|
|
|
|
|
|
await this.prismaService.property.create({ |
|
|
await this.prismaService.property.create({ |
|
@ -64,7 +64,7 @@ export class DataGatheringService { |
|
|
where: { key: PROPERTY_LAST_DATA_GATHERING } |
|
|
where: { key: PROPERTY_LAST_DATA_GATHERING } |
|
|
}); |
|
|
}); |
|
|
} catch (error) { |
|
|
} catch (error) { |
|
|
Logger.error(error); |
|
|
Logger.error(error, 'DataGatheringService'); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
await this.prismaService.property.delete({ |
|
|
await this.prismaService.property.delete({ |
|
@ -73,7 +73,10 @@ export class DataGatheringService { |
|
|
} |
|
|
} |
|
|
}); |
|
|
}); |
|
|
|
|
|
|
|
|
Logger.log('7d data gathering has been completed.'); |
|
|
Logger.log( |
|
|
|
|
|
'7d data gathering has been completed.', |
|
|
|
|
|
'DataGatheringService' |
|
|
|
|
|
); |
|
|
console.timeEnd('data-gathering-7d'); |
|
|
console.timeEnd('data-gathering-7d'); |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
@ -84,7 +87,10 @@ export class DataGatheringService { |
|
|
}); |
|
|
}); |
|
|
|
|
|
|
|
|
if (!isDataGatheringLocked) { |
|
|
if (!isDataGatheringLocked) { |
|
|
Logger.log('Max data gathering has been started.'); |
|
|
Logger.log( |
|
|
|
|
|
'Max data gathering has been started.', |
|
|
|
|
|
'DataGatheringService' |
|
|
|
|
|
); |
|
|
console.time('data-gathering-max'); |
|
|
console.time('data-gathering-max'); |
|
|
|
|
|
|
|
|
await this.prismaService.property.create({ |
|
|
await this.prismaService.property.create({ |
|
@ -108,7 +114,7 @@ export class DataGatheringService { |
|
|
where: { key: PROPERTY_LAST_DATA_GATHERING } |
|
|
where: { key: PROPERTY_LAST_DATA_GATHERING } |
|
|
}); |
|
|
}); |
|
|
} catch (error) { |
|
|
} catch (error) { |
|
|
Logger.error(error); |
|
|
Logger.error(error, 'DataGatheringService'); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
await this.prismaService.property.delete({ |
|
|
await this.prismaService.property.delete({ |
|
@ -117,7 +123,10 @@ export class DataGatheringService { |
|
|
} |
|
|
} |
|
|
}); |
|
|
}); |
|
|
|
|
|
|
|
|
Logger.log('Max data gathering has been completed.'); |
|
|
Logger.log( |
|
|
|
|
|
'Max data gathering has been completed.', |
|
|
|
|
|
'DataGatheringService' |
|
|
|
|
|
); |
|
|
console.timeEnd('data-gathering-max'); |
|
|
console.timeEnd('data-gathering-max'); |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
@ -128,7 +137,10 @@ export class DataGatheringService { |
|
|
}); |
|
|
}); |
|
|
|
|
|
|
|
|
if (!isDataGatheringLocked) { |
|
|
if (!isDataGatheringLocked) { |
|
|
Logger.log(`Symbol data gathering for ${symbol} has been started.`); |
|
|
Logger.log( |
|
|
|
|
|
`Symbol data gathering for ${symbol} has been started.`, |
|
|
|
|
|
'DataGatheringService' |
|
|
|
|
|
); |
|
|
console.time('data-gathering-symbol'); |
|
|
console.time('data-gathering-symbol'); |
|
|
|
|
|
|
|
|
await this.prismaService.property.create({ |
|
|
await this.prismaService.property.create({ |
|
@ -159,7 +171,7 @@ export class DataGatheringService { |
|
|
where: { key: PROPERTY_LAST_DATA_GATHERING } |
|
|
where: { key: PROPERTY_LAST_DATA_GATHERING } |
|
|
}); |
|
|
}); |
|
|
} catch (error) { |
|
|
} catch (error) { |
|
|
Logger.error(error); |
|
|
Logger.error(error, 'DataGatheringService'); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
await this.prismaService.property.delete({ |
|
|
await this.prismaService.property.delete({ |
|
@ -168,7 +180,10 @@ export class DataGatheringService { |
|
|
} |
|
|
} |
|
|
}); |
|
|
}); |
|
|
|
|
|
|
|
|
Logger.log(`Symbol data gathering for ${symbol} has been completed.`); |
|
|
Logger.log( |
|
|
|
|
|
`Symbol data gathering for ${symbol} has been completed.`, |
|
|
|
|
|
'DataGatheringService' |
|
|
|
|
|
); |
|
|
console.timeEnd('data-gathering-symbol'); |
|
|
console.timeEnd('data-gathering-symbol'); |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
@ -205,14 +220,17 @@ export class DataGatheringService { |
|
|
}); |
|
|
}); |
|
|
} |
|
|
} |
|
|
} catch (error) { |
|
|
} catch (error) { |
|
|
Logger.error(error); |
|
|
Logger.error(error, 'DataGatheringService'); |
|
|
} finally { |
|
|
} finally { |
|
|
return undefined; |
|
|
return undefined; |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
public async gatherProfileData(aDataGatheringItems?: IDataGatheringItem[]) { |
|
|
public async gatherProfileData(aDataGatheringItems?: IDataGatheringItem[]) { |
|
|
Logger.log('Profile data gathering has been started.'); |
|
|
Logger.log( |
|
|
|
|
|
'Profile data gathering has been started.', |
|
|
|
|
|
'DataGatheringService' |
|
|
|
|
|
); |
|
|
console.time('data-gathering-profile'); |
|
|
console.time('data-gathering-profile'); |
|
|
|
|
|
|
|
|
let dataGatheringItems = aDataGatheringItems?.filter( |
|
|
let dataGatheringItems = aDataGatheringItems?.filter( |
|
@ -248,7 +266,8 @@ export class DataGatheringService { |
|
|
} catch (error) { |
|
|
} catch (error) { |
|
|
Logger.error( |
|
|
Logger.error( |
|
|
`Failed to enhance data for symbol ${symbol} by ${dataEnhancer.getName()}`, |
|
|
`Failed to enhance data for symbol ${symbol} by ${dataEnhancer.getName()}`, |
|
|
error |
|
|
error, |
|
|
|
|
|
'DataGatheringService' |
|
|
); |
|
|
); |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
@ -294,11 +313,18 @@ export class DataGatheringService { |
|
|
} |
|
|
} |
|
|
}); |
|
|
}); |
|
|
} catch (error) { |
|
|
} catch (error) { |
|
|
Logger.error(`${symbol}: ${error?.meta?.cause}`); |
|
|
Logger.error( |
|
|
|
|
|
`${symbol}: ${error?.meta?.cause}`, |
|
|
|
|
|
error, |
|
|
|
|
|
'DataGatheringService' |
|
|
|
|
|
); |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
Logger.log('Profile data gathering has been completed.'); |
|
|
Logger.log( |
|
|
|
|
|
'Profile data gathering has been completed.', |
|
|
|
|
|
'DataGatheringService' |
|
|
|
|
|
); |
|
|
console.timeEnd('data-gathering-profile'); |
|
|
console.timeEnd('data-gathering-profile'); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
@ -361,7 +387,8 @@ export class DataGatheringService { |
|
|
`Failed to gather data for symbol ${symbol} from ${dataSource} at ${format( |
|
|
`Failed to gather data for symbol ${symbol} from ${dataSource} at ${format( |
|
|
currentDate, |
|
|
currentDate, |
|
|
DATE_FORMAT |
|
|
DATE_FORMAT |
|
|
)}.` |
|
|
)}.`,
|
|
|
|
|
|
'DataGatheringService' |
|
|
); |
|
|
); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
@ -377,14 +404,15 @@ export class DataGatheringService { |
|
|
} |
|
|
} |
|
|
} catch (error) { |
|
|
} catch (error) { |
|
|
hasError = true; |
|
|
hasError = true; |
|
|
Logger.error(error); |
|
|
Logger.error(error, 'DataGatheringService'); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
if (symbolCounter > 0 && symbolCounter % 100 === 0) { |
|
|
if (symbolCounter > 0 && symbolCounter % 100 === 0) { |
|
|
Logger.log( |
|
|
Logger.log( |
|
|
`Data gathering progress: ${( |
|
|
`Data gathering progress: ${( |
|
|
this.dataGatheringProgress * 100 |
|
|
this.dataGatheringProgress * 100 |
|
|
).toFixed(2)}%` |
|
|
).toFixed(2)}%`,
|
|
|
|
|
|
'DataGatheringService' |
|
|
); |
|
|
); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
@ -474,7 +502,7 @@ export class DataGatheringService { |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
public async reset() { |
|
|
public async reset() { |
|
|
Logger.log('Data gathering has been reset.'); |
|
|
Logger.log('Data gathering has been reset.', 'DataGatheringService'); |
|
|
|
|
|
|
|
|
await this.prismaService.property.deleteMany({ |
|
|
await this.prismaService.property.deleteMany({ |
|
|
where: { |
|
|
where: { |
|
|