forked from blacklightcms/recurly
-
Notifications
You must be signed in to change notification settings - Fork 0
/
transactions_service.go
99 lines (83 loc) · 2.98 KB
/
transactions_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
package recurly
import (
"encoding/xml"
"fmt"
"net/http"
)
var _ TransactionsService = &transactionsImpl{}
// transactionsImpl handles communication with the transactions related methods
// of the recurly API.
type transactionsImpl struct {
client *Client
}
// List returns a list of transactions
// https://dev.recurly.com/docs/list-transactions
func (s *transactionsImpl) List(params Params) (*Response, []Transaction, error) {
req, err := s.client.newRequest("GET", "transactions", params, nil)
if err != nil {
return nil, nil, err
}
var v struct {
XMLName xml.Name `xml:"transactions"`
Transactions []Transaction `xml:"transaction"`
}
resp, err := s.client.do(req, &v)
return resp, v.Transactions, err
}
// ListAccount returns a list of transactions for an account
// https://dev.recurly.com/docs/list-accounts-transactions
func (s *transactionsImpl) ListAccount(accountCode string, params Params) (*Response, []Transaction, error) {
action := fmt.Sprintf("accounts/%s/transactions", accountCode)
req, err := s.client.newRequest("GET", action, params, nil)
if err != nil {
return nil, nil, err
}
var v struct {
XMLName xml.Name `xml:"transactions"`
Transactions []Transaction `xml:"transaction"`
}
resp, err := s.client.do(req, &v)
return resp, v.Transactions, err
}
// Get returns account and billing information at the time the transaction was
// submitted. It may not reflect the latest account information. A
// transaction_error section may be included if the transaction failed.
// Please see transaction error codes for more details.
// https://dev.recurly.com/docs/lookup-transaction
func (s *transactionsImpl) Get(uuid string) (*Response, *Transaction, error) {
action := fmt.Sprintf("transactions/%s", SanitizeUUID(uuid))
req, err := s.client.newRequest("GET", action, nil, nil)
if err != nil {
return nil, nil, err
}
var dst Transaction
resp, err := s.client.do(req, &dst)
if err != nil || resp.StatusCode >= http.StatusBadRequest {
return resp, nil, err
}
return resp, &dst, err
}
// Create creates a new transaction. The Recurly API provides a shortcut for
// creating an invoice, charge, and optionally account, and processing the
// payment immediately. When creating an account all of the required account
// attributes must be supplied. When charging an existing account only the
// account_code must be supplied.
//
// See the documentation and Transaction.MarshalXML function for a detailed field list.
// https://dev.recurly.com/docs/create-transaction
func (s *transactionsImpl) Create(t Transaction) (*Response, *Transaction, error) {
req, err := s.client.newRequest("POST", "transactions", nil, t)
if err != nil {
return nil, nil, err
}
var dst Transaction
resp, err := s.client.do(req, &dst)
// If there is an error set the response transaction as the returned transaction
// so that the caller has access to TransactionError.
if resp.IsError() {
if resp.transaction != nil {
dst = *resp.transaction
}
}
return resp, &dst, err
}