forked from mrz1836/postmark
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtemplates.go
217 lines (196 loc) · 7.87 KB
/
templates.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 postmark
import (
"context"
"fmt"
"net/url"
)
// Template represents an email template on the server
type Template struct {
// TemplateID: ID of template
TemplateID int64 `json:"TemplateID"`
// Name: Name of template
Name string
// Subject: The content to use for the Subject when this template is used to send email.
Subject string
// HTMLBody: The content to use for the HTMLBody when this template is used to send email.
HTMLBody string `json:"HtmlBody"`
// TextBody: The content to use for the TextBody when this template is used to send email.
TextBody string
// AssociatedServerID: The ID of the Server with which this template is associated.
AssociatedServerID int64 `json:"AssociatedServerId"`
// Active: Indicates that this template may be used for sending email.
Active bool
}
// TemplateInfo is a limited set of template info returned via Index/Editing endpoints
type TemplateInfo struct {
// TemplateID: ID of template
TemplateID int64 `json:"TemplateID"`
// Name: Name of template
Name string
// Active: Indicates that this template may be used for sending email.
Active bool
}
// GetTemplate fetches a specific template via TemplateID
func (client *Client) GetTemplate(ctx context.Context, templateID string) (Template, error) {
res := Template{}
err := client.doRequest(ctx, parameters{
Method: "GET",
Path: fmt.Sprintf("templates/%s", templateID),
TokenType: serverToken,
}, &res)
return res, err
}
type templatesResponse struct {
TotalCount int64
Templates []TemplateInfo
}
// GetTemplates fetches a list of templates on the server
// It returns a TemplateInfo slice, the total template count, and any error that occurred
// Note: TemplateInfo only returns a subset of template attributes, use GetTemplate(id) to
// retrieve all template info.
func (client *Client) GetTemplates(ctx context.Context, count int64, offset int64) ([]TemplateInfo, int64, error) {
res := templatesResponse{}
values := &url.Values{}
values.Add("count", fmt.Sprintf("%d", count))
values.Add("offset", fmt.Sprintf("%d", offset))
err := client.doRequest(ctx, parameters{
Method: "GET",
Path: fmt.Sprintf("templates?%s", values.Encode()),
TokenType: serverToken,
}, &res)
return res.Templates, res.TotalCount, err
}
// CreateTemplate saves a new template to the server
func (client *Client) CreateTemplate(ctx context.Context, template Template) (TemplateInfo, error) {
res := TemplateInfo{}
err := client.doRequest(ctx, parameters{
Method: "POST",
Path: "templates",
Payload: template,
TokenType: serverToken,
}, &res)
return res, err
}
// EditTemplate updates details for a specific template with templateID
func (client *Client) EditTemplate(ctx context.Context, templateID string, template Template) (TemplateInfo, error) {
res := TemplateInfo{}
err := client.doRequest(ctx, parameters{
Method: "PUT",
Path: fmt.Sprintf("templates/%s", templateID),
Payload: template,
TokenType: serverToken,
}, &res)
return res, err
}
// DeleteTemplate removes a template (with templateID) from the server
func (client *Client) DeleteTemplate(ctx context.Context, templateID string) error {
res := APIError{}
err := client.doRequest(ctx, parameters{
Method: "DELETE",
Path: fmt.Sprintf("templates/%s", templateID),
TokenType: serverToken,
}, &res)
if res.ErrorCode != 0 {
return res
}
return err
}
// ValidateTemplateBody contains the template/render model combination to be validated
type ValidateTemplateBody struct {
Subject string
TextBody string
HTMLBody string `json:"HTMLBody"`
TestRenderModel map[string]interface{}
InlineCSSForHTMLTestRender bool `json:"InlineCssForHtmlTestRender"`
}
// ValidateTemplateResponse contains information as to how the validation went
type ValidateTemplateResponse struct {
AllContentIsValid bool
HTMLBody Validation `json:"HTMLBody"`
TextBody Validation
Subject Validation
SuggestedTemplateModel map[string]interface{}
}
// Validation contains the results of a field's validation
type Validation struct {
ContentIsValid bool
ValidationErrors []ValidationError
RenderedContent string
}
// ValidationError contains information about the errors which occurred during validation for a given field
type ValidationError struct {
Message string
Line int
CharacterPosition int
}
// ValidateTemplate validates the provided template/render model combination
func (client *Client) ValidateTemplate(ctx context.Context, validateTemplateBody ValidateTemplateBody) (ValidateTemplateResponse, error) {
res := ValidateTemplateResponse{}
err := client.doRequest(ctx, parameters{
Method: "POST",
Path: "templates/validate",
Payload: validateTemplateBody,
TokenType: serverToken,
}, &res)
return res, err
}
// TemplatedEmail is used to send an email via a template
type TemplatedEmail struct {
// TemplateID: REQUIRED if TemplateAlias is not specified. - The template id to use when sending this message.
TemplateID int64 `json:"TemplateId,omitempty"`
// TemplateAlias: REQUIRED if TemplateID is not specified. - The template alias to use when sending this message.
TemplateAlias string `json:",omitempty"`
// TemplateModel: The model to be applied to the specified template to generate HtmlBody, TextBody, and Subject.
TemplateModel map[string]interface{} `json:",omitempty"`
// InlineCSS: By default, if the specified template contains an HtmlBody, we will apply the style blocks as inline attributes to the rendered HTML content. You may opt out of this behavior by passing false for this request field.
InlineCSS bool `json:"InlineCSS,omitempty"`
// From: The sender email address. Must have a registered and confirmed Sender Signature.
From string `json:",omitempty"`
// To: REQUIRED Recipient email address. Multiple addresses are comma separated. Max 50.
To string `json:",omitempty"`
// Cc recipient email address. Multiple addresses are comma separated. Max 50.
Cc string `json:",omitempty"`
// Bcc recipient email address. Multiple addresses are comma separated. Max 50.
Bcc string `json:",omitempty"`
// Tag: Email tag that allows you to categorize outgoing emails and get detailed statistics.
Tag string `json:",omitempty"`
// Reply To override email address. Defaults to the Reply To set in the sender signature.
ReplyTo string `json:",omitempty"`
// Headers: List of custom headers to include.
Headers []Header `json:",omitempty"`
// TrackOpens: Activate open tracking for this email.
TrackOpens bool `json:",omitempty"`
// TrackLinks: Activate link tracking. Possible options: "None", "HtmlAndText", "HtmlOnly", "TextOnly".
TrackLinks string `json:",omitempty"`
// Attachments: List of attachments
Attachments []Attachment `json:",omitempty"`
// MessageStream: MessageStream will default to the outbound message stream ID (Default Transactional Stream) if no message stream ID is provided.
MessageStream string `json:",omitempty"`
// Metadata: Custom metadata key/value pairs.
Metadata map[string]interface{} `json:",omitempty"`
}
// SendTemplatedEmail sends an email using a template (TemplateID)
func (client *Client) SendTemplatedEmail(ctx context.Context, email TemplatedEmail) (EmailResponse, error) {
res := EmailResponse{}
err := client.doRequest(ctx, parameters{
Method: "POST",
Path: "email/withTemplate",
Payload: email,
TokenType: serverToken,
}, &res)
return res, err
}
// SendTemplatedEmailBatch sends batch email using a template (TemplateID)
func (client *Client) SendTemplatedEmailBatch(ctx context.Context, emails []TemplatedEmail) ([]EmailResponse, error) {
var res []EmailResponse
formatEmails := map[string]interface{}{
"Messages": emails,
}
err := client.doRequest(ctx, parameters{
Method: "POST",
Path: "email/batchWithTemplates",
Payload: formatEmails,
TokenType: serverToken,
}, &res)
return res, err
}