forked from hanzoai/gochimp3
-
Notifications
You must be signed in to change notification settings - Fork 0
/
common_types.go
139 lines (119 loc) · 3.66 KB
/
common_types.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
package gochimp3
import (
"fmt"
"strings"
)
// APIError is what the what the api returns on error
type APIError struct {
Type string `json:"type,omitempty"`
Title string `json:"title,omitempty"`
Status int `json:"status,omitempty"`
Detail string `json:"detail,omitempty"`
Instance string `json:"instance,omitempty"`
}
func (err APIError) String() string {
return fmt.Sprintf("%d : %s : %s : %s", err.Status, err.Type, err.Title, err.Detail)
}
func (err APIError) Error() string {
return err.String()
}
// HasError checks if this call had an error
func (err APIError) HasError() bool {
return err.Type != ""
}
// QueryParams defines the different params
type QueryParams interface {
Params() map[string]string
}
// ExtendedQueryParams includes a count and offset
type ExtendedQueryParams struct {
BasicQueryParams
Count int
Offset int
}
func (q ExtendedQueryParams) Params() map[string]string {
m := q.BasicQueryParams.Params()
m["count"] = fmt.Sprintf("%d", q.Count)
m["offset"] = fmt.Sprintf("%d", q.Offset)
return m
}
// BasicQueryParams basic filter queries
type BasicQueryParams struct {
Fields []string
ExcludeFields []string
}
func (q BasicQueryParams) Params() map[string]string {
return map[string]string{
"fields": strings.Join(q.Fields, ","),
"exclude_fields": strings.Join(q.ExcludeFields, ","),
}
}
type withLinks struct {
Link []Link `json:"_link"`
}
type baseList struct {
TotalItems int `json:"total_items"`
Links []Link `json:"_links"`
}
// Link refereneces another object
type Link struct {
Rel string `json:"re"`
Href string `json:"href"`
Method string `json:"method"`
TargetSchema string `json:"targetSchema"`
Schema string `json:"schema"`
}
// Address represents what it says
type Address struct {
Address1 string `json:"address1"`
Address2 string `json:"address2"`
City string `json:"city"`
Province string `json:"province"`
ProvinceCode string `json:"province_code"`
PostalCode string `json:"postal_code"`
Country string `json:"country"`
CountryCode string `json:"country_code"`
Longitude float64 `json:"longitude"`
Latitude float64 `json:"latitude"`
}
// Customer defines a mailchimp customer
type Customer struct {
// Required
ID string `json:"id"`
// Optional
EmailAddress string `json:"email_address,omitempty"`
OptInStatus bool `json:"opt_in_status,omitempty"`
Company string `json:"company,omitempty"`
FirstName string `json:"first_name,omitempty"`
LastName string `json:"last_name,omitempty"`
OrdersCount int `json:"orders_count,omitempty"`
TotalSpent float64 `json:"total_spent,omitempty"`
Address *Address `json:"address,omitempty"`
// Response
CreatedAt string `json:"created_at,omitempty"`
UpdatedAt string `json:"updated_at,omitempty"`
Links []Link `json:"_links,omitempty"`
}
// LineItem defines a mailchimp cart or order line item
type LineItem struct {
// Required
ID string `json:"id"`
ProductID string `json:"product_id"`
ProductVariantID string `json:"product_variant_id"`
Quantity int `json:"quantity"`
Price float64 `json:"price"`
// Optional
ProductTitle string `json:"product_title,omitempty"`
ProductVariantTitle string `json:"product_variant_title,omitempty"`
}
// Contact defines a single contact
type Contact struct {
Company string `json:"customer"`
Address1 string `json:"address1"`
Address2 string `json:"address2"`
City string `json:"city"`
State string `json:"state"`
Zip string `json:"zip"`
Country string `json:"country"`
PhoneNumber string `json:"phone"`
}