We're glad you want to make a contribution!
Fork this repository and send in a pull request when you're finished with your changes. Link any relevant issues in too.
Take note of the build status of your pull request, only builds that pass will be accepted. Please also keep to our conventions and style so we can keep this repository as clean as possible.
- Fork the repo
- Grab dependencies:
bundle install
- Make sure specs are green:
./spec/redis-server.sh
to run the Redis server andbundle exec rspec
to run the specs. Alternatively, you can run your own Redis server inlocalhost
, and add the port as an env var before running the specs,REDIS_PORT=6379 bundle exec rspec
- Make your changes
- Run
rubocop -a
- Make sure specs are still green
- Update
CHANGELOG.md
andAUTHORS
- Issue a Pull Request and link any relevant issues
Please make sure you read README.md before you start hacking so that you understand how the gem works :)
The Redis cache that we use stores Hashes with keys formatted as [namespace]:[base_currency]:[quote_currency]
.
These hashes contain ISO dates as keys with base currency rates as values.
For example, if currency
is the Redis namespace we used in the config,
USD is the base currency, and we're looking for HUF rates, they can be found in the currency:USD:HUF
key, and their format will be
{
"2016-05-01": "0.272511002E3", # Rates are stored as BigDecimal Strings
"2016-05-02": "0.270337998E3",
"2016-05-03": "0.271477498E3"
}
The first key of this Hash translates to: "on May 1st 2016, 1 USD was equivalent to 272.511002 HUF".
Apart from Redis, rates are also cached in the Bank's memory,
in @rates
. @rates
is a Hash[iso_currency][iso_date]
containing BigDecimal
exchange rates of iso_currency
on iso_date
.
When they don't exist in memory, they are retrieved from the Store,
and when they don't exist in the Store, they are retrieved from the
Provider.
- Make Redis optional
- Add another provider (e.g. XE.com)
- Add another store (e.g. DynamoDB, MongoDB, Cassandra, Postgres, etc)
By contributing your code, you agree to license your contribution under the terms of the APLv2: https://github.com/Skyscanner/historical-bank-ruby/blob/master/LICENSE
All files are released with the Apache 2.0 license.
If you are adding a new file it should have a header like this:
#
# Copyright 2017 Skyscanner Limited.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#