Skip to content

Rust bindings to Frankfurter, an open source exchange rates API

License

Notifications You must be signed in to change notification settings

Rolv-Apneseth/frankfurte-rs

Repository files navigation

Frankfurte-rs

Crates.io - Library docs.rs - Library Version AUR

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

  1. About
  2. Library
  3. CLI
  4. Installation
  5. Usage
  6. Self-hosting
  7. Contributing
  8. Related Projects
  9. Credit
  10. Licence

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 some 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

cargo install frankfurter_cli

AUR

paru -S frs

Usage

# List the latest supported currencies
frs currencies
# Get the latest exchange rates, converting from the EUR
frs convert
# Get exchange rates from 01/01/2024 (or the closest available date with data), converting from the USD to PHP and NOK
frs convert USD -d 2024-01-01
# Get exchange rates over a time period from 01/01/2024 to the present date, converting from EUR to AUD
frs period EUR 2024-01-01 -t AUD
# Get exchange rates over a time period from 01/01/2024 to the 10/01/2024, converting from GBP to EUR and USD
frs period GBP -t EUR,USD 2024-01-01 2024-01-10

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 full JSON response 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 and convenient 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 the Frankfurter API, which includes a SQLite database, locally using Docker
  3. When running commands, specify the desired API URL using either the --url flag or the FRANKFURTER_URL environment variable:
    • frs --url http://localhost:8080
    • FRANKFURTER_URL="http://localhost:8080 frs

Contributing

Contributions of any kind are welcome. Feel free to fork the repo, follow the suggested workflow below, commit your changes and open a pull request.

This project uses just, but if you wish to avoid installing that, you can find the individual commands in the justfile.

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you shall be licensed as in LICENSE, without any additional terms or conditions.

Suggested workflow

  1. Make your changes
  2. Ensure your changes do what you intend by adding tests. Use just develop to run the tests every time you make a change, or just test to run them once.
    • If your changes are for the CLI you can also check manually by running cargo run -- -d {args here}.
  3. Format and lint your code (requires the nightly Rust toolchain) with just format

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
  • LanguageTool-Rust for inspiration and a look at how Rust API bindings should look/function

Licence

MIT

About

Rust bindings to Frankfurter, an open source exchange rates API

Resources

License

Stars

Watchers

Forks

Packages

No packages published