forked from bold-commerce/go-shopify
-
Notifications
You must be signed in to change notification settings - Fork 1
/
draft_order.go
217 lines (189 loc) · 8.84 KB
/
draft_order.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
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
package goshopify
import (
"fmt"
"time"
"github.com/shopspring/decimal"
)
const (
draftOrdersBasePath = "draft_orders"
draftOrdersResourceName = "draft_orders"
)
// DraftOrderService is an interface for interfacing with the draft orders endpoints of
// the Shopify API.
// See: https://help.shopify.com/api/reference/orders/draftorder
type DraftOrderService interface {
List(interface{}) ([]DraftOrder, error)
Count(interface{}) (int, error)
Get(int64, interface{}) (*DraftOrder, error)
Create(DraftOrder) (*DraftOrder, error)
Update(DraftOrder) (*DraftOrder, error)
Delete(int64) error
Invoice(int64, DraftOrderInvoice) (*DraftOrderInvoice, error)
Complete(int64, bool) (*DraftOrder, error)
// MetafieldsService used for DrafT Order resource to communicate with Metafields resource
MetafieldsService
}
// DraftOrderServiceOp handles communication with the draft order related methods of the
// Shopify API.
type DraftOrderServiceOp struct {
client *Client
}
// DraftOrder represents a shopify draft order
type DraftOrder struct {
ID int64 `json:"id,omitempty"`
OrderID int64 `json:"order_id,omitempty"`
Name string `json:"name,omitempty"`
Customer *Customer `json:"customer,omitempty"`
ShippingAddress *Address `json:"shipping_address,omitempty"`
BillingAddress *Address `json:"billing_address,omitempty"`
Note string `json:"note,omitempty"`
NoteAttributes []NoteAttribute `json:"note_attribute,omitempty"`
Email string `json:"email,omitempty"`
Currency string `json:"currency,omitempty"`
InvoiceSentAt *time.Time `json:"invoice_sent_at,omitempty"`
InvoiceURL string `json:"invoice_url,omitempty"`
LineItems []LineItem `json:"line_items,omitempty"`
ShippingLine *ShippingLines `json:"shipping_line,omitempty"`
Tags string `json:"tags,omitempty"`
TaxLines []TaxLine `json:"tax_lines,omitempty"`
AppliedDiscount *AppliedDiscount `json:"applied_discount,omitempty"`
TaxesIncluded bool `json:"taxes_included,omitempty"`
TotalTax string `json:"total_tax,omitempty"`
TotalPrice string `json:"total_price,omitempty"`
SubtotalPrice *decimal.Decimal `json:"subtotal_price,omitempty"`
CompletedAt *time.Time `json:"completed_at,omitempty"`
CreatedAt *time.Time `json:"created_at,omitempty"`
UpdatedAt *time.Time `json:"updated_at,omitempty"`
Status string `json:"status,omitempty"`
// only in request to flag using the customer's default address
UseCustomerDefaultAddress bool `json:"use_customer_default_address,omitempty"`
}
// AppliedDiscount is the discount applied to the line item or the draft order object.
type AppliedDiscount struct {
Title string `json:"applied_discount,omitempty"`
Description string `json:"description,omitempty"`
Value string `json:"value,omitempty"`
ValueType string `json:"value_type,omitempty"`
Amount string `json:"amount,omitempty"`
}
// DraftOrderInvoice is the struct used to create an invoice for a draft order
type DraftOrderInvoice struct {
To string `json:"to,omitempty"`
From string `json:"from,omitempty"`
Subject string `json:"subject,omitempty"`
CustomMessage string `json:"custom_message,omitempty"`
Bcc []string `json:"bcc,omitempty"`
}
type DraftOrdersResource struct {
DraftOrders []DraftOrder `json:"draft_orders"`
}
type DraftOrderResource struct {
DraftOrder *DraftOrder `json:"draft_order"`
}
type DraftOrderInvoiceResource struct {
DraftOrderInvoice *DraftOrderInvoice `json:"draft_order_invoice,omitempty"`
}
// DraftOrderListOptions represents the possible options that can be used
// to further query the list draft orders endpoint
type DraftOrderListOptions struct {
Fields string `url:"fields,omitempty"`
Limit int `url:"limit,omitempty"`
SinceID int64 `url:"since_id,omitempty"`
UpdatedAtMin *time.Time `url:"updated_at_min,omitempty"`
UpdatedAtMax *time.Time `url:"updated_at_max,omitempty"`
IDs string `url:"ids,omitempty"`
Status string `url:"status,omitempty"`
}
// DraftOrderCountOptions represents the possible options to the count draft orders endpoint
type DraftOrderCountOptions struct {
Fields string `url:"fields,omitempty"`
Limit int `url:"limit,omitempty"`
SinceID int64 `url:"since_id,omitempty"`
IDs string `url:"ids,omitempty"`
Status string `url:"status,omitempty"`
}
// Create draft order
func (s *DraftOrderServiceOp) Create(draftOrder DraftOrder) (*DraftOrder, error) {
path := fmt.Sprintf("%s.json", draftOrdersBasePath)
wrappedData := DraftOrderResource{DraftOrder: &draftOrder}
resource := new(DraftOrderResource)
err := s.client.Post(path, wrappedData, resource)
return resource.DraftOrder, err
}
// List draft orders
func (s *DraftOrderServiceOp) List(options interface{}) ([]DraftOrder, error) {
path := fmt.Sprintf("%s.json", draftOrdersBasePath)
resource := new(DraftOrdersResource)
err := s.client.Get(path, resource, options)
return resource.DraftOrders, err
}
// Count draft orders
func (s *DraftOrderServiceOp) Count(options interface{}) (int, error) {
path := fmt.Sprintf("%s/count.json", draftOrdersBasePath)
return s.client.Count(path, options)
}
// Delete draft orders
func (s *DraftOrderServiceOp) Delete(draftOrderID int64) error {
path := fmt.Sprintf("%s/%d.json", draftOrdersBasePath, draftOrderID)
return s.client.Delete(path)
}
// Invoice a draft order
func (s *DraftOrderServiceOp) Invoice(draftOrderID int64, draftOrderInvoice DraftOrderInvoice) (*DraftOrderInvoice, error) {
path := fmt.Sprintf("%s/%d/send_invoice.json", draftOrdersBasePath, draftOrderID)
wrappedData := DraftOrderInvoiceResource{DraftOrderInvoice: &draftOrderInvoice}
resource := new(DraftOrderInvoiceResource)
err := s.client.Post(path, wrappedData, resource)
return resource.DraftOrderInvoice, err
}
// Get individual draft order
func (s *DraftOrderServiceOp) Get(draftOrderID int64, options interface{}) (*DraftOrder, error) {
path := fmt.Sprintf("%s/%d.json", draftOrdersBasePath, draftOrderID)
resource := new(DraftOrderResource)
err := s.client.Get(path, resource, options)
return resource.DraftOrder, err
}
// Update draft order
func (s *DraftOrderServiceOp) Update(draftOrder DraftOrder) (*DraftOrder, error) {
path := fmt.Sprintf("%s/%d.json", draftOrdersBasePath, draftOrder.ID)
wrappedData := DraftOrderResource{DraftOrder: &draftOrder}
resource := new(DraftOrderResource)
err := s.client.Put(path, wrappedData, resource)
return resource.DraftOrder, err
}
// Complete draft order
func (s *DraftOrderServiceOp) Complete(draftOrderID int64, paymentPending bool) (*DraftOrder, error) {
path := fmt.Sprintf("%s/%d/complete.json?payment_pending=%t", draftOrdersBasePath, draftOrderID, paymentPending)
resource := new(DraftOrderResource)
err := s.client.Put(path, nil, resource)
return resource.DraftOrder, err
}
// List metafields for an order
func (s *DraftOrderServiceOp) ListMetafields(draftOrderID int64, options interface{}) ([]Metafield, error) {
metafieldService := &MetafieldServiceOp{client: s.client, resource: draftOrdersResourceName, resourceID: draftOrderID}
return metafieldService.List(options)
}
// Count metafields for an order
func (s *DraftOrderServiceOp) CountMetafields(draftOrderID int64, options interface{}) (int, error) {
metafieldService := &MetafieldServiceOp{client: s.client, resource: draftOrdersResourceName, resourceID: draftOrderID}
return metafieldService.Count(options)
}
// Get individual metafield for an order
func (s *DraftOrderServiceOp) GetMetafield(draftOrderID int64, metafieldID int64, options interface{}) (*Metafield, error) {
metafieldService := &MetafieldServiceOp{client: s.client, resource: draftOrdersResourceName, resourceID: draftOrderID}
return metafieldService.Get(metafieldID, options)
}
// Create a new metafield for an order
func (s *DraftOrderServiceOp) CreateMetafield(draftOrderID int64, metafield Metafield) (*Metafield, error) {
metafieldService := &MetafieldServiceOp{client: s.client, resource: draftOrdersResourceName, resourceID: draftOrderID}
return metafieldService.Create(metafield)
}
// Update an existing metafield for an order
func (s *DraftOrderServiceOp) UpdateMetafield(draftOrderID int64, metafield Metafield) (*Metafield, error) {
metafieldService := &MetafieldServiceOp{client: s.client, resource: draftOrdersResourceName, resourceID: draftOrderID}
return metafieldService.Update(metafield)
}
// Delete an existing metafield for an order
func (s *DraftOrderServiceOp) DeleteMetafield(draftOrderID int64, metafieldID int64) error {
metafieldService := &MetafieldServiceOp{client: s.client, resource: draftOrdersResourceName, resourceID: draftOrderID}
return metafieldService.Delete(metafieldID)
}