A client implementation of the Bitstamp API, including websockets, in Golang.
package main
import (
"fmt"
"log"
"time"
"github.com/ajph/bitstamp-go"
)
const WS_TIMEOUT = 10 * time.Second
func handleEvent(e *bitstamp.Event, Ws *bitstamp.WebSocket) {
switch e.Event {
// pusher stuff
case "pusher:connection_established":
log.Println("Connected")
case "pusher_internal:subscription_succeeded":
log.Println("Subscribed")
case "pusher:pong":
// ignore
case "pusher:ping":
Ws.Pong()
// bitstamp
case "trade":
fmt.Printf("%#v\n", e.Data)
// other
default:
log.Printf("Unknown event: %#v\n", e)
}
}
func main() {
// setup bitstamp api
bitstamp.SetAuth("123456", "key", "secret")
// get balance
balances, err := bitstamp.AccountBalance()
if err != nil {
fmt.Printf("Can't get balance using bitstamp API: %s\n", err)
return
}
fmt.Println("\nAvailable Balances:")
fmt.Printf("USD %f\n", balances.UsdAvailable)
fmt.Printf("BTC %f\n", balances.BtcAvailable)
fmt.Printf("FEE %f\n\n", balances.BtcUsdFee)
// attempt to place a buy order
// BuyLimitOrder(pair string, amount float64, price float64, amountPrecision, pricePrecision int)
order, err := bitstamp.BuyLimitOrder("btcusd", 0.5, 600.00, 16, 16)
if err != nil {
log.Printf("Error placing buy order: %s", err)
return
}
fmt.Printf("Place oder %d", order.Id)
var Ws *bitstamp.WebSocket
// websocket read loop
for {
// connect
log.Println("Dialing...")
var err error
Ws, err = bitstamp.NewWebSocket(WS_TIMEOUT)
if err != nil {
log.Printf("Error connecting: %s", err)
time.Sleep(1 * time.Second)
continue
}
Ws.Subscribe("live_trades")
// read data
L:
for {
select {
case ev := <-Ws.Stream:
handleEvent(ev, Ws)
case err := <-Ws.Errors:
log.Printf("Socket error: %s, reconnecting...", err)
Ws.Close()
break L
case <-time.After(10 * time.Second):
Ws.Ping()
}
}
}
}
- Documentation
- Tests