Feature/add cryptocurrency solana (#563)

* Add support for Solana and clean up symbol conversion (SOL1USD)

* Update changelog
pull/566/head
Thomas Kaul 3 years ago committed by GitHub
parent 1602f976f0
commit 9f545e3e2b
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -7,6 +7,10 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
## Unreleased ## Unreleased
### Added
- Added support for cryptocurrency _Solana_ (`SOL-USD`)
### Fixed ### Fixed
- Converted errors to warnings in portfolio calculator - Converted errors to warnings in portfolio calculator

@ -4,5 +4,6 @@
"AVAX": "Avalanche", "AVAX": "Avalanche",
"MATIC": "Polygon", "MATIC": "Polygon",
"SHIB": "Shiba Inu", "SHIB": "Shiba Inu",
"SOL": "Solana",
"UNI3": "Uniswap" "UNI3": "Uniswap"
} }

@ -14,8 +14,6 @@ jest.mock(
return true; return true;
case 'DOGEUSD': case 'DOGEUSD':
return true; return true;
case 'SOLUSD':
return true;
default: default:
return false; return false;
} }
@ -55,9 +53,6 @@ describe('YahooFinanceService', () => {
expect( expect(
await yahooFinanceService.convertToYahooFinanceSymbol('DOGEUSD') await yahooFinanceService.convertToYahooFinanceSymbol('DOGEUSD')
).toEqual('DOGE-USD'); ).toEqual('DOGE-USD');
expect(
await yahooFinanceService.convertToYahooFinanceSymbol('SOL1USD')
).toEqual('SOL1-USD');
expect( expect(
await yahooFinanceService.convertToYahooFinanceSymbol('USDCHF') await yahooFinanceService.convertToYahooFinanceSymbol('USDCHF')
).toEqual('USDCHF=X'); ).toEqual('USDCHF=X');

@ -49,7 +49,6 @@ export class YahooFinanceService implements DataProviderInterface {
* Currency: USDCHF -> USDCHF=X * Currency: USDCHF -> USDCHF=X
* Cryptocurrency: BTCUSD -> BTC-USD * Cryptocurrency: BTCUSD -> BTC-USD
* DOGEUSD -> DOGE-USD * DOGEUSD -> DOGE-USD
* SOL1USD -> SOL1-USD
*/ */
public convertToYahooFinanceSymbol(aSymbol: string) { public convertToYahooFinanceSymbol(aSymbol: string) {
if (aSymbol.includes(baseCurrency) && aSymbol.length >= 6) { if (aSymbol.includes(baseCurrency) && aSymbol.length >= 6) {
@ -57,9 +56,7 @@ export class YahooFinanceService implements DataProviderInterface {
return `${aSymbol}=X`; return `${aSymbol}=X`;
} else if ( } else if (
this.cryptocurrencyService.isCryptocurrency( this.cryptocurrencyService.isCryptocurrency(
aSymbol aSymbol.replace(new RegExp(`-${baseCurrency}$`), baseCurrency)
.replace(new RegExp(`-${baseCurrency}$`), baseCurrency)
.replace('1', '')
) )
) { ) {
// Add a dash before the last three characters // Add a dash before the last three characters
@ -246,9 +243,7 @@ export class YahooFinanceService implements DataProviderInterface {
return ( return (
(quoteType === 'CRYPTOCURRENCY' && (quoteType === 'CRYPTOCURRENCY' &&
this.cryptocurrencyService.isCryptocurrency( this.cryptocurrencyService.isCryptocurrency(
symbol symbol.replace(new RegExp(`-${baseCurrency}$`), baseCurrency)
.replace(new RegExp(`-${baseCurrency}$`), baseCurrency)
.replace('1', '')
)) || )) ||
quoteType === 'EQUITY' || quoteType === 'EQUITY' ||
quoteType === 'ETF' quoteType === 'ETF'

Loading…
Cancel
Save