-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathl4e.go
111 lines (95 loc) · 3.24 KB
/
l4e.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
/*
Copyright (c) 2018 Usabilla
Permission is hereby granted, free of charge, to any person obtaining a
copy of this software and associated documentation files (the
"Software"), to deal in the Software without restriction, including
without limitation the rights to use, copy, modify, merge, publish, dis-
tribute, sublicense, and/or sell copies of the Software, and to permit
persons to whom the Software is furnished to do so, subject to the fol-
lowing conditions:
The above copyright notice and this permission notice shall be included
in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABIL-
ITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT
SHALL THE AUTHOR BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
IN THE SOFTWARE.
*/
package usabilla
import (
"encoding/json"
"net/http"
)
// Canonical URI constants.
const (
emailURI = "/live/email"
emailButtonURI = emailURI + "/button"
)
// EmailButton represents an email button item.
type EmailButton struct {
ID string `json:"id"`
Date string `json:"date"`
Name string `json:"name"`
IntroText string `json:"introText"`
Locale string `json:"locale"`
Groups []map[string]interface{} `json:"groups"`
}
// EmailButtonResponse is a response that contains email button data.
type EmailButtonResponse struct {
response
Items []EmailButton `json:"items"`
}
// EmailButtons represents the email button resource of Usabilla API.
type EmailButtons struct {
resource
client *http.Client
}
// NewEmailButtonResponse creates an email button response and unmarshals
// json API email button response to Go struct.
func NewEmailButtonResponse(data []byte) (*EmailButtonResponse, error) {
response := &EmailButtonResponse{}
err := json.Unmarshal(data, &response)
if err != nil {
return response, err
}
return response, nil
}
// Get function of EmailButtons resource returns all the email buttons
// taking into account the specified query parameters.
//
// Valid query parameters are:
// limit int
// since string (Time stamp)
func (eb *EmailButtons) Get(params map[string]string) (*EmailButtonResponse, error) {
request := request{
method: "GET",
auth: eb.auth,
uri: emailButtonURI,
params: params,
client: eb.client,
}
data, err := request.get()
if err != nil {
panic(err)
}
return NewEmailButtonResponse(data)
}
// Feedback encapsulates the email feedback item resource.
//
// We use the FeedbackItems subresource of websites button feedback, as the
// email feedback items have the same structure for websites . The only difference
// being that image is contained in the website feedback item response, but it is
// omitted for the email one.
//
// In this way, feedback items response for email use the same Get and Iterate
// functions.
func (eb *EmailButtons) Feedback() *FeedbackItems {
return &FeedbackItems{
resource: resource{
auth: eb.auth,
},
client: eb.client,
}
}