Frankfurte-rs
Rust library and CLI to interface with any Frankfurter API.
Frankfurter is a free, open source and self-hostable currency exchange rate API. It is based on data sets published by the European Central Bank.
Table of Contents
About
Frankfurte-rs (Frankfurters) is available as both an executable (frs) and a Rust library,
with the hope of providing safe and correct bindings for the API.
[!NOTE] While the Frankfurter API works well most of the time, there are many edge cases and the returned errors are not exactly informative. If you run into any problems while using these bindings, please open an issue with the details of the error encountered.
Library
Install with cargo add lib_frankfurter or simply add lib_frankfurter your Cargo.toml.
Then, check out the this example to see basic usage.
CLI
Installation
Cargo
AUR
Usage
# List the latest supported currencies
# Get the latest exchange rates, converting from the EUR
# Get exchange rates from 01/01/2024 (or the closest available date with data), converting from the USD to PHP and NOK
# Get exchange rates over a time period from 01/01/2024 to the present date, converting from EUR to AUD
# Get exchange rates over a time period from 01/01/2024 to the 10/01/2024, converting from GBP to EUR and USD
All options will print results in a table, but also accept the following options if you want the results in a different format:
--raw: prints values only separated by tabs, useful for piping the data to different commands--json: prints the fullJSONresponse from the server
View the full usage with frs --help.
Self-hosting
A public, free-to-use version of the API is available here, and will be used by default.
However, this repo comes with a docker-compose.yml for easy self-hosting of the Frankfurter API. To set up and use a self-hosted version of the API, follow these steps:
1. Copy/clone the docker-compose.yml file to your system
2. Run docker compose up -d --wait to start up both the postgresql database and the Frankfurter API itself locally using Docker
3. When running commands, specify the desired API URL, e.g. frs --url http://localhost:8080
Related Projects
- moneyman: Currency conversion using the same data sets from the ECB, but without the intermediary step of going through a separate API. Note that the caveat outlined there would also apply to
Frankfurter.
Credit
- Frankfurter of course, for be the underlying API that this project wraps
- ltrs for inspiration and a look at how Rust API bindings should look/function