Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mccallofthewild/gdax
📈 GDAX REST and WebSocket API wrapper to trade blockchain cryptocurrencies like bitcoin, Litecoin and Ethereum.
https://github.com/mccallofthewild/gdax
blockchain coinbase coinbase-api cryptocurrency cryptocurrency-exchanges gdax gdax-api trading-api
Last synced: 2 months ago
JSON representation
📈 GDAX REST and WebSocket API wrapper to trade blockchain cryptocurrencies like bitcoin, Litecoin and Ethereum.
- Host: GitHub
- URL: https://github.com/mccallofthewild/gdax
- Owner: mccallofthewild
- License: mit
- Created: 2017-10-10T20:02:16.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2019-10-05T05:20:37.000Z (over 5 years ago)
- Last Synced: 2024-10-30T17:48:24.347Z (2 months ago)
- Topics: blockchain, coinbase, coinbase-api, cryptocurrency, cryptocurrency-exchanges, gdax, gdax-api, trading-api
- Language: Crystal
- Homepage: https://mccallofthewild.github.io/gdax
- Size: 721 KB
- Stars: 7
- Watchers: 3
- Forks: 3
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-crystal - GDAX - GDAX REST and WebSocket API Wrapper with request signing (Third-party APIs)
- awesome-crystal - GDAX - GDAX REST and WebSocket API Wrapper with request signing (Third-party APIs)
- awesome-crystal - GDAX - GDAX REST and WebSocket API Wrapper with request signing (Third-party APIs)
README
# 📈 GDAX
A Crystal library for interacting with [GDAX](https://www.gdax.com/)'s REST and WebSocket API's.
[![Build Status](https://travis-ci.org/mccallofthewild/gdax.svg?branch=master)](https://travis-ci.org/mccallofthewild/gdax) [![Docs](https://img.shields.io/badge/docs-available-brightgreen.svg)](https://mccallofthewild.github.io/gdax/) [![GitHub release](https://img.shields.io/github/release/mccallofthewild/gdax.svg)](https://github.com/mccallofthewild/markov/releases)
### Visit the [API Documentation](https://mccallofthewild.github.io/gdax/) for a more in-depth look at the library's functionality.
## Installation
Add this to your application's `shard.yml`:
```yaml
dependencies:
gdax:
github: mccallofthewild/gdax
```## Usage
Begin by requiring `"gdax"`.
```crystal
require "gdax"
```### `GDAX::Client`
> Interact with the GDAX REST API`GDAX::Client` is derived from [HTTP::Client](https://crystal-lang.org/api/HTTP/Client.html). Use the inherited instance methods, `#get`, `#post`, `#put` and `#delete` to interact with GDAX's API.
Responses are instances of [HTTP::Client::Response](https://crystal-lang.org/api/HTTP/Client/Response.html).#### Basic
To authenticate, pass named argument, `auth` to the `GDAX::WebSocket` with a `GDAX::Auth` instance.
See [ _Authentication_ ](https://docs.gdax.com/#authentication) for help getting your `key`, `secret`, and `passphrase`.NOTE: For security purposes, it is recommended that you store your `key`, `secret`, and `passphrase` as environment variables.
e.g.
```crystal
auth = GDAX::Auth.new ENV["CB-ACCESS-KEY"], ENV["API-SECRET"], ENV["PASSPHRASE"]
client = GDAX::Client.new auth
client.get "/products/BTC-USD/trades" do |response|
puts response.body_io.gets_to_end
end
```#### Unauthenticated
To instantiate an unauthenticated `Client`, simply don't pass the `auth` argument.e.g.
```crystal
client = GDAX::Client.new
client.get "/products" do |response|
puts response.body_io.gets_to_end
end
```See [the API Documentation](https://mccallofthewild.github.io/gdax/GDAX/Client.html) for more information on `GDAX::WebSocket`.
### `GDAX::WebSocket`
> Interact with the GDAX WebSocket Feed#### Basic
It's recommended that you [spawn a Fiber](https://crystal-lang.org/docs/guides/concurrency.html) around each `GDAX::WebSocket` you instantiate in order to achieve concurrency.The following setup will give you access to GDAX's public _ticker_ stream.
```crystal
spawn do
ws = GDAX::WebSocket.new production: true, subscription: {
"type" => "subscribe",
"channels" => [{ "name" => "ticker", "product_ids" => ["ETH-EUR"] }]
}ws.run
end
Fiber.yield
```#### `GDAX::WebSocket#on`
Use the `#on` method to add event listeners to a `GDAX::WebSocket`.Events are based on [ _GDAX's message `type`'s_ ](https://docs.gdax.com/#protocol-overview).
`#on` takes in a `String` of the event to listen for and a block to call when the event is fired.
The block is passed two arguments: the first being the `JSON::Any` response data from GDAX, and the second being the event itself.```crystal
ws.on "subscriptions" do |data, event|
puts "subscribed!"
end
```Though event listeners _can_ be added dynamically on runtime, to avoid missing events, it is recommended that all listeners be added prior to invoking `GDAX::WebSocket#run`.
e.g.
```crystal
spawn do
ws = GDAX::WebSocket.new production: true, subscription: {
"type" => "subscribe",
"channels" => [{ "name" => "ticker", "product_ids" => ["ETH-EUR"] }]
}ws.on "subscriptions" do |data, event|
puts "subscribed!"
endws.on "ticker" do |data, event|
puts data["price"] #=> e.g. 264.10000000
endws.run
end
Fiber.yield
```#### Authenticating
It is possible to authenticate yourself when subscribing to the websocket feed. See the [GDAX documentation on the subject](https://docs.gdax.com/#subscribe).To authenticate, pass named argument, `auth` to the `GDAX::WebSocket` with a `GDAX::Auth` instance.
See [ _Authentication_ ](https://docs.gdax.com/#authentication) for help getting your `key`, `secret`, and `passphrase`.NOTE: For security purposes, it is recommended that you store your `key`, `secret`, and `passphrase` as environment variables.
```crystal
spawn do
auth = GDAX::Auth.new key: ENV["CB-ACCESS-KEY"], secret: ENV["API-SECRET"], passphrase: ENV["PASSPHRASE"]ws = GDAX::WebSocket.new production: true, subscription: {
"type" => "subscribe",
"channels" => [{ "name" => "ticker", "product_ids" => ["ETH-EUR"] }]
}, auth: auth
ws.on "subscriptions" do |data, event|
puts "subscribed!"
end
ws.run
end
```See [the API Documentation](https://mccallofthewild.github.io/gdax/GDAX/WebSocket.html) for more information on `GDAX::WebSocket`.
## Contributing
1. Fork it ( https://github.com/mccallofthewild/gdax/fork )
2. Create your feature branch (git checkout -b my-new-feature)
3. Commit your changes (git commit -am 'Add some feature')
4. Push to the branch (git push origin my-new-feature)
5. Create a new Pull Request## Contributors
- [McCall Alexander](https://github.com/mccallofthewild) mccallofthewild - creator, maintainer