@public-js/exchange-rates
TypeScript icon, indicating that this package has built-in type declarations

0.0.2 • Public • Published

@public-js/exchange-rates

Build Version Downloads Size

CodeQL Codacy Codecov Code Climate

An extensive exchange rates API client supporting multiple services for best results


Installing

Add the package to your project by running:

npm i @public-js/exchange-rates

Usage

Instantiate a class:

import { ExchangeRates } from '@public-js/exchange-rates';

const service = await new ExchangeRates({
  OpenexchangeratesOrg: env.OXR_API_KEY,
  ExchangerateHost: true,
});

Fetch the latest rates:

const rates = await service.getRates('USD', ['EUR', 'CNY']);
console.log(rates); // {"CNY":6.8936,"EUR":0.901185}

Fetch the historical rates:

const rates = await service.getRates('USD', ['EUR', 'CNY'], '2023-01-15');
console.log(rates); // {"CNY":6.8936,"EUR":0.901185}

Supported services

Note The majority of services require an API key/token to work. This doesn't apply to ExchangerateHost, which needs any truthy value provided as a key to be active.

How does it work

When the ExchangeRates class is instantiated it requires a configuration object to be provided. The said object has to list the desired services and their respective API keys/tokens.

Since some of the services don't handle unsupported currency codes well, they will be queried for a full rates list which then gets filtered out. This process is repeated for each service until all of them are queried or the required currencies are fetched.

The order of the services is listed in the "Supported services" section, it can't be altered at a time and is pre-defined based on data reliability, precision and currency coverage. It is possible however to enable only part of the supported services by providing only some of the API keys.

Resources

License

MIT, full license text. Read more about it on TLDRLegal.

Package Sidebar

Install

npm i @public-js/exchange-rates

Weekly Downloads

13

Version

0.0.2

License

MIT

Unpacked Size

15.5 kB

Total Files

14

Last publish

Collaborators

  • mullinsmikey