currency_layer 0.1.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +7 -0
- data/Gemfile +3 -0
- data/LICENSE +19 -0
- data/README.rdoc +78 -0
- data/Rakefile +5 -0
- data/lib/apilayer/currency.rb +152 -0
- data/lib/currencylayer.rb +4 -0
- metadata +194 -0
checksums.yaml
ADDED
@@ -0,0 +1,7 @@
|
|
1
|
+
---
|
2
|
+
SHA1:
|
3
|
+
metadata.gz: e86057cf2480a4d84c5ce402739a83faa1610c97
|
4
|
+
data.tar.gz: 37ce1a95d27e9983fd8959168ac453ab5f354c73
|
5
|
+
SHA512:
|
6
|
+
metadata.gz: dfb4d2b61462cb5364197de0a965dbf3a6eedfa127dfc1d858ffb6a457ed1ad8fd5cb4d37778ae2fef5b7128df8aec4513a283df5b3896698e5e2fe0397da9d2
|
7
|
+
data.tar.gz: 9c968459751b9021d406e395aabed0728377b928efcb8aa9bca5c4dd5baf0e917e556929c8350344f69cb942e3bf7ca5f4572345b94ad6b115d67fb98e2da27d
|
data/Gemfile
ADDED
data/LICENSE
ADDED
@@ -0,0 +1,19 @@
|
|
1
|
+
Copyright (C) 2016 Alex Fong http://www.github.com/actfong
|
2
|
+
|
3
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy of
|
4
|
+
this software and associated documentation files (the "Software"), to deal in
|
5
|
+
the Software without restriction, including without limitation the rights to
|
6
|
+
use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies
|
7
|
+
of the Software, and to permit persons to whom the Software is furnished to do
|
8
|
+
so, subject to the following conditions:
|
9
|
+
|
10
|
+
The above copyright notice and this permission notice shall be included in all
|
11
|
+
copies or substantial portions of the Software.
|
12
|
+
|
13
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
14
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
15
|
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
16
|
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
17
|
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
18
|
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
19
|
+
SOFTWARE.
|
data/README.rdoc
ADDED
@@ -0,0 +1,78 @@
|
|
1
|
+
== currency_layer {<img src="https://secure.travis-ci.org/actfong/currency_layer.png"/>}[http://travis-ci.org/actfong/currency_layer] {<img src="https://codeclimate.com/github/actfong/currency_layer.png"/>}[https://codeclimate.com/github/actfong/currency_layer] {<img src="https://badge.fury.io/rb/currency_layer.svg" alt="Gem Version" />}[https://badge.fury.io/rb/currency_layer]
|
2
|
+
|
3
|
+
Ruby wrapper for currencylayer of apilayer.
|
4
|
+
See https://currencylayer.com/ and http://apilayer.com for more details.
|
5
|
+
|
6
|
+
=== Introduction
|
7
|
+
This gem is extracted from the previous version of apilayer gem. The currency_layer gem depends on the apilayer gem to configure and create connections to apilayer.net
|
8
|
+
|
9
|
+
=== Installation
|
10
|
+
|
11
|
+
==== Using Bundler
|
12
|
+
|
13
|
+
Add apilayer in your <tt>Gemfile</tt>:
|
14
|
+
|
15
|
+
gem "currency_layer"
|
16
|
+
|
17
|
+
Run the following in your console:
|
18
|
+
|
19
|
+
$ bundle install
|
20
|
+
|
21
|
+
=== Usage
|
22
|
+
|
23
|
+
==== Set up currency_layer
|
24
|
+
Once you have signed up for *currencylayer.com*, you will receive an access_key.
|
25
|
+
Then configure your Apilayer::Currency module like this:
|
26
|
+
|
27
|
+
Apilayer::Currency.configure do |configs|
|
28
|
+
configs.access_key = "my_access_key_123"
|
29
|
+
configs.https = true
|
30
|
+
end
|
31
|
+
|
32
|
+
Please note that the https configuration is optional and only available to paid-accounts.
|
33
|
+
If unset, these configuration-values are just nil.
|
34
|
+
|
35
|
+
You can always review you configurations with:
|
36
|
+
|
37
|
+
Apilayer::Currency.configs
|
38
|
+
|
39
|
+
Once your configurations are set, you are ready to go
|
40
|
+
|
41
|
+
==== currencylayer
|
42
|
+
After setting the access_key for *currencylayer*, you can use Apilayer::Currency to call *currencylayer*'s API
|
43
|
+
Apilayer::Currency.list
|
44
|
+
|
45
|
+
Apilayer::Currency.live
|
46
|
+
Apilayer::Currency.live(:currencies => %w[GBP, CHF])
|
47
|
+
Apilayer::Currency.live(:source => "EUR") # source-currency is USD by default
|
48
|
+
Apilayer::Currency.live(:source => "EUR", :currencies => %w[GBP, CHF])
|
49
|
+
|
50
|
+
Apilayer::Currency.historical("2016-01-01")
|
51
|
+
Apilayer::Currency.historical("2016-01-01", :currencies => %w[GBP CHF])
|
52
|
+
Apilayer::Currency.historical(:source => "EUR") # source-currency is USD by default
|
53
|
+
Apilayer::Currency.historical("2016-01-01", :currencies => %w[GBP CHF], :source => "EUR")
|
54
|
+
|
55
|
+
Apilayer::Currency.convert("EUR", "CHF", 100) # convert 100 EUR to CHF
|
56
|
+
Apilayer::Currency.convert("EUR", "CHF", 100, "2015-06-01") # based on specific date
|
57
|
+
|
58
|
+
Apilayer::Currency.timeframe("2016-01-01", "2016-06-01")
|
59
|
+
Apilayer::Currency.timeframe("2016-01-01", "2016-06-01", :currencies => %w[GBP CHF])
|
60
|
+
Apilayer::Currency.timeframe("2016-01-01", "2016-06-01", :source => "EUR")
|
61
|
+
Apilayer::Currency.timeframe("2016-01-01", "2016-06-01", :currencies => %w[GBP CHF], :source => "EUR")
|
62
|
+
|
63
|
+
Apilayer::Currency.change
|
64
|
+
Apilayer::Currency.change("2016-01-01", "2016-03-01")
|
65
|
+
Apilayer::Currency.change("2016-01-01", "2016-03-01", :source => "EUR")
|
66
|
+
Apilayer::Currency.change("2016-01-01", "2016-03-01", :currencies => %w[GBP CHF])
|
67
|
+
Apilayer::Currency.change("2016-01-01", "2016-03-01", :source => "EUR", :currencies => %w[GBP CHF])
|
68
|
+
Apilayer::Currency.change(nil, nil, {:source => "EUR"})
|
69
|
+
Apilayer::Currency.change(nil, nil, {:currencies => %w[GBP CHF]})
|
70
|
+
Apilayer::Currency.change(nil, nil, {:source => "EUR", :currencies => %w[GBP CHF]})
|
71
|
+
|
72
|
+
==== Re-Configure access_key and https
|
73
|
+
If you happened to have forgotten to set or entered an incorrect value, you can re-configure your Apilayer module by:
|
74
|
+
|
75
|
+
# Example: reconfigure https
|
76
|
+
Apilayer::Currency.configure do |configs|
|
77
|
+
configs.https = true
|
78
|
+
end
|
data/Rakefile
ADDED
@@ -0,0 +1,152 @@
|
|
1
|
+
##
|
2
|
+
# Ruby wrapper for currencylayer. See https://currencylayer.com/documentation for more info
|
3
|
+
module Apilayer
|
4
|
+
module Currency
|
5
|
+
extend Apilayer::ConnectionHelper
|
6
|
+
|
7
|
+
INVALID_OPTIONS_MSG = "You have provided an invalid option. Allowed options are :currencies and :source"
|
8
|
+
INVALID_TIMEFRAME_MSG = "start_date and end_date must be either provided together or left out together."
|
9
|
+
LIVE_SLUG = "live"
|
10
|
+
HISTORICAL_SLUG = "historical"
|
11
|
+
CONVERT_SLUG = "convert"
|
12
|
+
TIMEFRAME_SLUG = "timeframe"
|
13
|
+
CHANGE_SLUG = "change"
|
14
|
+
LIST_SLUG = "list"
|
15
|
+
|
16
|
+
## Validations
|
17
|
+
#
|
18
|
+
def self.validate_options(options)
|
19
|
+
options.keys.each do |key|
|
20
|
+
unless [:currencies, :source].include? key
|
21
|
+
raise Apilayer::Error.new(INVALID_OPTIONS_MSG)
|
22
|
+
end
|
23
|
+
end
|
24
|
+
end
|
25
|
+
|
26
|
+
def self.validate_timeframe_completeness(start_date,end_date)
|
27
|
+
if [start_date,end_date].compact.size == 1
|
28
|
+
raise Apilayer::Error.new(INVALID_TIMEFRAME_MSG)
|
29
|
+
end
|
30
|
+
end
|
31
|
+
### API methods
|
32
|
+
#
|
33
|
+
|
34
|
+
##
|
35
|
+
# Api-Method: Calls the /list endpoint to display all supported currencies
|
36
|
+
def self.list
|
37
|
+
get_and_parse LIST_SLUG
|
38
|
+
end
|
39
|
+
|
40
|
+
##
|
41
|
+
# Api-Method: Calls the /live endpoint to get real-time exchange rates.
|
42
|
+
# When no currency-codes are specified, it will return all exchange rates for your source-currency.
|
43
|
+
# Examples:
|
44
|
+
# Apilayer::Currency.live
|
45
|
+
# Apilayer::Currency.live(:currencies => %w[GBP, CHF])
|
46
|
+
# Apilayer::Currency.live(:source => "EUR")
|
47
|
+
# Apilayer::Currency.live(:source => "EUR", :currencies => %w[GBP, CHF])
|
48
|
+
def self.live(opts={})
|
49
|
+
validate_options(opts)
|
50
|
+
|
51
|
+
if opts.empty?
|
52
|
+
get_and_parse LIVE_SLUG
|
53
|
+
else
|
54
|
+
get_and_parse_with_options(LIVE_SLUG, opts)
|
55
|
+
end
|
56
|
+
end
|
57
|
+
|
58
|
+
##
|
59
|
+
# Api-Method: Calls the /historical endpoint to get exchange rates for a specific date.
|
60
|
+
# When no currency-codes are specified, it will return all exchange rates for your source-currency.
|
61
|
+
# Examples:
|
62
|
+
# Apilayer::Currency.historical("2016-01-01")
|
63
|
+
# Apilayer::Currency.historical("2016-01-01", :currencies => %w[GBP CHF])
|
64
|
+
# Apilayer::Currency.historical(:source => "EUR")
|
65
|
+
# Apilayer::Currency.historical("2016-01-01", :currencies => %w[GBP CHF], :source => "EUR")
|
66
|
+
def self.historical(date, opts={})
|
67
|
+
validate_options(opts)
|
68
|
+
params = {:date => date}
|
69
|
+
|
70
|
+
if opts.empty?
|
71
|
+
get_and_parse(HISTORICAL_SLUG, params)
|
72
|
+
else
|
73
|
+
get_and_parse_with_options(HISTORICAL_SLUG, opts, params)
|
74
|
+
end
|
75
|
+
end
|
76
|
+
|
77
|
+
##
|
78
|
+
# Api-Method: Calls the /convert endpoint, requires :from, :to and :amount
|
79
|
+
# When :date hasn't been passed, the latest available exchange rates will be used for your conversion.
|
80
|
+
# Examples:
|
81
|
+
# Apilayer::Currency.convert("EUR", "CHF", 100)
|
82
|
+
# Apilayer::Currency.convert("EUR", "CHF", 100, "2015-03-01")
|
83
|
+
def self.convert(from, to, amount, date=nil)
|
84
|
+
params = {:from => from, :to => to, :amount => amount}
|
85
|
+
params.merge!(:date => date) if date
|
86
|
+
get_and_parse(CONVERT_SLUG, params)
|
87
|
+
end
|
88
|
+
|
89
|
+
##
|
90
|
+
# Api-Method: Calls the /timeframe endpoint. Requires :start_date and :end_date
|
91
|
+
# If :currencies hasn't been provided as an option, it will return all exchange-rates for that period of your source-currency
|
92
|
+
# :source can be provided as option to change the source-currency, which is USD by default
|
93
|
+
# The difference between start_date and end_date can be maximum 365 days
|
94
|
+
# Examples:
|
95
|
+
# Apilayer::Currency.timeframe("2016-01-01", "2016-03-01")
|
96
|
+
# Apilayer::Currency.timeframe("2016-01-01", "2016-03-01", :currencies => %w[GBP CHF])
|
97
|
+
# Apilayer::Currency.timeframe("2016-01-01", "2016-03-01", :currencies => %w[GBP CHF], :source => "EUR")
|
98
|
+
def self.timeframe(start_date, end_date, opts={})
|
99
|
+
validate_options(opts)
|
100
|
+
params = {:start_date => start_date, :end_date => end_date}
|
101
|
+
get_and_parse_with_options(TIMEFRAME_SLUG, opts, params)
|
102
|
+
end
|
103
|
+
|
104
|
+
##
|
105
|
+
# Api-Method: Calls the /change endpoint.
|
106
|
+
# start_date and end_date are optional, but can't provide one without the other
|
107
|
+
# :currencies and :source are optional
|
108
|
+
# Examples:
|
109
|
+
# Apilayer::Currency.change
|
110
|
+
# Apilayer::Currency.change("2016-01-01", "2016-03-01")
|
111
|
+
# Apilayer::Currency.change("2016-01-01", "2016-03-01", :source => "EUR")
|
112
|
+
# Apilayer::Currency.change("2016-01-01", "2016-03-01", :currencies => %w[GBP CHF])
|
113
|
+
# Apilayer::Currency.change("2016-01-01", "2016-03-01", :source => "EUR", :currencies => %w[GBP CHF])
|
114
|
+
# Apilayer::Currency.change(nil, nil, {:source => "EUR"})
|
115
|
+
# Apilayer::Currency.change(nil, nil, {:currencies => %w[GBP CHF]})
|
116
|
+
# Apilayer::Currency.change(nil, nil, {:source => "EUR", :currencies => %w[GBP CHF]})
|
117
|
+
def self.change(start_date=nil, end_date=nil, opts={})
|
118
|
+
validate_options(opts)
|
119
|
+
validate_timeframe_completeness(start_date,end_date)
|
120
|
+
params = {:start_date => start_date,
|
121
|
+
:end_date => end_date
|
122
|
+
}.reject{ |k,v| v.nil? }
|
123
|
+
get_and_parse_with_options(CHANGE_SLUG, opts, params)
|
124
|
+
end
|
125
|
+
|
126
|
+
##
|
127
|
+
#
|
128
|
+
def self.get_and_parse_with_options(slug, opts, params={})
|
129
|
+
params = add_options_to_params(opts, params)
|
130
|
+
get_and_parse(slug, params)
|
131
|
+
end
|
132
|
+
|
133
|
+
##
|
134
|
+
# Adds currencies and source to query string if they have been provided with options-hash
|
135
|
+
def self.add_options_to_params(opts, params)
|
136
|
+
if opts[:currencies] && opts[:currencies].any?
|
137
|
+
params[:currencies] = join_by_commas(opts[:currencies])
|
138
|
+
end
|
139
|
+
if opts[:source]
|
140
|
+
params[:source] = opts[:source]
|
141
|
+
end
|
142
|
+
params
|
143
|
+
end
|
144
|
+
|
145
|
+
##
|
146
|
+
# Joins currencies in an array as a comma-separated-string
|
147
|
+
def self.join_by_commas(currencies)
|
148
|
+
currencies.map(&:strip).join(",")
|
149
|
+
end
|
150
|
+
|
151
|
+
end
|
152
|
+
end
|
metadata
ADDED
@@ -0,0 +1,194 @@
|
|
1
|
+
--- !ruby/object:Gem::Specification
|
2
|
+
name: currency_layer
|
3
|
+
version: !ruby/object:Gem::Version
|
4
|
+
version: 0.1.1
|
5
|
+
platform: ruby
|
6
|
+
authors:
|
7
|
+
- Alex Fong
|
8
|
+
autorequire:
|
9
|
+
bindir: bin
|
10
|
+
cert_chain: []
|
11
|
+
date: 2016-06-02 00:00:00.000000000 Z
|
12
|
+
dependencies:
|
13
|
+
- !ruby/object:Gem::Dependency
|
14
|
+
name: rake
|
15
|
+
requirement: !ruby/object:Gem::Requirement
|
16
|
+
requirements:
|
17
|
+
- - "~>"
|
18
|
+
- !ruby/object:Gem::Version
|
19
|
+
version: '10.1'
|
20
|
+
- - ">="
|
21
|
+
- !ruby/object:Gem::Version
|
22
|
+
version: 0.10.1
|
23
|
+
type: :development
|
24
|
+
prerelease: false
|
25
|
+
version_requirements: !ruby/object:Gem::Requirement
|
26
|
+
requirements:
|
27
|
+
- - "~>"
|
28
|
+
- !ruby/object:Gem::Version
|
29
|
+
version: '10.1'
|
30
|
+
- - ">="
|
31
|
+
- !ruby/object:Gem::Version
|
32
|
+
version: 0.10.1
|
33
|
+
- !ruby/object:Gem::Dependency
|
34
|
+
name: pry
|
35
|
+
requirement: !ruby/object:Gem::Requirement
|
36
|
+
requirements:
|
37
|
+
- - "~>"
|
38
|
+
- !ruby/object:Gem::Version
|
39
|
+
version: '0.10'
|
40
|
+
- - ">="
|
41
|
+
- !ruby/object:Gem::Version
|
42
|
+
version: 0.10.1
|
43
|
+
type: :development
|
44
|
+
prerelease: false
|
45
|
+
version_requirements: !ruby/object:Gem::Requirement
|
46
|
+
requirements:
|
47
|
+
- - "~>"
|
48
|
+
- !ruby/object:Gem::Version
|
49
|
+
version: '0.10'
|
50
|
+
- - ">="
|
51
|
+
- !ruby/object:Gem::Version
|
52
|
+
version: 0.10.1
|
53
|
+
- !ruby/object:Gem::Dependency
|
54
|
+
name: bundler
|
55
|
+
requirement: !ruby/object:Gem::Requirement
|
56
|
+
requirements:
|
57
|
+
- - "~>"
|
58
|
+
- !ruby/object:Gem::Version
|
59
|
+
version: '1.7'
|
60
|
+
- - ">="
|
61
|
+
- !ruby/object:Gem::Version
|
62
|
+
version: 1.7.9
|
63
|
+
type: :development
|
64
|
+
prerelease: false
|
65
|
+
version_requirements: !ruby/object:Gem::Requirement
|
66
|
+
requirements:
|
67
|
+
- - "~>"
|
68
|
+
- !ruby/object:Gem::Version
|
69
|
+
version: '1.7'
|
70
|
+
- - ">="
|
71
|
+
- !ruby/object:Gem::Version
|
72
|
+
version: 1.7.9
|
73
|
+
- !ruby/object:Gem::Dependency
|
74
|
+
name: rspec
|
75
|
+
requirement: !ruby/object:Gem::Requirement
|
76
|
+
requirements:
|
77
|
+
- - "~>"
|
78
|
+
- !ruby/object:Gem::Version
|
79
|
+
version: '3.0'
|
80
|
+
- - ">="
|
81
|
+
- !ruby/object:Gem::Version
|
82
|
+
version: 3.0.0
|
83
|
+
type: :development
|
84
|
+
prerelease: false
|
85
|
+
version_requirements: !ruby/object:Gem::Requirement
|
86
|
+
requirements:
|
87
|
+
- - "~>"
|
88
|
+
- !ruby/object:Gem::Version
|
89
|
+
version: '3.0'
|
90
|
+
- - ">="
|
91
|
+
- !ruby/object:Gem::Version
|
92
|
+
version: 3.0.0
|
93
|
+
- !ruby/object:Gem::Dependency
|
94
|
+
name: simplecov
|
95
|
+
requirement: !ruby/object:Gem::Requirement
|
96
|
+
requirements:
|
97
|
+
- - "~>"
|
98
|
+
- !ruby/object:Gem::Version
|
99
|
+
version: '0.11'
|
100
|
+
- - ">="
|
101
|
+
- !ruby/object:Gem::Version
|
102
|
+
version: 0.11.0
|
103
|
+
type: :development
|
104
|
+
prerelease: false
|
105
|
+
version_requirements: !ruby/object:Gem::Requirement
|
106
|
+
requirements:
|
107
|
+
- - "~>"
|
108
|
+
- !ruby/object:Gem::Version
|
109
|
+
version: '0.11'
|
110
|
+
- - ">="
|
111
|
+
- !ruby/object:Gem::Version
|
112
|
+
version: 0.11.0
|
113
|
+
- !ruby/object:Gem::Dependency
|
114
|
+
name: vcr
|
115
|
+
requirement: !ruby/object:Gem::Requirement
|
116
|
+
requirements:
|
117
|
+
- - "~>"
|
118
|
+
- !ruby/object:Gem::Version
|
119
|
+
version: '3.0'
|
120
|
+
- - ">="
|
121
|
+
- !ruby/object:Gem::Version
|
122
|
+
version: 3.0.1
|
123
|
+
type: :development
|
124
|
+
prerelease: false
|
125
|
+
version_requirements: !ruby/object:Gem::Requirement
|
126
|
+
requirements:
|
127
|
+
- - "~>"
|
128
|
+
- !ruby/object:Gem::Version
|
129
|
+
version: '3.0'
|
130
|
+
- - ">="
|
131
|
+
- !ruby/object:Gem::Version
|
132
|
+
version: 3.0.1
|
133
|
+
- !ruby/object:Gem::Dependency
|
134
|
+
name: webmock
|
135
|
+
requirement: !ruby/object:Gem::Requirement
|
136
|
+
requirements:
|
137
|
+
- - "~>"
|
138
|
+
- !ruby/object:Gem::Version
|
139
|
+
version: '2.0'
|
140
|
+
- - ">="
|
141
|
+
- !ruby/object:Gem::Version
|
142
|
+
version: 2.0.1
|
143
|
+
type: :development
|
144
|
+
prerelease: false
|
145
|
+
version_requirements: !ruby/object:Gem::Requirement
|
146
|
+
requirements:
|
147
|
+
- - "~>"
|
148
|
+
- !ruby/object:Gem::Version
|
149
|
+
version: '2.0'
|
150
|
+
- - ">="
|
151
|
+
- !ruby/object:Gem::Version
|
152
|
+
version: 2.0.1
|
153
|
+
description: Ruby wrapper for currencylayer by apilayer. This gem depends on the apilayer
|
154
|
+
gem, which provides a common connection-interface to various services of apilayer.net
|
155
|
+
(such as currencylayer and vatlayer). See https://currencylayer.com/ and https://apilayer.com/
|
156
|
+
for more details.
|
157
|
+
email:
|
158
|
+
- actfong@gmail.com
|
159
|
+
executables: []
|
160
|
+
extensions: []
|
161
|
+
extra_rdoc_files: []
|
162
|
+
files:
|
163
|
+
- Gemfile
|
164
|
+
- LICENSE
|
165
|
+
- README.rdoc
|
166
|
+
- Rakefile
|
167
|
+
- lib/apilayer/currency.rb
|
168
|
+
- lib/currencylayer.rb
|
169
|
+
homepage: https://github.com/actfong/currency_layer
|
170
|
+
licenses:
|
171
|
+
- MIT
|
172
|
+
metadata: {}
|
173
|
+
post_install_message:
|
174
|
+
rdoc_options: []
|
175
|
+
require_paths:
|
176
|
+
- lib
|
177
|
+
required_ruby_version: !ruby/object:Gem::Requirement
|
178
|
+
requirements:
|
179
|
+
- - ">="
|
180
|
+
- !ruby/object:Gem::Version
|
181
|
+
version: '0'
|
182
|
+
required_rubygems_version: !ruby/object:Gem::Requirement
|
183
|
+
requirements:
|
184
|
+
- - ">="
|
185
|
+
- !ruby/object:Gem::Version
|
186
|
+
version: '0'
|
187
|
+
requirements: []
|
188
|
+
rubyforge_project:
|
189
|
+
rubygems_version: 2.4.5
|
190
|
+
signing_key:
|
191
|
+
specification_version: 4
|
192
|
+
summary: Ruby wrapper for currencylayer by apilayer. See https://currencylayer.com/
|
193
|
+
for more details.
|
194
|
+
test_files: []
|