func Example() {
logrus.SetLevel(logrus.DebugLevel)
bsSvc := bitstamp.NewPrivateClient("_", "_")
wsClient := bitstamp.NewWSClient("btcusdc")
go func() {
if err := wsClient.Run(bsSvc, time.Second*10); err != nil {
logrus.WithError(err).Error("got an error on WebSocket-client")
}
}()
go func() {
for trade := range wsClient.Fills() {
logrus.WithField("trade", trade).Info("got trade report")
}
}()
time.Sleep(time.Second * 4)
balances, err := bsSvc.GetBalances()
if err != nil {
logrus.WithError(err).Error("could not get balances")
} else {
logrus.Info("Balances: ", balances)
}
report, err := bsSvc.PlaceOrder(bitstamp.PlaceOrderRequest{
Amount: 0.00001,
Side: bitstamp.Buy,
Symbol: "btcusdt",
Type: bitstamp.Market,
})
if err != nil {
logrus.WithError(err).Error("could not place order")
} else {
logrus.Info("order has been placed: ", report)
}
time.Sleep(time.Second * 1)
report2, err := bsSvc.PlaceOrder(bitstamp.PlaceOrderRequest{
Amount: 0.00001,
Side: bitstamp.Sell,
Symbol: "btcusdt",
Type: bitstamp.Market,
})
if err != nil {
logrus.WithError(err).Error("could not place order")
} else {
logrus.Info("order has been placed: ", report2)
}
report3, err := bsSvc.PlaceOrder(bitstamp.PlaceOrderRequest{
Amount: 0.00001,
ExecType: bitstamp.ExecFOK,
Price: 1,
Side: bitstamp.Sell,
Symbol: "btcusdt",
Type: bitstamp.Limit,
})
if err != nil {
logrus.WithError(err).Error("could not place order")
} else {
logrus.Info("order has been placed: ", report3)
}
select {}
}
-
Notifications
You must be signed in to change notification settings - Fork 8
b2broker/bitstamp
Folders and files
Name | Name | Last commit message | Last commit date | |
---|---|---|---|---|