forked from adshao/go-binance
/
deposit_service.go
147 lines (129 loc) · 3.62 KB
/
deposit_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
package binance
import (
"context"
"encoding/json"
)
// ListDepositsService fetches deposit history.
//
// See https://binance-docs.github.io/apidocs/spot/en/#deposit-history-user_data
type ListDepositsService struct {
c *Client
asset *string
status *int
startTime *int64
endTime *int64
}
// Asset sets the asset parameter.
func (s *ListDepositsService) Asset(asset string) *ListDepositsService {
s.asset = &asset
return s
}
// Status sets the status parameter.
func (s *ListDepositsService) Status(status int) *ListDepositsService {
s.status = &status
return s
}
// StartTime sets the startTime parameter.
// If present, EndTime MUST be specified. The difference between EndTime - StartTime MUST be between 0-90 days.
func (s *ListDepositsService) StartTime(startTime int64) *ListDepositsService {
s.startTime = &startTime
return s
}
// EndTime sets the endTime parameter.
// If present, StartTime MUST be specified. The difference between EndTime - StartTime MUST be between 0-90 days.
func (s *ListDepositsService) EndTime(endTime int64) *ListDepositsService {
s.endTime = &endTime
return s
}
// Do sends the request.
func (s *ListDepositsService) Do(ctx context.Context) (deposits []*Deposit, err error) {
r := &request{
method: "GET",
endpoint: "/wapi/v3/depositHistory.html",
secType: secTypeSigned,
}
if s.asset != nil {
r.setParam("asset", *s.asset)
}
if s.status != nil {
r.setParam("status", *s.status)
}
if s.startTime != nil {
r.setParam("startTime", *s.startTime)
}
if s.endTime != nil {
r.setParam("endTime", *s.endTime)
}
data, err := s.c.callAPI(ctx, r)
if err != nil {
return
}
res := new(DepositHistoryResponse)
err = json.Unmarshal(data, res)
if err != nil {
return
}
return res.Deposits, nil
}
// DepositHistoryResponse represents a response from ListDepositsService.
type DepositHistoryResponse struct {
Success bool `json:"success"`
Deposits []*Deposit `json:"depositList"`
}
// Deposit represents a single deposit entry.
type Deposit struct {
InsertTime int64 `json:"insertTime"`
Amount float64 `json:"amount"`
Asset string `json:"asset"`
Address string `json:"address"`
AddressTag string `json:"addressTag"`
TxID string `json:"txId"`
Status int `json:"status"`
}
// GetDepositsAddressService retrieves the details of a deposit address.
//
// See https://binance-docs.github.io/apidocs/spot/en/#deposit-address-supporting-network-user_data
type GetDepositsAddressService struct {
c *Client
asset string
status *bool
}
// Asset sets the asset parameter (MANDATORY).
func (s *GetDepositsAddressService) Asset(v string) *GetDepositsAddressService {
s.asset = v
return s
}
// Status sets the status parameter.
func (s *GetDepositsAddressService) Status(v bool) *GetDepositsAddressService {
s.status = &v
return s
}
// Do sends the request.
func (s *GetDepositsAddressService) Do(ctx context.Context) (*GetDepositAddressResponse, error) {
r := &request{
method: "GET",
endpoint: "/wapi/v3/depositAddress.html",
secType: secTypeSigned,
}
r.setParam("asset", s.asset)
if v := s.status; v != nil {
r.setParam("status", *v)
}
data, err := s.c.callAPI(ctx, r)
if err != nil {
return nil, err
}
res := &GetDepositAddressResponse{}
if err := json.Unmarshal(data, res); err != nil {
return nil, err
}
return res, nil
}
// GetDepositAddressResponse represents a response from GetDepositsAddressService.
type GetDepositAddressResponse struct {
Success bool `json:"success"`
Address string `json:"address"`
AddressTag string `json:"addressTag"`
Asset string `json:"asset"`
URL string `json:"url"`
}