|
@ -11,6 +11,7 @@ import { |
|
|
IDataProviderHistoricalResponse, |
|
|
IDataProviderHistoricalResponse, |
|
|
IDataProviderResponse |
|
|
IDataProviderResponse |
|
|
} from '@ghostfolio/api/services/interfaces/interfaces'; |
|
|
} from '@ghostfolio/api/services/interfaces/interfaces'; |
|
|
|
|
|
import { SymbolProfileService } from '@ghostfolio/api/services/symbol-profile/symbol-profile.service'; |
|
|
import { |
|
|
import { |
|
|
DEFAULT_CURRENCY, |
|
|
DEFAULT_CURRENCY, |
|
|
REPLACE_NAME_PARTS |
|
|
REPLACE_NAME_PARTS |
|
@ -35,7 +36,8 @@ export class EodHistoricalDataService implements DataProviderInterface { |
|
|
private readonly URL = 'https://eodhistoricaldata.com/api'; |
|
|
private readonly URL = 'https://eodhistoricaldata.com/api'; |
|
|
|
|
|
|
|
|
public constructor( |
|
|
public constructor( |
|
|
private readonly configurationService: ConfigurationService |
|
|
private readonly configurationService: ConfigurationService, |
|
|
|
|
|
private readonly symbolProfileService: SymbolProfileService |
|
|
) { |
|
|
) { |
|
|
this.apiKey = this.configurationService.get('API_KEY_EOD_HISTORICAL_DATA'); |
|
|
this.apiKey = this.configurationService.get('API_KEY_EOD_HISTORICAL_DATA'); |
|
|
} |
|
|
} |
|
@ -230,15 +232,33 @@ export class EodHistoricalDataService implements DataProviderInterface { |
|
|
? [realTimeResponse] |
|
|
? [realTimeResponse] |
|
|
: realTimeResponse; |
|
|
: realTimeResponse; |
|
|
|
|
|
|
|
|
response = quotes.reduce( |
|
|
const symbolProfiles = await this.symbolProfileService.getSymbolProfiles( |
|
|
async ( |
|
|
symbols.map((symbol) => { |
|
|
result: { [symbol: string]: IDataProviderResponse }, |
|
|
return { |
|
|
{ close, code, timestamp } |
|
|
symbol, |
|
|
) => { |
|
|
dataSource: this.getName() |
|
|
|
|
|
}; |
|
|
|
|
|
}) |
|
|
|
|
|
); |
|
|
|
|
|
|
|
|
|
|
|
for (const { close, code, timestamp } of quotes) { |
|
|
let currency: string; |
|
|
let currency: string; |
|
|
|
|
|
|
|
|
if (symbols.length === 1) { |
|
|
if (code.endsWith('.FOREX')) { |
|
|
const { items } = await this.search({ query: symbols[0] }); |
|
|
currency = this.convertFromEodSymbol(code)?.replace( |
|
|
|
|
|
DEFAULT_CURRENCY, |
|
|
|
|
|
'' |
|
|
|
|
|
); |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
if (!currency) { |
|
|
|
|
|
currency = symbolProfiles.find(({ symbol }) => { |
|
|
|
|
|
return symbol === code; |
|
|
|
|
|
})?.currency; |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
if (!currency) { |
|
|
|
|
|
const { items } = await this.search({ query: code }); |
|
|
|
|
|
|
|
|
if (items.length === 1) { |
|
|
if (items.length === 1) { |
|
|
currency = items[0].currency; |
|
|
currency = items[0].currency; |
|
@ -246,13 +266,11 @@ export class EodHistoricalDataService implements DataProviderInterface { |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
if (isNumber(close)) { |
|
|
if (isNumber(close)) { |
|
|
result[this.convertFromEodSymbol(code)] = { |
|
|
response[this.convertFromEodSymbol(code)] = { |
|
|
currency, |
|
|
currency, |
|
|
dataSource: this.getName(), |
|
|
dataSource: this.getName(), |
|
|
marketPrice: close, |
|
|
marketPrice: close, |
|
|
marketState: isToday(new Date(timestamp * 1000)) |
|
|
marketState: isToday(new Date(timestamp * 1000)) ? 'open' : 'closed' |
|
|
? 'open' |
|
|
|
|
|
: 'closed' |
|
|
|
|
|
}; |
|
|
}; |
|
|
} else { |
|
|
} else { |
|
|
Logger.error( |
|
|
Logger.error( |
|
@ -260,11 +278,7 @@ export class EodHistoricalDataService implements DataProviderInterface { |
|
|
'EodHistoricalDataService' |
|
|
'EodHistoricalDataService' |
|
|
); |
|
|
); |
|
|
} |
|
|
} |
|
|
|
|
|
} |
|
|
return result; |
|
|
|
|
|
}, |
|
|
|
|
|
{} |
|
|
|
|
|
); |
|
|
|
|
|
|
|
|
|
|
|
return response; |
|
|
return response; |
|
|
} catch (error) { |
|
|
} catch (error) { |
|
|