forked from ccxt/go-binance
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtrade_service.go
154 lines (139 loc) · 3.24 KB
/
trade_service.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
package binance
import (
"context"
"encoding/json"
)
// ListTradesService list trades
type ListTradesService struct {
c *Client
symbol string
limit *int
fromID *int64
}
// Symbol set symbol
func (s *ListTradesService) Symbol(symbol string) *ListTradesService {
s.symbol = symbol
return s
}
// Limit set limit
func (s *ListTradesService) Limit(limit int) *ListTradesService {
s.limit = &limit
return s
}
// FromID set fromID
func (s *ListTradesService) FromID(fromID int64) *ListTradesService {
s.fromID = &fromID
return s
}
// Do send request
func (s *ListTradesService) Do(ctx context.Context, opts ...RequestOption) (res []*Trade, err error) {
r := &request{
method: "GET",
endpoint: "/api/v3/myTrades",
secType: secTypeSigned,
}
r.setParam("symbol", s.symbol)
if s.limit != nil {
r.setParam("limit", *s.limit)
}
if s.fromID != nil {
r.setParam("fromId", *s.fromID)
}
data, err := s.c.callAPI(ctx, r, opts...)
if err != nil {
return
}
res = make([]*Trade, 0)
err = json.Unmarshal(data, &res)
if err != nil {
return
}
return
}
// Trade define trade info
type Trade struct {
ID int64 `json:"id"`
Price string `json:"price"`
Quantity string `json:"qty"`
Commission string `json:"commission"`
CommissionAsset string `json:"commissionAsset"`
Time int64 `json:"time"`
IsBuyer bool `json:"isBuyer"`
IsMaker bool `json:"isMaker"`
IsBestMatch bool `json:"isBestMatch"`
}
// AggTradesService list aggregate trades
type AggTradesService struct {
c *Client
symbol string
fromID *int64
startTime *int64
endTime *int64
limit *int
}
// Symbol set symbol
func (s *AggTradesService) Symbol(symbol string) *AggTradesService {
s.symbol = symbol
return s
}
// FromID set fromID
func (s *AggTradesService) FromID(fromID int64) *AggTradesService {
s.fromID = &fromID
return s
}
// StartTime set startTime
func (s *AggTradesService) StartTime(startTime int64) *AggTradesService {
s.startTime = &startTime
return s
}
// EndTime set endTime
func (s *AggTradesService) EndTime(endTime int64) *AggTradesService {
s.endTime = &endTime
return s
}
// Limit set limit
func (s *AggTradesService) Limit(limit int) *AggTradesService {
s.limit = &limit
return s
}
// Do send request
func (s *AggTradesService) Do(ctx context.Context, opts ...RequestOption) (res []*AggTrade, err error) {
r := &request{
method: "GET",
endpoint: "/api/v1/aggTrades",
}
r.setParam("symbol", s.symbol)
if s.fromID != nil {
r.setParam("fromId", *s.fromID)
}
if s.startTime != nil {
r.setParam("startTime", *s.startTime)
}
if s.endTime != nil {
r.setParam("endTime", *s.endTime)
}
if s.limit != nil {
r.setParam("limit", *s.limit)
}
data, err := s.c.callAPI(ctx, r, opts...)
if err != nil {
return
}
res = make([]*AggTrade, 0)
err = json.Unmarshal(data, &res)
if err != nil {
return
}
return
}
// AggTrade define aggregate trade info
type AggTrade struct {
AggTradeID int64 `json:"a"`
Price string `json:"p"`
Quantity string `json:"q"`
FirstTradeID int64 `json:"f"`
LastTradeID int64 `json:"l"`
Timestamp int64 `json:"T"`
IsBuyerMaker bool `json:"m"`
IsBestPriceMatch bool `json:"M"`
}