peatio-client-ruby
is a client for Peatio API, support all Peatio API functions like submit order, get tickers, etc. It's also a reference client implementation, where you can find how to authenticate private Peatio API.
- ruby 2.0.0 or higher (if you want to run 'rake test' in this gem you'll need ruby 2.1.0 or higher)
- openssl
gem install peatio_client
TBD
Use #get
or #post
to access API after you created a PeatioAPI::Client
:
require 'peatio_client'
# Client can be initialized not providing key and sercet, but this client can only access public APIs
client_public = PeatioAPI::Client.new endpoint: 'https://yunbi.com'
# GET public api /api/v2/markets
client_public.get_public '/api/v2/markets'
# To build a full functional client which can access both public/private api, access_key/secret_key
# are required.
#
# `endpoint` can be ignored or set to any Peatio powered exchange.
#
# If there's no data received in `timeout` seconds, Net::OpenTimeout will be raised. Default to 60.
#
client = PeatioAPI::Client.new access_key: 'your_access_key', secret_key: 'your_secret_key', endpoint: 'https://yunbi.com', timeout: 60
# GET private api /api/v2/orders with 'market=btccny'
client.get '/api/v2/orders', market: 'btccny'
# POST to create an order
client.post '/api/v2/orders', market: 'btccny', side: 'sell', volume: '0.11', price: '2955.0'
# POST to create multiple orders at once
client.post '/api/v2/orders/multi', market: 'btccny', orders: [{side: 'buy', volume: '0.15', price: '2955.0'}, {side: 'sell', volume: '0.16', price: '2956'}]
Check Peatio API v2 Documents for details on Peatio API.
Streaming API client is built upon eventmachine, it will start an endless loop to accept updates from server side, you only need to provide a callback block:
require 'peatio_client'
client = PeatioAPI::StreamingClient.new access_key: 'your_access_key', secret_key: 'your_secret_key', endpoint: 'wss://yunbi.com:8080'
client.run do |message|
# do whatever you want with message
end
peatio-client-ruby
is released under MIT license. See http://peatio.mit-license.org for more information.
Just create an issue or open a pull request :)