This gem is currently built to only query data. There is an experimental add_order
trading method that can be used at your own risk. Please thoroughly vet everything in the code for yourself before using this gem to buy, sell, or move any of your assets.
PLEASE submit an issue or pull request if you notice any bugs, security holes, or potential improvements.
This gem is a wrapper for the Kraken Digital Asset Trading Platform API. Official documentation from Kraken can be found here.
The current version (0.2.0) can be used to query public and private market data. Private data queries require use of your account API keys.
- Solid trade execution functionality
- More comprehensive test suite for methods requiring authentication (using VCR perhaps)
- More comprehensive documentation
Add this line to your application's Gemfile:
gem 'kraken_ruby'
And then execute:
$ bundle
Or install it yourself as:
$ gem install kraken_ruby
Create a Kraken client:
API_KEY = '3bH+M/nLp......'
API_SECRET = 'wQG+7Lr9b.....'
kraken = Kraken::Client.new(API_KEY, API_SECRET)
time = kraken.server_time
time.unixtime #=> 1393056191
This functionality is provided by Kraken to to aid in approximating the skew time between the server and client.
time = kraken.server_time
time.unixtime #=> 1393056191
time.rfc1123 #=> "Sat, 22 Feb 2014 08:28:04 GMT"
Returns the assets that can be traded on the exchange. This method can be passed info
, aclass
(asset class), and asset
options. An example below is given for each:
kraken.assets
pairs = kraken.asset_pairs
ticker_data = kraken.ticker('XLTCXXDG, ZUSDXXVN')
Get market depth information for given asset pairs
depth_data = kraken.order_book('LTCXRP')
Get recent trades
trades = kraken.trades('LTCXRP')
Get spread data for a given asset pair
spread = kraken.spread('LTCXRP')
Get account balance for each asset Note: Rates used for the floating valuation is the midpoint of the best bid and ask prices
balance = kraken.balance
Get account trade balance
trade_balance = kraken.trade_balance
open_orders = kraken.open_orders
See all orders
orders = kraken.query_orders
Get array of all trades
trades = kraken.trade_history
Input: Comma delimited list of transaction (tx) ids
trades = kraken.query_trades(tx_ids)
Input: Comma delimited list of transaction (tx) ids
positions = kraken.open_positions(tx_ids)
ledgers = kraken.ledgers_info
Input: Comma delimited list of ledger ids
ledgers = kraken.query_ledgers(ledger_ids)
Input: Comma delimited list of asset pairs
asset_pairs = 'XLTCXXDG, ZEURXXDG'
volume = kraken.query_ledgers(asset_pairs)
- Fork it
- Create your feature branch (
git checkout -b my-new-feature
) - Commit your changes (
git commit -am 'Add some feature'
) - Push to the branch (
git push origin my-new-feature
) - Create new Pull Request