forked from jeffwalsh/go-coinpayments
-
Notifications
You must be signed in to change notification settings - Fork 0
/
withdrawal.go
47 lines (39 loc) · 1.43 KB
/
withdrawal.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
package coinpayments
import (
"net/url"
)
// WithdrawalRequest is what we sent to the API
type WithdrawalRequest struct {
Amount string `json:"amount"`
Currency string `json:"currency"`
MerchantID string `json:"merchant_id"`
PBNTag string `json:"pbntag"`
AutoConfirm int `json:"auto_confirm"`
}
// WithdrawalResult is a result from the API for a Withdrawal command
type WithdrawalResult struct {
Amount string `json:"amount"`
ID string `json:"id"`
Status int `json:"status"` // 0 or 1. 0 = transfer created, waiting for email conf. 1 = transfer created with no email conf.
}
// WithdrawalResponse is the response we expect from the API server.
type WithdrawalResponse struct {
ErrorResponse
Result *WithdrawalResult `json:"result"`
}
// CallCreateTransfer calls the create_Withdrawal command on the API
func (c *Client) CallCreateTransfer(req *WithdrawalRequest) (*WithdrawalResult, error) {
// add in data specific to this Withdrawal, then forward the request to the call method
data := url.Values{}
data.Add("amount", req.Amount)
data.Add("currency", req.Currency)
data.Add("merchant", req.MerchantID)
data.Add("pbntag", req.PBNTag)
// make the actual call and unmarshal the response into our WithdrawalResponse struct
var response WithdrawalResponse
if err := c.Call(CmdCreateTransfer, data, &response); err != nil {
return nil, err
}
// return the entire result to be used
return response.Result, nil
}